diff --git a/SiriIntents/IntentHandler.swift b/SiriIntents/IntentHandler.swift index 50daf8ba39..1854ac20c7 100644 --- a/SiriIntents/IntentHandler.swift +++ b/SiriIntents/IntentHandler.swift @@ -56,8 +56,7 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag override init() { super.init() - let appBundleIdentifier = Bundle.main.bundleIdentifier! - guard let lastDotRange = appBundleIdentifier.range(of: ".", options: [.backwards]) else { + guard let appBundleIdentifier = Bundle.main.bundleIdentifier, let lastDotRange = appBundleIdentifier.range(of: ".", options: [.backwards]) else { return } @@ -98,30 +97,31 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag 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))), supplementary: true, manager: accountManager, rootPath: rootPath, auxiliaryMethods: accountAuxiliaryMethods, encryptionParameters: encryptionParameters) - |> mapToSignal { account -> Signal in - if let account = account { - switch account { - case .upgrading: - return .complete() - case let .authorized(account): - return applicationSettings(accountManager: accountManager) - |> deliverOnMainQueue - |> map { settings -> Account in - accountCache = account - Logger.shared.logToFile = settings.logging.logToFile - Logger.shared.logToConsole = settings.logging.logToConsole - - Logger.shared.redactSensitiveData = settings.logging.redactSensitiveData - return account - } - case .unauthorized: - return .complete() + |> mapToSignal { account -> Signal in + if let account = account { + switch account { + case .upgrading: + return .complete() + case let .authorized(account): + account.shouldKeepOnlinePresence.set(.single(false)) + return applicationSettings(accountManager: accountManager) + |> deliverOnMainQueue + |> map { settings -> Account in + accountCache = account + Logger.shared.logToFile = settings.logging.logToFile + Logger.shared.logToConsole = settings.logging.logToConsole + + Logger.shared.redactSensitiveData = settings.logging.redactSensitiveData + return account } - } else { - return .single(nil) + case .unauthorized: + return .complete() } + } else { + return .single(nil) } - |> take(1) + } + |> take(1) } self.accountPromise.set(account) } @@ -145,36 +145,37 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag @available(iOSApplicationExtension 11.0, *) var sendMessageRecipientResulutionResult: INSendMessageRecipientResolutionResult { switch self { - case let .success(person): - return .success(with: person) - case let .disambiguation(persons): - return .disambiguation(with: persons) - case .needsValue: - return .needsValue() - case .noResult: - return .unsupported() - case .skip: - return .notRequired() + case let .success(person): + return .success(with: person) + case let .disambiguation(persons): + return .disambiguation(with: persons) + case .needsValue: + return .needsValue() + case .noResult: + return .unsupported() + case .skip: + return .notRequired() } } var personResolutionResult: INPersonResolutionResult { switch self { - case let .success(person): - return .success(with: person) - case let .disambiguation(persons): - return .disambiguation(with: persons) - case .needsValue: - return .needsValue() - case .noResult: - return .unsupported() - case .skip: - return .notRequired() + case let .success(person): + return .success(with: person) + case let .disambiguation(persons): + return .disambiguation(with: persons) + case .needsValue: + return .needsValue() + case .noResult: + return .unsupported() + case .skip: + return .notRequired() } } } private func resolve(persons: [INPerson]?, with completion: @escaping ([ResolveResult]) -> Void) { + let account = self.accountPromise.get() guard let initialPersons = persons, !initialPersons.isEmpty else { completion([.needsValue]) return @@ -231,20 +232,18 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag return nil }) - let account = self.accountPromise.get() - let signal = matchingDeviceContacts(stableIds: stableIds) |> take(1) |> mapToSignal { matchedContacts in return account - |> introduceError(IntentContactsError.self) - |> mapToSignal { account -> Signal<[(String, TelegramUser)], IntentContactsError> in - if let account = account { - return matchingCloudContacts(postbox: account.postbox, contacts: matchedContacts) - |> introduceError(IntentContactsError.self) - } else { - return .fail(.generic) - } + |> introduceError(IntentContactsError.self) + |> mapToSignal { account -> Signal<[(String, TelegramUser)], IntentContactsError> in + if let account = account { + return matchingCloudContacts(postbox: account.postbox, contacts: matchedContacts) + |> introduceError(IntentContactsError.self) + } else { + return .fail(.generic) + } } } self.resolvePersonsDisposable.set((signal @@ -276,36 +275,34 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag @available(iOSApplicationExtension 11.0, *) func resolveRecipients(for intent: INSendMessageIntent, with completion: @escaping ([INSendMessageRecipientResolutionResult]) -> Void) { if let peerId = intent.conversationIdentifier.flatMap(Int64.init) { - let account = self.accountPromise.get() - - let signal = account - |> introduceError(IntentHandlingError.self) - |> mapToSignal { account -> Signal in - if let account = account { - return matchingCloudContact(postbox: account.postbox, peerId: PeerId(peerId)) - |> introduceError(IntentHandlingError.self) - |> map { user -> INPerson? in - if let user = user { - return personWithUser(stableId: "tg\(peerId)", user: user) - } else { - return nil - } + let signal = self.accountPromise.get() + |> introduceError(IntentHandlingError.self) + |> mapToSignal { account -> Signal in + if let account = account { + return matchingCloudContact(postbox: account.postbox, peerId: PeerId(peerId)) + |> introduceError(IntentHandlingError.self) + |> map { user -> INPerson? in + if let user = user { + return personWithUser(stableId: "tg\(peerId)", user: user) + } else { + return nil } - } else { - return .fail(.generic) } + } else { + return .fail(.generic) + } } self.resolvePersonsDisposable.set((signal - |> deliverOnMainQueue).start(next: { person in - if let person = person { - completion([INSendMessageRecipientResolutionResult.success(with: person)]) - } else { - completion([INSendMessageRecipientResolutionResult.needsValue()]) - } - }, error: { error in - completion([INSendMessageRecipientResolutionResult.unsupported(forReason: .noAccount)]) - })) + |> deliverOnMainQueue).start(next: { person in + if let person = person { + completion([INSendMessageRecipientResolutionResult.success(with: person)]) + } else { + completion([INSendMessageRecipientResolutionResult.needsValue()]) + } + }, error: { error in + completion([INSendMessageRecipientResolutionResult.unsupported(forReason: .noAccount)]) + })) } else { guard CNContactStore.authorizationStatus(for: .contacts) == .authorized else { completion([INSendMessageRecipientResolutionResult.notRequired()]) @@ -342,48 +339,48 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag func handle(intent: INSendMessageIntent, completion: @escaping (INSendMessageIntentResponse) -> Void) { self.actionDisposable.set((self.accountPromise.get() - |> take(1) + |> take(1) + |> mapError { _ -> IntentHandlingError in + return .generic + } + |> mapToSignal { account -> Signal in + guard let account = account else { + return .fail(.generic) + } + guard let recipient = intent.recipients?.first, let customIdentifier = recipient.customIdentifier, customIdentifier.hasPrefix("tg") else { + return .fail(.generic) + } + + guard let peerIdValue = Int64(String(customIdentifier[customIdentifier.index(customIdentifier.startIndex, offsetBy: 2)...])) else { + return .fail(.generic) + } + + let peerId = PeerId(peerIdValue) + if peerId.namespace != Namespaces.Peer.CloudUser { + return .fail(.generic) + } + + account.shouldBeServiceTaskMaster.set(.single(.now)) + return standaloneSendMessage(account: account, peerId: peerId, text: intent.content ?? "", attributes: [], media: nil, replyToMessageId: nil) |> mapError { _ -> IntentHandlingError in return .generic } - |> mapToSignal { account -> Signal in - guard let account = account else { - return .fail(.generic) - } - guard let recipient = intent.recipients?.first, let customIdentifier = recipient.customIdentifier, customIdentifier.hasPrefix("tg") else { - return .fail(.generic) - } - - guard let peerIdValue = Int64(String(customIdentifier[customIdentifier.index(customIdentifier.startIndex, offsetBy: 2)...])) else { - return .fail(.generic) - } - - let peerId = PeerId(peerIdValue) - if peerId.namespace != Namespaces.Peer.CloudUser { - return .fail(.generic) - } - - account.shouldBeServiceTaskMaster.set(.single(.now)) - return standaloneSendMessage(account: account, peerId: peerId, text: intent.content ?? "", attributes: [], media: nil, replyToMessageId: nil) - |> mapError { _ -> IntentHandlingError in - return .generic - } - |> mapToSignal { _ -> Signal in - return .complete() - } - |> afterDisposed { - account.shouldBeServiceTaskMaster.set(.single(.never)) - } + |> mapToSignal { _ -> Signal in + return .complete() } - |> deliverOnMainQueue).start(error: { _ in - let userActivity = NSUserActivity(activityType: NSStringFromClass(INSendMessageIntent.self)) - let response = INSendMessageIntentResponse(code: .failureRequiringAppLaunch, userActivity: userActivity) - completion(response) - }, completed: { - let userActivity = NSUserActivity(activityType: NSStringFromClass(INSendMessageIntent.self)) - let response = INSendMessageIntentResponse(code: .success, userActivity: userActivity) - completion(response) - })) + |> afterDisposed { + account.shouldBeServiceTaskMaster.set(.single(.never)) + } + } + |> deliverOnMainQueue).start(error: { _ in + let userActivity = NSUserActivity(activityType: NSStringFromClass(INSendMessageIntent.self)) + let response = INSendMessageIntentResponse(code: .failureRequiringAppLaunch, userActivity: userActivity) + completion(response) + }, completed: { + let userActivity = NSUserActivity(activityType: NSStringFromClass(INSendMessageIntent.self)) + let response = INSendMessageIntentResponse(code: .success, userActivity: userActivity) + completion(response) + })) } // MARK: - INSearchForMessagesIntentHandling @@ -394,42 +391,48 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag func handle(intent: INSearchForMessagesIntent, completion: @escaping (INSearchForMessagesIntentResponse) -> Void) { self.actionDisposable.set((self.accountPromise.get() - |> take(1) + |> take(1) + |> introduceError(IntentHandlingError.self) + |> mapToSignal { account -> Signal<[INMessage], IntentHandlingError> in + guard let account = account else { + return .fail(.generic) + } + + account.shouldBeServiceTaskMaster.set(.single(.now)) + account.resetStateManagement() + + let completion: Signal = account.stateManager.pollStateUpdateCompletion() + |> map { _ in + return Void() + } + + return (completion |> timeout(4.0, queue: Queue.mainQueue(), alternate: .single(Void()))) |> introduceError(IntentHandlingError.self) - |> mapToSignal { account -> Signal<[INMessage], IntentHandlingError> in - guard let account = account else { - return .fail(.generic) + |> take(1) + |> mapToSignal { _ -> Signal<[INMessage], IntentHandlingError> in + let messages: Signal<[INMessage], NoError> + if let identifiers = intent.identifiers, !identifiers.isEmpty { + messages = getMessages(account: account, ids: identifiers.compactMap(MessageId.init(string:))) + } else { + messages = unreadMessages(account: account) } - - account.shouldBeServiceTaskMaster.set(.single(.now)) - account.resetStateManagement() - - let completion: Signal = account.stateManager.pollStateUpdateCompletion() - |> map { _ in - return Void() - } - - return (completion |> timeout(4.0, queue: Queue.mainQueue(), alternate: .single(Void()))) - |> introduceError(IntentHandlingError.self) - |> take(1) - |> mapToSignal { _ -> Signal<[INMessage], IntentHandlingError> in - return unreadMessages(account: account) - |> introduceError(IntentHandlingError.self) - |> afterDisposed { - account.shouldBeServiceTaskMaster.set(.single(.never)) - } + return messages + |> introduceError(IntentHandlingError.self) + |> afterDisposed { + account.shouldBeServiceTaskMaster.set(.single(.never)) } } - |> deliverOnMainQueue).start(next: { messages in - let userActivity = NSUserActivity(activityType: NSStringFromClass(INSearchForMessagesIntent.self)) - let response = INSearchForMessagesIntentResponse(code: .success, userActivity: userActivity) - response.messages = messages - completion(response) - }, error: { _ in - let userActivity = NSUserActivity(activityType: NSStringFromClass(INSearchForMessagesIntent.self)) - let response = INSearchForMessagesIntentResponse(code: .failureRequiringAppLaunch, userActivity: userActivity) - completion(response) - })) + } + |> deliverOnMainQueue).start(next: { messages in + let userActivity = NSUserActivity(activityType: NSStringFromClass(INSearchForMessagesIntent.self)) + let response = INSearchForMessagesIntentResponse(code: .success, userActivity: userActivity) + response.messages = messages + completion(response) + }, error: { _ in + let userActivity = NSUserActivity(activityType: NSStringFromClass(INSearchForMessagesIntent.self)) + let response = INSearchForMessagesIntentResponse(code: .failureRequiringAppLaunch, userActivity: userActivity) + completion(response) + })) } // MARK: - INSetMessageAttributeIntentHandling @@ -449,61 +452,61 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag func handle(intent: INSetMessageAttributeIntent, completion: @escaping (INSetMessageAttributeIntentResponse) -> Void) { self.actionDisposable.set((self.accountPromise.get() - |> take(1) - |> mapError { _ -> IntentHandlingError in - return .generic + |> take(1) + |> mapError { _ -> IntentHandlingError in + return .generic + } + |> mapToSignal { account -> Signal in + guard let account = account else { + return .fail(.generic) } - |> mapToSignal { account -> Signal in - guard let account = account else { - return .fail(.generic) - } - - var signals: [Signal] = [] - var maxMessageIdsToApply: [PeerId: MessageId] = [:] - if let identifiers = intent.identifiers { - for identifier in identifiers { - let components = identifier.components(separatedBy: "_") - if let first = components.first, let peerId = Int64(first), let namespace = Int32(components[1]), let id = Int32(components[2]) { - let peerId = PeerId(peerId) - let messageId = MessageId(peerId: peerId, namespace: namespace, id: id) - if let currentMessageId = maxMessageIdsToApply[peerId] { - if currentMessageId < messageId { - maxMessageIdsToApply[peerId] = messageId - } - } else { + + var signals: [Signal] = [] + var maxMessageIdsToApply: [PeerId: MessageId] = [:] + if let identifiers = intent.identifiers { + for identifier in identifiers { + let components = identifier.components(separatedBy: "_") + if let first = components.first, let peerId = Int64(first), let namespace = Int32(components[1]), let id = Int32(components[2]) { + let peerId = PeerId(peerId) + let messageId = MessageId(peerId: peerId, namespace: namespace, id: id) + if let currentMessageId = maxMessageIdsToApply[peerId] { + if currentMessageId < messageId { maxMessageIdsToApply[peerId] = messageId } + } else { + maxMessageIdsToApply[peerId] = messageId } } } - - for (_, messageId) in maxMessageIdsToApply { - signals.append(applyMaxReadIndexInteractively(postbox: account.postbox, stateManager: account.stateManager, index: MessageIndex(id: messageId, timestamp: 0)) - |> introduceError(IntentHandlingError.self)) - } - - if signals.isEmpty { - return .complete() - } else { - account.shouldBeServiceTaskMaster.set(.single(.now)) - return combineLatest(signals) - |> mapToSignal { _ -> Signal in - return .complete() - } - |> afterDisposed { - account.shouldBeServiceTaskMaster.set(.single(.never)) - } - } } - |> deliverOnMainQueue).start(error: { _ in - let userActivity = NSUserActivity(activityType: NSStringFromClass(INSetMessageAttributeIntent.self)) - let response = INSetMessageAttributeIntentResponse(code: .failure, userActivity: userActivity) - completion(response) - }, completed: { - let userActivity = NSUserActivity(activityType: NSStringFromClass(INSetMessageAttributeIntent.self)) - let response = INSetMessageAttributeIntentResponse(code: .success, userActivity: userActivity) - completion(response) - })) + + for (_, messageId) in maxMessageIdsToApply { + signals.append(applyMaxReadIndexInteractively(postbox: account.postbox, stateManager: account.stateManager, index: MessageIndex(id: messageId, timestamp: 0)) + |> introduceError(IntentHandlingError.self)) + } + + if signals.isEmpty { + return .complete() + } else { + account.shouldBeServiceTaskMaster.set(.single(.now)) + return combineLatest(signals) + |> mapToSignal { _ -> Signal in + return .complete() + } + |> afterDisposed { + account.shouldBeServiceTaskMaster.set(.single(.never)) + } + } + } + |> deliverOnMainQueue).start(error: { _ in + let userActivity = NSUserActivity(activityType: NSStringFromClass(INSetMessageAttributeIntent.self)) + let response = INSetMessageAttributeIntentResponse(code: .failure, userActivity: userActivity) + completion(response) + }, completed: { + let userActivity = NSUserActivity(activityType: NSStringFromClass(INSetMessageAttributeIntent.self)) + let response = INSetMessageAttributeIntentResponse(code: .success, userActivity: userActivity) + completion(response) + })) } // MARK: - INStartAudioCallIntentHandling @@ -518,38 +521,43 @@ class IntentHandler: INExtension, INSendMessageIntentHandling, INSearchForMessag }) } + @available(iOSApplicationExtension 11.0, *) + func resolveDestinationType(for intent: INStartAudioCallIntent, with completion: @escaping (INCallDestinationTypeResolutionResult) -> Void) { + completion(.success(with: .normal)) + } + func handle(intent: INStartAudioCallIntent, completion: @escaping (INStartAudioCallIntentResponse) -> Void) { self.actionDisposable.set((self.accountPromise.get() - |> take(1) - |> mapError { _ -> IntentHandlingError in - return .generic + |> take(1) + |> mapError { _ -> IntentHandlingError in + return .generic + } + |> mapToSignal { account -> Signal in + guard let contact = intent.contacts?.first, let customIdentifier = contact.customIdentifier, customIdentifier.hasPrefix("tg") else { + return .fail(.generic) } - |> mapToSignal { account -> Signal in - guard let contact = intent.contacts?.first, let customIdentifier = contact.customIdentifier, customIdentifier.hasPrefix("tg") else { - return .fail(.generic) - } - - guard let peerIdValue = Int64(String(customIdentifier[customIdentifier.index(customIdentifier.startIndex, offsetBy: 2)...])) else { - return .fail(.generic) - } - - let peerId = PeerId(peerIdValue) - if peerId.namespace != Namespaces.Peer.CloudUser { - return .fail(.generic) - } - - return .single(peerId) + + guard let peerIdValue = Int64(String(customIdentifier[customIdentifier.index(customIdentifier.startIndex, offsetBy: 2)...])) else { + return .fail(.generic) } - |> deliverOnMainQueue).start(next: { peerId in - let userActivity = NSUserActivity(activityType: NSStringFromClass(INStartAudioCallIntent.self)) - userActivity.userInfo = ["handle": "TGCA\(peerId.toInt64())"] - let response = INStartAudioCallIntentResponse(code: .continueInApp, userActivity: userActivity) - completion(response) - }, error: { _ in - let userActivity = NSUserActivity(activityType: NSStringFromClass(INStartAudioCallIntent.self)) - let response = INStartAudioCallIntentResponse(code: .failureRequiringAppLaunch, userActivity: userActivity) - completion(response) - })) + + let peerId = PeerId(peerIdValue) + if peerId.namespace != Namespaces.Peer.CloudUser { + return .fail(.generic) + } + + return .single(peerId) + } + |> deliverOnMainQueue).start(next: { peerId in + let userActivity = NSUserActivity(activityType: NSStringFromClass(INStartAudioCallIntent.self)) + userActivity.userInfo = ["handle": "TGCA\(peerId.toInt64())"] + let response = INStartAudioCallIntentResponse(code: .continueInApp, userActivity: userActivity) + completion(response) + }, error: { _ in + let userActivity = NSUserActivity(activityType: NSStringFromClass(INStartAudioCallIntent.self)) + let response = INStartAudioCallIntentResponse(code: .failureRequiringAppLaunch, userActivity: userActivity) + completion(response) + })) } // MARK: - INSearchCallHistoryIntentHandling diff --git a/SiriIntents/IntentMessages.swift b/SiriIntents/IntentMessages.swift index b059f14e8c..2797af5b64 100644 --- a/SiriIntents/IntentMessages.swift +++ b/SiriIntents/IntentMessages.swift @@ -1,11 +1,33 @@ import Foundation -import Display import SwiftSignalKit import Postbox import TelegramCore import Contacts import Intents +extension MessageId { + init?(string: String) { + let components = string.components(separatedBy: "_") + if components.count == 3, let peerIdValue = Int64(components[0]), let namespaceValue = Int32(components[1]), let idValue = Int32(components[2]) { + self.init(peerId: PeerId(peerIdValue), namespace: namespaceValue, id: idValue) + } else { + return nil + } + } +} + +func getMessages(account: Account, ids: [MessageId]) -> Signal<[INMessage], NoError> { + return account.postbox.transaction { transaction -> [INMessage] in + var messages: [INMessage] = [] + for id in ids { + if let message = transaction.getMessage(id).flatMap(messageWithTelegramMessage) { + messages.append(message) + } + } + return messages.sorted { $0.dateSent!.compare($1.dateSent!) == .orderedDescending } + } +} + func unreadMessages(account: Account) -> Signal<[INMessage], NoError> { return account.postbox.tailChatListView(groupId: .root, count: 20, summaryComponents: ChatListEntrySummaryComponents()) |> take(1) @@ -31,7 +53,7 @@ func unreadMessages(account: Account) -> Signal<[INMessage], NoError> { } if !isMuted && hasUnread { - signals.append(account.postbox.aroundMessageHistoryViewForLocation(.peer(index.messageIndex.id.peerId), anchor: .upperBound, count: 10, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: Set(), tagMask: nil, excludeNamespaces: [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal], orderStatistics: .combinedLocation) + signals.append(account.postbox.aroundMessageHistoryViewForLocation(.peer(index.messageIndex.id.peerId), anchor: .upperBound, count: 10, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: Set(), tagMask: nil, namespaces: .not([Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal]), orderStatistics: .combinedLocation) |> take(1) |> map { view -> [INMessage] in var messages: [INMessage] = [] @@ -42,7 +64,7 @@ func unreadMessages(account: Account) -> Signal<[INMessage], NoError> { } if !isRead { - if let message = messageWithTelegramMessage(entry.message, account: account) { + if let message = messageWithTelegramMessage(entry.message) { messages.append(message) } } @@ -58,7 +80,7 @@ func unreadMessages(account: Account) -> Signal<[INMessage], NoError> { } else { return combineLatest(signals) |> map { results -> [INMessage] in - return results.flatMap { $0 }.sorted(by: { $0.dateSent!.compare($1.dateSent!) == ComparisonResult.orderedDescending }) + return results.flatMap { $0 }.sorted { $0.dateSent!.compare($1.dateSent!) == .orderedDescending } } } } @@ -94,7 +116,7 @@ func missedCalls(account: Account) -> Signal<[CallRecord], NoError> { break } } - return calls.sorted(by: { $0.date.compare($1.date) == ComparisonResult.orderedDescending }) + return calls.sorted { $0.date.compare($1.date) == .orderedDescending } } } @@ -136,7 +158,7 @@ private func callWithTelegramMessage(_ telegramMessage: Message, account: Accoun return CallRecord(identifier: identifier, date: date, caller: caller, duration: duration, unseen: true) } -private func messageWithTelegramMessage(_ telegramMessage: Message, account: Account) -> INMessage? { +private func messageWithTelegramMessage(_ telegramMessage: Message) -> INMessage? { guard let author = telegramMessage.author, let user = telegramMessage.peers[author.id] as? TelegramUser, user.id.id != 777000 else { return nil } @@ -181,7 +203,7 @@ private func messageWithTelegramMessage(_ telegramMessage: Message, account: Acc messageType = .mediaAudio break loop } else if file.isVoice { - messageType = .audio + messageType = .mediaAudio break loop } else if file.isSticker || file.isAnimatedSticker { messageType = .sticker @@ -189,6 +211,9 @@ private func messageWithTelegramMessage(_ telegramMessage: Message, account: Acc } else if file.isAnimated { messageType = .mediaVideo break loop + } else if #available(iOSApplicationExtension 12.0, *) { + messageType = .file + break loop } } else if media is TelegramMediaMap { messageType = .mediaLocation diff --git a/Telegram-iOS/Telegram-iOS-AppStoreLLC.entitlements b/Telegram-iOS/Telegram-iOS-AppStoreLLC.entitlements index 385a149c1a..6accd7694a 100644 --- a/Telegram-iOS/Telegram-iOS-AppStoreLLC.entitlements +++ b/Telegram-iOS/Telegram-iOS-AppStoreLLC.entitlements @@ -33,7 +33,7 @@ merchant.privatbank.test.telergramios merchant.privatbank.prod.telergram - com.apple.developer.carplay-messaging - com.apple.developer.carplay-calling + com.apple.developer.carplay-messaging + diff --git a/Telegram-iOS/en.lproj/Localizable.strings b/Telegram-iOS/en.lproj/Localizable.strings index 811f5ba21d..4771f22914 100644 --- a/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram-iOS/en.lproj/Localizable.strings @@ -4610,6 +4610,7 @@ Any member of this group will be able to see messages in the channel."; "ScheduledMessages.EditTime" = "Reschedule"; "ScheduledMessages.ClearAll" = "Clear All"; "ScheduledMessages.Delete" = "Delete"; +"ScheduledMessages.EmptyPlaceholder" = "No scheduled messages here yet..."; "Conversation.SendMessage.SetReminder" = "Set a Reminder"; diff --git a/submodules/GalleryUI/Sources/GalleryController.swift b/submodules/GalleryUI/Sources/GalleryController.swift index 52dc67ace8..5b4c9ef05d 100644 --- a/submodules/GalleryUI/Sources/GalleryController.swift +++ b/submodules/GalleryUI/Sources/GalleryController.swift @@ -368,16 +368,13 @@ public class GalleryController: ViewController { switch source { case .peerMessagesAtId: if let tags = tagsForMessage(message!) { - var excludeNamespaces: [MessageId.Namespace] - if message!.id.namespace == Namespaces.Message.ScheduledCloud { - excludeNamespaces = [Namespaces.Message.Cloud, Namespaces.Message.Local, Namespaces.Message.SecretIncoming] + let namespaces: HistoryViewNamespaces + if Namespaces.Message.allScheduled.contains(message!.id.namespace) { + namespaces = .just(Namespaces.Message.allScheduled) } else { - excludeNamespaces = [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal] + namespaces = .not(Namespaces.Message.allScheduled) } - - let view = context.account.postbox.aroundMessageHistoryViewForLocation(.peer(message!.id.peerId), anchor: .index(message!.index), count: 50, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tags, excludeNamespaces: excludeNamespaces, orderStatistics: [.combinedLocation]) - - return view + return context.account.postbox.aroundMessageHistoryViewForLocation(.peer(message!.id.peerId), anchor: .index(message!.index), count: 50, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tags, namespaces: namespaces, orderStatistics: [.combinedLocation]) |> mapToSignal { (view, _, _) -> Signal in let mapped = GalleryMessageHistoryView.view(view) return .single(mapped) diff --git a/submodules/Postbox/Postbox/MessageHistoryView.swift b/submodules/Postbox/Postbox/MessageHistoryView.swift index bdc9608b73..c21ad9de35 100644 --- a/submodules/Postbox/Postbox/MessageHistoryView.swift +++ b/submodules/Postbox/Postbox/MessageHistoryView.swift @@ -224,10 +224,27 @@ public enum HistoryViewInputAnchor: Equatable { case unread } +public enum HistoryViewNamespaces { + case all + case just(Set) + case not(Set) + + public func contains(_ namespace: MessageId.Namespace) -> Bool { + switch self { + case .all: + return true + case let .just(namespaces): + return namespaces.contains(namespace) + case let .not(namespaces): + return !namespaces.contains(namespace) + } + } +} + final class MutableMessageHistoryView { private(set) var peerIds: MessageHistoryViewPeerIds let tag: MessageTags? - let excludeNamespaces: [MessageId.Namespace] + let namespaces: HistoryViewNamespaces private let orderStatistics: MessageHistoryViewOrderStatistics private let anchor: HistoryViewInputAnchor @@ -242,7 +259,7 @@ final class MutableMessageHistoryView { fileprivate(set) var sampledState: HistoryViewSample - init(postbox: Postbox, orderStatistics: MessageHistoryViewOrderStatistics, peerIds: MessageHistoryViewPeerIds, anchor inputAnchor: HistoryViewInputAnchor, combinedReadStates: MessageHistoryViewReadState?, transientReadStates: MessageHistoryViewReadState?, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], count: Int, topTaggedMessages: [MessageId.Namespace: MessageHistoryTopTaggedMessage?], additionalDatas: [AdditionalMessageHistoryViewDataEntry], getMessageCountInRange: (MessageIndex, MessageIndex) -> Int32) { + init(postbox: Postbox, orderStatistics: MessageHistoryViewOrderStatistics, peerIds: MessageHistoryViewPeerIds, anchor inputAnchor: HistoryViewInputAnchor, combinedReadStates: MessageHistoryViewReadState?, transientReadStates: MessageHistoryViewReadState?, tag: MessageTags?, namespaces: HistoryViewNamespaces, count: Int, topTaggedMessages: [MessageId.Namespace: MessageHistoryTopTaggedMessage?], additionalDatas: [AdditionalMessageHistoryViewDataEntry], getMessageCountInRange: (MessageIndex, MessageIndex) -> Int32) { self.anchor = inputAnchor self.orderStatistics = orderStatistics @@ -250,17 +267,17 @@ final class MutableMessageHistoryView { self.combinedReadStates = combinedReadStates self.transientReadStates = transientReadStates self.tag = tag - self.excludeNamespaces = excludeNamespaces + self.namespaces = namespaces self.fillCount = count self.topTaggedMessages = topTaggedMessages self.additionalDatas = additionalDatas - self.state = HistoryViewState(postbox: postbox, inputAnchor: inputAnchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds) + self.state = HistoryViewState(postbox: postbox, inputAnchor: inputAnchor, tag: tag, namespaces: namespaces, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds) if case let .loading(loadingState) = self.state { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, namespaces: namespaces, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds, postbox: postbox, holes: holes)) self.sampledState = self.state.sample(postbox: postbox) case .loadHole: break @@ -272,12 +289,12 @@ final class MutableMessageHistoryView { } private func reset(postbox: Postbox) { - self.state = HistoryViewState(postbox: postbox, inputAnchor: self.anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds) + self.state = HistoryViewState(postbox: postbox, inputAnchor: self.anchor, tag: self.tag, namespaces: self.namespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds) if case let .loading(loadingState) = self.state { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, namespaces: self.namespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) case .loadHole: break } @@ -286,7 +303,7 @@ final class MutableMessageHistoryView { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, namespaces: self.namespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) case .loadHole: break } @@ -472,7 +489,7 @@ final class MutableMessageHistoryView { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, namespaces: self.namespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) case .loadHole: break } @@ -672,6 +689,7 @@ final class MutableMessageHistoryView { public final class MessageHistoryView { public let tagMask: MessageTags? + public let namespaces: HistoryViewNamespaces public let anchorIndex: MessageHistoryAnchorIndex public let earlierId: MessageIndex? public let laterId: MessageIndex? @@ -686,6 +704,7 @@ public final class MessageHistoryView { init(_ mutableView: MutableMessageHistoryView) { self.tagMask = mutableView.tag + self.namespaces = mutableView.namespaces var entries: [MessageHistoryEntry] switch mutableView.sampledState { case .loading: @@ -714,7 +733,7 @@ public final class MessageHistoryView { entries = [] if let transientReadStates = mutableView.transientReadStates, case let .peer(states) = transientReadStates { for entry in state.entries { - if !mutableView.excludeNamespaces.contains(entry.message.id.namespace) { + if mutableView.namespaces.contains(entry.message.id.namespace) { let read: Bool if entry.message.flags.contains(.Incoming) { read = false @@ -728,7 +747,7 @@ public final class MessageHistoryView { } } else { for entry in state.entries { - if !mutableView.excludeNamespaces.contains(entry.message.id.namespace) { + if mutableView.namespaces.contains(entry.message.id.namespace) { entries.append(MessageHistoryEntry(message: entry.message, isRead: false, location: entry.location, monthLocation: entry.monthLocation, attributes: entry.attributes)) } } diff --git a/submodules/Postbox/Postbox/MessageHistoryViewState.swift b/submodules/Postbox/Postbox/MessageHistoryViewState.swift index f6f5d5d38c..10a6084cfb 100644 --- a/submodules/Postbox/Postbox/MessageHistoryViewState.swift +++ b/submodules/Postbox/Postbox/MessageHistoryViewState.swift @@ -748,7 +748,7 @@ struct HistoryViewLoadedSample { final class HistoryViewLoadedState { let anchor: HistoryViewAnchor let tag: MessageTags? - let excludeNamespaces: [MessageId.Namespace] + let namespaces: HistoryViewNamespaces let statistics: MessageHistoryViewOrderStatistics let halfLimit: Int let seedConfiguration: SeedConfiguration @@ -756,11 +756,11 @@ final class HistoryViewLoadedState { var holes: HistoryViewHoles var spacesWithRemovals = Set() - init(anchor: HistoryViewAnchor, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds, postbox: Postbox, holes: HistoryViewHoles) { + init(anchor: HistoryViewAnchor, tag: MessageTags?, namespaces: HistoryViewNamespaces, statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds, postbox: Postbox, holes: HistoryViewHoles) { precondition(halfLimit >= 3) self.anchor = anchor self.tag = tag - self.excludeNamespaces = excludeNamespaces + self.namespaces = namespaces self.statistics = statistics self.halfLimit = halfLimit self.seedConfiguration = postbox.seedConfiguration @@ -781,7 +781,7 @@ final class HistoryViewLoadedState { var spaces: [PeerIdAndNamespace] = [] for peerId in peerIds { for namespace in postbox.messageHistoryIndexTable.existingNamespaces(peerId: peerId) { - if !excludeNamespaces.contains(namespace) { + if namespaces.contains(namespace) { spaces.append(PeerIdAndNamespace(peerId: peerId, namespace: namespace)) } } @@ -1178,7 +1178,7 @@ final class HistoryViewLoadedState { } } -private func fetchHoles(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace]) -> [PeerIdAndNamespace: IndexSet] { +private func fetchHoles(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?, namespaces: HistoryViewNamespaces) -> [PeerIdAndNamespace: IndexSet] { var holesBySpace: [PeerIdAndNamespace: IndexSet] = [:] var peerIds: [PeerId] = [] switch locations { @@ -1193,7 +1193,7 @@ private func fetchHoles(postbox: Postbox, locations: MessageHistoryViewPeerIds, let holeSpace = tag.flatMap(MessageHistoryHoleSpace.tag) ?? .everywhere for peerId in peerIds { for namespace in postbox.messageHistoryHoleIndexTable.existingNamespaces(peerId: peerId, holeSpace: holeSpace) { - if !excludeNamespaces.contains(namespace) { + if namespaces.contains(namespace) { let indices = postbox.messageHistoryHoleIndexTable.closest(peerId: peerId, namespace: namespace, space: holeSpace, range: 1 ... (Int32.max - 1)) if !indices.isEmpty { let peerIdAndNamespace = PeerIdAndNamespace(peerId: peerId, namespace: namespace) @@ -1217,11 +1217,11 @@ final class HistoryViewLoadingState { let halfLimit: Int var holes: HistoryViewHoles - init(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], messageId: MessageId, halfLimit: Int) { + init(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?, namespaces: HistoryViewNamespaces, messageId: MessageId, halfLimit: Int) { self.messageId = messageId self.tag = tag self.halfLimit = halfLimit - self.holes = HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)) + self.holes = HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, namespaces: namespaces)) } func insertHole(space: PeerIdAndNamespace, range: ClosedRange) -> Bool { @@ -1261,14 +1261,14 @@ enum HistoryViewState { case loaded(HistoryViewLoadedState) case loading(HistoryViewLoadingState) - init(postbox: Postbox, inputAnchor: HistoryViewInputAnchor, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds) { + init(postbox: Postbox, inputAnchor: HistoryViewInputAnchor, tag: MessageTags?, namespaces: HistoryViewNamespaces, statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds) { switch inputAnchor { case let .index(index): - self = .loaded(HistoryViewLoadedState(anchor: .index(index), tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) + self = .loaded(HistoryViewLoadedState(anchor: .index(index), tag: tag, namespaces: namespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, namespaces: namespaces)))) case .lowerBound: - self = .loaded(HistoryViewLoadedState(anchor: .lowerBound, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) + self = .loaded(HistoryViewLoadedState(anchor: .lowerBound, tag: tag, namespaces: namespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, namespaces: namespaces)))) case .upperBound: - self = .loaded(HistoryViewLoadedState(anchor: .upperBound, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) + self = .loaded(HistoryViewLoadedState(anchor: .upperBound, tag: tag, namespaces: namespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, namespaces: namespaces)))) case .unread: let anchorPeerId: PeerId switch locations { @@ -1301,26 +1301,26 @@ enum HistoryViewState { } } if let messageId = messageId { - let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces, messageId: messageId, halfLimit: halfLimit) + let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, namespaces: namespaces, messageId: messageId, halfLimit: halfLimit) let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) + self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, namespaces: namespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) case .loadHole: self = .loading(loadingState) } } else { - self = .loaded(HistoryViewLoadedState(anchor: anchor ?? .upperBound, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) + self = .loaded(HistoryViewLoadedState(anchor: anchor ?? .upperBound, tag: tag, namespaces: namespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, namespaces: namespaces)))) } } else { preconditionFailure() } case let .message(messageId): - let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces, messageId: messageId, halfLimit: halfLimit) + let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, namespaces: namespaces, messageId: messageId, halfLimit: halfLimit) let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) + self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, namespaces: namespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) case .loadHole: self = .loading(loadingState) } diff --git a/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift b/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift index 3458f527fc..b07fe3c366 100644 --- a/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift +++ b/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift @@ -52,7 +52,7 @@ final class MutableMessageOfInterestHolesView: MutablePostboxView { } } self.anchor = anchor - self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, excludeNamespaces: [], count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) + self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, namespaces: .all, count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) let _ = self.updateFromView() } @@ -117,7 +117,7 @@ final class MutableMessageOfInterestHolesView: MutablePostboxView { if self.anchor != anchor { self.anchor = anchor - self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, excludeNamespaces: [], count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) + self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, namespaces: .all, count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) return self.updateFromView() } else if self.wrappedView.replay(postbox: postbox, transaction: transaction) { return self.updateFromView() diff --git a/submodules/Postbox/Postbox/Postbox.swift b/submodules/Postbox/Postbox/Postbox.swift index 5992af79f4..005b38a090 100644 --- a/submodules/Postbox/Postbox/Postbox.swift +++ b/submodules/Postbox/Postbox/Postbox.swift @@ -2219,7 +2219,7 @@ public final class Postbox { return peerIds } - public func aroundMessageOfInterestHistoryViewForChatLocation(_ chatLocation: ChatLocation, count: Int, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageOfInterestHistoryViewForChatLocation(_ chatLocation: ChatLocation, count: Int, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, namespaces: HistoryViewNamespaces, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { return self.transactionSignal(userInteractive: true, { subscriber, transaction in let peerIds = self.peerIdsForLocation(chatLocation, tagMask: tagMask) @@ -2263,26 +2263,26 @@ public final class Postbox { } } } - return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: additionalData) + return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, namespaces: namespaces, orderStatistics: orderStatistics, additionalData: additionalData) }) } - public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, namespaces: HistoryViewNamespaces, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { return self.transactionSignal { subscriber, transaction in let peerIds = self.peerIdsForLocation(chatLocation, tagMask: tagMask) - return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: .message(messageId), fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: additionalData) + return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: .message(messageId), fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, namespaces: namespaces, orderStatistics: orderStatistics, additionalData: additionalData) } } - public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, anchor: HistoryViewInputAnchor, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, anchor: HistoryViewInputAnchor, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, namespaces: HistoryViewNamespaces, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { return self.transactionSignal { subscriber, transaction in let peerIds = self.peerIdsForLocation(chatLocation, tagMask: tagMask) - return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: additionalData) + return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, namespaces: namespaces, orderStatistics: orderStatistics, additionalData: additionalData) } } - private func syncAroundMessageHistoryViewForPeerId(subscriber: Subscriber<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError>, peerIds: MessageHistoryViewPeerIds, count: Int, anchor: HistoryViewInputAnchor, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Disposable { + private func syncAroundMessageHistoryViewForPeerId(subscriber: Subscriber<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError>, peerIds: MessageHistoryViewPeerIds, count: Int, anchor: HistoryViewInputAnchor, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, namespaces: HistoryViewNamespaces, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Disposable { var topTaggedMessages: [MessageId.Namespace: MessageHistoryTopTaggedMessage?] = [:] var mainPeerId: PeerId? switch peerIds { @@ -2371,7 +2371,7 @@ public final class Postbox { readStates = transientReadStates } - let mutableView = MutableMessageHistoryView(postbox: self, orderStatistics: orderStatistics, peerIds: peerIds, anchor: anchor, combinedReadStates: readStates, transientReadStates: transientReadStates, tag: tagMask, excludeNamespaces: excludeNamespaces, count: count, topTaggedMessages: topTaggedMessages, additionalDatas: additionalDataEntries, getMessageCountInRange: { lowerBound, upperBound in + let mutableView = MutableMessageHistoryView(postbox: self, orderStatistics: orderStatistics, peerIds: peerIds, anchor: anchor, combinedReadStates: readStates, transientReadStates: transientReadStates, tag: tagMask, namespaces: namespaces, count: count, topTaggedMessages: topTaggedMessages, additionalDatas: additionalDataEntries, getMessageCountInRange: { lowerBound, upperBound in if let tagMask = tagMask { return Int32(self.messageHistoryTable.getMessageCountInRange(peerId: lowerBound.id.peerId, namespace: lowerBound.id.namespace, tag: tagMask, lowerBound: lowerBound, upperBound: upperBound)) } else { diff --git a/submodules/TelegramCore/TelegramCore/Account.swift b/submodules/TelegramCore/TelegramCore/Account.swift index ad88b732c1..28d757fcc7 100644 --- a/submodules/TelegramCore/TelegramCore/Account.swift +++ b/submodules/TelegramCore/TelegramCore/Account.swift @@ -1243,6 +1243,7 @@ public class Account { self.managedOperationsDisposable.add(managedSynchronizeMarkAllUnseenPersonalMessagesOperations(postbox: self.postbox, network: self.network, stateManager: self.stateManager).start()) self.managedOperationsDisposable.add(managedApplyPendingMessageReactionsActions(postbox: self.postbox, network: self.network, stateManager: self.stateManager).start()) self.managedOperationsDisposable.add(managedSynchronizeEmojiKeywordsOperations(postbox: self.postbox, network: self.network).start()) + self.managedOperationsDisposable.add(managedApplyPendingScheduledMessagesActions(postbox: self.postbox, network: self.network, stateManager: self.stateManager).start()) let importantBackgroundOperations: [Signal] = [ managedSynchronizeChatInputStateOperations(postbox: self.postbox, network: self.network) |> map { $0 ? AccountRunningImportantTasks.other : [] }, diff --git a/submodules/TelegramCore/TelegramCore/AccountManager.swift b/submodules/TelegramCore/TelegramCore/AccountManager.swift index 7ad94b7401..4e7f876d51 100644 --- a/submodules/TelegramCore/TelegramCore/AccountManager.swift +++ b/submodules/TelegramCore/TelegramCore/AccountManager.swift @@ -143,7 +143,6 @@ private var declaredEncodables: Void = { declareEncodable(EmojiKeywordCollectionInfo.self, f: { EmojiKeywordCollectionInfo(decoder: $0) }) declareEncodable(EmojiKeywordItem.self, f: { EmojiKeywordItem(decoder: $0) }) declareEncodable(SynchronizeEmojiKeywordsOperation.self, f: { SynchronizeEmojiKeywordsOperation(decoder: $0) }) - declareEncodable(CloudPhotoSizeMediaResource.self, f: { CloudPhotoSizeMediaResource(decoder: $0) }) declareEncodable(CloudDocumentSizeMediaResource.self, f: { CloudDocumentSizeMediaResource(decoder: $0) }) declareEncodable(CloudPeerPhotoSizeMediaResource.self, f: { CloudPeerPhotoSizeMediaResource(decoder: $0) }) @@ -153,6 +152,7 @@ private var declaredEncodables: Void = { declareEncodable(OutgoingScheduleInfoMessageAttribute.self, f: { OutgoingScheduleInfoMessageAttribute(decoder: $0) }) declareEncodable(UpdateMessageReactionsAction.self, f: { UpdateMessageReactionsAction(decoder: $0) }) declareEncodable(RestrictedContentMessageAttribute.self, f: { RestrictedContentMessageAttribute(decoder: $0) }) + declareEncodable(SendScheduledMessageImmediatelyAction.self, f: { SendScheduledMessageImmediatelyAction(decoder: $0) }) return }() diff --git a/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift b/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift index bef9977a45..19c61472be 100644 --- a/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift +++ b/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift @@ -189,7 +189,7 @@ private func wrappedHistoryViewAdditionalData(chatLocation: ChatLocation, additi switch chatLocation { case let .peer(peerId): if peerId.namespace == Namespaces.Peer.CloudChannel { - if result.index(where: { if case .peerChatState = $0 { return true } else { return false } }) == nil { + if result.firstIndex(where: { if case .peerChatState = $0 { return true } else { return false } }) == nil { result.append(.peerChatState(peerId)) } } @@ -872,9 +872,7 @@ public final class AccountViewTracker { strongSelf.updatePolls(viewId: viewId, messageIds: pollMessageIds, messages: pollMessageDict) if case let .peer(peerId) = chatLocation, peerId.namespace == Namespaces.Peer.CloudChannel { strongSelf.historyViewStateValidationContexts.updateView(id: viewId, view: next.0) - }/* else if case .group = chatLocation { - strongSelf.historyViewStateValidationContexts.updateView(id: viewId, view: next.0) - }*/ + } } } }, disposed: { [weak self] viewId in @@ -887,8 +885,6 @@ public final class AccountViewTracker { if peerId.namespace == Namespaces.Peer.CloudChannel { strongSelf.historyViewStateValidationContexts.updateView(id: viewId, view: nil) } - /*case .group: - strongSelf.historyViewStateValidationContexts.updateView(id: viewId, view: nil)*/ } } } @@ -915,28 +911,54 @@ public final class AccountViewTracker { } public func scheduledMessagesViewForLocation(_ chatLocation: ChatLocation) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { - return self.aroundMessageHistoryViewForLocation(chatLocation, index: .upperBound, anchorIndex: .upperBound, count: 100, fixedCombinedReadStates: nil, tagMask: nil, excludeNamespaces: [Namespaces.Message.Cloud, Namespaces.Message.Local], orderStatistics: []) + if let account = self.account { + let signal = account.postbox.aroundMessageHistoryViewForLocation(chatLocation, anchor: .upperBound, count: 200, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: nil, namespaces: .just(Namespaces.Message.allScheduled), orderStatistics: [], additionalData: []) + return withState(signal, { [weak self] () -> Int32 in + if let strongSelf = self { + return OSAtomicIncrement32(&strongSelf.nextViewId) + } else { + return -1 + } + }, next: { [weak self] next, viewId in + if let strongSelf = self { + strongSelf.queue.async { + let (messageIds, localWebpages) = pendingWebpages(entries: next.0.entries) + strongSelf.updatePendingWebpages(viewId: viewId, messageIds: messageIds, localWebpages: localWebpages) + strongSelf.historyViewStateValidationContexts.updateView(id: viewId, view: next.0, location: chatLocation) + } + } + }, disposed: { [weak self] viewId in + if let strongSelf = self { + strongSelf.queue.async { + strongSelf.updatePendingWebpages(viewId: viewId, messageIds: [], localWebpages: [:]) + strongSelf.historyViewStateValidationContexts.updateView(id: viewId, view: nil) + } + } + }) + } else { + return .never() + } } - public func aroundMessageOfInterestHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, tagMask: MessageTags? = nil, excludeNamespaces: [MessageId.Namespace] = [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal], orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageOfInterestHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, tagMask: MessageTags? = nil, orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { if let account = self.account { - let signal = account.postbox.aroundMessageOfInterestHistoryViewForChatLocation(chatLocation, count: count, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) + let signal = account.postbox.aroundMessageOfInterestHistoryViewForChatLocation(chatLocation, count: count, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, namespaces: .not(Namespaces.Message.allScheduled), orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) return wrappedMessageHistorySignal(chatLocation: chatLocation, signal: signal) } else { return .never() } } - public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, tagMask: MessageTags? = nil, excludeNamespaces: [MessageId.Namespace] = [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal], orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, tagMask: MessageTags? = nil, orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { if let account = self.account { - let signal = account.postbox.aroundIdMessageHistoryViewForLocation(chatLocation, count: count, messageId: messageId, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) + let signal = account.postbox.aroundIdMessageHistoryViewForLocation(chatLocation, count: count, messageId: messageId, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, namespaces: .not(Namespaces.Message.allScheduled), orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) return wrappedMessageHistorySignal(chatLocation: chatLocation, signal: signal) } else { return .never() } } - public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, index: MessageHistoryAnchorIndex, anchorIndex: MessageHistoryAnchorIndex, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, tagMask: MessageTags? = nil, excludeNamespaces: [MessageId.Namespace] = [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal], orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, index: MessageHistoryAnchorIndex, anchorIndex: MessageHistoryAnchorIndex, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, tagMask: MessageTags? = nil, orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { if let account = self.account { let inputAnchor: HistoryViewInputAnchor switch index { @@ -947,7 +969,7 @@ public final class AccountViewTracker { case let .message(index): inputAnchor = .index(index) } - let signal = account.postbox.aroundMessageHistoryViewForLocation(chatLocation, anchor: inputAnchor, count: count, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) + let signal = account.postbox.aroundMessageHistoryViewForLocation(chatLocation, anchor: inputAnchor, count: count, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, namespaces: .not(Namespaces.Message.allScheduled), orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) return wrappedMessageHistorySignal(chatLocation: chatLocation, signal: signal) } else { return .never() @@ -1163,18 +1185,18 @@ public final class AccountViewTracker { let pendingKey: PostboxViewKey = .pendingMessageActionsSummary(type: .consumeUnseenPersonalMessage, peerId: peerId, namespace: Namespaces.Message.Cloud) let summaryKey: PostboxViewKey = .historyTagSummaryView(tag: .unseenPersonalMessage, peerId: peerId, namespace: Namespaces.Message.Cloud) return account.postbox.combinedView(keys: [pendingKey, summaryKey]) - |> map { views -> Int32 in - var count: Int32 = 0 - if let view = views.views[pendingKey] as? PendingMessageActionsSummaryView { - count -= view.count + |> map { views -> Int32 in + var count: Int32 = 0 + if let view = views.views[pendingKey] as? PendingMessageActionsSummaryView { + count -= view.count + } + if let view = views.views[summaryKey] as? MessageHistoryTagSummaryView { + if let unseenCount = view.count { + count += unseenCount } - if let view = views.views[summaryKey] as? MessageHistoryTagSummaryView { - if let unseenCount = view.count { - count += unseenCount - } - } - return max(0, count) - } |> distinctUntilChanged + } + return max(0, count) + } |> distinctUntilChanged } else { return .never() } diff --git a/submodules/TelegramCore/TelegramCore/EnqueueMessage.swift b/submodules/TelegramCore/TelegramCore/EnqueueMessage.swift index ac1022b9ee..3b835c5dd0 100644 --- a/submodules/TelegramCore/TelegramCore/EnqueueMessage.swift +++ b/submodules/TelegramCore/TelegramCore/EnqueueMessage.swift @@ -387,14 +387,17 @@ func enqueueMessages(transaction: Transaction, account: Account, peerId: PeerId, } var messageNamespace = Namespaces.Message.Local + var effectiveTimestamp = timestamp for attribute in attributes { - if attribute is OutgoingScheduleInfoMessageAttribute { + if let attribute = attribute as? OutgoingScheduleInfoMessageAttribute { messageNamespace = Namespaces.Message.ScheduledLocal + effectiveTimestamp = attribute.scheduleTime break } } - storeMessages.append(StoreMessage(peerId: peerId, namespace: messageNamespace, globallyUniqueId: randomId, groupingKey: localGroupingKey, timestamp: timestamp, flags: flags, tags: tags, globalTags: globalTags, localTags: localTags, forwardInfo: nil, authorId: authorId, text: text, attributes: attributes, media: mediaList)) + + storeMessages.append(StoreMessage(peerId: peerId, namespace: messageNamespace, globallyUniqueId: randomId, groupingKey: localGroupingKey, timestamp: effectiveTimestamp, flags: flags, tags: tags, globalTags: globalTags, localTags: localTags, forwardInfo: nil, authorId: authorId, text: text, attributes: attributes, media: mediaList)) case let .forward(source, grouping, requestedAttributes): let sourceMessage = transaction.getMessage(source) if let sourceMessage = sourceMessage, let author = sourceMessage.author ?? sourceMessage.peers[sourceMessage.id.peerId] { @@ -506,12 +509,14 @@ func enqueueMessages(transaction: Transaction, account: Account, peerId: PeerId, var messageNamespace = Namespaces.Message.Local var entitiesAttribute: TextEntitiesMessageAttribute? + var effectiveTimestamp = timestamp for attribute in attributes { if let attribute = attribute as? TextEntitiesMessageAttribute { entitiesAttribute = attribute } - if attribute is OutgoingScheduleInfoMessageAttribute { + if let attribute = attribute as? OutgoingScheduleInfoMessageAttribute { messageNamespace = Namespaces.Message.ScheduledLocal + effectiveTimestamp = attribute.scheduleTime } } @@ -543,7 +548,7 @@ func enqueueMessages(transaction: Transaction, account: Account, peerId: PeerId, augmentedMediaList = augmentedMediaList.map(convertForwardedMediaForSecretChat) } - storeMessages.append(StoreMessage(peerId: peerId, namespace: messageNamespace, globallyUniqueId: randomId, groupingKey: localGroupingKey, timestamp: timestamp, flags: flags, tags: tags, globalTags: globalTags, localTags: [], forwardInfo: forwardInfo, authorId: authorId, text: sourceMessage.text, attributes: attributes, media: augmentedMediaList)) + storeMessages.append(StoreMessage(peerId: peerId, namespace: messageNamespace, globallyUniqueId: randomId, groupingKey: localGroupingKey, timestamp: effectiveTimestamp, flags: flags, tags: tags, globalTags: globalTags, localTags: [], forwardInfo: forwardInfo, authorId: authorId, text: sourceMessage.text, attributes: attributes, media: augmentedMediaList)) } } } diff --git a/submodules/TelegramCore/TelegramCore/HistoryViewChannelStateValidation.swift b/submodules/TelegramCore/TelegramCore/HistoryViewChannelStateValidation.swift deleted file mode 100644 index 02ac52a32e..0000000000 --- a/submodules/TelegramCore/TelegramCore/HistoryViewChannelStateValidation.swift +++ /dev/null @@ -1,610 +0,0 @@ -import Foundation -#if os(macOS) - import PostboxMac - import SwiftSignalKitMac - import MtProtoKitMac - import TelegramApiMac -#else - import Postbox - import SwiftSignalKit - import TelegramApi - #if BUCK - import MtProtoKit - #else - import MtProtoKitDynamic - #endif -#endif - -private final class HistoryStateValidationBatch { - private let disposable: Disposable - let invalidatedState: HistoryState - - var cancelledMessageIds = Set() - - init(disposable: Disposable, invalidatedState: HistoryState) { - self.disposable = disposable - self.invalidatedState = invalidatedState - } - - deinit { - disposable.dispose() - } -} - -private final class HistoryStateValidationContext { - var batchReferences: [MessageId: HistoryStateValidationBatch] = [:] -} - -private enum HistoryState { - case channel(PeerId, ChannelState) - //case group(PeerGroupId, TelegramPeerGroupState) - - var hasInvalidationIndex: Bool { - switch self { - case let .channel(_, state): - return state.invalidatedPts != nil - /*case let .group(_, state): - return state.invalidatedStateIndex != nil*/ - } - } - - func isMessageValid(_ message: Message) -> Bool { - switch self { - case let .channel(_, state): - if let invalidatedPts = state.invalidatedPts { - var messagePts: Int32? - inner: for attribute in message.attributes { - if let attribute = attribute as? ChannelMessageStateVersionAttribute { - messagePts = attribute.pts - break inner - } - } - var requiresValidation = false - if let messagePts = messagePts { - if messagePts < invalidatedPts { - requiresValidation = true - } - } else { - requiresValidation = true - } - - return !requiresValidation - } else { - return true - } - /*case let .group(_, state): - if let invalidatedStateIndex = state.invalidatedStateIndex { - var messageStateIndex: Int32? - inner: for attribute in message.attributes { - if let attribute = attribute as? PeerGroupMessageStateVersionAttribute { - messageStateIndex = attribute.stateIndex - break inner - } - } - var requiresValidation = false - if let messageStateIndex = messageStateIndex { - if messageStateIndex < invalidatedStateIndex { - requiresValidation = true - } - } else { - requiresValidation = true - } - return !requiresValidation - } else { - return true - }*/ - } - } - - func matchesPeerId(_ peerId: PeerId) -> Bool { - switch self { - case let .channel(statePeerId, state): - return statePeerId == peerId - /*case .group: - return true*/ - } - } -} - -private func slicedForValidationMessages(_ messages: [MessageId]) -> [[MessageId]] { - let block = 64 - - if messages.count <= block { - return [messages] - } else { - var result: [[MessageId]] = [] - var offset = 0 - while offset < messages.count { - result.append(Array(messages[offset ..< min(offset + block, messages.count)])) - offset += block - } - return result - } -} - -final class HistoryViewStateValidationContexts { - private let queue: Queue - private let postbox: Postbox - private let network: Network - private let accountPeerId: PeerId - - private var contexts: [Int32: HistoryStateValidationContext] = [:] - - init(queue: Queue, postbox: Postbox, network: Network, accountPeerId: PeerId) { - self.queue = queue - self.postbox = postbox - self.network = network - self.accountPeerId = accountPeerId - } - - func updateView(id: Int32, view: MessageHistoryView?) { - assert(self.queue.isCurrent()) - guard let view = view, view.tagMask == nil || view.tagMask == MessageTags.unseenPersonalMessage else { - if self.contexts[id] != nil { - self.contexts.removeValue(forKey: id) - } - return - } - var historyState: HistoryState? - for entry in view.additionalData { - if case let .peerChatState(peerId, chatState) = entry { - if let chatState = chatState as? ChannelState { - historyState = .channel(peerId, chatState) - } - break - } - } - - if let historyState = historyState, historyState.hasInvalidationIndex { - var rangesToInvalidate: [[MessageId]] = [] - let addToRange: (MessageId, inout [[MessageId]]) -> Void = { id, ranges in - if ranges.isEmpty { - ranges = [[id]] - } else { - ranges[ranges.count - 1].append(id) - } - } - - let addRangeBreak: (inout [[MessageId]]) -> Void = { ranges in - if ranges.last?.count != 0 { - ranges.append([]) - } - } - - for entry in view.entries { - if historyState.matchesPeerId(entry.message.id.peerId) && entry.message.id.namespace == Namespaces.Message.Cloud { - if !historyState.isMessageValid(entry.message) { - addToRange(entry.message.id, &rangesToInvalidate) - } else { - addRangeBreak(&rangesToInvalidate) - } - } - } - - if !rangesToInvalidate.isEmpty && rangesToInvalidate[rangesToInvalidate.count - 1].isEmpty { - rangesToInvalidate.removeLast() - } - - var invalidatedMessageIds = Set() - - if !rangesToInvalidate.isEmpty { - let context: HistoryStateValidationContext - if let current = self.contexts[id] { - context = current - } else { - context = HistoryStateValidationContext() - self.contexts[id] = context - } - - var addedRanges: [[MessageId]] = [] - for messages in rangesToInvalidate { - for id in messages { - invalidatedMessageIds.insert(id) - - if context.batchReferences[id] != nil { - addRangeBreak(&addedRanges) - } else { - addToRange(id, &addedRanges) - } - } - addRangeBreak(&addedRanges) - } - - if !addedRanges.isEmpty && addedRanges[addedRanges.count - 1].isEmpty { - addedRanges.removeLast() - } - - for rangeMessages in addedRanges { - for messages in slicedForValidationMessages(rangeMessages) { - let disposable = MetaDisposable() - let batch = HistoryStateValidationBatch(disposable: disposable, invalidatedState: historyState) - for messageId in messages { - context.batchReferences[messageId] = batch - } - - disposable.set((validateBatch(postbox: self.postbox, network: self.network, accountPeerId: self.accountPeerId, tag: view.tagMask, messageIds: messages, historyState: historyState) - |> deliverOn(self.queue)).start(completed: { [weak self, weak batch] in - if let strongSelf = self, let context = strongSelf.contexts[id], let batch = batch { - var completedMessageIds: [MessageId] = [] - for (messageId, messageBatch) in context.batchReferences { - if messageBatch === batch { - completedMessageIds.append(messageId) - } - } - for messageId in completedMessageIds { - context.batchReferences.removeValue(forKey: messageId) - } - } - })) - } - } - } - - if let context = self.contexts[id] { - var removeIds: [MessageId] = [] - - for batchMessageId in context.batchReferences.keys { - if !invalidatedMessageIds.contains(batchMessageId) { - removeIds.append(batchMessageId) - } - } - - for messageId in removeIds { - context.batchReferences.removeValue(forKey: messageId) - } - } - } - } -} - -private func hashForMessages(_ messages: [Message], withChannelIds: Bool) -> Int32 { - var acc: UInt32 = 0 - - let sorted = messages.sorted(by: { $0.index > $1.index }) - - for message in sorted { - if withChannelIds { - acc = (acc &* 20261) &+ UInt32(message.id.peerId.id) - } - - acc = (acc &* 20261) &+ UInt32(message.id.id) - var timestamp = message.timestamp - inner: for attribute in message.attributes { - if let attribute = attribute as? EditedMessageAttribute { - timestamp = attribute.date - break inner - } - } - acc = (acc &* 20261) &+ UInt32(timestamp) - } - return Int32(bitPattern: acc & UInt32(0x7FFFFFFF)) -} - -private func hashForMessages(_ messages: [StoreMessage], withChannelIds: Bool) -> Int32 { - var acc: UInt32 = 0 - - for message in messages { - if case let .Id(id) = message.id { - if withChannelIds { - acc = (acc &* 20261) &+ UInt32(id.peerId.id) - } - acc = (acc &* 20261) &+ UInt32(id.id) - var timestamp = message.timestamp - inner: for attribute in message.attributes { - if let attribute = attribute as? EditedMessageAttribute { - timestamp = attribute.date - break inner - } - } - acc = (acc &* 20261) &+ UInt32(timestamp) - } - } - return Int32(bitPattern: acc & UInt32(0x7FFFFFFF)) -} - -private enum ValidatedMessages { - case notModified - case messages([Api.Message], [Api.Chat], [Api.User], Int32?) -} - -private func validateBatch(postbox: Postbox, network: Network, accountPeerId: PeerId, tag: MessageTags?, messageIds: [MessageId], historyState: HistoryState) -> Signal { - return postbox.transaction { transaction -> Signal in - var previousMessages: [Message] = [] - var previous: [MessageId: Message] = [:] - for messageId in messageIds { - if let message = transaction.getMessage(messageId) { - previousMessages.append(message) - previous[message.id] = message - } - } - - var signal: Signal - switch historyState { - case let .channel(peerId, _): - let hash = hashForMessages(previousMessages, withChannelIds: false) - Logger.shared.log("HistoryValidation", "validate batch for \(peerId): \(previousMessages.map({ $0.id }))") - if let peer = transaction.getPeer(peerId), let inputPeer = apiInputPeer(peer) { - let requestSignal: Signal - if let tag = tag { - if tag == MessageTags.unseenPersonalMessage { - requestSignal = network.request(Api.functions.messages.getUnreadMentions(peer: inputPeer, offsetId: messageIds[messageIds.count - 1].id + 1, addOffset: 0, limit: Int32(messageIds.count), maxId: messageIds[messageIds.count - 1].id + 1, minId: messageIds[0].id - 1)) - } else { - assertionFailure() - requestSignal = .complete() - } - } else { - requestSignal = network.request(Api.functions.messages.getHistory(peer: inputPeer, offsetId: messageIds[messageIds.count - 1].id + 1, offsetDate: 0, addOffset: 0, limit: Int32(messageIds.count), maxId: messageIds[messageIds.count - 1].id + 1, minId: messageIds[0].id - 1, hash: hash)) - } - - signal = requestSignal - |> map { result -> ValidatedMessages in - let messages: [Api.Message] - let chats: [Api.Chat] - let users: [Api.User] - var channelPts: Int32? - - switch result { - case let .messages(messages: apiMessages, chats: apiChats, users: apiUsers): - messages = apiMessages - chats = apiChats - users = apiUsers - case let .messagesSlice(_, _, _, messages: apiMessages, chats: apiChats, users: apiUsers): - messages = apiMessages - chats = apiChats - users = apiUsers - case let .channelMessages(_, pts, _, apiMessages, apiChats, apiUsers): - messages = apiMessages - chats = apiChats - users = apiUsers - channelPts = pts - case .messagesNotModified: - return .notModified - } - return .messages(messages, chats, users, channelPts) - } - } else { - return .complete() - } - } - - return signal - |> map(Optional.init) - |> `catch` { _ -> Signal in - return .single(nil) - } - |> mapToSignal { result -> Signal in - guard let result = result else { - return .complete() - } - switch result { - case let .messages(messages, chats, users, channelPts): - var storeMessages: [StoreMessage] = [] - - for message in messages { - if let storeMessage = StoreMessage(apiMessage: message) { - var attributes = storeMessage.attributes - - if let channelPts = channelPts { - attributes.append(ChannelMessageStateVersionAttribute(pts: channelPts)) - } - - storeMessages.append(storeMessage.withUpdatedAttributes(attributes)) - } - } - - var validMessageIds = Set() - for message in storeMessages { - if case let .Id(id) = message.id { - validMessageIds.insert(id) - } - } - - var maybeRemovedMessageIds: [MessageId] = [] - for id in previous.keys { - if !validMessageIds.contains(id) { - maybeRemovedMessageIds.append(id) - } - } - - let actuallyRemovedMessagesSignal: Signal, NoError> - if maybeRemovedMessageIds.isEmpty { - actuallyRemovedMessagesSignal = .single(Set()) - } else { - actuallyRemovedMessagesSignal = postbox.transaction { transaction -> Signal, NoError> in - switch historyState { - case let .channel(peerId, _): - if let inputChannel = transaction.getPeer(peerId).flatMap(apiInputChannel) { - return network.request(Api.functions.channels.getMessages(channel: inputChannel, id: maybeRemovedMessageIds.map({ Api.InputMessage.inputMessageID(id: $0.id) }))) - |> map { result -> Set in - let apiMessages: [Api.Message] - switch result { - case let .channelMessages(_, _, _, messages, _, _): - apiMessages = messages - case let .messages(messages, _, _): - apiMessages = messages - case let .messagesSlice(_, _, _, messages, _, _): - apiMessages = messages - case .messagesNotModified: - return Set() - } - var ids = Set() - for message in apiMessages { - if let parsedMessage = StoreMessage(apiMessage: message), case let .Id(id) = parsedMessage.id { - if let tag = tag { - if parsedMessage.tags.contains(tag) { - ids.insert(id) - } - } else { - ids.insert(id) - } - } - } - return Set(maybeRemovedMessageIds).subtracting(ids) - } - |> `catch` { _ -> Signal, NoError> in - return .single(Set(maybeRemovedMessageIds)) - } - } - } - return .single(Set(maybeRemovedMessageIds)) - } - |> switchToLatest - } - - return actuallyRemovedMessagesSignal - |> mapToSignal { removedMessageIds -> Signal in - return postbox.transaction { transaction -> Void in - var validMessageIds = Set() - for message in storeMessages { - if case let .Id(id) = message.id { - validMessageIds.insert(id) - let previousMessage = previous[id] ?? transaction.getMessage(id) - - if let previousMessage = previousMessage { - var updatedTimestamp = message.timestamp - inner: for attribute in message.attributes { - if let attribute = attribute as? EditedMessageAttribute { - updatedTimestamp = attribute.date - break inner - } - } - - var timestamp = previousMessage.timestamp - inner: for attribute in previousMessage.attributes { - if let attribute = attribute as? EditedMessageAttribute { - timestamp = attribute.date - break inner - } - } - - transaction.updateMessage(id, update: { currentMessage in - if updatedTimestamp != timestamp { - var updatedLocalTags = message.localTags - if currentMessage.localTags.contains(.OutgoingLiveLocation) { - updatedLocalTags.insert(.OutgoingLiveLocation) - } - return .update(message.withUpdatedLocalTags(updatedLocalTags)) - } else { - var storeForwardInfo: StoreMessageForwardInfo? - if let forwardInfo = currentMessage.forwardInfo { - storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) - } - var attributes = currentMessage.attributes - if let channelPts = channelPts { - for i in (0 ..< attributes.count).reversed() { - if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { - attributes.remove(at: i) - } - } - attributes.append(ChannelMessageStateVersionAttribute(pts: channelPts)) - } - - let updatedFlags = StoreMessageFlags(currentMessage.flags) - - return .update(StoreMessage(id: message.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: updatedFlags, tags: currentMessage.tags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) - } - }) - - if previous[id] == nil { - print("\(id) missing") - } - } else { - let _ = transaction.addMessages([message], location: .Random) - } - } - } - - if let tag = tag { - for (_, previousMessage) in previous { - if !validMessageIds.contains(previousMessage.id) { - transaction.updateMessage(previousMessage.id, update: { currentMessage in - var updatedTags = currentMessage.tags - updatedTags.remove(tag) - var storeForwardInfo: StoreMessageForwardInfo? - if let forwardInfo = currentMessage.forwardInfo { - storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) - } - var attributes = currentMessage.attributes - for i in (0 ..< attributes.count).reversed() { - switch historyState { - case .channel: - if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { - attributes.remove(at: i) - } - } - } - switch historyState { - case let .channel(_, channelState): - attributes.append(ChannelMessageStateVersionAttribute(pts: channelState.pts)) - } - return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: updatedTags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) - }) - } - } - } - - for id in removedMessageIds { - if !validMessageIds.contains(id) { - if let tag = tag { - transaction.updateMessage(id, update: { currentMessage in - var updatedTags = currentMessage.tags - updatedTags.remove(tag) - var storeForwardInfo: StoreMessageForwardInfo? - if let forwardInfo = currentMessage.forwardInfo { - storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) - } - var attributes = currentMessage.attributes - for i in (0 ..< attributes.count).reversed() { - switch historyState { - case .channel: - if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { - attributes.remove(at: i) - } - } - } - switch historyState { - case let .channel(_, channelState): - attributes.append(ChannelMessageStateVersionAttribute(pts: channelState.pts)) - } - return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: updatedTags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) - }) - } else { - switch historyState { - case .channel: - deleteMessages(transaction: transaction, mediaBox: postbox.mediaBox, ids: [id]) - Logger.shared.log("HistoryValidation", "deleting message \(id) in \(id.peerId)") - } - } - } - } - } - } - case .notModified: - return postbox.transaction { transaction -> Void in - for id in previous.keys { - transaction.updateMessage(id, update: { currentMessage in - var storeForwardInfo: StoreMessageForwardInfo? - if let forwardInfo = currentMessage.forwardInfo { - storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) - } - var attributes = currentMessage.attributes - for i in (0 ..< attributes.count).reversed() { - switch historyState { - case .channel: - if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { - attributes.remove(at: i) - } - } - } - switch historyState { - case let .channel(_, channelState): - attributes.append(ChannelMessageStateVersionAttribute(pts: channelState.pts)) - } - return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: currentMessage.tags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) - }) - } - } - } - } - } |> switchToLatest -} diff --git a/submodules/TelegramCore/TelegramCore/HistoryViewStateValidation.swift b/submodules/TelegramCore/TelegramCore/HistoryViewStateValidation.swift new file mode 100644 index 0000000000..853787d471 --- /dev/null +++ b/submodules/TelegramCore/TelegramCore/HistoryViewStateValidation.swift @@ -0,0 +1,695 @@ +import Foundation +#if os(macOS) + import PostboxMac + import SwiftSignalKitMac + import MtProtoKitMac + import TelegramApiMac +#else + import Postbox + import SwiftSignalKit + import TelegramApi + #if BUCK + import MtProtoKit + #else + import MtProtoKitDynamic + #endif +#endif + +private final class HistoryStateValidationBatch { + private let disposable: Disposable + let invalidatedState: HistoryState? + + var cancelledMessageIds = Set() + + init(disposable: Disposable, invalidatedState: HistoryState? = nil) { + self.disposable = disposable + self.invalidatedState = invalidatedState + } + + deinit { + self.disposable.dispose() + } +} + +private final class HistoryStateValidationContext { + var batchReferences: [MessageId: HistoryStateValidationBatch] = [:] + var batch: HistoryStateValidationBatch? +} + +private enum HistoryState { + case channel(PeerId, ChannelState) + //case group(PeerGroupId, TelegramPeerGroupState) + case scheduledMessages(PeerId) + + var hasInvalidationIndex: Bool { + switch self { + case let .channel(_, state): + return state.invalidatedPts != nil + /*case let .group(_, state): + return state.invalidatedStateIndex != nil*/ + case .scheduledMessages: + return false + } + } + + func isMessageValid(_ message: Message) -> Bool { + switch self { + case let .channel(_, state): + if let invalidatedPts = state.invalidatedPts { + var messagePts: Int32? + inner: for attribute in message.attributes { + if let attribute = attribute as? ChannelMessageStateVersionAttribute { + messagePts = attribute.pts + break inner + } + } + var requiresValidation = false + if let messagePts = messagePts { + if messagePts < invalidatedPts { + requiresValidation = true + } + } else { + requiresValidation = true + } + + return !requiresValidation + } else { + return true + } + /*case let .group(_, state): + if let invalidatedStateIndex = state.invalidatedStateIndex { + var messageStateIndex: Int32? + inner: for attribute in message.attributes { + if let attribute = attribute as? PeerGroupMessageStateVersionAttribute { + messageStateIndex = attribute.stateIndex + break inner + } + } + var requiresValidation = false + if let messageStateIndex = messageStateIndex { + if messageStateIndex < invalidatedStateIndex { + requiresValidation = true + } + } else { + requiresValidation = true + } + return !requiresValidation + } else { + return true + }*/ + case .scheduledMessages: + return false + } + } + + func matchesPeerId(_ peerId: PeerId) -> Bool { + switch self { + case let .channel(statePeerId, _): + return statePeerId == peerId + /*case .group: + return true*/ + case let .scheduledMessages(statePeerId): + return statePeerId == peerId + } + } +} + +private func slicedForValidationMessages(_ messages: [MessageId]) -> [[MessageId]] { + let block = 64 + + if messages.count <= block { + return [messages] + } else { + var result: [[MessageId]] = [] + var offset = 0 + while offset < messages.count { + result.append(Array(messages[offset ..< min(offset + block, messages.count)])) + offset += block + } + return result + } +} + +final class HistoryViewStateValidationContexts { + private let queue: Queue + private let postbox: Postbox + private let network: Network + private let accountPeerId: PeerId + + private var contexts: [Int32: HistoryStateValidationContext] = [:] + + init(queue: Queue, postbox: Postbox, network: Network, accountPeerId: PeerId) { + self.queue = queue + self.postbox = postbox + self.network = network + self.accountPeerId = accountPeerId + } + + func updateView(id: Int32, view: MessageHistoryView?, location: ChatLocation? = nil) { + assert(self.queue.isCurrent()) + guard let view = view, view.tagMask == nil || view.tagMask == MessageTags.unseenPersonalMessage else { + if self.contexts[id] != nil { + self.contexts.removeValue(forKey: id) + } + return + } + var historyState: HistoryState? + for entry in view.additionalData { + if case let .peerChatState(peerId, chatState) = entry { + if let chatState = chatState as? ChannelState { + historyState = .channel(peerId, chatState) + } + break + } + } + + if let historyState = historyState, historyState.hasInvalidationIndex { + var rangesToInvalidate: [[MessageId]] = [] + let addToRange: (MessageId, inout [[MessageId]]) -> Void = { id, ranges in + if ranges.isEmpty { + ranges = [[id]] + } else { + ranges[ranges.count - 1].append(id) + } + } + + let addRangeBreak: (inout [[MessageId]]) -> Void = { ranges in + if ranges.last?.count != 0 { + ranges.append([]) + } + } + + for entry in view.entries { + if historyState.matchesPeerId(entry.message.id.peerId) && entry.message.id.namespace == Namespaces.Message.Cloud { + if !historyState.isMessageValid(entry.message) { + addToRange(entry.message.id, &rangesToInvalidate) + } else { + addRangeBreak(&rangesToInvalidate) + } + } + } + + if !rangesToInvalidate.isEmpty && rangesToInvalidate[rangesToInvalidate.count - 1].isEmpty { + rangesToInvalidate.removeLast() + } + + var invalidatedMessageIds = Set() + + if !rangesToInvalidate.isEmpty { + let context: HistoryStateValidationContext + if let current = self.contexts[id] { + context = current + } else { + context = HistoryStateValidationContext() + self.contexts[id] = context + } + + var addedRanges: [[MessageId]] = [] + for messages in rangesToInvalidate { + for id in messages { + invalidatedMessageIds.insert(id) + + if context.batchReferences[id] != nil { + addRangeBreak(&addedRanges) + } else { + addToRange(id, &addedRanges) + } + } + addRangeBreak(&addedRanges) + } + + if !addedRanges.isEmpty && addedRanges[addedRanges.count - 1].isEmpty { + addedRanges.removeLast() + } + + for rangeMessages in addedRanges { + for messages in slicedForValidationMessages(rangeMessages) { + let disposable = MetaDisposable() + let batch = HistoryStateValidationBatch(disposable: disposable, invalidatedState: historyState) + for messageId in messages { + context.batchReferences[messageId] = batch + } + + disposable.set((validateChannelMessagesBatch(postbox: self.postbox, network: self.network, accountPeerId: self.accountPeerId, tag: view.tagMask, messageIds: messages, historyState: historyState) + |> deliverOn(self.queue)).start(completed: { [weak self, weak batch] in + if let strongSelf = self, let context = strongSelf.contexts[id], let batch = batch { + var completedMessageIds: [MessageId] = [] + for (messageId, messageBatch) in context.batchReferences { + if messageBatch === batch { + completedMessageIds.append(messageId) + } + } + for messageId in completedMessageIds { + context.batchReferences.removeValue(forKey: messageId) + } + } + })) + } + } + } + + if let context = self.contexts[id] { + var removeIds: [MessageId] = [] + + for batchMessageId in context.batchReferences.keys { + if !invalidatedMessageIds.contains(batchMessageId) { + removeIds.append(batchMessageId) + } + } + + for messageId in removeIds { + context.batchReferences.removeValue(forKey: messageId) + } + } + } else if view.namespaces.contains(Namespaces.Message.ScheduledCloud) { + if let _ = self.contexts[id] { + } else if let location = location, case let .peer(peerId) = location { + let context = HistoryStateValidationContext() + self.contexts[id] = context + + let disposable = MetaDisposable() + let batch = HistoryStateValidationBatch(disposable: disposable) + context.batch = batch + + let messages: [Message] = view.entries.map { $0.message } + + disposable.set((validateScheduledMessagesBatch(postbox: self.postbox, network: self.network, accountPeerId: peerId, tag: nil, messages: messages, historyState: .scheduledMessages(peerId)) + |> deliverOn(self.queue)).start(completed: { [weak self] in + if let strongSelf = self, let context = strongSelf.contexts[id] { + context.batch = nil + } + })) + } + } + } +} + +private func hashForMessages(_ messages: [Message], withChannelIds: Bool) -> Int32 { + var acc: UInt32 = 0 + + let sorted = messages.sorted(by: { $0.index > $1.index }) + + for message in sorted { + if withChannelIds { + acc = (acc &* 20261) &+ UInt32(message.id.peerId.id) + } + + acc = (acc &* 20261) &+ UInt32(message.id.id) + var timestamp = message.timestamp + inner: for attribute in message.attributes { + if let attribute = attribute as? EditedMessageAttribute { + timestamp = attribute.date + break inner + } + } + acc = (acc &* 20261) &+ UInt32(timestamp) + } + return Int32(bitPattern: acc & UInt32(0x7FFFFFFF)) +} + +private func hashForMessages(_ messages: [StoreMessage], withChannelIds: Bool) -> Int32 { + var acc: UInt32 = 0 + + for message in messages { + if case let .Id(id) = message.id { + if withChannelIds { + acc = (acc &* 20261) &+ UInt32(id.peerId.id) + } + acc = (acc &* 20261) &+ UInt32(id.id) + var timestamp = message.timestamp + inner: for attribute in message.attributes { + if let attribute = attribute as? EditedMessageAttribute { + timestamp = attribute.date + break inner + } + } + acc = (acc &* 20261) &+ UInt32(timestamp) + } + } + return Int32(bitPattern: acc & UInt32(0x7FFFFFFF)) +} + +private enum ValidatedMessages { + case notModified + case messages([Api.Message], [Api.Chat], [Api.User], Int32?) +} + +private func validateChannelMessagesBatch(postbox: Postbox, network: Network, accountPeerId: PeerId, tag: MessageTags?, messageIds: [MessageId], historyState: HistoryState) -> Signal { + return postbox.transaction { transaction -> Signal in + var previousMessages: [Message] = [] + var previous: [MessageId: Message] = [:] + for messageId in messageIds { + if let message = transaction.getMessage(messageId) { + previousMessages.append(message) + previous[message.id] = message + } + } + + var signal: Signal + switch historyState { + case let .channel(peerId, _): + let hash = hashForMessages(previousMessages, withChannelIds: false) + Logger.shared.log("HistoryValidation", "validate batch for \(peerId): \(previousMessages.map({ $0.id }))") + if let peer = transaction.getPeer(peerId), let inputPeer = apiInputPeer(peer) { + let requestSignal: Signal + if let tag = tag { + if tag == MessageTags.unseenPersonalMessage { + requestSignal = network.request(Api.functions.messages.getUnreadMentions(peer: inputPeer, offsetId: messageIds[messageIds.count - 1].id + 1, addOffset: 0, limit: Int32(messageIds.count), maxId: messageIds[messageIds.count - 1].id + 1, minId: messageIds[0].id - 1)) + } else { + assertionFailure() + requestSignal = .complete() + } + } else { + requestSignal = network.request(Api.functions.messages.getHistory(peer: inputPeer, offsetId: messageIds[messageIds.count - 1].id + 1, offsetDate: 0, addOffset: 0, limit: Int32(messageIds.count), maxId: messageIds[messageIds.count - 1].id + 1, minId: messageIds[0].id - 1, hash: hash)) + } + + signal = requestSignal + |> map { result -> ValidatedMessages in + let messages: [Api.Message] + let chats: [Api.Chat] + let users: [Api.User] + var channelPts: Int32? + + switch result { + case let .messages(messages: apiMessages, chats: apiChats, users: apiUsers): + messages = apiMessages + chats = apiChats + users = apiUsers + case let .messagesSlice(_, _, _, messages: apiMessages, chats: apiChats, users: apiUsers): + messages = apiMessages + chats = apiChats + users = apiUsers + case let .channelMessages(_, pts, _, apiMessages, apiChats, apiUsers): + messages = apiMessages + chats = apiChats + users = apiUsers + channelPts = pts + case .messagesNotModified: + return .notModified + } + return .messages(messages, chats, users, channelPts) + } + } else { + return .complete() + } + default: + signal = .complete() + } + + return validateBatch(postbox: postbox, network: network, transaction: transaction, accountPeerId: accountPeerId, tag: tag, historyState: historyState, signal: signal, previous: previous, messageNamespace: Namespaces.Message.Cloud) + } |> switchToLatest +} + +private func validateScheduledMessagesBatch(postbox: Postbox, network: Network, accountPeerId: PeerId, tag: MessageTags?, messages: [Message], historyState: HistoryState) -> Signal { + return postbox.transaction { transaction -> Signal in + var signal: Signal + switch historyState { + case let .scheduledMessages(peerId): + if let peer = transaction.getPeer(peerId), let inputPeer = apiInputPeer(peer) { + signal = network.request(Api.functions.messages.getScheduledHistory(peer: inputPeer, hash: 0)) + |> map { result -> ValidatedMessages in + let messages: [Api.Message] + let chats: [Api.Chat] + let users: [Api.User] + + switch result { + case let .messages(messages: apiMessages, chats: apiChats, users: apiUsers): + messages = apiMessages + chats = apiChats + users = apiUsers + case let .messagesSlice(_, _, _, messages: apiMessages, chats: apiChats, users: apiUsers): + messages = apiMessages + chats = apiChats + users = apiUsers + case let .channelMessages(_, _, _, apiMessages, apiChats, apiUsers): + messages = apiMessages + chats = apiChats + users = apiUsers + case .messagesNotModified: + return .notModified + } + return .messages(messages, chats, users, nil) + } + } else { + signal = .complete() + } + default: + signal = .complete() + } + var previous: [MessageId: Message] = [:] + for message in messages { + previous[message.id] = message + } + return validateBatch(postbox: postbox, network: network, transaction: transaction, accountPeerId: accountPeerId, tag: tag, historyState: historyState, signal: signal, previous: previous, messageNamespace: Namespaces.Message.ScheduledCloud) + } |> switchToLatest +} + +private func validateBatch(postbox: Postbox, network: Network, transaction: Transaction, accountPeerId: PeerId, tag: MessageTags?, historyState: HistoryState, signal: Signal, previous: [MessageId: Message], messageNamespace: MessageId.Namespace) -> Signal { + return signal + |> map(Optional.init) + |> `catch` { _ -> Signal in + return .single(nil) + } + |> mapToSignal { result -> Signal in + guard let result = result else { + return .complete() + } + switch result { + case let .messages(messages, _, users, channelPts): + var storeMessages: [StoreMessage] = [] + + for message in messages { + if let storeMessage = StoreMessage(apiMessage: message, namespace: messageNamespace) { + var attributes = storeMessage.attributes + if let channelPts = channelPts { + attributes.append(ChannelMessageStateVersionAttribute(pts: channelPts)) + } + storeMessages.append(storeMessage.withUpdatedAttributes(attributes)) + } + } + + var validMessageIds = Set() + for message in storeMessages { + if case let .Id(id) = message.id { + validMessageIds.insert(id) + } + } + + var maybeRemovedMessageIds: [MessageId] = [] + for id in previous.keys { + if !validMessageIds.contains(id) { + maybeRemovedMessageIds.append(id) + } + } + + let actuallyRemovedMessagesSignal: Signal, NoError> + if maybeRemovedMessageIds.isEmpty { + actuallyRemovedMessagesSignal = .single(Set()) + } else { + switch historyState { + case let .channel(peerId, _): + actuallyRemovedMessagesSignal = postbox.transaction { transaction -> Signal, NoError> in + if let inputChannel = transaction.getPeer(peerId).flatMap(apiInputChannel) { + return network.request(Api.functions.channels.getMessages(channel: inputChannel, id: maybeRemovedMessageIds.map({ Api.InputMessage.inputMessageID(id: $0.id) }))) + |> map { result -> Set in + let apiMessages: [Api.Message] + switch result { + case let .channelMessages(_, _, _, messages, _, _): + apiMessages = messages + case let .messages(messages, _, _): + apiMessages = messages + case let .messagesSlice(_, _, _, messages, _, _): + apiMessages = messages + case .messagesNotModified: + return Set() + } + var ids = Set() + for message in apiMessages { + if let parsedMessage = StoreMessage(apiMessage: message), case let .Id(id) = parsedMessage.id { + if let tag = tag { + if parsedMessage.tags.contains(tag) { + ids.insert(id) + } + } else { + ids.insert(id) + } + } + } + return Set(maybeRemovedMessageIds).subtracting(ids) + } + |> `catch` { _ -> Signal, NoError> in + return .single(Set(maybeRemovedMessageIds)) + } + } + return .single(Set(maybeRemovedMessageIds)) + } |> switchToLatest + default: + actuallyRemovedMessagesSignal = .single(Set(maybeRemovedMessageIds)) + } + } + + return actuallyRemovedMessagesSignal + |> mapToSignal { removedMessageIds -> Signal in + return postbox.transaction { transaction -> Void in + var validMessageIds = Set() + for message in storeMessages { + if case let .Id(id) = message.id { + validMessageIds.insert(id) + let previousMessage = previous[id] ?? transaction.getMessage(id) + + if let previousMessage = previousMessage { + var updatedTimestamp = message.timestamp + inner: for attribute in message.attributes { + if let attribute = attribute as? EditedMessageAttribute { + updatedTimestamp = attribute.date + break inner + } + } + + var timestamp = previousMessage.timestamp + inner: for attribute in previousMessage.attributes { + if let attribute = attribute as? EditedMessageAttribute { + timestamp = attribute.date + break inner + } + } + + transaction.updateMessage(id, update: { currentMessage in + if updatedTimestamp != timestamp { + var updatedLocalTags = message.localTags + if currentMessage.localTags.contains(.OutgoingLiveLocation) { + updatedLocalTags.insert(.OutgoingLiveLocation) + } + return .update(message.withUpdatedLocalTags(updatedLocalTags)) + } else { + var storeForwardInfo: StoreMessageForwardInfo? + if let forwardInfo = currentMessage.forwardInfo { + storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) + } + var attributes = currentMessage.attributes + if let channelPts = channelPts { + for i in (0 ..< attributes.count).reversed() { + if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { + attributes.remove(at: i) + } + } + attributes.append(ChannelMessageStateVersionAttribute(pts: channelPts)) + } + + let updatedFlags = StoreMessageFlags(currentMessage.flags) + + return .update(StoreMessage(id: message.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: updatedFlags, tags: currentMessage.tags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) + } + }) + + if previous[id] == nil { + print("\(id) missing") + } + } else { + let _ = transaction.addMessages([message], location: .Random) + } + } + } + + if let tag = tag { + for (_, previousMessage) in previous { + if !validMessageIds.contains(previousMessage.id) { + transaction.updateMessage(previousMessage.id, update: { currentMessage in + var updatedTags = currentMessage.tags + updatedTags.remove(tag) + var storeForwardInfo: StoreMessageForwardInfo? + if let forwardInfo = currentMessage.forwardInfo { + storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) + } + var attributes = currentMessage.attributes + for i in (0 ..< attributes.count).reversed() { + switch historyState { + case .channel: + if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { + attributes.remove(at: i) + } + default: + break + } + } + switch historyState { + case let .channel(_, channelState): + attributes.append(ChannelMessageStateVersionAttribute(pts: channelState.pts)) + default: + break + } + return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: updatedTags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) + }) + } + } + } + + for id in removedMessageIds { + if !validMessageIds.contains(id) { + if let tag = tag { + transaction.updateMessage(id, update: { currentMessage in + var updatedTags = currentMessage.tags + updatedTags.remove(tag) + var storeForwardInfo: StoreMessageForwardInfo? + if let forwardInfo = currentMessage.forwardInfo { + storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) + } + var attributes = currentMessage.attributes + for i in (0 ..< attributes.count).reversed() { + switch historyState { + case .channel: + if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { + attributes.remove(at: i) + } + default: + break + } + } + switch historyState { + case let .channel(_, channelState): + attributes.append(ChannelMessageStateVersionAttribute(pts: channelState.pts)) + default: + break + } + return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: updatedTags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) + }) + } else { + deleteMessages(transaction: transaction, mediaBox: postbox.mediaBox, ids: [id]) + Logger.shared.log("HistoryValidation", "deleting message \(id) in \(id.peerId)") + } + } + } + } + } + case .notModified: + return postbox.transaction { transaction -> Void in + for id in previous.keys { + transaction.updateMessage(id, update: { currentMessage in + var storeForwardInfo: StoreMessageForwardInfo? + if let forwardInfo = currentMessage.forwardInfo { + storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: forwardInfo.authorSignature) + } + var attributes = currentMessage.attributes + for i in (0 ..< attributes.count).reversed() { + switch historyState { + case .channel: + if let _ = attributes[i] as? ChannelMessageStateVersionAttribute { + attributes.remove(at: i) + } + default: + break + } + } + switch historyState { + case let .channel(_, channelState): + attributes.append(ChannelMessageStateVersionAttribute(pts: channelState.pts)) + default: + break + } + return .update(StoreMessage(id: currentMessage.id, globallyUniqueId: currentMessage.globallyUniqueId, groupingKey: currentMessage.groupingKey, timestamp: currentMessage.timestamp, flags: StoreMessageFlags(currentMessage.flags), tags: currentMessage.tags, globalTags: currentMessage.globalTags, localTags: currentMessage.localTags, forwardInfo: storeForwardInfo, authorId: currentMessage.author?.id, text: currentMessage.text, attributes: attributes, media: currentMessage.media)) + }) + } + } + } + } +} diff --git a/submodules/TelegramCore/TelegramCore/Holes.swift b/submodules/TelegramCore/TelegramCore/Holes.swift index cc5eb728f7..859f709377 100644 --- a/submodules/TelegramCore/TelegramCore/Holes.swift +++ b/submodules/TelegramCore/TelegramCore/Holes.swift @@ -151,16 +151,57 @@ func fetchMessageHistoryHole(accountPeerId: PeerId, source: FetchMessageHistoryH var implicitelyFillHole = false let minMaxRange: ClosedRange - if namespace == Namespaces.Message.ScheduledCloud { - switch direction { - case .aroundId, .range: - implicitelyFillHole = true - } - minMaxRange = 1 ... (Int32.max - 1) - request = source.request(Api.functions.messages.getScheduledHistory(peer: inputPeer, hash: 0)) - } else { - switch space { - case .everywhere: + switch space { + case .everywhere: + let offsetId: Int32 + let addOffset: Int32 + let selectedLimit = limit + let maxId: Int32 + let minId: Int32 + + switch direction { + case let .range(start, end): + if start.id <= end.id { + offsetId = start.id <= 1 ? 1 : (start.id - 1) + addOffset = Int32(-selectedLimit) + maxId = end.id + minId = start.id - 1 + + let rangeStartId = start.id + let rangeEndId = min(end.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId + } else { + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() + } + } else { + offsetId = start.id == Int32.max ? start.id : (start.id + 1) + addOffset = 0 + maxId = start.id == Int32.max ? start.id : (start.id + 1) + minId = end.id + + let rangeStartId = end.id + let rangeEndId = min(start.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId + } else { + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() + } + } + case let .aroundId(id): + offsetId = id.id + addOffset = Int32(-selectedLimit / 2) + maxId = Int32.max + minId = 1 + minMaxRange = 1 ... Int32.max - 1 + } + + request = source.request(Api.functions.messages.getHistory(peer: inputPeer, offsetId: offsetId, offsetDate: 0, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) + case let .tag(tag): + assert(tag.containsSingleElement) + if tag == .unseenPersonalMessage { let offsetId: Int32 let addOffset: Int32 let selectedLimit = limit @@ -203,122 +244,72 @@ func fetchMessageHistoryHole(accountPeerId: PeerId, source: FetchMessageHistoryH addOffset = Int32(-selectedLimit / 2) maxId = Int32.max minId = 1 + minMaxRange = 1 ... Int32.max - 1 } - request = source.request(Api.functions.messages.getHistory(peer: inputPeer, offsetId: offsetId, offsetDate: 0, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) - case let .tag(tag): - assert(tag.containsSingleElement) - if tag == .unseenPersonalMessage { - let offsetId: Int32 - let addOffset: Int32 - let selectedLimit = limit - let maxId: Int32 - let minId: Int32 - - switch direction { - case let .range(start, end): - if start.id <= end.id { - offsetId = start.id <= 1 ? 1 : (start.id - 1) - addOffset = Int32(-selectedLimit) - maxId = end.id - minId = start.id - 1 - - let rangeStartId = start.id - let rangeEndId = min(end.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } + request = source.request(Api.functions.messages.getUnreadMentions(peer: inputPeer, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId)) + } else if tag == .liveLocation { + let selectedLimit = limit + + switch direction { + case .aroundId, .range: + implicitelyFillHole = true + } + minMaxRange = 1 ... (Int32.max - 1) + request = source.request(Api.functions.messages.getRecentLocations(peer: inputPeer, limit: Int32(selectedLimit), hash: 0)) + } else if let filter = messageFilterForTagMask(tag) { + let offsetId: Int32 + let addOffset: Int32 + let selectedLimit = limit + let maxId: Int32 + let minId: Int32 + + switch direction { + case let .range(start, end): + if start.id <= end.id { + offsetId = start.id <= 1 ? 1 : (start.id - 1) + addOffset = Int32(-selectedLimit) + maxId = end.id + minId = start.id - 1 + + let rangeStartId = start.id + let rangeEndId = min(end.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId } else { - offsetId = start.id == Int32.max ? start.id : (start.id + 1) - addOffset = 0 - maxId = start.id == Int32.max ? start.id : (start.id + 1) - minId = end.id - - let rangeStartId = end.id - let rangeEndId = min(start.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() } - case let .aroundId(id): - offsetId = id.id - addOffset = Int32(-selectedLimit / 2) - maxId = Int32.max - minId = 1 - - minMaxRange = 1 ... Int32.max - 1 - } - - request = source.request(Api.functions.messages.getUnreadMentions(peer: inputPeer, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId)) - } else if tag == .liveLocation { - let selectedLimit = limit - - switch direction { - case .aroundId, .range: - implicitelyFillHole = true - } - minMaxRange = 1 ... (Int32.max - 1) - request = source.request(Api.functions.messages.getRecentLocations(peer: inputPeer, limit: Int32(selectedLimit), hash: 0)) - } else if let filter = messageFilterForTagMask(tag) { - let offsetId: Int32 - let addOffset: Int32 - let selectedLimit = limit - let maxId: Int32 - let minId: Int32 - - switch direction { - case let .range(start, end): - if start.id <= end.id { - offsetId = start.id <= 1 ? 1 : (start.id - 1) - addOffset = Int32(-selectedLimit) - maxId = end.id - minId = start.id - 1 - - let rangeStartId = start.id - let rangeEndId = min(end.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } + } else { + offsetId = start.id == Int32.max ? start.id : (start.id + 1) + addOffset = 0 + maxId = start.id == Int32.max ? start.id : (start.id + 1) + minId = end.id + + let rangeStartId = end.id + let rangeEndId = min(start.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId } else { - offsetId = start.id == Int32.max ? start.id : (start.id + 1) - addOffset = 0 - maxId = start.id == Int32.max ? start.id : (start.id + 1) - minId = end.id - - let rangeStartId = end.id - let rangeEndId = min(start.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() } - case let .aroundId(id): - offsetId = id.id - addOffset = Int32(-selectedLimit / 2) - maxId = Int32.max - minId = 1 - - minMaxRange = 1 ... (Int32.max - 1) - } + } + case let .aroundId(id): + offsetId = id.id + addOffset = Int32(-selectedLimit / 2) + maxId = Int32.max + minId = 1 - request = source.request(Api.functions.messages.search(flags: 0, peer: inputPeer, q: "", fromId: nil, filter: filter, minDate: 0, maxDate: 0, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) - } else { - assertionFailure() - minMaxRange = 1 ... 1 - request = .never() - } + minMaxRange = 1 ... (Int32.max - 1) + } + + request = source.request(Api.functions.messages.search(flags: 0, peer: inputPeer, q: "", fromId: nil, filter: filter, minDate: 0, maxDate: 0, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) + } else { + assertionFailure() + minMaxRange = 1 ... 1 + request = .never() } } diff --git a/submodules/TelegramCore/TelegramCore/ManagedSynchronizeEmojiKeywordsOperations.swift b/submodules/TelegramCore/TelegramCore/ManagedSynchronizeEmojiKeywordsOperations.swift index 4773e2d9c7..c9ca8718cb 100644 --- a/submodules/TelegramCore/TelegramCore/ManagedSynchronizeEmojiKeywordsOperations.swift +++ b/submodules/TelegramCore/TelegramCore/ManagedSynchronizeEmojiKeywordsOperations.swift @@ -63,7 +63,7 @@ private func withTakenOperation(postbox: Postbox, peerId: PeerId, tagLocalIndex: return postbox.transaction { transaction -> Signal in var result: PeerMergedOperationLogEntry? transaction.operationLogUpdateEntry(peerId: peerId, tag: OperationLogTags.SynchronizeEmojiKeywords, tagLocalIndex: tagLocalIndex, { entry in - if let entry = entry, let _ = entry.mergedIndex, entry.contents is SynchronizeEmojiKeywordsOperation { + if let entry = entry, let _ = entry.mergedIndex, entry.contents is SynchronizeEmojiKeywordsOperation { result = entry.mergedEntry! return PeerOperationLogEntryUpdate(mergedIndex: .none, contents: .none) } else { diff --git a/submodules/TelegramCore/TelegramCore/Namespaces.swift b/submodules/TelegramCore/TelegramCore/Namespaces.swift index 352a42aef6..1b6fc51ff3 100644 --- a/submodules/TelegramCore/TelegramCore/Namespaces.swift +++ b/submodules/TelegramCore/TelegramCore/Namespaces.swift @@ -12,6 +12,8 @@ public struct Namespaces { public static let SecretIncoming: Int32 = 2 public static let ScheduledCloud: Int32 = 3 public static let ScheduledLocal: Int32 = 4 + + public static let allScheduled: Set = Set([Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal]) } public struct Media { @@ -110,6 +112,7 @@ public extension LocalMessageTags { public extension PendingMessageActionType { static let consumeUnseenPersonalMessage = PendingMessageActionType(rawValue: 0) static let updateReaction = PendingMessageActionType(rawValue: 1) + static let sendScheduledMessageImmediately = PendingMessageActionType(rawValue: 2) } let peerIdNamespacesWithInitialCloudMessageHoles = [Namespaces.Peer.CloudUser, Namespaces.Peer.CloudGroup, Namespaces.Peer.CloudChannel] diff --git a/submodules/TelegramCore/TelegramCore/ScheduledMessages.swift b/submodules/TelegramCore/TelegramCore/ScheduledMessages.swift index a57f91700b..23f66776b6 100644 --- a/submodules/TelegramCore/TelegramCore/ScheduledMessages.swift +++ b/submodules/TelegramCore/TelegramCore/ScheduledMessages.swift @@ -9,21 +9,171 @@ import Foundation import TelegramApi #endif -public func sendScheduledMessageNow(account: Account, messageId: MessageId) -> Signal { - return account.postbox.transaction { transaction -> Signal in - if let _ = transaction.getMessage(messageId), let peer = transaction.getPeer(messageId.peerId), let inputPeer = apiInputPeer(peer) { - return account.network.request(Api.functions.messages.sendScheduledMessages(peer: inputPeer, id: [messageId.id])) - |> map(Optional.init) - |> `catch` { _ -> Signal in - return .single(nil) - } - |> mapToSignal { updates -> Signal in - if let updates = updates { - account.stateManager.addUpdates(updates) +final class SendScheduledMessageImmediatelyAction: PendingMessageActionData { + init() { + } + + init(decoder: PostboxDecoder) { + } + + func encode(_ encoder: PostboxEncoder) { + } + + func isEqual(to: PendingMessageActionData) -> Bool { + if let _ = to as? SendScheduledMessageImmediatelyAction { + return true + } else { + return false + } + } +} + +public func sendScheduledMessageNowInteractively(postbox: Postbox, messageId: MessageId) -> Signal { + return postbox.transaction { transaction -> Void in + transaction.setPendingMessageAction(type: .sendScheduledMessageImmediately, id: messageId, action: SendScheduledMessageImmediatelyAction()) + } + |> ignoreValues +} + +private final class ManagedApplyPendingScheduledMessagesActionsHelper { + var operationDisposables: [MessageId: Disposable] = [:] + + func update(entries: [PendingMessageActionsEntry]) -> (disposeOperations: [Disposable], beginOperations: [(PendingMessageActionsEntry, MetaDisposable)]) { + var disposeOperations: [Disposable] = [] + var beginOperations: [(PendingMessageActionsEntry, MetaDisposable)] = [] + + var hasRunningOperationForPeerId = Set() + var validIds = Set() + for entry in entries { + if !hasRunningOperationForPeerId.contains(entry.id.peerId) { + hasRunningOperationForPeerId.insert(entry.id.peerId) + validIds.insert(entry.id) + + if self.operationDisposables[entry.id] == nil { + let disposable = MetaDisposable() + beginOperations.append((entry, disposable)) + self.operationDisposables[entry.id] = disposable } - return .complete() } } - return .complete() - } |> switchToLatest + + var removeMergedIds: [MessageId] = [] + for (id, disposable) in self.operationDisposables { + if !validIds.contains(id) { + removeMergedIds.append(id) + disposeOperations.append(disposable) + } + } + + for id in removeMergedIds { + self.operationDisposables.removeValue(forKey: id) + } + + return (disposeOperations, beginOperations) + } + + func reset() -> [Disposable] { + let disposables = Array(self.operationDisposables.values) + self.operationDisposables.removeAll() + return disposables + } +} + +private func withTakenAction(postbox: Postbox, type: PendingMessageActionType, id: MessageId, _ f: @escaping (Transaction, PendingMessageActionsEntry?) -> Signal) -> Signal { + return postbox.transaction { transaction -> Signal in + var result: PendingMessageActionsEntry? + + if let action = transaction.getPendingMessageAction(type: type, id: id) as? SendScheduledMessageImmediatelyAction { + result = PendingMessageActionsEntry(id: id, action: action) + } + + return f(transaction, result) + } + |> switchToLatest +} + +func managedApplyPendingScheduledMessagesActions(postbox: Postbox, network: Network, stateManager: AccountStateManager) -> Signal { + return Signal { _ in + let helper = Atomic(value: ManagedApplyPendingScheduledMessagesActionsHelper()) + + let actionsKey = PostboxViewKey.pendingMessageActions(type: .sendScheduledMessageImmediately) + let disposable = postbox.combinedView(keys: [actionsKey]).start(next: { view in + var entries: [PendingMessageActionsEntry] = [] + if let v = view.views[actionsKey] as? PendingMessageActionsView { + entries = v.entries + } + + let (disposeOperations, beginOperations) = helper.with { helper -> (disposeOperations: [Disposable], beginOperations: [(PendingMessageActionsEntry, MetaDisposable)]) in + return helper.update(entries: entries) + } + + for disposable in disposeOperations { + disposable.dispose() + } + + for (entry, disposable) in beginOperations { + let signal = withTakenAction(postbox: postbox, type: .sendScheduledMessageImmediately, id: entry.id, { transaction, entry -> Signal in + if let entry = entry { + if let _ = entry.action as? SendScheduledMessageImmediatelyAction { + return sendScheduledMessageNow(postbox: postbox, network: network, stateManager: stateManager, messageId: entry.id) + |> `catch` { _ -> Signal in + return .complete() + } + } else { + assertionFailure() + } + } + return .complete() + }) + |> then( + postbox.transaction { transaction -> Void in + transaction.deleteMessages([entry.id]) + } + |> ignoreValues + ) + + disposable.set(signal.start()) + } + }) + + return ActionDisposable { + let disposables = helper.with { helper -> [Disposable] in + return helper.reset() + } + for disposable in disposables { + disposable.dispose() + } + disposable.dispose() + } + } +} + +private enum SendScheduledMessageNowError { + case generic +} + +private func sendScheduledMessageNow(postbox: Postbox, network: Network, stateManager: AccountStateManager, messageId: MessageId) -> Signal { + return postbox.transaction { transaction -> Peer? in + guard let peer = transaction.getPeer(messageId.peerId) else { + return nil + } + return peer + } + |> introduceError(SendScheduledMessageNowError.self) + |> mapToSignal { peer -> Signal in + guard let peer = peer else { + return .fail(.generic) + } + guard let inputPeer = apiInputPeer(peer) else { + return .fail(.generic) + } + return network.request(Api.functions.messages.sendScheduledMessages(peer: inputPeer, id: [messageId.id])) + |> mapError { _ -> SendScheduledMessageNowError in + return .generic + } + |> mapToSignal { updates -> Signal in + stateManager.addUpdates(updates) + return .complete() + } + } } diff --git a/submodules/TelegramCore/TelegramCore/SearchStickers.swift b/submodules/TelegramCore/TelegramCore/SearchStickers.swift index 8d365f88ba..42406113dd 100644 --- a/submodules/TelegramCore/TelegramCore/SearchStickers.swift +++ b/submodules/TelegramCore/TelegramCore/SearchStickers.swift @@ -97,7 +97,7 @@ public func searchStickers(account: Account, query: String, scope: SearchSticker for entry in transaction.getOrderedListItems(collectionId: Namespaces.OrderedItemList.CloudSavedStickers) { if let item = entry.contents as? SavedStickerItem { for representation in item.stringRepresentations { - if representation == query { + if representation.hasPrefix(query) { result.append(FoundStickerItem(file: item.file, stringRepresentations: item.stringRepresentations)) break } @@ -115,7 +115,7 @@ public func searchStickers(account: Account, query: String, scope: SearchSticker if let item = entry.contents as? RecentMediaItem, let file = item.media as? TelegramMediaFile { if !currentItems.contains(file.fileId) { for case let .Sticker(sticker) in file.attributes { - if sticker.displayText == query { + if sticker.displayText.hasPrefix(query) { matchingRecentItemsIds.insert(file.fileId) } recentItemsIds.insert(file.fileId) @@ -130,9 +130,14 @@ public func searchStickers(account: Account, query: String, scope: SearchSticker } } + var searchQuery: ItemCollectionSearchQuery = .exact(ValueBoxKey(query)) + if query == "\u{2764}" { + searchQuery = .matching([ValueBoxKey("\u{2764}"), ValueBoxKey("\u{2764}\u{fe0f}")]) + } + var installedItems: [FoundStickerItem] = [] var installedAnimatedItems: [FoundStickerItem] = [] - for item in transaction.searchItemCollection(namespace: Namespaces.ItemCollection.CloudStickerPacks, query: .exact(ValueBoxKey(query))) { + for item in transaction.searchItemCollection(namespace: Namespaces.ItemCollection.CloudStickerPacks, query: searchQuery) { if let item = item as? StickerPackItem { if !currentItems.contains(item.file.fileId) { var stringRepresentations: [String] = [] diff --git a/submodules/TelegramCore/TelegramCore_Xcode.xcodeproj/project.pbxproj b/submodules/TelegramCore/TelegramCore_Xcode.xcodeproj/project.pbxproj index 07163e4c85..e39dd695d5 100644 --- a/submodules/TelegramCore/TelegramCore_Xcode.xcodeproj/project.pbxproj +++ b/submodules/TelegramCore/TelegramCore_Xcode.xcodeproj/project.pbxproj @@ -501,8 +501,8 @@ D098908022942E3B0053F151 /* ActiveSessionsContext.swift in Sources */ = {isa = PBXBuildFile; fileRef = D098907E22942E3B0053F151 /* ActiveSessionsContext.swift */; }; D099D7461EEF0C2700A3128C /* ChannelMessageStateVersionAttribute.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099D7451EEF0C2700A3128C /* ChannelMessageStateVersionAttribute.swift */; }; D099D7471EEF0C2700A3128C /* ChannelMessageStateVersionAttribute.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099D7451EEF0C2700A3128C /* ChannelMessageStateVersionAttribute.swift */; }; - D099D7491EEF418D00A3128C /* HistoryViewChannelStateValidation.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099D7481EEF418D00A3128C /* HistoryViewChannelStateValidation.swift */; }; - D099D74A1EEF418D00A3128C /* HistoryViewChannelStateValidation.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099D7481EEF418D00A3128C /* HistoryViewChannelStateValidation.swift */; }; + D099D7491EEF418D00A3128C /* HistoryViewStateValidation.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099D7481EEF418D00A3128C /* HistoryViewStateValidation.swift */; }; + D099D74A1EEF418D00A3128C /* HistoryViewStateValidation.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099D7481EEF418D00A3128C /* HistoryViewStateValidation.swift */; }; D099E222229420D600561B75 /* BlockedPeersContext.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099E221229420D600561B75 /* BlockedPeersContext.swift */; }; D099E223229420D600561B75 /* BlockedPeersContext.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099E221229420D600561B75 /* BlockedPeersContext.swift */; }; D099EA1C1DE72867001AF5A8 /* PeerCommands.swift in Sources */ = {isa = PBXBuildFile; fileRef = D099EA1B1DE72867001AF5A8 /* PeerCommands.swift */; }; @@ -1055,7 +1055,7 @@ D093D805206539D000BC3599 /* SaveSecureIdValue.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SaveSecureIdValue.swift; sourceTree = ""; }; D098907E22942E3B0053F151 /* ActiveSessionsContext.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ActiveSessionsContext.swift; sourceTree = ""; }; D099D7451EEF0C2700A3128C /* ChannelMessageStateVersionAttribute.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ChannelMessageStateVersionAttribute.swift; sourceTree = ""; }; - D099D7481EEF418D00A3128C /* HistoryViewChannelStateValidation.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HistoryViewChannelStateValidation.swift; sourceTree = ""; }; + D099D7481EEF418D00A3128C /* HistoryViewStateValidation.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HistoryViewStateValidation.swift; sourceTree = ""; }; D099E221229420D600561B75 /* BlockedPeersContext.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BlockedPeersContext.swift; sourceTree = ""; }; D099EA1B1DE72867001AF5A8 /* PeerCommands.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = PeerCommands.swift; sourceTree = ""; }; D09A2FE51D7CD4940018FB72 /* TelegramChannel.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TelegramChannel.swift; sourceTree = ""; }; @@ -1552,7 +1552,7 @@ D0BEAF5C1E54941B00BD963D /* Authorization.swift */, D0BEAF5F1E54ACF900BD963D /* AccountManager.swift */, D0528E591E658B3600E2FEF5 /* ManagedLocalInputActivities.swift */, - D099D7481EEF418D00A3128C /* HistoryViewChannelStateValidation.swift */, + D099D7481EEF418D00A3128C /* HistoryViewStateValidation.swift */, D0B1671C1F9EA2C300976B40 /* ChatHistoryPreloadManager.swift */, D06ECFC720B810D300C576C2 /* TermsOfService.swift */, D051DB16215ECC4D00F30F92 /* AppChangelog.swift */, @@ -2235,7 +2235,7 @@ D08984FB2118816A00918162 /* Reachability.m in Sources */, D0DA1D321F7043D50034E892 /* ManagedPendingPeerNotificationSettings.swift in Sources */, 0925903722F0D02D003D6283 /* ManagedAnimatedEmojiUpdates.swift in Sources */, - D099D7491EEF418D00A3128C /* HistoryViewChannelStateValidation.swift in Sources */, + D099D7491EEF418D00A3128C /* HistoryViewStateValidation.swift in Sources */, C23BC3871E9BE3CA00D79F92 /* ImportContact.swift in Sources */, D0D376E622DCCFD600FA7D7C /* SlowMode.swift in Sources */, D00422D321677F4500719B67 /* ManagedAccountPresence.swift in Sources */, @@ -2649,7 +2649,7 @@ D0E35A131DE4C69100BC6096 /* OutgoingChatContextResultMessageAttribute.swift in Sources */, D0B418961D7E0580004562A4 /* TelegramMediaFile.swift in Sources */, D08CAA881ED81DD40000FDA8 /* LocalizationInfo.swift in Sources */, - D099D74A1EEF418D00A3128C /* HistoryViewChannelStateValidation.swift in Sources */, + D099D74A1EEF418D00A3128C /* HistoryViewStateValidation.swift in Sources */, D0AF32231FAC95C20097362B /* StandaloneUploadedMedia.swift in Sources */, D04554A721B43440007A6DD9 /* CancelAccountReset.swift in Sources */, D001F3EC1E128A1C007A8C60 /* Holes.swift in Sources */, diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index f00b107d68..4cd235bf6e 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -2044,2201 +2044,2200 @@ public final class PresentationStrings { public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1723]! } public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1724]! } public var Common_Search: String { return self._s[1725]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[1726]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1726]!, self._r[1726]!, [_0]) + return formatWithArgumentRanges(self._s[1727]!, self._r[1727]!, [_0]) } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1727]! } - public var Message_InvoiceLabel: String { return self._s[1728]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1729]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1730]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1728]! } + public var Message_InvoiceLabel: String { return self._s[1729]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1730]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1731]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1731]!, self._r[1731]!, [_0]) + return formatWithArgumentRanges(self._s[1732]!, self._r[1732]!, [_0]) } - public var Conversation_Info: String { return self._s[1732]! } - public var Login_InfoDeletePhoto: String { return self._s[1733]! } - public var Passport_Language_vi: String { return self._s[1735]! } - public var UserInfo_ScamUserWarning: String { return self._s[1736]! } - public var Conversation_Search: String { return self._s[1737]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1738]! } - public var ReportPeer_ReasonPornography: String { return self._s[1739]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[1740]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1741]! } - public var Map_LiveLocationGroupDescription: String { return self._s[1742]! } - public var Channel_Setup_TypeHeader: String { return self._s[1743]! } - public var AuthSessions_LoggedIn: String { return self._s[1744]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1745]! } - public var Login_SmsRequestState3: String { return self._s[1746]! } - public var Passport_Address_EditUtilityBill: String { return self._s[1747]! } - public var Appearance_ReduceMotionInfo: String { return self._s[1748]! } - public var Join_ChannelsTooMuch: String { return self._s[1749]! } - public var Channel_Edit_LinkItem: String { return self._s[1750]! } - public var Privacy_Calls_P2PNever: String { return self._s[1751]! } - public var Conversation_AddToReadingList: String { return self._s[1753]! } - public var Share_MultipleMessagesDisabled: String { return self._s[1754]! } - public var Message_Animation: String { return self._s[1755]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[1756]! } - public var Map_Unknown: String { return self._s[1757]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[1758]! } + public var Conversation_Info: String { return self._s[1733]! } + public var Login_InfoDeletePhoto: String { return self._s[1734]! } + public var Passport_Language_vi: String { return self._s[1736]! } + public var UserInfo_ScamUserWarning: String { return self._s[1737]! } + public var Conversation_Search: String { return self._s[1738]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1739]! } + public var ReportPeer_ReasonPornography: String { return self._s[1740]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[1741]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1742]! } + public var Map_LiveLocationGroupDescription: String { return self._s[1743]! } + public var Channel_Setup_TypeHeader: String { return self._s[1744]! } + public var AuthSessions_LoggedIn: String { return self._s[1745]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1746]! } + public var Login_SmsRequestState3: String { return self._s[1747]! } + public var Passport_Address_EditUtilityBill: String { return self._s[1748]! } + public var Appearance_ReduceMotionInfo: String { return self._s[1749]! } + public var Join_ChannelsTooMuch: String { return self._s[1750]! } + public var Channel_Edit_LinkItem: String { return self._s[1751]! } + public var Privacy_Calls_P2PNever: String { return self._s[1752]! } + public var Conversation_AddToReadingList: String { return self._s[1754]! } + public var Share_MultipleMessagesDisabled: String { return self._s[1755]! } + public var Message_Animation: String { return self._s[1756]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[1757]! } + public var Map_Unknown: String { return self._s[1758]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[1759]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1759]!, self._r[1759]!, [_1, _2]) - } - public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1760]!, self._r[1760]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[1761]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[1762]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1763]! } + public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1761]!, self._r[1761]!, [_1, _2]) + } + public var Call_StatusRequesting: String { return self._s[1762]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[1763]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1764]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1764]!, self._r[1764]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1765]!, self._r[1765]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1765]!, self._r[1765]!, [_0]) + return formatWithArgumentRanges(self._s[1766]!, self._r[1766]!, [_0]) } - public var Update_Skip: String { return self._s[1766]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1767]! } - public var Message_PinnedPollMessage: String { return self._s[1768]! } - public var BlockedUsers_Title: String { return self._s[1769]! } + public var Update_Skip: String { return self._s[1767]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1768]! } + public var Message_PinnedPollMessage: String { return self._s[1769]! } + public var BlockedUsers_Title: String { return self._s[1770]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1770]!, self._r[1770]!, [_1]) + return formatWithArgumentRanges(self._s[1771]!, self._r[1771]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[1771]! } - public var NotificationsSound_Bell: String { return self._s[1772]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[1773]! } - public var Weekday_Monday: String { return self._s[1774]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1775]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1776]! } - public var ChatSettings_Groups: String { return self._s[1777]! } + public var Username_CheckingUsername: String { return self._s[1772]! } + public var NotificationsSound_Bell: String { return self._s[1773]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[1774]! } + public var Weekday_Monday: String { return self._s[1775]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1776]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1777]! } + public var ChatSettings_Groups: String { return self._s[1778]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_0]) + return formatWithArgumentRanges(self._s[1779]!, self._r[1779]!, [_0]) } - public var Your_card_was_declined: String { return self._s[1779]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1781]! } - public var ChatList_Unmute: String { return self._s[1782]! } - public var PhotoEditor_CurvesAll: String { return self._s[1783]! } - public var Weekday_ShortTuesday: String { return self._s[1784]! } - public var DialogList_Read: String { return self._s[1785]! } - public var Appearance_AppIconClassic: String { return self._s[1786]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1787]! } - public var Passport_Identity_Gender: String { return self._s[1788]! } + public var Your_card_was_declined: String { return self._s[1780]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1782]! } + public var ChatList_Unmute: String { return self._s[1783]! } + public var PhotoEditor_CurvesAll: String { return self._s[1784]! } + public var Weekday_ShortTuesday: String { return self._s[1785]! } + public var DialogList_Read: String { return self._s[1786]! } + public var Appearance_AppIconClassic: String { return self._s[1787]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1788]! } + public var Passport_Identity_Gender: String { return self._s[1789]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1789]!, self._r[1789]!, [_0]) + return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_0]) } - public var Target_SelectGroup: String { return self._s[1790]! } + public var Target_SelectGroup: String { return self._s[1791]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1792]!, self._r[1792]!, [_0]) + return formatWithArgumentRanges(self._s[1793]!, self._r[1793]!, [_0]) } - public var Passport_Language_en: String { return self._s[1793]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[1794]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1795]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[1796]! } - public var ScheduledMessages_SendNow: String { return self._s[1797]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[1799]! } - public var Login_InfoHelp: String { return self._s[1800]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1801]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[1802]! } + public var Passport_Language_en: String { return self._s[1794]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[1795]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1796]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[1797]! } + public var ScheduledMessages_SendNow: String { return self._s[1798]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[1800]! } + public var Login_InfoHelp: String { return self._s[1801]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1802]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[1803]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1803]!, self._r[1803]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1804]!, self._r[1804]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[1806]! } - public var CreatePoll_Title: String { return self._s[1807]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[1808]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1809]! } - public var UserInfo_GroupsInCommon: String { return self._s[1810]! } - public var Call_AudioRouteHide: String { return self._s[1811]! } - public var ContactInfo_PhoneLabelMobile: String { return self._s[1813]! } + public var SocksProxySetup_AddProxy: String { return self._s[1807]! } + public var CreatePoll_Title: String { return self._s[1808]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[1809]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1810]! } + public var UserInfo_GroupsInCommon: String { return self._s[1811]! } + public var Call_AudioRouteHide: String { return self._s[1812]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[1814]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1814]!, self._r[1814]!, [_0]) + return formatWithArgumentRanges(self._s[1815]!, self._r[1815]!, [_0]) } - public var TextFormat_Bold: String { return self._s[1815]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[1816]! } - public var Notifications_Title: String { return self._s[1817]! } - public var Group_Username_InvalidTooShort: String { return self._s[1818]! } - public var Channel_ErrorAddTooMuch: String { return self._s[1819]! } + public var TextFormat_Bold: String { return self._s[1816]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[1817]! } + public var Notifications_Title: String { return self._s[1818]! } + public var Group_Username_InvalidTooShort: String { return self._s[1819]! } + public var Channel_ErrorAddTooMuch: String { return self._s[1820]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1820]!, self._r[1820]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1821]!, self._r[1821]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[1822]! } - public var Stickers_SuggestAdded: String { return self._s[1823]! } - public var Login_CountryCode: String { return self._s[1824]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[1825]! } - public var Map_GetDirections: String { return self._s[1826]! } - public var Login_PhoneFloodError: String { return self._s[1827]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[1823]! } + public var Stickers_SuggestAdded: String { return self._s[1824]! } + public var Login_CountryCode: String { return self._s[1825]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[1826]! } + public var Map_GetDirections: String { return self._s[1827]! } + public var Login_PhoneFloodError: String { return self._s[1828]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1828]!, self._r[1828]!, [_0]) + return formatWithArgumentRanges(self._s[1829]!, self._r[1829]!, [_0]) } - public var Settings_SetUsername: String { return self._s[1830]! } - public var Group_Location_ChangeLocation: String { return self._s[1831]! } - public var Notification_GroupInviterSelf: String { return self._s[1832]! } - public var InstantPage_TapToOpenLink: String { return self._s[1833]! } + public var Settings_SetUsername: String { return self._s[1831]! } + public var Group_Location_ChangeLocation: String { return self._s[1832]! } + public var Notification_GroupInviterSelf: String { return self._s[1833]! } + public var InstantPage_TapToOpenLink: String { return self._s[1834]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1834]!, self._r[1834]!, [_0]) + return formatWithArgumentRanges(self._s[1835]!, self._r[1835]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[1835]! } - public var SecretChat_Title: String { return self._s[1836]! } - public var Group_UpgradeNoticeText1: String { return self._s[1837]! } - public var AuthSessions_Title: String { return self._s[1838]! } + public var Watch_Suggestion_TalkLater: String { return self._s[1836]! } + public var SecretChat_Title: String { return self._s[1837]! } + public var Group_UpgradeNoticeText1: String { return self._s[1838]! } + public var AuthSessions_Title: String { return self._s[1839]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1839]!, self._r[1839]!, [_0]) + return formatWithArgumentRanges(self._s[1840]!, self._r[1840]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[1840]! } - public var Channel_About_Title: String { return self._s[1841]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[1842]! } + public var PhotoEditor_CropAuto: String { return self._s[1841]! } + public var Channel_About_Title: String { return self._s[1842]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[1843]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1844]!, self._r[1844]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1845]!, self._r[1845]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[1845]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1847]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[1848]! } + public var VoiceOver_MessageContextReport: String { return self._s[1846]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1848]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[1849]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1849]!, self._r[1849]!, [_1]) + return formatWithArgumentRanges(self._s[1850]!, self._r[1850]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1851]!, self._r[1851]!, [_0]) - } - public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1852]!, self._r[1852]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[1853]! } - public var Presence_online: String { return self._s[1855]! } - public var PasscodeSettings_Title: String { return self._s[1856]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1857]! } - public var Web_OpenExternal: String { return self._s[1858]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[1860]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[1861]! } - public var LocalGroup_Title: String { return self._s[1862]! } + public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1853]!, self._r[1853]!, [_0]) + } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[1854]! } + public var Presence_online: String { return self._s[1856]! } + public var PasscodeSettings_Title: String { return self._s[1857]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1858]! } + public var Web_OpenExternal: String { return self._s[1859]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[1861]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[1862]! } + public var LocalGroup_Title: String { return self._s[1863]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1863]!, self._r[1863]!, [_0]) + return formatWithArgumentRanges(self._s[1864]!, self._r[1864]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1864]! } - public var Map_YouAreHere: String { return self._s[1865]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1865]! } + public var Map_YouAreHere: String { return self._s[1866]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1866]!, self._r[1866]!, [_0]) - } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1867]!, self._r[1867]!, [_0]) } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1868]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1869]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1870]!, self._r[1870]!, [_0]) + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1868]!, self._r[1868]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1869]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1870]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1871]!, self._r[1871]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[1872]! } - public var Bot_Start: String { return self._s[1873]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1874]!, self._r[1874]!, [_0]) + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1872]!, self._r[1872]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + public var SocksProxySetup_Username: String { return self._s[1873]! } + public var Bot_Start: String { return self._s[1874]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1875]!, self._r[1875]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[1876]! } - public var AccentColor_Title: String { return self._s[1878]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1879]! } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1876]!, self._r[1876]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[1877]! } + public var AccentColor_Title: String { return self._s[1879]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1880]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1880]!, self._r[1880]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1881]!, self._r[1881]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1881]!, self._r[1881]!, [_0]) + return formatWithArgumentRanges(self._s[1882]!, self._r[1882]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1882]!, self._r[1882]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1883]!, self._r[1883]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[1883]! } - public var Login_InfoAvatarPhoto: String { return self._s[1884]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1885]! } - public var Tour_Title4: String { return self._s[1886]! } - public var Passport_Identity_Translation: String { return self._s[1887]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[1888]! } - public var Login_TermsOfServiceLabel: String { return self._s[1890]! } - public var Passport_Language_it: String { return self._s[1891]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1892]! } - public var Passport_Identity_SelfieHelp: String { return self._s[1893]! } - public var Conversation_ClearAll: String { return self._s[1895]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[1897]! } - public var TwoStepAuth_FloodError: String { return self._s[1898]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[1884]! } + public var Login_InfoAvatarPhoto: String { return self._s[1885]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1886]! } + public var Tour_Title4: String { return self._s[1887]! } + public var Passport_Identity_Translation: String { return self._s[1888]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[1889]! } + public var Login_TermsOfServiceLabel: String { return self._s[1891]! } + public var Passport_Language_it: String { return self._s[1892]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1893]! } + public var Passport_Identity_SelfieHelp: String { return self._s[1894]! } + public var Conversation_ClearAll: String { return self._s[1896]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[1898]! } + public var TwoStepAuth_FloodError: String { return self._s[1899]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1899]!, self._r[1899]!, [_1]) + return formatWithArgumentRanges(self._s[1900]!, self._r[1900]!, [_1]) } - public var Paint_Delete: String { return self._s[1900]! } - public var Privacy_AddNewPeer: String { return self._s[1901]! } + public var Paint_Delete: String { return self._s[1901]! } + public var Privacy_AddNewPeer: String { return self._s[1902]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1902]!, self._r[1902]!, [_1]) + return formatWithArgumentRanges(self._s[1903]!, self._r[1903]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[1903]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[1904]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1904]!, self._r[1904]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1905]!, self._r[1905]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[1905]! } + public var Message_PinnedAudioMessage: String { return self._s[1906]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1906]!, self._r[1906]!, [_0]) + return formatWithArgumentRanges(self._s[1907]!, self._r[1907]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[1907]! } - public var Notifications_GroupNotificationsSound: String { return self._s[1908]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[1909]! } - public var Conversation_MessageEditedLabel: String { return self._s[1910]! } - public var Notification_Exceptions_AlwaysOff: String { return self._s[1911]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[1912]! } + public var Notification_Mute1hMin: String { return self._s[1908]! } + public var Notifications_GroupNotificationsSound: String { return self._s[1909]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[1910]! } + public var Conversation_MessageEditedLabel: String { return self._s[1911]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[1912]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[1913]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1913]!, self._r[1913]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1914]!, self._r[1914]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[1914]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[1915]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1915]!, self._r[1915]!, [_1]) + return formatWithArgumentRanges(self._s[1916]!, self._r[1916]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[1916]! } - public var Month_GenOctober: String { return self._s[1917]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1918]! } - public var EnterPasscode_EnterPasscode: String { return self._s[1919]! } - public var MediaPicker_TimerTooltip: String { return self._s[1921]! } - public var SharedMedia_TitleAll: String { return self._s[1922]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[1925]! } - public var Conversation_RestrictedMedia: String { return self._s[1926]! } - public var AccessDenied_PhotosRestricted: String { return self._s[1927]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[1929]! } - public var ChangePhoneNumberCode_Called: String { return self._s[1930]! } + public var AccessDenied_LocationTracking: String { return self._s[1917]! } + public var Month_GenOctober: String { return self._s[1918]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1919]! } + public var EnterPasscode_EnterPasscode: String { return self._s[1920]! } + public var MediaPicker_TimerTooltip: String { return self._s[1922]! } + public var SharedMedia_TitleAll: String { return self._s[1923]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[1926]! } + public var Conversation_RestrictedMedia: String { return self._s[1927]! } + public var AccessDenied_PhotosRestricted: String { return self._s[1928]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[1930]! } + public var ChangePhoneNumberCode_Called: String { return self._s[1931]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1931]!, self._r[1931]!, [_0]) + return formatWithArgumentRanges(self._s[1932]!, self._r[1932]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[1934]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[1936]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1937]! } + public var Conversation_SavedMessages: String { return self._s[1935]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[1937]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1938]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1939]!, self._r[1939]!, [_0]) + return formatWithArgumentRanges(self._s[1940]!, self._r[1940]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[1940]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[1941]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1941]!, self._r[1941]!, [_0]) + return formatWithArgumentRanges(self._s[1942]!, self._r[1942]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[1942]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1943]! } + public var ReportPeer_AlertSuccess: String { return self._s[1943]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1944]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1944]!, self._r[1944]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1945]!, self._r[1945]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[1945]! } - public var PhotoEditor_FadeTool: String { return self._s[1946]! } - public var Privacy_ContactsReset: String { return self._s[1947]! } + public var Checkout_PasswordEntry_Title: String { return self._s[1946]! } + public var PhotoEditor_FadeTool: String { return self._s[1947]! } + public var Privacy_ContactsReset: String { return self._s[1948]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1949]!, self._r[1949]!, [_0]) + return formatWithArgumentRanges(self._s[1950]!, self._r[1950]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[1950]! } - public var ChatList_Mute: String { return self._s[1951]! } - public var Permissions_CellularDataText_v0: String { return self._s[1952]! } - public var ShareMenu_SelectChats: String { return self._s[1954]! } - public var MusicPlayer_VoiceNote: String { return self._s[1955]! } - public var Conversation_RestrictedText: String { return self._s[1956]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[1957]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[1958]! } - public var Cache_Videos: String { return self._s[1959]! } - public var PrivacySettings_PhoneNumber: String { return self._s[1960]! } - public var FeatureDisabled_Oops: String { return self._s[1962]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[1963]! } + public var Message_PinnedVideoMessage: String { return self._s[1951]! } + public var ChatList_Mute: String { return self._s[1952]! } + public var Permissions_CellularDataText_v0: String { return self._s[1953]! } + public var ShareMenu_SelectChats: String { return self._s[1955]! } + public var MusicPlayer_VoiceNote: String { return self._s[1956]! } + public var Conversation_RestrictedText: String { return self._s[1957]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[1958]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[1959]! } + public var Cache_Videos: String { return self._s[1960]! } + public var PrivacySettings_PhoneNumber: String { return self._s[1961]! } + public var FeatureDisabled_Oops: String { return self._s[1963]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[1964]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1964]!, self._r[1964]!, [_0]) + return formatWithArgumentRanges(self._s[1965]!, self._r[1965]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[1965]! } - public var GroupPermission_NoSendPolls: String { return self._s[1966]! } - public var Message_VideoExpired: String { return self._s[1968]! } - public var Notifications_Badge: String { return self._s[1969]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[1970]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[1971]! } - public var Username_InvalidTooShort: String { return self._s[1972]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1973]! } - public var Channel_AdminLog_PinMessages: String { return self._s[1974]! } - public var ArchivedChats_IntroTitle3: String { return self._s[1975]! } + public var Stickers_GroupStickersHelp: String { return self._s[1966]! } + public var GroupPermission_NoSendPolls: String { return self._s[1967]! } + public var Message_VideoExpired: String { return self._s[1969]! } + public var Notifications_Badge: String { return self._s[1970]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[1971]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[1972]! } + public var Username_InvalidTooShort: String { return self._s[1973]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1974]! } + public var Channel_AdminLog_PinMessages: String { return self._s[1975]! } + public var ArchivedChats_IntroTitle3: String { return self._s[1976]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1976]!, self._r[1976]!, [_1]) + return formatWithArgumentRanges(self._s[1977]!, self._r[1977]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[1977]! } - public var Conversation_DefaultRestrictedText: String { return self._s[1978]! } - public var SharedMedia_CategoryDocs: String { return self._s[1981]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[1978]! } + public var Conversation_DefaultRestrictedText: String { return self._s[1979]! } + public var SharedMedia_CategoryDocs: String { return self._s[1982]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1982]!, self._r[1982]!, [_1]) + return formatWithArgumentRanges(self._s[1983]!, self._r[1983]!, [_1]) } - public var Privacy_Forwards_NeverLink: String { return self._s[1984]! } + public var Privacy_Forwards_NeverLink: String { return self._s[1985]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1985]!, self._r[1985]!, [_1]) + return formatWithArgumentRanges(self._s[1986]!, self._r[1986]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1986]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1987]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1987]!, self._r[1987]!, [_0]) + return formatWithArgumentRanges(self._s[1988]!, self._r[1988]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[1988]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[1989]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[1990]! } - public var Channel_UpdatePhotoItem: String { return self._s[1991]! } - public var GroupInfo_LeftStatus: String { return self._s[1992]! } - public var Watch_MessageView_Forward: String { return self._s[1994]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[1995]! } - public var Cache_ClearEmpty: String { return self._s[1997]! } - public var Localization_LanguageName: String { return self._s[1998]! } - public var WebSearch_GIFs: String { return self._s[1999]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2000]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2001]! } - public var Common_Back: String { return self._s[2002]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2003]! } + public var ChatSettings_PrivateChats: String { return self._s[1989]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[1990]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[1991]! } + public var Channel_UpdatePhotoItem: String { return self._s[1992]! } + public var GroupInfo_LeftStatus: String { return self._s[1993]! } + public var Watch_MessageView_Forward: String { return self._s[1995]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[1996]! } + public var Cache_ClearEmpty: String { return self._s[1998]! } + public var Localization_LanguageName: String { return self._s[1999]! } + public var WebSearch_GIFs: String { return self._s[2000]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2001]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2002]! } + public var Common_Back: String { return self._s[2003]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2004]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2005]!, self._r[2005]!, [_1, _2]) } - public var Passport_Email_Help: String { return self._s[2005]! } - public var Watch_Conversation_Reply: String { return self._s[2007]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2009]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2010]! } - public var Channel_BanUser_Unban: String { return self._s[2012]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2013]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2014]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2016]! } - public var Passport_Identity_Name: String { return self._s[2017]! } + public var Passport_Email_Help: String { return self._s[2006]! } + public var Watch_Conversation_Reply: String { return self._s[2008]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2010]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2011]! } + public var Channel_BanUser_Unban: String { return self._s[2013]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2014]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2015]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2017]! } + public var Passport_Identity_Name: String { return self._s[2018]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2018]!, self._r[2018]!, [_0]) + return formatWithArgumentRanges(self._s[2019]!, self._r[2019]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2019]! } - public var Conversation_BlockUser: String { return self._s[2020]! } - public var Month_GenJanuary: String { return self._s[2021]! } - public var ChatSettings_TextSize: String { return self._s[2022]! } - public var Notification_PassportValuePhone: String { return self._s[2023]! } - public var Passport_Language_ne: String { return self._s[2024]! } - public var Notification_CallBack: String { return self._s[2025]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2026]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2020]! } + public var Conversation_BlockUser: String { return self._s[2021]! } + public var Month_GenJanuary: String { return self._s[2022]! } + public var ChatSettings_TextSize: String { return self._s[2023]! } + public var Notification_PassportValuePhone: String { return self._s[2024]! } + public var Passport_Language_ne: String { return self._s[2025]! } + public var Notification_CallBack: String { return self._s[2026]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2027]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2027]!, self._r[2027]!, [_0]) + return formatWithArgumentRanges(self._s[2028]!, self._r[2028]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2028]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2029]! } - public var Stickers_FrequentlyUsed: String { return self._s[2030]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2031]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2033]! } + public var Channel_Info_Management: String { return self._s[2029]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2030]! } + public var Stickers_FrequentlyUsed: String { return self._s[2031]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2032]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2034]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2034]!, self._r[2034]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2035]!, self._r[2035]!, [_1, "\(_2)"]) } - public var Passport_Address_EditResidentialAddress: String { return self._s[2035]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2036]! } - public var CreatePoll_TextHeader: String { return self._s[2037]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2036]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2037]! } + public var CreatePoll_TextHeader: String { return self._s[2038]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2038]!, self._r[2038]!, [_0]) + return formatWithArgumentRanges(self._s[2039]!, self._r[2039]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2039]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2040]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2042]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2043]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2044]! } + public var PhotoEditor_QualityMedium: String { return self._s[2040]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2041]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2043]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2044]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2045]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2045]!, self._r[2045]!, [_0]) + return formatWithArgumentRanges(self._s[2046]!, self._r[2046]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2046]!, self._r[2046]!, [_1]) + return formatWithArgumentRanges(self._s[2047]!, self._r[2047]!, [_1]) } - public var Conversation_LinkDialogOpen: String { return self._s[2048]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2049]! } - public var Settings_Username: String { return self._s[2051]! } - public var Conversation_Block: String { return self._s[2053]! } - public var Wallpaper_Wallpaper: String { return self._s[2054]! } - public var SocksProxySetup_UseProxy: String { return self._s[2056]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2057]! } - public var MessageTimer_Forever: String { return self._s[2058]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2059]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2060]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2061]! } - public var Passport_Language_da: String { return self._s[2062]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2063]! } + public var Conversation_LinkDialogOpen: String { return self._s[2049]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2050]! } + public var Settings_Username: String { return self._s[2052]! } + public var Conversation_Block: String { return self._s[2054]! } + public var Wallpaper_Wallpaper: String { return self._s[2055]! } + public var SocksProxySetup_UseProxy: String { return self._s[2057]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2058]! } + public var MessageTimer_Forever: String { return self._s[2059]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2060]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2061]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2062]! } + public var Passport_Language_da: String { return self._s[2063]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2064]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2064]!, self._r[2064]!, [_0]) + return formatWithArgumentRanges(self._s[2065]!, self._r[2065]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2065]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2066]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2067]!, self._r[2067]!, [_0]) + return formatWithArgumentRanges(self._s[2068]!, self._r[2068]!, [_0]) } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2069]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2070]! } - public var Conversation_PinnedPoll: String { return self._s[2071]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2072]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2070]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2071]! } + public var Conversation_PinnedPoll: String { return self._s[2072]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2073]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2073]!, self._r[2073]!, [_1]) + return formatWithArgumentRanges(self._s[2074]!, self._r[2074]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2074]! } - public var Cache_ByPeerHeader: String { return self._s[2075]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2075]! } + public var Cache_ByPeerHeader: String { return self._s[2076]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2076]!, self._r[2076]!, [_0]) + return formatWithArgumentRanges(self._s[2077]!, self._r[2077]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2077]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2080]! } - public var Notification_PinnedMessage: String { return self._s[2081]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2083]! } - public var Contacts_SortBy: String { return self._s[2084]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2078]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2081]! } + public var Notification_PinnedMessage: String { return self._s[2082]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2084]! } + public var Contacts_SortBy: String { return self._s[2085]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2085]!, self._r[2085]!, [_1]) + return formatWithArgumentRanges(self._s[2086]!, self._r[2086]!, [_1]) } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2087]!, self._r[2087]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2088]!, self._r[2088]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2088]! } - public var Watch_UserInfo_Service: String { return self._s[2089]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2091]! } - public var Conversation_Unpin: String { return self._s[2093]! } - public var CancelResetAccount_Title: String { return self._s[2094]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2095]! } + public var Call_EncryptionKey_Title: String { return self._s[2089]! } + public var Watch_UserInfo_Service: String { return self._s[2090]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2092]! } + public var Conversation_Unpin: String { return self._s[2094]! } + public var CancelResetAccount_Title: String { return self._s[2095]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2096]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2097]!, self._r[2097]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2098]!, self._r[2098]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2098]! } - public var CallSettings_Title: String { return self._s[2099]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2100]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2102]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2103]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2099]! } + public var CallSettings_Title: String { return self._s[2100]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2101]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2103]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2104]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2105]!, self._r[2105]!, [_1, _2]) } - public var Passport_Identity_DocumentDetails: String { return self._s[2105]! } - public var LoginPassword_PasswordHelp: String { return self._s[2106]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2107]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2108]! } - public var Checkout_TotalPaidAmount: String { return self._s[2109]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2106]! } + public var LoginPassword_PasswordHelp: String { return self._s[2107]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2108]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2109]! } + public var Checkout_TotalPaidAmount: String { return self._s[2110]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2110]!, self._r[2110]!, [_0]) + return formatWithArgumentRanges(self._s[2111]!, self._r[2111]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[2111]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2113]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2114]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2112]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2114]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2115]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2115]!, self._r[2115]!, [_1]) + return formatWithArgumentRanges(self._s[2116]!, self._r[2116]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2116]! } - public var Contacts_InviteFriends: String { return self._s[2118]! } - public var Map_ChooseLocationTitle: String { return self._s[2119]! } - public var Conversation_StopPoll: String { return self._s[2121]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2117]! } + public var Contacts_InviteFriends: String { return self._s[2119]! } + public var Map_ChooseLocationTitle: String { return self._s[2120]! } + public var Conversation_StopPoll: String { return self._s[2122]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2122]!, self._r[2122]!, [_0]) + return formatWithArgumentRanges(self._s[2123]!, self._r[2123]!, [_0]) } - public var Call_Camera: String { return self._s[2123]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2124]! } - public var Calls_RatingFeedback: String { return self._s[2125]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2126]! } - public var NotificationsSound_Pulse: String { return self._s[2127]! } - public var Watch_LastSeen_Lately: String { return self._s[2128]! } - public var ReportGroupLocation_Report: String { return self._s[2131]! } - public var Widget_NoUsers: String { return self._s[2132]! } - public var Conversation_UnvotePoll: String { return self._s[2133]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2135]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2136]! } - public var NotificationsSound_Circles: String { return self._s[2137]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2139]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2140]! } - public var Proxy_TooltipUnavailable: String { return self._s[2141]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2143]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2145]! } - public var Conversation_FileDropbox: String { return self._s[2146]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2147]! } - public var Tour_Text3: String { return self._s[2149]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2151]! } - public var GroupPermission_NoSendMessages: String { return self._s[2152]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2153]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2154]! } + public var Call_Camera: String { return self._s[2124]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2125]! } + public var Calls_RatingFeedback: String { return self._s[2126]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2127]! } + public var NotificationsSound_Pulse: String { return self._s[2128]! } + public var Watch_LastSeen_Lately: String { return self._s[2129]! } + public var ReportGroupLocation_Report: String { return self._s[2132]! } + public var Widget_NoUsers: String { return self._s[2133]! } + public var Conversation_UnvotePoll: String { return self._s[2134]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2136]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2137]! } + public var NotificationsSound_Circles: String { return self._s[2138]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2140]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2141]! } + public var Proxy_TooltipUnavailable: String { return self._s[2142]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2144]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2146]! } + public var Conversation_FileDropbox: String { return self._s[2147]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2148]! } + public var Tour_Text3: String { return self._s[2150]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2152]! } + public var GroupPermission_NoSendMessages: String { return self._s[2153]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2154]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2155]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2156]!, self._r[2156]!, [_0]) + return formatWithArgumentRanges(self._s[2157]!, self._r[2157]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2157]! } - public var Checkout_ShippingOption_Title: String { return self._s[2158]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2159]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2158]! } + public var Checkout_ShippingOption_Title: String { return self._s[2159]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2160]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2160]!, self._r[2160]!, [_0]) - } - public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2161]!, self._r[2161]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2162]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2163]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2164]! } - public var AutoDownloadSettings_Photos: String { return self._s[2166]! } - public var Appearance_PreviewIncomingText: String { return self._s[2167]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2168]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2169]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2170]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2171]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2172]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2173]! } - public var Notification_SecretChatScreenshot: String { return self._s[2174]! } - public var AccessDenied_Wallpapers: String { return self._s[2175]! } - public var Passport_Address_City: String { return self._s[2177]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2178]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2179]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2180]! } - public var AccessDenied_LocationDisabled: String { return self._s[2181]! } - public var Group_Location_Title: String { return self._s[2182]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2184]! } - public var GroupInfo_Sound: String { return self._s[2185]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2186]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2187]! } - public var Contacts_Title: String { return self._s[2188]! } - public var Passport_Language_fr: String { return self._s[2189]! } - public var Notifications_ResetAllNotifications: String { return self._s[2190]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2193]! } - public var Checkout_NewCard_Title: String { return self._s[2194]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2195]! } - public var Conversation_ForwardChats: String { return self._s[2196]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2198]! } - public var Settings_FAQ: String { return self._s[2200]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2201]! } - public var Conversation_ContextMenuForward: String { return self._s[2202]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2205]! } - public var PrivacyPolicy_Title: String { return self._s[2208]! } - public var Notifications_TextTone: String { return self._s[2209]! } - public var Profile_CreateNewContact: String { return self._s[2210]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2211]! } - public var Call_Speaker: String { return self._s[2213]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2214]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2216]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2217]! } + public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2162]!, self._r[2162]!, [_0]) + } + public var Channel_Management_LabelAdministrator: String { return self._s[2163]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2164]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2165]! } + public var AutoDownloadSettings_Photos: String { return self._s[2167]! } + public var Appearance_PreviewIncomingText: String { return self._s[2168]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2169]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2170]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2171]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2172]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2173]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2174]! } + public var Notification_SecretChatScreenshot: String { return self._s[2175]! } + public var AccessDenied_Wallpapers: String { return self._s[2176]! } + public var Passport_Address_City: String { return self._s[2178]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2179]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2180]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2181]! } + public var AccessDenied_LocationDisabled: String { return self._s[2182]! } + public var Group_Location_Title: String { return self._s[2183]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2185]! } + public var GroupInfo_Sound: String { return self._s[2186]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2187]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2188]! } + public var Contacts_Title: String { return self._s[2189]! } + public var Passport_Language_fr: String { return self._s[2190]! } + public var Notifications_ResetAllNotifications: String { return self._s[2191]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2194]! } + public var Checkout_NewCard_Title: String { return self._s[2195]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2196]! } + public var Conversation_ForwardChats: String { return self._s[2197]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2199]! } + public var Settings_FAQ: String { return self._s[2201]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2202]! } + public var Conversation_ContextMenuForward: String { return self._s[2203]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2206]! } + public var PrivacyPolicy_Title: String { return self._s[2209]! } + public var Notifications_TextTone: String { return self._s[2210]! } + public var Profile_CreateNewContact: String { return self._s[2211]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2212]! } + public var Call_Speaker: String { return self._s[2214]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2215]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2217]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2218]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2218]!, self._r[2218]!, [_0]) + return formatWithArgumentRanges(self._s[2219]!, self._r[2219]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2219]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2220]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2221]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2222]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2223]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2224]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2225]! } - public var Bot_Unblock: String { return self._s[2226]! } - public var TextFormat_Italic: String { return self._s[2227]! } - public var WallpaperSearch_ColorPink: String { return self._s[2228]! } - public var Settings_About_Help: String { return self._s[2229]! } - public var SearchImages_Title: String { return self._s[2230]! } - public var Weekday_Wednesday: String { return self._s[2231]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2232]! } - public var ExplicitContent_AlertTitle: String { return self._s[2233]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2220]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2221]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2222]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2223]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2224]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2225]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2226]! } + public var Bot_Unblock: String { return self._s[2227]! } + public var TextFormat_Italic: String { return self._s[2228]! } + public var WallpaperSearch_ColorPink: String { return self._s[2229]! } + public var Settings_About_Help: String { return self._s[2230]! } + public var SearchImages_Title: String { return self._s[2231]! } + public var Weekday_Wednesday: String { return self._s[2232]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2233]! } + public var ExplicitContent_AlertTitle: String { return self._s[2234]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2235]! } - public var Weekday_Thursday: String { return self._s[2236]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2237]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2238]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2236]! } + public var Weekday_Thursday: String { return self._s[2237]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2238]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2239]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2239]!, self._r[2239]!, [_0]) + return formatWithArgumentRanges(self._s[2240]!, self._r[2240]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2240]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2241]! } - public var Passport_RequestedInformation: String { return self._s[2242]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2243]! } - public var Conversation_EncryptionProcessing: String { return self._s[2245]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2246]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2248]! } - public var Channel_Setup_Title: String { return self._s[2249]! } - public var Conversation_SearchPlaceholder: String { return self._s[2250]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2251]! } - public var Checkout_ErrorGeneric: String { return self._s[2252]! } - public var Passport_Language_hu: String { return self._s[2253]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2241]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2242]! } + public var Passport_RequestedInformation: String { return self._s[2243]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2244]! } + public var Conversation_EncryptionProcessing: String { return self._s[2246]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2247]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2249]! } + public var Channel_Setup_Title: String { return self._s[2250]! } + public var Conversation_SearchPlaceholder: String { return self._s[2251]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2252]! } + public var Checkout_ErrorGeneric: String { return self._s[2253]! } + public var Passport_Language_hu: String { return self._s[2254]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_0]) + return formatWithArgumentRanges(self._s[2256]!, self._r[2256]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2258]!, self._r[2258]!, [_1]) + return formatWithArgumentRanges(self._s[2259]!, self._r[2259]!, [_1]) } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2259]!, self._r[2259]!, [_0]) + return formatWithArgumentRanges(self._s[2260]!, self._r[2260]!, [_0]) } - public var Group_Location_Info: String { return self._s[2260]! } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2261]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2262]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2263]! } + public var Group_Location_Info: String { return self._s[2261]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2262]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2263]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2264]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2264]!, self._r[2264]!, [_0]) + return formatWithArgumentRanges(self._s[2265]!, self._r[2265]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2265]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2266]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2267]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2266]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2267]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2268]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2268]!, self._r[2268]!, [_0]) + return formatWithArgumentRanges(self._s[2269]!, self._r[2269]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2269]! } - public var Message_PinnedAnimationMessage: String { return self._s[2271]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2273]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2274]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2276]! } - public var Embed_PlayingInPIP: String { return self._s[2277]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2278]! } + public var Passport_Language_cs: String { return self._s[2270]! } + public var Message_PinnedAnimationMessage: String { return self._s[2272]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2274]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2275]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2277]! } + public var Embed_PlayingInPIP: String { return self._s[2278]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2279]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2279]!, self._r[2279]!, [_0]) + return formatWithArgumentRanges(self._s[2280]!, self._r[2280]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2280]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2281]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2281]!, self._r[2281]!, [_1]) + return formatWithArgumentRanges(self._s[2282]!, self._r[2282]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2282]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2283]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2284]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2285]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2286]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2287]! } + public var Notification_PaymentSent: String { return self._s[2283]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2284]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2285]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2286]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2287]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2288]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_1]) - } - public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2291]!, self._r[2291]!, [_1]) } - public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2292]!, self._r[2292]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2294]! } - public var PasscodeSettings_HelpTop: String { return self._s[2295]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2296]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2297]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2298]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2299]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2300]! } - public var Call_Accept: String { return self._s[2302]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2303]! } - public var Month_GenMarch: String { return self._s[2305]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2306]! } - public var LoginPassword_Title: String { return self._s[2307]! } - public var Call_End: String { return self._s[2308]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2309]! } - public var VoiceOver_Chat_Contact: String { return self._s[2310]! } - public var CallSettings_Always: String { return self._s[2311]! } - public var CallFeedback_Success: String { return self._s[2312]! } - public var TwoStepAuth_SetupHint: String { return self._s[2313]! } + public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_1]) + } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2295]! } + public var PasscodeSettings_HelpTop: String { return self._s[2296]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2297]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2298]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2299]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2300]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2301]! } + public var Call_Accept: String { return self._s[2303]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2304]! } + public var Month_GenMarch: String { return self._s[2306]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2307]! } + public var LoginPassword_Title: String { return self._s[2308]! } + public var Call_End: String { return self._s[2309]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2310]! } + public var VoiceOver_Chat_Contact: String { return self._s[2311]! } + public var CallSettings_Always: String { return self._s[2312]! } + public var CallFeedback_Success: String { return self._s[2313]! } + public var TwoStepAuth_SetupHint: String { return self._s[2314]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2314]!, self._r[2314]!, [_1]) + return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2315]! } - public var Login_PhoneTitle: String { return self._s[2316]! } - public var Passport_FieldPhoneHelp: String { return self._s[2317]! } - public var Weekday_ShortSunday: String { return self._s[2318]! } - public var Passport_InfoFAQ_URL: String { return self._s[2319]! } - public var ContactInfo_Job: String { return self._s[2321]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2322]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2323]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2324]! } - public var Invite_ChannelsTooMuch: String { return self._s[2325]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2326]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2327]! } - public var CallFeedback_ReasonNoise: String { return self._s[2328]! } - public var Appearance_AppIconDefault: String { return self._s[2330]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2331]! } - public var MediaPicker_AddCaption: String { return self._s[2332]! } - public var CallSettings_TabIconDescription: String { return self._s[2333]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2316]! } + public var Login_PhoneTitle: String { return self._s[2317]! } + public var Passport_FieldPhoneHelp: String { return self._s[2318]! } + public var Weekday_ShortSunday: String { return self._s[2319]! } + public var Passport_InfoFAQ_URL: String { return self._s[2320]! } + public var ContactInfo_Job: String { return self._s[2322]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2323]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2324]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2325]! } + public var Invite_ChannelsTooMuch: String { return self._s[2326]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2327]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2328]! } + public var CallFeedback_ReasonNoise: String { return self._s[2329]! } + public var Appearance_AppIconDefault: String { return self._s[2331]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2332]! } + public var MediaPicker_AddCaption: String { return self._s[2333]! } + public var CallSettings_TabIconDescription: String { return self._s[2334]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2334]!, self._r[2334]!, [_0]) + return formatWithArgumentRanges(self._s[2335]!, self._r[2335]!, [_0]) } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2335]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2336]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2337]! } - public var DialogList_SearchSectionRecent: String { return self._s[2338]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2339]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2342]! } - public var LastSeen_WithinAWeek: String { return self._s[2343]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2344]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2346]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2347]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2336]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2337]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2338]! } + public var DialogList_SearchSectionRecent: String { return self._s[2339]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2340]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2343]! } + public var LastSeen_WithinAWeek: String { return self._s[2344]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2345]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2347]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2348]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2348]!, self._r[2348]!, [_0]) + return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2349]! } - public var Conversation_StatusLeftGroup: String { return self._s[2350]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2351]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2353]! } - public var GroupPermission_AddSuccess: String { return self._s[2354]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2356]! } - public var Conversation_ContextMenuCopy: String { return self._s[2357]! } - public var AccessDenied_CallMicrophone: String { return self._s[2358]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2350]! } + public var Conversation_StatusLeftGroup: String { return self._s[2351]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2352]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2354]! } + public var GroupPermission_AddSuccess: String { return self._s[2355]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2357]! } + public var Conversation_ContextMenuCopy: String { return self._s[2358]! } + public var AccessDenied_CallMicrophone: String { return self._s[2359]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2359]!, self._r[2359]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2360]!, self._r[2360]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2360]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2361]! } - public var Checkout_PaymentMethod_New: String { return self._s[2362]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2363]! } - public var PhotoEditor_QualityTool: String { return self._s[2364]! } - public var Login_SendCodeViaSms: String { return self._s[2365]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2366]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2367]! } - public var Login_EmailNotConfiguredError: String { return self._s[2368]! } - public var SocksProxySetup_Status: String { return self._s[2369]! } - public var PrivacyPolicy_Accept: String { return self._s[2370]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2371]! } - public var Appearance_AppIconClassicX: String { return self._s[2372]! } + public var Login_InvalidFirstNameError: String { return self._s[2361]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2362]! } + public var Checkout_PaymentMethod_New: String { return self._s[2363]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2364]! } + public var PhotoEditor_QualityTool: String { return self._s[2365]! } + public var Login_SendCodeViaSms: String { return self._s[2366]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2367]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2368]! } + public var Login_EmailNotConfiguredError: String { return self._s[2369]! } + public var SocksProxySetup_Status: String { return self._s[2370]! } + public var PrivacyPolicy_Accept: String { return self._s[2371]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2372]! } + public var Appearance_AppIconClassicX: String { return self._s[2373]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2374]!, self._r[2374]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2374]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2375]! } - public var AutoNightTheme_Automatic: String { return self._s[2376]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2377]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2378]! } - public var Cache_Help: String { return self._s[2379]! } - public var Group_ErrorAccessDenied: String { return self._s[2380]! } - public var Passport_Language_fa: String { return self._s[2381]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2382]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2383]! } - public var PrivacySettings_LastSeen: String { return self._s[2384]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2375]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2376]! } + public var AutoNightTheme_Automatic: String { return self._s[2377]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2378]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2379]! } + public var Cache_Help: String { return self._s[2380]! } + public var Group_ErrorAccessDenied: String { return self._s[2381]! } + public var Passport_Language_fa: String { return self._s[2382]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2383]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2384]! } + public var PrivacySettings_LastSeen: String { return self._s[2385]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2385]!, self._r[2385]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2386]!, self._r[2386]!, [_0, _1]) } - public var Preview_SaveGif: String { return self._s[2389]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2390]! } - public var Profile_About: String { return self._s[2391]! } - public var Channel_About_Placeholder: String { return self._s[2392]! } - public var Login_InfoTitle: String { return self._s[2393]! } + public var Preview_SaveGif: String { return self._s[2390]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2391]! } + public var Profile_About: String { return self._s[2392]! } + public var Channel_About_Placeholder: String { return self._s[2393]! } + public var Login_InfoTitle: String { return self._s[2394]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2394]!, self._r[2394]!, [_0]) + return formatWithArgumentRanges(self._s[2395]!, self._r[2395]!, [_0]) } - public var Watch_Suggestion_CantTalk: String { return self._s[2396]! } - public var ContactInfo_Title: String { return self._s[2397]! } - public var Media_ShareThisVideo: String { return self._s[2398]! } - public var Weekday_ShortFriday: String { return self._s[2399]! } - public var AccessDenied_Contacts: String { return self._s[2401]! } - public var Notification_CallIncomingShort: String { return self._s[2402]! } - public var Group_Setup_TypePublic: String { return self._s[2403]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2404]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2405]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2408]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2409]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2410]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2411]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2412]! } - public var DialogList_Typing: String { return self._s[2413]! } - public var CallFeedback_IncludeLogs: String { return self._s[2415]! } - public var Checkout_Phone: String { return self._s[2417]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2420]! } - public var Privacy_Calls_Integration: String { return self._s[2421]! } - public var Notifications_PermissionsAllow: String { return self._s[2422]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2426]! } - public var Settings_ChatSettings: String { return self._s[2427]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2397]! } + public var ContactInfo_Title: String { return self._s[2398]! } + public var Media_ShareThisVideo: String { return self._s[2399]! } + public var Weekday_ShortFriday: String { return self._s[2400]! } + public var AccessDenied_Contacts: String { return self._s[2402]! } + public var Notification_CallIncomingShort: String { return self._s[2403]! } + public var Group_Setup_TypePublic: String { return self._s[2404]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2405]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2406]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2409]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2410]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2411]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2412]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2413]! } + public var DialogList_Typing: String { return self._s[2414]! } + public var CallFeedback_IncludeLogs: String { return self._s[2416]! } + public var Checkout_Phone: String { return self._s[2418]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2421]! } + public var Privacy_Calls_Integration: String { return self._s[2422]! } + public var Notifications_PermissionsAllow: String { return self._s[2423]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2427]! } + public var Settings_ChatSettings: String { return self._s[2428]! } public func PUSH_MESSAGE_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2428]!, self._r[2428]!, [_1]) + return formatWithArgumentRanges(self._s[2429]!, self._r[2429]!, [_1]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2429]!, self._r[2429]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2430]!, self._r[2430]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2431]! } + public var GroupRemoved_DeleteUser: String { return self._s[2432]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2432]!, self._r[2432]!, [_0]) + return formatWithArgumentRanges(self._s[2433]!, self._r[2433]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2433]!, self._r[2433]!, [_1]) + return formatWithArgumentRanges(self._s[2434]!, self._r[2434]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2434]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2435]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2437]! } - public var Conversation_Unblock: String { return self._s[2438]! } - public var PrivacySettings_DataSettings: String { return self._s[2439]! } - public var Group_PublicLink_Info: String { return self._s[2440]! } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2441]! } + public var Login_ContinueWithLocalization: String { return self._s[2435]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2436]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2438]! } + public var Conversation_Unblock: String { return self._s[2439]! } + public var PrivacySettings_DataSettings: String { return self._s[2440]! } + public var Group_PublicLink_Info: String { return self._s[2441]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2442]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2442]!, self._r[2442]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2443]!, self._r[2443]!, [_0, _1]) } - public var PrivacySettings_Passcode: String { return self._s[2445]! } - public var Call_Mute: String { return self._s[2446]! } - public var Passport_Language_dz: String { return self._s[2447]! } - public var Passport_Language_tk: String { return self._s[2448]! } + public var PrivacySettings_Passcode: String { return self._s[2446]! } + public var Call_Mute: String { return self._s[2447]! } + public var Passport_Language_dz: String { return self._s[2448]! } + public var Passport_Language_tk: String { return self._s[2449]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2449]!, self._r[2449]!, [_0]) + return formatWithArgumentRanges(self._s[2450]!, self._r[2450]!, [_0]) } - public var Settings_Search: String { return self._s[2450]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2451]! } - public var Conversation_ContextMenuReply: String { return self._s[2452]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2453]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2454]! } - public var Tour_Title1: String { return self._s[2455]! } - public var Conversation_ClearGroupHistory: String { return self._s[2457]! } - public var WallpaperPreview_Motion: String { return self._s[2458]! } + public var Settings_Search: String { return self._s[2451]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2452]! } + public var Conversation_ContextMenuReply: String { return self._s[2453]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2454]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2455]! } + public var Tour_Title1: String { return self._s[2456]! } + public var Conversation_ClearGroupHistory: String { return self._s[2458]! } + public var WallpaperPreview_Motion: String { return self._s[2459]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2459]!, self._r[2459]!, [_0]) + return formatWithArgumentRanges(self._s[2460]!, self._r[2460]!, [_0]) } - public var Call_RateCall: String { return self._s[2460]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2461]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2462]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2463]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2465]! } + public var Call_RateCall: String { return self._s[2461]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2462]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2463]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2464]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2466]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2467]!, self._r[2467]!, [_0]) + return formatWithArgumentRanges(self._s[2468]!, self._r[2468]!, [_0]) } - public var Compose_Create: String { return self._s[2468]! } - public var Contacts_InviteToTelegram: String { return self._s[2469]! } - public var GroupInfo_Notifications: String { return self._s[2470]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2472]! } - public var Month_GenApril: String { return self._s[2473]! } - public var Appearance_AutoNightTheme: String { return self._s[2474]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2476]! } - public var Login_CodeSentSms: String { return self._s[2478]! } + public var Compose_Create: String { return self._s[2469]! } + public var Contacts_InviteToTelegram: String { return self._s[2470]! } + public var GroupInfo_Notifications: String { return self._s[2471]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2473]! } + public var Month_GenApril: String { return self._s[2474]! } + public var Appearance_AutoNightTheme: String { return self._s[2475]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2477]! } + public var Login_CodeSentSms: String { return self._s[2479]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2479]!, self._r[2479]!, [_0]) + return formatWithArgumentRanges(self._s[2480]!, self._r[2480]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2480]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2481]! } - public var Passport_Language_hr: String { return self._s[2482]! } - public var Common_ActionNotAllowedError: String { return self._s[2483]! } + public var EmptyGroupInfo_Line3: String { return self._s[2481]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2482]! } + public var Passport_Language_hr: String { return self._s[2483]! } + public var Common_ActionNotAllowedError: String { return self._s[2484]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2484]!, self._r[2484]!, [_0]) + return formatWithArgumentRanges(self._s[2485]!, self._r[2485]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2485]! } - public var Appearance_ThemePreview_ChatList_8_Text: String { return self._s[2486]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2487]! } - public var Privacy_SecretChatsTitle: String { return self._s[2488]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2490]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2491]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2492]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2493]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2494]! } - public var Preview_DeleteGif: String { return self._s[2495]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2496]! } - public var Group_ErrorNotMutualContact: String { return self._s[2497]! } - public var Notification_MessageLifetime5s: String { return self._s[2498]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2486]! } + public var Appearance_ThemePreview_ChatList_8_Text: String { return self._s[2487]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2488]! } + public var Privacy_SecretChatsTitle: String { return self._s[2489]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2491]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2492]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2493]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2494]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2495]! } + public var Preview_DeleteGif: String { return self._s[2496]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2497]! } + public var Group_ErrorNotMutualContact: String { return self._s[2498]! } + public var Notification_MessageLifetime5s: String { return self._s[2499]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2499]!, self._r[2499]!, [_0]) + return formatWithArgumentRanges(self._s[2500]!, self._r[2500]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2500]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2502]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2503]! } - public var Passport_Address_AddBankStatement: String { return self._s[2504]! } - public var Notification_CallIncoming: String { return self._s[2505]! } - public var Compose_NewGroupTitle: String { return self._s[2506]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2508]! } - public var Passport_Address_Postcode: String { return self._s[2510]! } + public var VoiceOver_Chat_Video: String { return self._s[2501]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2503]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2504]! } + public var Passport_Address_AddBankStatement: String { return self._s[2505]! } + public var Notification_CallIncoming: String { return self._s[2506]! } + public var Compose_NewGroupTitle: String { return self._s[2507]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2509]! } + public var Passport_Address_Postcode: String { return self._s[2511]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2511]!, self._r[2511]!, [_0]) + return formatWithArgumentRanges(self._s[2512]!, self._r[2512]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2512]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2513]! } - public var WallpaperColors_Title: String { return self._s[2514]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2515]! } - public var VoiceOver_MessageContextForward: String { return self._s[2516]! } - public var GroupPermission_Duration: String { return self._s[2517]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2513]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2514]! } + public var WallpaperColors_Title: String { return self._s[2515]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2516]! } + public var VoiceOver_MessageContextForward: String { return self._s[2517]! } + public var GroupPermission_Duration: String { return self._s[2518]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2518]!, self._r[2518]!, [_0]) + return formatWithArgumentRanges(self._s[2519]!, self._r[2519]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2519]! } - public var Username_Placeholder: String { return self._s[2520]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2521]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2522]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2523]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2520]! } + public var Username_Placeholder: String { return self._s[2521]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2522]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2523]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2524]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2525]!, self._r[2525]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2526]!, self._r[2526]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[2526]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2527]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2528]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2529]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2530]! } - public var Conversation_ContextMenuMore: String { return self._s[2531]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2532]! } - public var CallSettings_TabIcon: String { return self._s[2533]! } - public var KeyCommand_Find: String { return self._s[2534]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2535]! } - public var Message_PinnedGame: String { return self._s[2536]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2537]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2539]! } - public var Login_CallRequestState2: String { return self._s[2541]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2543]! } + public var Passport_PasswordDescription: String { return self._s[2527]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2528]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2529]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2530]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2531]! } + public var Conversation_ContextMenuMore: String { return self._s[2532]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2533]! } + public var CallSettings_TabIcon: String { return self._s[2534]! } + public var KeyCommand_Find: String { return self._s[2535]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2536]! } + public var Message_PinnedGame: String { return self._s[2537]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2538]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2540]! } + public var Login_CallRequestState2: String { return self._s[2542]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2544]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2544]!, self._r[2544]!, [_0]) + return formatWithArgumentRanges(self._s[2545]!, self._r[2545]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2546]!, self._r[2546]!, [_0]) + return formatWithArgumentRanges(self._s[2547]!, self._r[2547]!, [_0]) } - public var WallpaperPreview_Blurred: String { return self._s[2547]! } - public var Conversation_InstantPagePreview: String { return self._s[2548]! } + public var WallpaperPreview_Blurred: String { return self._s[2548]! } + public var Conversation_InstantPagePreview: String { return self._s[2549]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_0]) + return formatWithArgumentRanges(self._s[2550]!, self._r[2550]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2552]! } - public var WallpaperSearch_ColorRed: String { return self._s[2553]! } - public var GroupPermission_NoPinMessages: String { return self._s[2554]! } - public var Passport_Language_es: String { return self._s[2555]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2557]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2558]! } + public var SecretTimer_VideoDescription: String { return self._s[2553]! } + public var WallpaperSearch_ColorRed: String { return self._s[2554]! } + public var GroupPermission_NoPinMessages: String { return self._s[2555]! } + public var Passport_Language_es: String { return self._s[2556]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2558]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2559]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2559]!, self._r[2559]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2560]!, self._r[2560]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2560]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2561]! } - public var Watch_UserInfo_Unmute: String { return self._s[2562]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2563]! } - public var AccessDenied_CameraRestricted: String { return self._s[2565]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2561]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2562]! } + public var Watch_UserInfo_Unmute: String { return self._s[2563]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2564]! } + public var AccessDenied_CameraRestricted: String { return self._s[2566]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2566]!, self._r[2566]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2567]!, self._r[2567]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2568]! } - public var Settings_CopyUsername: String { return self._s[2569]! } - public var Contacts_SearchLabel: String { return self._s[2570]! } - public var Map_OpenInYandexNavigator: String { return self._s[2572]! } - public var PasscodeSettings_EncryptData: String { return self._s[2573]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2574]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2575]! } - public var DialogList_AdNoticeAlert: String { return self._s[2576]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2578]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2579]! } - public var Localization_LanguageCustom: String { return self._s[2580]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2581]! } - public var CallFeedback_Title: String { return self._s[2582]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2585]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2586]! } - public var Conversation_InfoGroup: String { return self._s[2587]! } - public var Compose_NewMessage: String { return self._s[2588]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2589]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2590]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2591]! } + public var ChatList_ReadAll: String { return self._s[2569]! } + public var Settings_CopyUsername: String { return self._s[2570]! } + public var Contacts_SearchLabel: String { return self._s[2571]! } + public var Map_OpenInYandexNavigator: String { return self._s[2573]! } + public var PasscodeSettings_EncryptData: String { return self._s[2574]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2575]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2576]! } + public var DialogList_AdNoticeAlert: String { return self._s[2577]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2579]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2580]! } + public var Localization_LanguageCustom: String { return self._s[2581]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2582]! } + public var CallFeedback_Title: String { return self._s[2583]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2586]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2587]! } + public var Conversation_InfoGroup: String { return self._s[2588]! } + public var Compose_NewMessage: String { return self._s[2589]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2590]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2591]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2592]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2592]!, self._r[2592]!, [_0]) + return formatWithArgumentRanges(self._s[2593]!, self._r[2593]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2593]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2594]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2595]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2596]! } - public var Channel_BlackList_Title: String { return self._s[2597]! } - public var UserInfo_PhoneCall: String { return self._s[2598]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2600]! } - public var State_connecting: String { return self._s[2601]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2602]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2594]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2595]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2596]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2597]! } + public var Channel_BlackList_Title: String { return self._s[2598]! } + public var UserInfo_PhoneCall: String { return self._s[2599]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2601]! } + public var State_connecting: String { return self._s[2602]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2603]! } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2603]!, self._r[2603]!, [_0]) + return formatWithArgumentRanges(self._s[2604]!, self._r[2604]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2604]! } - public var Passport_Identity_EditPassport: String { return self._s[2605]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2607]! } - public var Localization_EnglishLanguageName: String { return self._s[2608]! } - public var Share_AuthDescription: String { return self._s[2609]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2610]! } - public var Passport_Identity_Surname: String { return self._s[2611]! } - public var Compose_TokenListPlaceholder: String { return self._s[2612]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2613]! } - public var Settings_AboutEmpty: String { return self._s[2614]! } - public var Conversation_Unmute: String { return self._s[2615]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[2617]! } + public var Notifications_GroupNotifications: String { return self._s[2605]! } + public var Passport_Identity_EditPassport: String { return self._s[2606]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2608]! } + public var Localization_EnglishLanguageName: String { return self._s[2609]! } + public var Share_AuthDescription: String { return self._s[2610]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2611]! } + public var Passport_Identity_Surname: String { return self._s[2612]! } + public var Compose_TokenListPlaceholder: String { return self._s[2613]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2614]! } + public var Settings_AboutEmpty: String { return self._s[2615]! } + public var Conversation_Unmute: String { return self._s[2616]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[2618]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2618]!, self._r[2618]!, [_1]) + return formatWithArgumentRanges(self._s[2619]!, self._r[2619]!, [_1]) } - public var Login_CodeSentCall: String { return self._s[2619]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2621]! } - public var ChatSettings_Appearance: String { return self._s[2622]! } - public var Appearance_PickAccentColor: String { return self._s[2623]! } + public var Login_CodeSentCall: String { return self._s[2620]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2622]! } + public var ChatSettings_Appearance: String { return self._s[2623]! } + public var Appearance_PickAccentColor: String { return self._s[2624]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2624]!, self._r[2624]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2625]!, self._r[2625]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2625]!, self._r[2625]!, [_1]) + return formatWithArgumentRanges(self._s[2626]!, self._r[2626]!, [_1]) } - public var Notification_CallMissed: String { return self._s[2626]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2627]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2628]! } - public var ChatAdmins_AdminLabel: String { return self._s[2630]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2631]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2633]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2634]! } - public var Month_GenJune: String { return self._s[2635]! } - public var Watch_Location_Current: String { return self._s[2636]! } - public var Conversation_TitleMute: String { return self._s[2637]! } + public var Notification_CallMissed: String { return self._s[2627]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2628]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2629]! } + public var ChatAdmins_AdminLabel: String { return self._s[2631]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2632]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2634]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2635]! } + public var Month_GenJune: String { return self._s[2636]! } + public var Watch_Location_Current: String { return self._s[2637]! } + public var Conversation_TitleMute: String { return self._s[2638]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2638]!, self._r[2638]!, [_1]) + return formatWithArgumentRanges(self._s[2639]!, self._r[2639]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2639]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2640]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2640]!, self._r[2640]!, [_0]) + return formatWithArgumentRanges(self._s[2641]!, self._r[2641]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[2641]! } - public var Chat_SlowmodeSendError: String { return self._s[2642]! } - public var MaskStickerSettings_Info: String { return self._s[2643]! } + public var Call_ReportPlaceholder: String { return self._s[2642]! } + public var Chat_SlowmodeSendError: String { return self._s[2643]! } + public var MaskStickerSettings_Info: String { return self._s[2644]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2644]!, self._r[2644]!, [_0]) + return formatWithArgumentRanges(self._s[2645]!, self._r[2645]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2645]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2647]! } - public var Contacts_ShareTelegram: String { return self._s[2648]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2649]! } - public var Channel_ErrorAccessDenied: String { return self._s[2650]! } - public var UserInfo_ScamBotWarning: String { return self._s[2652]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2653]! } - public var Call_ConnectionErrorTitle: String { return self._s[2654]! } - public var UserInfo_NotificationsEnable: String { return self._s[2655]! } - public var ArchivedChats_IntroText1: String { return self._s[2656]! } - public var Tour_Text4: String { return self._s[2659]! } - public var WallpaperSearch_Recent: String { return self._s[2660]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[2661]! } - public var Profile_MessageLifetime2s: String { return self._s[2663]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[2664]! } - public var Notification_MessageLifetime2s: String { return self._s[2665]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2646]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2648]! } + public var Contacts_ShareTelegram: String { return self._s[2649]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2650]! } + public var Channel_ErrorAccessDenied: String { return self._s[2651]! } + public var UserInfo_ScamBotWarning: String { return self._s[2653]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2654]! } + public var Call_ConnectionErrorTitle: String { return self._s[2655]! } + public var UserInfo_NotificationsEnable: String { return self._s[2656]! } + public var ArchivedChats_IntroText1: String { return self._s[2657]! } + public var Tour_Text4: String { return self._s[2660]! } + public var WallpaperSearch_Recent: String { return self._s[2661]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[2662]! } + public var Profile_MessageLifetime2s: String { return self._s[2664]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[2665]! } + public var Notification_MessageLifetime2s: String { return self._s[2666]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2666]!, self._r[2666]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2667]!, self._r[2667]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[2667]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[2668]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2669]! } + public var Cache_ClearCache: String { return self._s[2668]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[2669]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2670]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2673]!, self._r[2673]!, [_0]) + return formatWithArgumentRanges(self._s[2674]!, self._r[2674]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2675]!, self._r[2675]!, [_0]) + return formatWithArgumentRanges(self._s[2676]!, self._r[2676]!, [_0]) } - public var LocalGroup_Text: String { return self._s[2676]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2677]! } - public var SocksProxySetup_TypeSocks: String { return self._s[2678]! } - public var ChatList_UnarchiveAction: String { return self._s[2679]! } - public var AutoNightTheme_Title: String { return self._s[2680]! } - public var InstantPage_FeedbackButton: String { return self._s[2681]! } - public var Passport_FieldAddress: String { return self._s[2682]! } + public var LocalGroup_Text: String { return self._s[2677]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2678]! } + public var SocksProxySetup_TypeSocks: String { return self._s[2679]! } + public var ChatList_UnarchiveAction: String { return self._s[2680]! } + public var AutoNightTheme_Title: String { return self._s[2681]! } + public var InstantPage_FeedbackButton: String { return self._s[2682]! } + public var Passport_FieldAddress: String { return self._s[2683]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2683]!, self._r[2683]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2684]!, self._r[2684]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[2684]! } + public var Month_ShortMarch: String { return self._s[2685]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2685]!, self._r[2685]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2686]!, self._r[2686]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2686]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2687]! } - public var Passport_FloodError: String { return self._s[2688]! } - public var SecretGif_Title: String { return self._s[2689]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[2690]! } - public var Passport_Language_th: String { return self._s[2692]! } - public var Passport_Address_Address: String { return self._s[2693]! } - public var Login_InvalidLastNameError: String { return self._s[2694]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[2695]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[2696]! } - public var SettingsSearch_FAQ: String { return self._s[2697]! } - public var ShareMenu_Send: String { return self._s[2698]! } - public var WallpaperSearch_ColorYellow: String { return self._s[2700]! } - public var Month_GenNovember: String { return self._s[2702]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[2704]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2687]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2688]! } + public var Passport_FloodError: String { return self._s[2689]! } + public var SecretGif_Title: String { return self._s[2690]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[2691]! } + public var Passport_Language_th: String { return self._s[2693]! } + public var Passport_Address_Address: String { return self._s[2694]! } + public var Login_InvalidLastNameError: String { return self._s[2695]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[2696]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[2697]! } + public var SettingsSearch_FAQ: String { return self._s[2698]! } + public var ShareMenu_Send: String { return self._s[2699]! } + public var WallpaperSearch_ColorYellow: String { return self._s[2701]! } + public var Month_GenNovember: String { return self._s[2703]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[2705]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2706]!, self._r[2706]!, [_1, _2]) } - public var Checkout_Email: String { return self._s[2706]! } - public var NotificationsSound_Tritone: String { return self._s[2707]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[2709]! } + public var Checkout_Email: String { return self._s[2707]! } + public var NotificationsSound_Tritone: String { return self._s[2708]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[2710]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2712]!, self._r[2712]!, [_1]) + return formatWithArgumentRanges(self._s[2713]!, self._r[2713]!, [_1]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[2713]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[2714]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2714]!, self._r[2714]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[2715]!, self._r[2715]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[2715]! } - public var Notification_Exceptions_Add: String { return self._s[2716]! } - public var DialogList_You: String { return self._s[2717]! } - public var MediaPicker_Send: String { return self._s[2720]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[2721]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[2722]! } - public var Call_AudioRouteSpeaker: String { return self._s[2723]! } - public var Watch_UserInfo_Title: String { return self._s[2724]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[2725]! } - public var Appearance_AccentColor: String { return self._s[2726]! } + public var ChatList_UndoArchiveTitle: String { return self._s[2716]! } + public var Notification_Exceptions_Add: String { return self._s[2717]! } + public var DialogList_You: String { return self._s[2718]! } + public var MediaPicker_Send: String { return self._s[2721]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[2722]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[2723]! } + public var Call_AudioRouteSpeaker: String { return self._s[2724]! } + public var Watch_UserInfo_Title: String { return self._s[2725]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[2726]! } + public var Appearance_AccentColor: String { return self._s[2727]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2727]!, self._r[2727]!, [_0]) + return formatWithArgumentRanges(self._s[2728]!, self._r[2728]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2728]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2729]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2729]!, self._r[2729]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2730]!, self._r[2730]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[2730]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[2731]! } - public var Notification_CallOutgoing: String { return self._s[2732]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2733]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[2734]! } - public var Call_RecordingDisabledMessage: String { return self._s[2735]! } - public var Message_Game: String { return self._s[2736]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[2737]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2738]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[2739]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2740]! } - public var Date_DialogDateFormat: String { return self._s[2741]! } - public var WallpaperColors_SetCustomColor: String { return self._s[2742]! } - public var Notifications_InAppNotifications: String { return self._s[2743]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[2731]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[2732]! } + public var Notification_CallOutgoing: String { return self._s[2733]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2734]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[2735]! } + public var Call_RecordingDisabledMessage: String { return self._s[2736]! } + public var Message_Game: String { return self._s[2737]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[2738]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2739]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[2740]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2741]! } + public var Date_DialogDateFormat: String { return self._s[2742]! } + public var WallpaperColors_SetCustomColor: String { return self._s[2743]! } + public var Notifications_InAppNotifications: String { return self._s[2744]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_0]) + return formatWithArgumentRanges(self._s[2745]!, self._r[2745]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2745]!, self._r[2745]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2746]!, self._r[2746]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[2746]! } + public var NewContact_Title: String { return self._s[2747]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2747]!, self._r[2747]!, [_0]) + return formatWithArgumentRanges(self._s[2748]!, self._r[2748]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[2748]! } + public var Conversation_ViewContactDetails: String { return self._s[2749]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2750]!, self._r[2750]!, [_1]) + return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2751]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[2752]! } - public var PrivacySettings_Title: String { return self._s[2753]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2756]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[2757]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[2758]! } - public var Contacts_PhoneNumber: String { return self._s[2759]! } - public var Map_ShowPlaces: String { return self._s[2761]! } - public var ChatAdmins_Title: String { return self._s[2762]! } - public var InstantPage_Reference: String { return self._s[2764]! } - public var ReportGroupLocation_Text: String { return self._s[2765]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2752]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[2753]! } + public var PrivacySettings_Title: String { return self._s[2754]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2757]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[2758]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[2759]! } + public var Contacts_PhoneNumber: String { return self._s[2760]! } + public var Map_ShowPlaces: String { return self._s[2762]! } + public var ChatAdmins_Title: String { return self._s[2763]! } + public var InstantPage_Reference: String { return self._s[2765]! } + public var ReportGroupLocation_Text: String { return self._s[2766]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2766]!, self._r[2766]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2767]!, self._r[2767]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[2767]! } - public var Watch_UserInfo_Block: String { return self._s[2768]! } - public var ChatSettings_Stickers: String { return self._s[2769]! } - public var ChatSettings_DownloadInBackground: String { return self._s[2770]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[2771]! } + public var Camera_FlashOff: String { return self._s[2768]! } + public var Watch_UserInfo_Block: String { return self._s[2769]! } + public var ChatSettings_Stickers: String { return self._s[2770]! } + public var ChatSettings_DownloadInBackground: String { return self._s[2771]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[2772]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2772]!, self._r[2772]!, [_0]) + return formatWithArgumentRanges(self._s[2773]!, self._r[2773]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[2773]! } - public var Login_CheckOtherSessionMessages: String { return self._s[2774]! } - public var AutoDownloadSettings_Cellular: String { return self._s[2775]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[2776]! } - public var VoiceOver_MessageContextShare: String { return self._s[2777]! } + public var Settings_ViewPhoto: String { return self._s[2774]! } + public var Login_CheckOtherSessionMessages: String { return self._s[2775]! } + public var AutoDownloadSettings_Cellular: String { return self._s[2776]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[2777]! } + public var VoiceOver_MessageContextShare: String { return self._s[2778]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2779]!, self._r[2779]!, [_0]) + return formatWithArgumentRanges(self._s[2780]!, self._r[2780]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[2780]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[2781]! } + public var Privacy_DeleteDrafts: String { return self._s[2781]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[2782]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2782]!, self._r[2782]!, [_0]) + return formatWithArgumentRanges(self._s[2783]!, self._r[2783]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[2783]! } - public var DialogList_SavedMessages: String { return self._s[2784]! } - public var GroupInfo_UpgradeButton: String { return self._s[2785]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[2787]! } - public var DialogList_Pin: String { return self._s[2788]! } + public var DialogList_SavedMessagesHelp: String { return self._s[2784]! } + public var DialogList_SavedMessages: String { return self._s[2785]! } + public var GroupInfo_UpgradeButton: String { return self._s[2786]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[2788]! } + public var DialogList_Pin: String { return self._s[2789]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2789]!, self._r[2789]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2790]!, self._r[2790]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2790]!, self._r[2790]!, [_0]) + return formatWithArgumentRanges(self._s[2791]!, self._r[2791]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[2791]! } - public var UserInfo_NotificationsDisable: String { return self._s[2792]! } - public var Paint_Outlined: String { return self._s[2793]! } - public var Activity_PlayingGame: String { return self._s[2794]! } - public var SearchImages_NoImagesFound: String { return self._s[2795]! } - public var SocksProxySetup_ProxyType: String { return self._s[2796]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[2798]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[2799]! } - public var Settings_AppLanguage: String { return self._s[2800]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[2801]! } - public var Common_ChoosePhoto: String { return self._s[2802]! } - public var CallFeedback_ReasonEcho: String { return self._s[2803]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[2792]! } + public var UserInfo_NotificationsDisable: String { return self._s[2793]! } + public var Paint_Outlined: String { return self._s[2794]! } + public var Activity_PlayingGame: String { return self._s[2795]! } + public var SearchImages_NoImagesFound: String { return self._s[2796]! } + public var SocksProxySetup_ProxyType: String { return self._s[2797]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[2799]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[2800]! } + public var Settings_AppLanguage: String { return self._s[2801]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[2802]! } + public var Common_ChoosePhoto: String { return self._s[2803]! } + public var CallFeedback_ReasonEcho: String { return self._s[2804]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2804]!, self._r[2804]!, [_1]) + return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[2805]! } - public var Activity_UploadingVideo: String { return self._s[2806]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2807]! } - public var NetworkUsageSettings_Wifi: String { return self._s[2808]! } - public var VoiceOver_Editing_ClearText: String { return self._s[2809]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[2810]! } - public var Checkout_PayWithTouchId: String { return self._s[2811]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[2812]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[2806]! } + public var Activity_UploadingVideo: String { return self._s[2807]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2808]! } + public var NetworkUsageSettings_Wifi: String { return self._s[2809]! } + public var VoiceOver_Editing_ClearText: String { return self._s[2810]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[2811]! } + public var Checkout_PayWithTouchId: String { return self._s[2812]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[2813]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2814]!, self._r[2814]!, [_1]) + return formatWithArgumentRanges(self._s[2815]!, self._r[2815]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[2815]! } + public var Notifications_ExceptionsNone: String { return self._s[2816]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2816]!, self._r[2816]!, [_0]) + return formatWithArgumentRanges(self._s[2817]!, self._r[2817]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2817]!, self._r[2817]!, [_1]) + return formatWithArgumentRanges(self._s[2818]!, self._r[2818]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[2819]! } - public var Passport_Address_Region: String { return self._s[2822]! } - public var ChatList_DeleteChat: String { return self._s[2823]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[2824]! } - public var PhotoEditor_TiltShift: String { return self._s[2825]! } - public var Settings_FAQ_URL: String { return self._s[2826]! } - public var Passport_Language_sl: String { return self._s[2827]! } - public var Settings_PrivacySettings: String { return self._s[2829]! } - public var SharedMedia_TitleLink: String { return self._s[2830]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[2831]! } - public var Settings_SetProfilePhoto: String { return self._s[2832]! } - public var Channel_About_Help: String { return self._s[2833]! } - public var Contacts_PermissionsEnable: String { return self._s[2834]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[2835]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[2836]! } - public var CallFeedback_ReasonInterruption: String { return self._s[2838]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[2839]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[2840]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[2841]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[2842]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[2844]! } - public var Map_OpenInYandexMaps: String { return self._s[2846]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[2847]! } - public var VoiceOver_MessageContextReply: String { return self._s[2848]! } - public var PhotoEditor_SaturationTool: String { return self._s[2849]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[2820]! } + public var Passport_Address_Region: String { return self._s[2823]! } + public var ChatList_DeleteChat: String { return self._s[2824]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[2825]! } + public var PhotoEditor_TiltShift: String { return self._s[2826]! } + public var Settings_FAQ_URL: String { return self._s[2827]! } + public var Passport_Language_sl: String { return self._s[2828]! } + public var Settings_PrivacySettings: String { return self._s[2830]! } + public var SharedMedia_TitleLink: String { return self._s[2831]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[2832]! } + public var Settings_SetProfilePhoto: String { return self._s[2833]! } + public var Channel_About_Help: String { return self._s[2834]! } + public var Contacts_PermissionsEnable: String { return self._s[2835]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[2836]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[2837]! } + public var CallFeedback_ReasonInterruption: String { return self._s[2839]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[2840]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[2841]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[2842]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[2843]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[2845]! } + public var Map_OpenInYandexMaps: String { return self._s[2847]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[2848]! } + public var VoiceOver_MessageContextReply: String { return self._s[2849]! } + public var PhotoEditor_SaturationTool: String { return self._s[2850]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2850]!, self._r[2850]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2851]!, self._r[2851]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[2851]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2852]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[2853]! } - public var Appearance_TextSize: String { return self._s[2854]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[2852]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2853]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[2854]! } + public var Appearance_TextSize: String { return self._s[2855]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2855]!, self._r[2855]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2856]!, self._r[2856]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[2856]! } - public var Channel_Username_InvalidTooShort: String { return self._s[2858]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[2857]! } + public var Channel_Username_InvalidTooShort: String { return self._s[2859]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2859]!, self._r[2859]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2860]!, self._r[2860]!, [_1, _2]) } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2860]!, self._r[2860]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2861]!, self._r[2861]!, [_1, _2, _3]) } - public var GroupInfo_PublicLinkAdd: String { return self._s[2861]! } - public var Passport_PassportInformation: String { return self._s[2864]! } - public var WatchRemote_AlertTitle: String { return self._s[2865]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2866]! } - public var ConvertToSupergroup_HelpText: String { return self._s[2868]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[2862]! } + public var Passport_PassportInformation: String { return self._s[2865]! } + public var WatchRemote_AlertTitle: String { return self._s[2866]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2867]! } + public var ConvertToSupergroup_HelpText: String { return self._s[2869]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2869]!, self._r[2869]!, [_0]) + return formatWithArgumentRanges(self._s[2870]!, self._r[2870]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2870]!, self._r[2870]!, [_1]) + return formatWithArgumentRanges(self._s[2871]!, self._r[2871]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2871]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2873]! } - public var AccessDenied_CameraDisabled: String { return self._s[2874]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2872]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2874]! } + public var AccessDenied_CameraDisabled: String { return self._s[2875]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2875]!, self._r[2875]!, [_0]) + return formatWithArgumentRanges(self._s[2876]!, self._r[2876]!, [_0]) } - public var PhotoEditor_ContrastTool: String { return self._s[2878]! } + public var PhotoEditor_ContrastTool: String { return self._s[2879]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2879]!, self._r[2879]!, [_1]) + return formatWithArgumentRanges(self._s[2880]!, self._r[2880]!, [_1]) } - public var DialogList_Draft: String { return self._s[2880]! } - public var Privacy_TopPeersDelete: String { return self._s[2882]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[2883]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2884]! } - public var WebSearch_RecentSectionClear: String { return self._s[2885]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[2887]! } - public var Common_Done: String { return self._s[2889]! } - public var AuthSessions_EmptyText: String { return self._s[2890]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[2891]! } - public var Tour_Title5: String { return self._s[2892]! } + public var DialogList_Draft: String { return self._s[2881]! } + public var Privacy_TopPeersDelete: String { return self._s[2883]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[2884]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2885]! } + public var WebSearch_RecentSectionClear: String { return self._s[2886]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[2888]! } + public var Common_Done: String { return self._s[2890]! } + public var AuthSessions_EmptyText: String { return self._s[2891]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[2892]! } + public var Tour_Title5: String { return self._s[2893]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2893]!, self._r[2893]!, [_0]) + return formatWithArgumentRanges(self._s[2894]!, self._r[2894]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2894]! } - public var Conversation_LinkDialogSave: String { return self._s[2895]! } - public var GroupInfo_ActionRestrict: String { return self._s[2896]! } - public var Checkout_Title: String { return self._s[2897]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[2899]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[2901]! } - public var Notification_RenamedGroup: String { return self._s[2902]! } - public var PeopleNearby_Groups: String { return self._s[2903]! } - public var Checkout_PayWithFaceId: String { return self._s[2904]! } - public var Channel_BanList_BlockedTitle: String { return self._s[2905]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[2907]! } - public var Checkout_WebConfirmation_Title: String { return self._s[2908]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[2909]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2895]! } + public var Conversation_LinkDialogSave: String { return self._s[2896]! } + public var GroupInfo_ActionRestrict: String { return self._s[2897]! } + public var Checkout_Title: String { return self._s[2898]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[2900]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[2902]! } + public var Notification_RenamedGroup: String { return self._s[2903]! } + public var PeopleNearby_Groups: String { return self._s[2904]! } + public var Checkout_PayWithFaceId: String { return self._s[2905]! } + public var Channel_BanList_BlockedTitle: String { return self._s[2906]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[2908]! } + public var Checkout_WebConfirmation_Title: String { return self._s[2909]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[2910]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2910]!, self._r[2910]!, [_0]) + return formatWithArgumentRanges(self._s[2911]!, self._r[2911]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[2912]! } + public var Profile_AddToExisting: String { return self._s[2913]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2913]!, self._r[2913]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2914]!, self._r[2914]!, [_0, _1]) } - public var Cache_Files: String { return self._s[2915]! } - public var Permissions_PrivacyPolicy: String { return self._s[2916]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[2917]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2918]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[2920]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[2922]! } - public var Calls_NoCallsPlaceholder: String { return self._s[2923]! } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2924]! } - public var VoiceOver_AttachMedia: String { return self._s[2926]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2927]! } + public var Cache_Files: String { return self._s[2916]! } + public var Permissions_PrivacyPolicy: String { return self._s[2917]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[2918]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2919]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[2921]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[2923]! } + public var Calls_NoCallsPlaceholder: String { return self._s[2924]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2925]! } + public var VoiceOver_AttachMedia: String { return self._s[2927]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2928]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2928]!, self._r[2928]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2929]!, self._r[2929]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[2929]! } - public var Conversation_SetReminder_Title: String { return self._s[2930]! } - public var Passport_FieldAddressHelp: String { return self._s[2931]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2932]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[2930]! } + public var Conversation_SetReminder_Title: String { return self._s[2931]! } + public var Passport_FieldAddressHelp: String { return self._s[2932]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2933]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2933]!, self._r[2933]!, [_0]) + return formatWithArgumentRanges(self._s[2934]!, self._r[2934]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[2934]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[2936]! } - public var Login_UnknownError: String { return self._s[2937]! } - public var Group_UpgradeNoticeText2: String { return self._s[2939]! } - public var Watch_Compose_AddContact: String { return self._s[2940]! } - public var Web_Error: String { return self._s[2941]! } - public var Gif_Search: String { return self._s[2942]! } - public var Profile_MessageLifetime1h: String { return self._s[2943]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2944]! } - public var Channel_Username_CheckingUsername: String { return self._s[2945]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[2946]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[2947]! } - public var Channel_AboutItem: String { return self._s[2948]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2950]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[2951]! } - public var GroupInfo_SharedMedia: String { return self._s[2952]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[2935]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[2937]! } + public var Login_UnknownError: String { return self._s[2938]! } + public var Group_UpgradeNoticeText2: String { return self._s[2940]! } + public var Watch_Compose_AddContact: String { return self._s[2941]! } + public var Web_Error: String { return self._s[2942]! } + public var Gif_Search: String { return self._s[2943]! } + public var Profile_MessageLifetime1h: String { return self._s[2944]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2945]! } + public var Channel_Username_CheckingUsername: String { return self._s[2946]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[2947]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[2948]! } + public var Channel_AboutItem: String { return self._s[2949]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2951]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[2952]! } + public var GroupInfo_SharedMedia: String { return self._s[2953]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2953]!, self._r[2953]!, [_1]) + return formatWithArgumentRanges(self._s[2954]!, self._r[2954]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[2954]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[2955]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2955]!, self._r[2955]!, [_1]) + return formatWithArgumentRanges(self._s[2956]!, self._r[2956]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[2956]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2957]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[2958]! } - public var CreatePoll_AddOption: String { return self._s[2959]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2960]! } - public var Group_UpgradeNoticeHeader: String { return self._s[2961]! } - public var Channel_Management_AddModerator: String { return self._s[2962]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[2963]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[2964]! } - public var NotificationsSound_Hello: String { return self._s[2965]! } - public var SocksProxySetup_SavedProxies: String { return self._s[2966]! } - public var Channel_Stickers_Placeholder: String { return self._s[2968]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[2957]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2958]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[2959]! } + public var CreatePoll_AddOption: String { return self._s[2960]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2961]! } + public var Group_UpgradeNoticeHeader: String { return self._s[2962]! } + public var Channel_Management_AddModerator: String { return self._s[2963]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[2964]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[2965]! } + public var NotificationsSound_Hello: String { return self._s[2966]! } + public var SocksProxySetup_SavedProxies: String { return self._s[2967]! } + public var Channel_Stickers_Placeholder: String { return self._s[2969]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2969]!, self._r[2969]!, [_0]) + return formatWithArgumentRanges(self._s[2970]!, self._r[2970]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2970]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[2971]! } - public var ContactInfo_BirthdayLabel: String { return self._s[2972]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2973]! } - public var AutoDownloadSettings_Channels: String { return self._s[2974]! } - public var Passport_Language_mn: String { return self._s[2975]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[2978]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[2979]! } - public var Passport_Language_ja: String { return self._s[2981]! } - public var Settings_About_Title: String { return self._s[2982]! } - public var Settings_NotificationsAndSounds: String { return self._s[2983]! } - public var ChannelInfo_DeleteGroup: String { return self._s[2984]! } - public var Settings_BlockedUsers: String { return self._s[2985]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2971]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[2972]! } + public var ContactInfo_BirthdayLabel: String { return self._s[2973]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2974]! } + public var AutoDownloadSettings_Channels: String { return self._s[2975]! } + public var Passport_Language_mn: String { return self._s[2976]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[2979]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[2980]! } + public var Passport_Language_ja: String { return self._s[2982]! } + public var Settings_About_Title: String { return self._s[2983]! } + public var Settings_NotificationsAndSounds: String { return self._s[2984]! } + public var ChannelInfo_DeleteGroup: String { return self._s[2985]! } + public var Settings_BlockedUsers: String { return self._s[2986]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_0]) + return formatWithArgumentRanges(self._s[2987]!, self._r[2987]!, [_0]) } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[2987]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[2988]! } - public var Channel_Username_Title: String { return self._s[2989]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[2988]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[2989]! } + public var Channel_Username_Title: String { return self._s[2990]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_0]) + return formatWithArgumentRanges(self._s[2991]!, self._r[2991]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[2992]! } - public var AppleWatch_Title: String { return self._s[2993]! } - public var Activity_RecordingVideoMessage: String { return self._s[2994]! } + public var AttachmentMenu_File: String { return self._s[2993]! } + public var AppleWatch_Title: String { return self._s[2994]! } + public var Activity_RecordingVideoMessage: String { return self._s[2995]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2995]!, self._r[2995]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2996]!, self._r[2996]!, [_1, _2]) } - public var Weekday_Saturday: String { return self._s[2996]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[2997]! } - public var Profile_CreateEncryptedChatError: String { return self._s[2998]! } - public var Common_Next: String { return self._s[3000]! } - public var Channel_Stickers_YourStickers: String { return self._s[3002]! } - public var Call_AudioRouteHeadphones: String { return self._s[3003]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3005]! } - public var Watch_Contacts_NoResults: String { return self._s[3007]! } - public var PhotoEditor_TintTool: String { return self._s[3010]! } - public var LoginPassword_ResetAccount: String { return self._s[3012]! } - public var Settings_SavedMessages: String { return self._s[3013]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3014]! } - public var Bot_GenericSupportStatus: String { return self._s[3015]! } - public var StickerPack_Add: String { return self._s[3016]! } - public var Checkout_TotalAmount: String { return self._s[3017]! } - public var Your_cards_number_is_invalid: String { return self._s[3018]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3019]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3020]! } + public var Weekday_Saturday: String { return self._s[2997]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[2998]! } + public var Profile_CreateEncryptedChatError: String { return self._s[2999]! } + public var Common_Next: String { return self._s[3001]! } + public var Channel_Stickers_YourStickers: String { return self._s[3003]! } + public var Call_AudioRouteHeadphones: String { return self._s[3004]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3006]! } + public var Watch_Contacts_NoResults: String { return self._s[3008]! } + public var PhotoEditor_TintTool: String { return self._s[3011]! } + public var LoginPassword_ResetAccount: String { return self._s[3013]! } + public var Settings_SavedMessages: String { return self._s[3014]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3015]! } + public var Bot_GenericSupportStatus: String { return self._s[3016]! } + public var StickerPack_Add: String { return self._s[3017]! } + public var Checkout_TotalAmount: String { return self._s[3018]! } + public var Your_cards_number_is_invalid: String { return self._s[3019]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3020]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3021]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3021]!, self._r[3021]!, [_0]) + return formatWithArgumentRanges(self._s[3022]!, self._r[3022]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3022]!, self._r[3022]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3023]!, self._r[3023]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3023]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3024]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3025]!, self._r[3025]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_0]) + return formatWithArgumentRanges(self._s[3027]!, self._r[3027]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3027]! } - public var StickerPack_Share: String { return self._s[3028]! } - public var Passport_DeleteAddress: String { return self._s[3029]! } - public var Settings_Passport: String { return self._s[3030]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3031]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3032]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3033]! } - public var Contacts_PermissionsText: String { return self._s[3034]! } - public var Group_Setup_HistoryVisible: String { return self._s[3035]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3037]! } - public var SocksProxySetup_Title: String { return self._s[3038]! } - public var Notification_Mute1h: String { return self._s[3039]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3028]! } + public var StickerPack_Share: String { return self._s[3029]! } + public var Passport_DeleteAddress: String { return self._s[3030]! } + public var Settings_Passport: String { return self._s[3031]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3032]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3033]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3034]! } + public var Contacts_PermissionsText: String { return self._s[3035]! } + public var Group_Setup_HistoryVisible: String { return self._s[3036]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3038]! } + public var SocksProxySetup_Title: String { return self._s[3039]! } + public var Notification_Mute1h: String { return self._s[3040]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3040]!, self._r[3040]!, [_0]) + return formatWithArgumentRanges(self._s[3041]!, self._r[3041]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3041]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3042]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3042]!, self._r[3042]!, [_1]) + return formatWithArgumentRanges(self._s[3043]!, self._r[3043]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3043]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3046]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3048]! } - public var DialogList_NoMessagesText: String { return self._s[3049]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3050]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3051]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3053]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3054]! } - public var Common_TakePhotoOrVideo: String { return self._s[3055]! } - public var Call_StatusBusy: String { return self._s[3056]! } - public var Conversation_PinnedMessage: String { return self._s[3057]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3058]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3059]! } - public var Undo_ChatCleared: String { return self._s[3060]! } - public var AppleWatch_ReplyPresets: String { return self._s[3061]! } - public var Passport_DiscardMessageDescription: String { return self._s[3063]! } - public var Login_NetworkError: String { return self._s[3064]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3044]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3047]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3049]! } + public var DialogList_NoMessagesText: String { return self._s[3050]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3051]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3052]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3054]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3055]! } + public var Common_TakePhotoOrVideo: String { return self._s[3056]! } + public var Call_StatusBusy: String { return self._s[3057]! } + public var Conversation_PinnedMessage: String { return self._s[3058]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3059]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3060]! } + public var Undo_ChatCleared: String { return self._s[3061]! } + public var AppleWatch_ReplyPresets: String { return self._s[3062]! } + public var Passport_DiscardMessageDescription: String { return self._s[3064]! } + public var Login_NetworkError: String { return self._s[3065]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3065]!, self._r[3065]!, [_0]) - } - public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3066]!, self._r[3066]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3067]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3069]! } + public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3067]!, self._r[3067]!, [_0]) + } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3068]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3070]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3071]!, self._r[3071]!, [_0]) + return formatWithArgumentRanges(self._s[3072]!, self._r[3072]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3072]! } - public var VoiceOver_Chat_Music: String { return self._s[3073]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3074]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3076]! } - public var ConversationMedia_Title: String { return self._s[3077]! } - public var EncryptionKey_Title: String { return self._s[3079]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3080]! } - public var Notification_Exceptions_AddException: String { return self._s[3081]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3082]! } - public var Profile_MessageLifetime1m: String { return self._s[3083]! } + public var Call_ConnectionErrorMessage: String { return self._s[3073]! } + public var VoiceOver_Chat_Music: String { return self._s[3074]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3075]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3077]! } + public var ConversationMedia_Title: String { return self._s[3078]! } + public var EncryptionKey_Title: String { return self._s[3080]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3081]! } + public var Notification_Exceptions_AddException: String { return self._s[3082]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3083]! } + public var Profile_MessageLifetime1m: String { return self._s[3084]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3084]!, self._r[3084]!, [_1]) + return formatWithArgumentRanges(self._s[3085]!, self._r[3085]!, [_1]) } - public var Month_GenMay: String { return self._s[3085]! } + public var Month_GenMay: String { return self._s[3086]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3086]!, self._r[3086]!, [_0]) + return formatWithArgumentRanges(self._s[3087]!, self._r[3087]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3087]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3088]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3089]! } - public var Conversation_EmptyPlaceholder: String { return self._s[3091]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3092]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3093]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3094]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3095]! } - public var Channel_JoinChannel: String { return self._s[3097]! } - public var Appearance_Animations: String { return self._s[3100]! } + public var PeopleNearby_Users: String { return self._s[3088]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3089]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3090]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3092]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3093]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3094]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3095]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3096]! } + public var Channel_JoinChannel: String { return self._s[3098]! } + public var Appearance_Animations: String { return self._s[3101]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3101]!, self._r[3101]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3102]!, self._r[3102]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3103]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3105]! } - public var Passport_Address_Street: String { return self._s[3106]! } - public var Conversation_AddContact: String { return self._s[3107]! } - public var Login_PhonePlaceholder: String { return self._s[3108]! } - public var Channel_Members_InviteLink: String { return self._s[3110]! } - public var Bot_Stop: String { return self._s[3111]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3113]! } - public var Notification_PassportValueAddress: String { return self._s[3114]! } - public var Month_ShortJuly: String { return self._s[3115]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3116]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3117]! } - public var Passport_Identity_ReverseSide: String { return self._s[3118]! } - public var Watch_Stickers_Recents: String { return self._s[3121]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3123]! } - public var Map_SendThisLocation: String { return self._s[3124]! } + public var Stickers_GroupStickers: String { return self._s[3104]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3106]! } + public var Passport_Address_Street: String { return self._s[3107]! } + public var Conversation_AddContact: String { return self._s[3108]! } + public var Login_PhonePlaceholder: String { return self._s[3109]! } + public var Channel_Members_InviteLink: String { return self._s[3111]! } + public var Bot_Stop: String { return self._s[3112]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3114]! } + public var Notification_PassportValueAddress: String { return self._s[3115]! } + public var Month_ShortJuly: String { return self._s[3116]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3117]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3118]! } + public var Passport_Identity_ReverseSide: String { return self._s[3119]! } + public var Watch_Stickers_Recents: String { return self._s[3122]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3124]! } + public var Map_SendThisLocation: String { return self._s[3125]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3125]!, self._r[3125]!, [_0]) - } - public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3126]!, self._r[3126]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3127]! } + public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3127]!, self._r[3127]!, [_0]) + } + public var ConvertToSupergroup_Note: String { return self._s[3128]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3128]!, self._r[3128]!, [_0]) + return formatWithArgumentRanges(self._s[3129]!, self._r[3129]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3129]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3130]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3130]!, self._r[3130]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3131]!, self._r[3131]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3132]! } - public var Wallpaper_SearchShort: String { return self._s[3133]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3135]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3136]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3137]! } + public var Login_CallRequestState3: String { return self._s[3133]! } + public var Wallpaper_SearchShort: String { return self._s[3134]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3136]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3137]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3138]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3138]!, self._r[3138]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3139]!, self._r[3139]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3139]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3141]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3144]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3140]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3142]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3145]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3145]!, self._r[3145]!, [_0]) + return formatWithArgumentRanges(self._s[3146]!, self._r[3146]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3146]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3147]! } + public var Passport_CorrectErrors: String { return self._s[3147]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3148]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3148]!, self._r[3148]!, [_0]) + return formatWithArgumentRanges(self._s[3149]!, self._r[3149]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3149]! } - public var Channel_DiscussionGroup: String { return self._s[3150]! } + public var Map_SendMyCurrentLocation: String { return self._s[3150]! } + public var Channel_DiscussionGroup: String { return self._s[3151]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3151]!, self._r[3151]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3152]!, self._r[3152]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3152]! } - public var Permissions_NotificationsText_v0: String { return self._s[3153]! } - public var Appearance_AppIcon: String { return self._s[3154]! } - public var LoginPassword_FloodError: String { return self._s[3155]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3157]! } + public var SharedMedia_SearchNoResults: String { return self._s[3153]! } + public var Permissions_NotificationsText_v0: String { return self._s[3154]! } + public var Appearance_AppIcon: String { return self._s[3155]! } + public var LoginPassword_FloodError: String { return self._s[3156]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3158]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3158]!, self._r[3158]!, [_0]) + return formatWithArgumentRanges(self._s[3159]!, self._r[3159]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3159]! } + public var Passport_Language_bn: String { return self._s[3160]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3160]!, self._r[3160]!, [_0]) - } - public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3161]!, self._r[3161]!, [_0]) } - public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_0]) } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3165]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3167]! } - public var Contacts_PermissionsAllow: String { return self._s[3168]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3169]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3170]! } - public var WallpaperPreview_Pattern: String { return self._s[3171]! } - public var Paint_Duplicate: String { return self._s[3172]! } - public var Passport_Address_Country: String { return self._s[3173]! } - public var Notification_RenamedChannel: String { return self._s[3175]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3176]! } - public var Group_MessagePhotoUpdated: String { return self._s[3177]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3178]! } - public var Conversation_ContextMenuBan: String { return self._s[3179]! } - public var TwoStepAuth_EmailSent: String { return self._s[3180]! } - public var MessagePoll_NoVotes: String { return self._s[3181]! } - public var Passport_Language_is: String { return self._s[3182]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3184]! } - public var Tour_Text5: String { return self._s[3185]! } + public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3163]!, self._r[3163]!, [_0]) + } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3166]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3168]! } + public var Contacts_PermissionsAllow: String { return self._s[3169]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3170]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3171]! } + public var WallpaperPreview_Pattern: String { return self._s[3172]! } + public var Paint_Duplicate: String { return self._s[3173]! } + public var Passport_Address_Country: String { return self._s[3174]! } + public var Notification_RenamedChannel: String { return self._s[3176]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3177]! } + public var Group_MessagePhotoUpdated: String { return self._s[3178]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3179]! } + public var Conversation_ContextMenuBan: String { return self._s[3180]! } + public var TwoStepAuth_EmailSent: String { return self._s[3181]! } + public var MessagePoll_NoVotes: String { return self._s[3182]! } + public var Passport_Language_is: String { return self._s[3183]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3185]! } + public var Tour_Text5: String { return self._s[3186]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3187]!, self._r[3187]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3188]!, self._r[3188]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3188]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3189]! } + public var Undo_SecretChatDeleted: String { return self._s[3189]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3190]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3190]!, self._r[3190]!, [_0]) + return formatWithArgumentRanges(self._s[3191]!, self._r[3191]!, [_0]) } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3191]! } - public var Paint_Edit: String { return self._s[3193]! } - public var Undo_DeletedGroup: String { return self._s[3196]! } - public var LoginPassword_ForgotPassword: String { return self._s[3197]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3198]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3192]! } + public var Paint_Edit: String { return self._s[3194]! } + public var Undo_DeletedGroup: String { return self._s[3197]! } + public var LoginPassword_ForgotPassword: String { return self._s[3198]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3199]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3199]!, self._r[3199]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3200]!, self._r[3200]!, [_0, _1]) } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3200]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3201]! } - public var Passport_Language_uz: String { return self._s[3202]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3203]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3204]! } - public var Map_StopLiveLocation: String { return self._s[3206]! } - public var VoiceOver_MessageContextSend: String { return self._s[3208]! } - public var PasscodeSettings_Help: String { return self._s[3209]! } - public var NotificationsSound_Input: String { return self._s[3210]! } - public var Share_Title: String { return self._s[3213]! } - public var LogoutOptions_Title: String { return self._s[3214]! } - public var Login_TermsOfServiceAgree: String { return self._s[3215]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3216]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3217]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3218]! } - public var EnterPasscode_EnterTitle: String { return self._s[3219]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3201]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3202]! } + public var Passport_Language_uz: String { return self._s[3203]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3204]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3205]! } + public var Map_StopLiveLocation: String { return self._s[3207]! } + public var VoiceOver_MessageContextSend: String { return self._s[3209]! } + public var PasscodeSettings_Help: String { return self._s[3210]! } + public var NotificationsSound_Input: String { return self._s[3211]! } + public var Share_Title: String { return self._s[3214]! } + public var LogoutOptions_Title: String { return self._s[3215]! } + public var Login_TermsOfServiceAgree: String { return self._s[3216]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3217]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3218]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3219]! } + public var EnterPasscode_EnterTitle: String { return self._s[3220]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3220]!, self._r[3220]!, [_0]) + return formatWithArgumentRanges(self._s[3221]!, self._r[3221]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3221]! } - public var Conversation_AddToContacts: String { return self._s[3222]! } + public var Settings_CopyPhoneNumber: String { return self._s[3222]! } + public var Conversation_AddToContacts: String { return self._s[3223]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3223]!, self._r[3223]!, [_0]) + return formatWithArgumentRanges(self._s[3224]!, self._r[3224]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3224]! } + public var NotificationsSound_Keys: String { return self._s[3225]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3225]!, self._r[3225]!, [_0]) + return formatWithArgumentRanges(self._s[3226]!, self._r[3226]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3226]! } - public var Message_Video: String { return self._s[3227]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3228]! } + public var Notification_MessageLifetime1w: String { return self._s[3227]! } + public var Message_Video: String { return self._s[3228]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3229]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3229]!, self._r[3229]!, [_1]) + return formatWithArgumentRanges(self._s[3230]!, self._r[3230]!, [_1]) } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3232]!, self._r[3232]!, [_0]) - } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3233]!, self._r[3233]!, [_0]) } - public var Passport_Language_mk: String { return self._s[3234]! } - public var CreatePoll_CancelConfirmation: String { return self._s[3235]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3237]! } - public var PrivacyPolicy_Decline: String { return self._s[3238]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3239]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3240]! } - public var Permissions_SiriAllow_v0: String { return self._s[3242]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3243]! } + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3234]!, self._r[3234]!, [_0]) + } + public var Passport_Language_mk: String { return self._s[3235]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3236]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3238]! } + public var PrivacyPolicy_Decline: String { return self._s[3239]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3240]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3241]! } + public var Permissions_SiriAllow_v0: String { return self._s[3243]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3244]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3244]!, self._r[3244]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3245]!, self._r[3245]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3245]!, self._r[3245]!, [_0]) + return formatWithArgumentRanges(self._s[3246]!, self._r[3246]!, [_0]) } - public var Paint_Regular: String { return self._s[3246]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3247]! } - public var SocksProxySetup_ShareLink: String { return self._s[3248]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3249]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3251]! } - public var GroupInfo_InviteByLink: String { return self._s[3252]! } - public var MessageTimer_Custom: String { return self._s[3253]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3254]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3256]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3257]! } - public var VoiceOver_Chat_Selected: String { return self._s[3258]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3259]! } - public var Channel_Username_InvalidTaken: String { return self._s[3260]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3261]! } - public var Settings_ChatBackground: String { return self._s[3262]! } - public var Channel_Subscribers_Title: String { return self._s[3263]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3264]! } - public var Watch_ConnectionDescription: String { return self._s[3265]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3269]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3270]! } - public var EditProfile_Title: String { return self._s[3271]! } - public var NotificationsSound_Bamboo: String { return self._s[3273]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3275]! } - public var Login_SmsRequestState2: String { return self._s[3276]! } - public var Passport_Language_ar: String { return self._s[3277]! } + public var Paint_Regular: String { return self._s[3247]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3248]! } + public var SocksProxySetup_ShareLink: String { return self._s[3249]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3250]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3252]! } + public var GroupInfo_InviteByLink: String { return self._s[3253]! } + public var MessageTimer_Custom: String { return self._s[3254]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3255]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3257]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3258]! } + public var VoiceOver_Chat_Selected: String { return self._s[3259]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3260]! } + public var Channel_Username_InvalidTaken: String { return self._s[3261]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3262]! } + public var Settings_ChatBackground: String { return self._s[3263]! } + public var Channel_Subscribers_Title: String { return self._s[3264]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3265]! } + public var Watch_ConnectionDescription: String { return self._s[3266]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3270]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3271]! } + public var EditProfile_Title: String { return self._s[3272]! } + public var NotificationsSound_Bamboo: String { return self._s[3274]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3276]! } + public var Login_SmsRequestState2: String { return self._s[3277]! } + public var Passport_Language_ar: String { return self._s[3278]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3278]!, self._r[3278]!, [_0]) + return formatWithArgumentRanges(self._s[3279]!, self._r[3279]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3279]! } - public var Conversation_MessageDialogEdit: String { return self._s[3280]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3281]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3280]! } + public var Conversation_MessageDialogEdit: String { return self._s[3281]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3282]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3282]!, self._r[3282]!, [_1]) + return formatWithArgumentRanges(self._s[3283]!, self._r[3283]!, [_1]) } - public var Common_Close: String { return self._s[3283]! } - public var GroupInfo_PublicLink: String { return self._s[3284]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3285]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3286]! } + public var Common_Close: String { return self._s[3284]! } + public var GroupInfo_PublicLink: String { return self._s[3285]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3286]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3287]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3290]!, self._r[3290]!, [_0]) + return formatWithArgumentRanges(self._s[3291]!, self._r[3291]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3291]! } + public var UserInfo_About_Placeholder: String { return self._s[3292]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3292]!, self._r[3292]!, [_0]) + return formatWithArgumentRanges(self._s[3293]!, self._r[3293]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3293]! } - public var Channel_Info_Banned: String { return self._s[3295]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3294]! } + public var Channel_Info_Banned: String { return self._s[3296]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3296]!, self._r[3296]!, [_0]) + return formatWithArgumentRanges(self._s[3297]!, self._r[3297]!, [_0]) } - public var Appearance_Other: String { return self._s[3297]! } - public var Passport_Language_my: String { return self._s[3298]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3299]! } + public var Appearance_Other: String { return self._s[3298]! } + public var Passport_Language_my: String { return self._s[3299]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3300]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3300]!, self._r[3300]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3301]!, self._r[3301]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3301]! } - public var Preview_CopyAddress: String { return self._s[3302]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3302]! } + public var Preview_CopyAddress: String { return self._s[3303]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3303]!, self._r[3303]!, [_0]) + return formatWithArgumentRanges(self._s[3304]!, self._r[3304]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3304]! } - public var UserInfo_BotSettings: String { return self._s[3305]! } - public var LiveLocation_MenuStopAll: String { return self._s[3307]! } - public var Passport_PasswordCreate: String { return self._s[3308]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3309]! } - public var Message_PinnedLocationMessage: String { return self._s[3310]! } - public var Map_Satellite: String { return self._s[3311]! } - public var Watch_Message_Unsupported: String { return self._s[3312]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3313]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3314]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3305]! } + public var UserInfo_BotSettings: String { return self._s[3306]! } + public var LiveLocation_MenuStopAll: String { return self._s[3308]! } + public var Passport_PasswordCreate: String { return self._s[3309]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3310]! } + public var Message_PinnedLocationMessage: String { return self._s[3311]! } + public var Map_Satellite: String { return self._s[3312]! } + public var Watch_Message_Unsupported: String { return self._s[3313]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3314]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3315]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3316]!, self._r[3316]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3316]!, self._r[3316]!, [_0]) + return formatWithArgumentRanges(self._s[3317]!, self._r[3317]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3317]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3318]! } - public var NotificationsSound_None: String { return self._s[3319]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3321]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3322]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3318]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3319]! } + public var NotificationsSound_None: String { return self._s[3320]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3322]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3323]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3323]!, self._r[3323]!, [_1]) + return formatWithArgumentRanges(self._s[3324]!, self._r[3324]!, [_1]) } - public var Cache_Indexing: String { return self._s[3324]! } - public var DialogList_RecentTitlePeople: String { return self._s[3326]! } - public var DialogList_EncryptionRejected: String { return self._s[3327]! } - public var GroupInfo_Administrators: String { return self._s[3328]! } - public var Passport_ScanPassportHelp: String { return self._s[3329]! } - public var Application_Name: String { return self._s[3330]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3331]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3333]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3334]! } + public var Cache_Indexing: String { return self._s[3325]! } + public var DialogList_RecentTitlePeople: String { return self._s[3327]! } + public var DialogList_EncryptionRejected: String { return self._s[3328]! } + public var GroupInfo_Administrators: String { return self._s[3329]! } + public var Passport_ScanPassportHelp: String { return self._s[3330]! } + public var Application_Name: String { return self._s[3331]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3332]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3334]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3335]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3335]!, self._r[3335]!, [_0]) - } - public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3336]!, self._r[3336]!, [_0]) } - public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3338]! } - public var Privacy_ChatsTitle: String { return self._s[3339]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3340]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3341]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3342]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3343]! } - public var Group_LinkedChannel: String { return self._s[3344]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3345]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3346]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3347]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3348]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[3350]! } - public var Channel_Setup_TypePublic: String { return self._s[3352]! } + public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3338]!, self._r[3338]!, [_0]) + } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3339]! } + public var Privacy_ChatsTitle: String { return self._s[3340]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3341]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3342]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3343]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3344]! } + public var Group_LinkedChannel: String { return self._s[3345]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3346]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3347]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3348]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3349]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3351]! } + public var Channel_Setup_TypePublic: String { return self._s[3353]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3353]!, self._r[3353]!, [_0]) + return formatWithArgumentRanges(self._s[3354]!, self._r[3354]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3355]! } - public var Map_OpenInMaps: String { return self._s[3357]! } + public var Channel_TypeSetup_Title: String { return self._s[3356]! } + public var Map_OpenInMaps: String { return self._s[3358]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3358]!, self._r[3358]!, [_1]) + return formatWithArgumentRanges(self._s[3359]!, self._r[3359]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3360]! } + public var NotificationsSound_Tremolo: String { return self._s[3361]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3361]!, self._r[3361]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3362]!, self._r[3362]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3362]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3363]! } - public var Passport_PasswordHelp: String { return self._s[3364]! } - public var Login_CodeExpiredError: String { return self._s[3365]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3366]! } - public var Conversation_TitleUnmute: String { return self._s[3367]! } - public var Passport_Identity_ScansHelp: String { return self._s[3368]! } - public var Passport_Language_lo: String { return self._s[3369]! } - public var Camera_FlashAuto: String { return self._s[3370]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3371]! } - public var Common_Cancel: String { return self._s[3372]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3373]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3374]! } - public var Appearance_TintAllColors: String { return self._s[3375]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3363]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3364]! } + public var Passport_PasswordHelp: String { return self._s[3365]! } + public var Login_CodeExpiredError: String { return self._s[3366]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3367]! } + public var Conversation_TitleUnmute: String { return self._s[3368]! } + public var Passport_Identity_ScansHelp: String { return self._s[3369]! } + public var Passport_Language_lo: String { return self._s[3370]! } + public var Camera_FlashAuto: String { return self._s[3371]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3372]! } + public var Common_Cancel: String { return self._s[3373]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3374]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3375]! } + public var Appearance_TintAllColors: String { return self._s[3376]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3376]!, self._r[3376]!, [_1]) + return formatWithArgumentRanges(self._s[3377]!, self._r[3377]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3377]! } - public var ChatSettings_Title: String { return self._s[3379]! } - public var Passport_PasswordReset: String { return self._s[3380]! } - public var SocksProxySetup_TypeNone: String { return self._s[3381]! } - public var PhoneNumberHelp_Help: String { return self._s[3383]! } - public var Checkout_EnterPassword: String { return self._s[3384]! } - public var Share_AuthTitle: String { return self._s[3386]! } - public var Activity_UploadingDocument: String { return self._s[3387]! } - public var State_Connecting: String { return self._s[3388]! } - public var Profile_MessageLifetime1w: String { return self._s[3389]! } - public var Conversation_ContextMenuReport: String { return self._s[3390]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3391]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3392]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3378]! } + public var ChatSettings_Title: String { return self._s[3380]! } + public var Passport_PasswordReset: String { return self._s[3381]! } + public var SocksProxySetup_TypeNone: String { return self._s[3382]! } + public var PhoneNumberHelp_Help: String { return self._s[3384]! } + public var Checkout_EnterPassword: String { return self._s[3385]! } + public var Share_AuthTitle: String { return self._s[3387]! } + public var Activity_UploadingDocument: String { return self._s[3388]! } + public var State_Connecting: String { return self._s[3389]! } + public var Profile_MessageLifetime1w: String { return self._s[3390]! } + public var Conversation_ContextMenuReport: String { return self._s[3391]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3392]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3393]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3393]!, self._r[3393]!, [_0]) + return formatWithArgumentRanges(self._s[3394]!, self._r[3394]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3394]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3395]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3396]! } - public var PhotoEditor_Set: String { return self._s[3397]! } - public var EmptyGroupInfo_Title: String { return self._s[3398]! } - public var Login_PadPhoneHelp: String { return self._s[3399]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3401]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3403]! } - public var NotificationsSound_Complete: String { return self._s[3404]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3405]! } - public var Group_Info_AdminLog: String { return self._s[3406]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3407]! } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3408]! } - public var Conversation_Admin: String { return self._s[3410]! } - public var Conversation_GifTooltip: String { return self._s[3411]! } - public var Passport_NotLoggedInMessage: String { return self._s[3412]! } + public var AuthSessions_Terminate: String { return self._s[3395]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3396]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3397]! } + public var PhotoEditor_Set: String { return self._s[3398]! } + public var EmptyGroupInfo_Title: String { return self._s[3399]! } + public var Login_PadPhoneHelp: String { return self._s[3400]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3402]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3404]! } + public var NotificationsSound_Complete: String { return self._s[3405]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3406]! } + public var Group_Info_AdminLog: String { return self._s[3407]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3408]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3409]! } + public var Conversation_Admin: String { return self._s[3411]! } + public var Conversation_GifTooltip: String { return self._s[3412]! } + public var Passport_NotLoggedInMessage: String { return self._s[3413]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3413]!, self._r[3413]!, [_0]) + return formatWithArgumentRanges(self._s[3414]!, self._r[3414]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3414]! } - public var SharedMedia_EmptyTitle: String { return self._s[3416]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3418]! } - public var Username_Help: String { return self._s[3419]! } - public var DialogList_LanguageTooltip: String { return self._s[3421]! } - public var Map_LoadError: String { return self._s[3422]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3423]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3424]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3425]! } - public var Notification_Exceptions_NewException: String { return self._s[3426]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3427]! } - public var WatchRemote_AlertText: String { return self._s[3428]! } - public var ChatSettings_ConnectionType_Title: String { return self._s[3431]! } + public var Profile_MessageLifetimeForever: String { return self._s[3415]! } + public var SharedMedia_EmptyTitle: String { return self._s[3417]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3419]! } + public var Username_Help: String { return self._s[3420]! } + public var DialogList_LanguageTooltip: String { return self._s[3422]! } + public var Map_LoadError: String { return self._s[3423]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3424]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3425]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3426]! } + public var Notification_Exceptions_NewException: String { return self._s[3427]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3428]! } + public var WatchRemote_AlertText: String { return self._s[3429]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[3432]! } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3432]!, self._r[3432]!, [_0]) + return formatWithArgumentRanges(self._s[3433]!, self._r[3433]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3433]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3434]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3434]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3435]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3435]!, self._r[3435]!, [_0]) + return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3437]!, self._r[3437]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3437]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3438]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[3440]! } - public var ChatList_UndoArchiveText1: String { return self._s[3441]! } - public var AccessDenied_VideoMicrophone: String { return self._s[3442]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3443]! } - public var Cache_ClearNone: String { return self._s[3444]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[3445]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[3446]! } + public var Group_AdminLog_EmptyText: String { return self._s[3438]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3439]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[3441]! } + public var ChatList_UndoArchiveText1: String { return self._s[3442]! } + public var AccessDenied_VideoMicrophone: String { return self._s[3443]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3444]! } + public var Cache_ClearNone: String { return self._s[3445]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[3446]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[3447]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3447]!, self._r[3447]!, [_0]) + return formatWithArgumentRanges(self._s[3448]!, self._r[3448]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[3448]! } + public var Passport_Identity_Country: String { return self._s[3449]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3449]!, self._r[3449]!, [_0]) - } - public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3450]!, self._r[3450]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[3451]! } - public var AccessDenied_Settings: String { return self._s[3452]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3453]! } - public var Month_ShortMay: String { return self._s[3454]! } - public var Compose_NewGroup: String { return self._s[3455]! } - public var Group_Setup_TypePrivate: String { return self._s[3457]! } - public var Login_PadPhoneHelpTitle: String { return self._s[3459]! } - public var Appearance_ThemeDayClassic: String { return self._s[3460]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3461]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[3462]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3463]! } - public var Conversation_typing: String { return self._s[3465]! } - public var Paint_Masks: String { return self._s[3466]! } - public var Contacts_DeselectAll: String { return self._s[3467]! } - public var Username_InvalidTaken: String { return self._s[3468]! } - public var Call_StatusNoAnswer: String { return self._s[3469]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[3470]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3471]! } - public var Passport_Identity_Selfie: String { return self._s[3472]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[3473]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3474]! } - public var Conversation_ClearSecretHistory: String { return self._s[3475]! } - public var PeopleNearby_Description: String { return self._s[3477]! } - public var NetworkUsageSettings_Title: String { return self._s[3478]! } - public var Your_cards_security_code_is_invalid: String { return self._s[3480]! } + public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3451]!, self._r[3451]!, [_0]) + } + public var Exceptions_AddToExceptions: String { return self._s[3452]! } + public var AccessDenied_Settings: String { return self._s[3453]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3454]! } + public var Month_ShortMay: String { return self._s[3455]! } + public var Compose_NewGroup: String { return self._s[3456]! } + public var Group_Setup_TypePrivate: String { return self._s[3458]! } + public var Login_PadPhoneHelpTitle: String { return self._s[3460]! } + public var Appearance_ThemeDayClassic: String { return self._s[3461]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3462]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[3463]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3464]! } + public var Conversation_typing: String { return self._s[3466]! } + public var Paint_Masks: String { return self._s[3467]! } + public var Contacts_DeselectAll: String { return self._s[3468]! } + public var Username_InvalidTaken: String { return self._s[3469]! } + public var Call_StatusNoAnswer: String { return self._s[3470]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[3471]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3472]! } + public var Passport_Identity_Selfie: String { return self._s[3473]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[3474]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3475]! } + public var Conversation_ClearSecretHistory: String { return self._s[3476]! } + public var PeopleNearby_Description: String { return self._s[3478]! } + public var NetworkUsageSettings_Title: String { return self._s[3479]! } + public var Your_cards_security_code_is_invalid: String { return self._s[3481]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3482]!, self._r[3482]!, [_0]) + return formatWithArgumentRanges(self._s[3483]!, self._r[3483]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3483]!, self._r[3483]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3484]!, self._r[3484]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[3485]! } - public var VoiceOver_Navigation_Search: String { return self._s[3486]! } - public var Map_LiveLocationTitle: String { return self._s[3487]! } - public var Login_InfoAvatarAdd: String { return self._s[3488]! } - public var Passport_Identity_FilesView: String { return self._s[3489]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[3490]! } - public var Privacy_Calls_NeverAllow: String { return self._s[3491]! } - public var VoiceOver_Chat_File: String { return self._s[3492]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[3486]! } + public var VoiceOver_Navigation_Search: String { return self._s[3487]! } + public var Map_LiveLocationTitle: String { return self._s[3488]! } + public var Login_InfoAvatarAdd: String { return self._s[3489]! } + public var Passport_Identity_FilesView: String { return self._s[3490]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[3491]! } + public var Privacy_Calls_NeverAllow: String { return self._s[3492]! } + public var VoiceOver_Chat_File: String { return self._s[3493]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3493]!, self._r[3493]!, [_0]) + return formatWithArgumentRanges(self._s[3494]!, self._r[3494]!, [_0]) } - public var ContactInfo_PhoneNumberHidden: String { return self._s[3494]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[3495]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3496]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[3495]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[3496]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3497]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3497]!, self._r[3497]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3498]!, self._r[3498]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3498]! } - public var Tour_Title2: String { return self._s[3499]! } - public var Conversation_FileOpenIn: String { return self._s[3500]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3501]! } - public var Wallpaper_Set: String { return self._s[3502]! } - public var Passport_Identity_Translations: String { return self._s[3504]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3499]! } + public var Tour_Title2: String { return self._s[3500]! } + public var Conversation_FileOpenIn: String { return self._s[3501]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3502]! } + public var Wallpaper_Set: String { return self._s[3503]! } + public var Passport_Identity_Translations: String { return self._s[3505]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3505]!, self._r[3505]!, [_0]) + return formatWithArgumentRanges(self._s[3506]!, self._r[3506]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[3506]! } + public var Channel_LeaveChannel: String { return self._s[3507]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3507]!, self._r[3507]!, [_1]) + return formatWithArgumentRanges(self._s[3508]!, self._r[3508]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3509]! } - public var PhotoEditor_HighlightsTint: String { return self._s[3510]! } - public var Passport_Email_Delete: String { return self._s[3511]! } - public var Conversation_Mute: String { return self._s[3513]! } - public var Channel_AddBotAsAdmin: String { return self._s[3514]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[3516]! } - public var Channel_Management_LabelOwner: String { return self._s[3518]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3510]! } + public var PhotoEditor_HighlightsTint: String { return self._s[3511]! } + public var Passport_Email_Delete: String { return self._s[3512]! } + public var Conversation_Mute: String { return self._s[3514]! } + public var Channel_AddBotAsAdmin: String { return self._s[3515]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[3517]! } + public var Channel_Management_LabelOwner: String { return self._s[3519]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3519]!, self._r[3519]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3520]!, self._r[3520]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[3520]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[3521]! } - public var Common_No: String { return self._s[3522]! } - public var Weekday_Sunday: String { return self._s[3523]! } - public var Notification_Reply: String { return self._s[3524]! } - public var Conversation_ViewMessage: String { return self._s[3525]! } + public var Calls_CallTabDescription: String { return self._s[3521]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[3522]! } + public var Common_No: String { return self._s[3523]! } + public var Weekday_Sunday: String { return self._s[3524]! } + public var Notification_Reply: String { return self._s[3525]! } + public var Conversation_ViewMessage: String { return self._s[3526]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3526]!, self._r[3526]!, [_0]) - } - public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3527]!, self._r[3527]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3528]! } - public var Message_PinnedDocumentMessage: String { return self._s[3529]! } - public var DialogList_TabTitle: String { return self._s[3531]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[3532]! } - public var Passport_FieldEmail: String { return self._s[3533]! } - public var Conversation_UnpinMessageAlert: String { return self._s[3534]! } - public var Passport_Address_TypeBankStatement: String { return self._s[3535]! } - public var Passport_Identity_ExpiryDate: String { return self._s[3536]! } - public var Privacy_Calls_P2P: String { return self._s[3537]! } + public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3528]!, self._r[3528]!, [_0]) + } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3529]! } + public var Message_PinnedDocumentMessage: String { return self._s[3530]! } + public var DialogList_TabTitle: String { return self._s[3532]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[3533]! } + public var Passport_FieldEmail: String { return self._s[3534]! } + public var Conversation_UnpinMessageAlert: String { return self._s[3535]! } + public var Passport_Address_TypeBankStatement: String { return self._s[3536]! } + public var Passport_Identity_ExpiryDate: String { return self._s[3537]! } + public var Privacy_Calls_P2P: String { return self._s[3538]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3539]!, self._r[3539]!, [_0]) + return formatWithArgumentRanges(self._s[3540]!, self._r[3540]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[3540]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[3541]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3541]!, self._r[3541]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3542]!, self._r[3542]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[3542]! } - public var EnterPasscode_ChangeTitle: String { return self._s[3543]! } - public var Passport_InfoText: String { return self._s[3544]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3545]! } + public var Stickers_ClearRecent: String { return self._s[3543]! } + public var EnterPasscode_ChangeTitle: String { return self._s[3544]! } + public var Passport_InfoText: String { return self._s[3545]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3546]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3546]!, self._r[3546]!, [_0]) + return formatWithArgumentRanges(self._s[3547]!, self._r[3547]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3547]!, self._r[3547]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3548]!, self._r[3548]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3548]! } - public var VoiceOver_Navigation_Compose: String { return self._s[3549]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[3550]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[3552]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3553]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3549]! } + public var VoiceOver_Navigation_Compose: String { return self._s[3550]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[3551]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[3553]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3554]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3554]!, self._r[3554]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3555]!, self._r[3555]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3556]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3557]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3558]!, self._r[3558]!, [_0]) + return formatWithArgumentRanges(self._s[3559]!, self._r[3559]!, [_0]) } - public var DialogList_Unread: String { return self._s[3559]! } + public var DialogList_Unread: String { return self._s[3560]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3560]!, self._r[3560]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3561]!, self._r[3561]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[3561]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[3562]! } + public var User_DeletedAccount: String { return self._s[3562]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[3563]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3563]!, self._r[3563]!, [_0]) + return formatWithArgumentRanges(self._s[3564]!, self._r[3564]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[3564]! } - public var SharedMedia_CategoryMedia: String { return self._s[3565]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[3566]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[3567]! } - public var Watch_ChatList_Compose: String { return self._s[3568]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[3569]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[3570]! } - public var Watch_Microphone_Access: String { return self._s[3571]! } - public var Group_Setup_HistoryHeader: String { return self._s[3572]! } - public var Map_SetThisLocation: String { return self._s[3573]! } - public var Activity_UploadingPhoto: String { return self._s[3574]! } - public var Conversation_Edit: String { return self._s[3576]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[3577]! } - public var Login_TermsOfServiceDecline: String { return self._s[3578]! } - public var Message_PinnedContactMessage: String { return self._s[3579]! } + public var UserInfo_NotificationsDefault: String { return self._s[3565]! } + public var SharedMedia_CategoryMedia: String { return self._s[3566]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[3567]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[3568]! } + public var Watch_ChatList_Compose: String { return self._s[3569]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[3570]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[3571]! } + public var Watch_Microphone_Access: String { return self._s[3572]! } + public var Group_Setup_HistoryHeader: String { return self._s[3573]! } + public var Map_SetThisLocation: String { return self._s[3574]! } + public var Activity_UploadingPhoto: String { return self._s[3575]! } + public var Conversation_Edit: String { return self._s[3577]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[3578]! } + public var Login_TermsOfServiceDecline: String { return self._s[3579]! } + public var Message_PinnedContactMessage: String { return self._s[3580]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3580]!, self._r[3580]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3581]!, self._r[3581]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3581]!, self._r[3581]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[3582]!, self._r[3582]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[3582]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[3584]! } + public var Appearance_LargeEmoji: String { return self._s[3583]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[3585]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3585]!, self._r[3585]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3586]!, self._r[3586]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[3586]! } - public var Message_PinnedPhotoMessage: String { return self._s[3587]! } - public var Passport_FieldPhone: String { return self._s[3588]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3589]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[3590]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[3592]! } - public var Conversation_Call: String { return self._s[3593]! } - public var Common_TakePhoto: String { return self._s[3595]! } - public var Group_EditAdmin_RankTitle: String { return self._s[3596]! } - public var Channel_NotificationLoading: String { return self._s[3597]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[3587]! } + public var Message_PinnedPhotoMessage: String { return self._s[3588]! } + public var Passport_FieldPhone: String { return self._s[3589]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3590]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[3591]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[3593]! } + public var Conversation_Call: String { return self._s[3594]! } + public var Common_TakePhoto: String { return self._s[3596]! } + public var Group_EditAdmin_RankTitle: String { return self._s[3597]! } + public var Channel_NotificationLoading: String { return self._s[3598]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3598]!, self._r[3598]!, [_0]) - } - public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3599]!, self._r[3599]!, [_0]) } + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_0]) + } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_1]) + return formatWithArgumentRanges(self._s[3601]!, self._r[3601]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[3601]! } + public var Permissions_SiriTitle_v0: String { return self._s[3602]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3602]!, self._r[3602]!, [_0]) - } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3603]!, self._r[3603]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[3604]! } - public var Common_edit: String { return self._s[3605]! } - public var PrivacySettings_AuthSessions: String { return self._s[3606]! } - public var Month_ShortJune: String { return self._s[3607]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3608]! } - public var Call_ReportSend: String { return self._s[3609]! } - public var Watch_LastSeen_JustNow: String { return self._s[3610]! } - public var Notifications_MessageNotifications: String { return self._s[3611]! } - public var WallpaperSearch_ColorGreen: String { return self._s[3612]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[3614]! } - public var Group_Status: String { return self._s[3615]! } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3604]!, self._r[3604]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[3605]! } + public var Common_edit: String { return self._s[3606]! } + public var PrivacySettings_AuthSessions: String { return self._s[3607]! } + public var Month_ShortJune: String { return self._s[3608]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3609]! } + public var Call_ReportSend: String { return self._s[3610]! } + public var Watch_LastSeen_JustNow: String { return self._s[3611]! } + public var Notifications_MessageNotifications: String { return self._s[3612]! } + public var WallpaperSearch_ColorGreen: String { return self._s[3613]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[3615]! } + public var Group_Status: String { return self._s[3616]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3616]!, self._r[3616]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3617]!, self._r[3617]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[3617]! } - public var ShareMenu_ShareTo: String { return self._s[3618]! } - public var Conversation_Moderate_Ban: String { return self._s[3619]! } + public var TextFormat_AddLinkTitle: String { return self._s[3618]! } + public var ShareMenu_ShareTo: String { return self._s[3619]! } + public var Conversation_Moderate_Ban: String { return self._s[3620]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3620]!, self._r[3620]!, [_0]) + return formatWithArgumentRanges(self._s[3621]!, self._r[3621]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[3621]! } - public var Map_LiveLocationFor8Hours: String { return self._s[3622]! } + public var SharedMedia_ViewInChat: String { return self._s[3622]! } + public var Map_LiveLocationFor8Hours: String { return self._s[3623]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3623]!, self._r[3623]!, [_1]) + return formatWithArgumentRanges(self._s[3624]!, self._r[3624]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3624]!, self._r[3624]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3625]!, self._r[3625]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3626]!, self._r[3626]!, [_0]) + return formatWithArgumentRanges(self._s[3627]!, self._r[3627]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[3627]! } - public var Appearance_ReduceMotion: String { return self._s[3628]! } + public var Map_OpenInHereMaps: String { return self._s[3628]! } + public var Appearance_ReduceMotion: String { return self._s[3629]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3630]!, self._r[3630]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[3630]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[3631]! } - public var PhotoEditor_Skip: String { return self._s[3632]! } - public func Media_ShareItem(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[3631]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[3632]! } + public var PhotoEditor_Skip: String { return self._s[3633]! } + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_SelectedMessages(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedContacts(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_StickerCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, _1, _2) } - public func MuteFor_Days(_ value: Int32) -> String { + public func Invitation_Members(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedLocations(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteFor_Hours(_ value: Int32) -> String { + public func ForwardedPolls(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Months(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(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 { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareVideo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, _1, _2) } - public func UserCount(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Days(_ value: Int32) -> String { + public func Call_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedPhotos(_ value: Int32) -> String { + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public func SharedMedia_Generic(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, _2, _1, _3) + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, _1, _2) } - public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + public func MuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) @@ -4248,434 +4247,436 @@ public final class PresentationStrings { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func MuteFor_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) } - public func Passport_Scans(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedMessages(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedVideos(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func ForwardedStickers(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Hours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Weeks(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_Exceptions(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_HoursAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSimple(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func ForwardedGifs(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Invitation_Members(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Days(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Minutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreExtended(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortMinutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_File(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(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 = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) } public func SharedMedia_Video(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortHours(_ value: Int32) -> String { + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Media_ShareVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_AddStickerCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Weeks(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_UserInfo_Mute(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) } public func QuickSend_Photos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, _1, _2) + public func InviteText_ContactsCountText(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) } public func Call_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func Notification_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) } - public func Map_ETAMinutes(_ value: Int32) -> String { + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func StickerPack_StickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPolls(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusOnline(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Map_ETAHours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessagePoll_VotedCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_SharePhoto(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(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[45 * 6 + Int(form.rawValue)]!, _1, _2) } public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) } public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessagePoll_VotedCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_Minutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_SelectedMessages(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedFiles(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPhotos(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, _1, _2) } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) - } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Conversation_StatusMembers(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Hours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAudios(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortDays(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_SelectedChats(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) } public func SharedMedia_Link(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_SharePhoto(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func MessageTimer_Hours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Months(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Seconds(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Hours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAHours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) } public func ForwardedVideoMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_File(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideos(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func LastSeen_HoursAgo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Contacts_ImportersCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedStickers(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func AttachmentMenu_SendItem(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedLocations(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortDays(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareItem(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedGifs(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAudios(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_ShortSeconds(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_Exceptions(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MessageTimer_ShortHours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusMembers(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_Days(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Passport_Scans(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + } + public func UserCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) } public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAMinutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramUI/TelegramUI/ChatController.swift b/submodules/TelegramUI/TelegramUI/ChatController.swift index 9f422aa62e..9ae957ac83 100644 --- a/submodules/TelegramUI/TelegramUI/ChatController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatController.swift @@ -1461,44 +1461,38 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G strongSelf.sendScheduledMessagesNow(messageIds) } }, editScheduledMessagesTime: { [weak self] messageIds in - if let strongSelf = self { + if let strongSelf = self, let messageId = messageIds.first { let mode: ChatScheduleTimeControllerMode if case let .peer(peerId) = strongSelf.presentationInterfaceState.chatLocation, peerId == strongSelf.context.account.peerId { mode = .reminders } else { mode = .scheduledMessages } - let controller = ChatScheduleTimeController(context: strongSelf.context, mode: mode, completion: { [weak self] scheduleTime in - if let strongSelf = self, let messageId = messageIds.first { - let signal = (strongSelf.context.account.postbox.transaction { transaction -> Message? in - return transaction.getMessage(messageId) - } - |> introduceError(RequestEditMessageError.self) - |> mapToSignal({ message -> Signal in - if let message = message { - var entities: TextEntitiesMessageAttribute? - for attribute in message.attributes { - if let attribute = attribute as? TextEntitiesMessageAttribute { - entities = attribute - break - } - } - return requestEditMessage(account: strongSelf.context.account, messageId: messageId, text: message.text, media: .keep - , entities: entities, disableUrlPreview: false, scheduleTime: scheduleTime) - } else { - return .complete() - } - })) - - strongSelf.editMessageDisposable.set((signal |> deliverOnMainQueue).start(next: { result in - - }, error: { error in - - })) + + let _ = (strongSelf.context.account.postbox.transaction { transaction -> Message? in + return transaction.getMessage(messageId) + } |> deliverOnMainQueue).start(next: { [weak self] message in + guard let strongSelf = self, let message = message else { + return } + let controller = ChatScheduleTimeController(context: strongSelf.context, mode: mode, currentTime: message.timestamp, completion: { [weak self] scheduleTime in + if let strongSelf = self { + var entities: TextEntitiesMessageAttribute? + for attribute in message.attributes { + if let attribute = attribute as? TextEntitiesMessageAttribute { + entities = attribute + break + } + } + let signal = requestEditMessage(account: strongSelf.context.account, messageId: messageId, text: message.text, media: .keep, entities: entities, disableUrlPreview: false, scheduleTime: scheduleTime) + strongSelf.editMessageDisposable.set((signal |> deliverOnMainQueue).start(next: { result in + }, error: { error in + })) + } + }) + strongSelf.chatDisplayNode.dismissInput() + strongSelf.present(controller, in: .window(.root)) }) - strongSelf.chatDisplayNode.dismissInput() - strongSelf.present(controller, in: .window(.root)) } }, performTextSelectionAction: { [weak self] _, text, action in guard let strongSelf = self else { @@ -1638,8 +1632,8 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self.reportIrrelvantGeoNoticePromise.set(.single(nil)) } - if !isScheduledMessages { - hasScheduledMessages = context.account.viewTracker.aroundMessageHistoryViewForLocation(chatLocation, index: .upperBound, anchorIndex: .upperBound, count: 100, fixedCombinedReadStates: nil, tagMask: nil, excludeNamespaces: [Namespaces.Message.Cloud, Namespaces.Message.Local], orderStatistics: []) + if !isScheduledMessages && peerId.namespace != Namespaces.Peer.SecretChat { + hasScheduledMessages = context.account.viewTracker.scheduledMessagesViewForLocation(chatLocation) |> map { view, _, _ in return !view.entries.isEmpty } @@ -5299,7 +5293,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G } private func sendScheduledMessagesNow(_ messageId: [MessageId]) { - let _ = sendScheduledMessageNow(account: self.context.account, messageId: messageId.first!).start() + let _ = sendScheduledMessageNowInteractively(postbox: self.context.account.postbox, messageId: messageId.first!).start() } private func sendMessages(_ messages: [EnqueueMessage], commit: Bool = false) { diff --git a/submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift b/submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift index 96dc0604a6..4a6914766f 100644 --- a/submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatEmptyNode.swift @@ -33,7 +33,7 @@ private final class ChatEmptyNodeRegularChatContent: ASDisplayNode, ChatEmptyNod self.currentStrings = interfaceState.strings let serviceColor = serviceMessageColorComponents(theme: interfaceState.theme, wallpaper: interfaceState.chatWallpaper) - self.textNode.attributedText = NSAttributedString(string: interfaceState.strings.Conversation_EmptyPlaceholder, font: messageFont, textColor: serviceColor.primaryText) + self.textNode.attributedText = NSAttributedString(string: interfaceState.isScheduledMessages ? interfaceState.strings.ScheduledMessages_EmptyPlaceholder : interfaceState.strings.Conversation_EmptyPlaceholder, font: messageFont, textColor: serviceColor.primaryText) } let insets = UIEdgeInsets(top: 6.0, left: 10.0, bottom: 6.0, right: 10.0) diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift index 94512dcb1d..ae12d1ee33 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift @@ -30,7 +30,6 @@ func chatHistoryViewForLocation(_ location: ChatHistoryLocationInput, account: A if scheduled { var preloaded = false var fadeIn = false - let count = 100 return account.viewTracker.scheduledMessagesViewForLocation(chatLocation) |> map { view, updateType, initialData -> ChatHistoryViewUpdate in let (cachedData, cachedDataMessages, readStateData) = extractAdditionalData(view: view, chatLocation: chatLocation) diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift index c27f4832ec..596232963e 100644 --- a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift +++ b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateContextMenus.swift @@ -382,14 +382,18 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: } if data.messageActions.options.contains(.sendScheduledNow) { - actions.append(.action(ContextMenuActionItem(text: chatPresentationInterfaceState.strings.ScheduledMessages_SendNow, icon: { _ in return nil }, action: { _, f in + actions.append(.action(ContextMenuActionItem(text: chatPresentationInterfaceState.strings.ScheduledMessages_SendNow, icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Resend"), color: theme.actionSheet.primaryTextColor) + }, action: { _, f in controllerInteraction.sendScheduledMessagesNow(selectAll ? messages.map { $0.id } : [message.id]) f(.dismissWithoutContent) }))) } if data.messageActions.options.contains(.editScheduledTime) { - actions.append(.action(ContextMenuActionItem(text: chatPresentationInterfaceState.strings.ScheduledMessages_EditTime, icon: { _ in return nil }, action: { _, f in + actions.append(.action(ContextMenuActionItem(text: chatPresentationInterfaceState.strings.ScheduledMessages_EditTime, icon: { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Schedule"), color: theme.actionSheet.primaryTextColor) + }, action: { _, f in controllerInteraction.editScheduledMessagesTime(selectAll ? messages.map { $0.id } : [message.id]) f(.dismissWithoutContent) }))) diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift b/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift index 8d36e6ca21..0af69211ca 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift @@ -329,13 +329,7 @@ public final class ChatMessageItem: ListViewItem, CustomStringConvertible { self.effectiveAuthorId = effectiveAuthor?.id - let timestamp: Int32 - if let scheduleTime = content.firstMessage.scheduleTime { - timestamp = scheduleTime - } else { - timestamp = content.index.timestamp - } - self.header = ChatMessageDateHeader(timestamp: timestamp, scheduled: associatedData.isScheduledMessages, presentationData: presentationData, context: context, action: { timestamp in + self.header = ChatMessageDateHeader(timestamp: content.index.timestamp, scheduled: associatedData.isScheduledMessages, presentationData: presentationData, context: context, action: { timestamp in var calendar = NSCalendar.current calendar.timeZone = TimeZone(abbreviation: "UTC")! let date = Date(timeIntervalSince1970: TimeInterval(timestamp)) diff --git a/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift index d99c00c5b1..2b5b3ebc45 100644 --- a/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift @@ -105,7 +105,7 @@ class ChatScheduleTimeControllerNode: ViewControllerTracingNode, UIScrollViewDel self.contentContainerNode.addSubnode(self.doneButton) self.pickerView.timeZone = TimeZone.current - self.pickerView.minuteInterval = 5 + self.pickerView.minuteInterval = 1 self.pickerView.setValue(self.presentationData.theme.actionSheet.primaryTextColor, forKey: "textColor") self.contentContainerNode.view.addSubview(self.pickerView) @@ -265,8 +265,11 @@ class ChatScheduleTimeControllerNode: ViewControllerTracingNode, UIScrollViewDel insets.top = max(10.0, insets.top) let bottomInset: CGFloat = 10.0 + cleanInsets.bottom - let titleAreaHeight: CGFloat = 54.0 - let contentHeight = titleAreaHeight + bottomInset + 285.0 + let titleHeight: CGFloat = 54.0 + var contentHeight = titleHeight + bottomInset + 52.0 + 17.0 + let pickerHeight: CGFloat = min(216.0, layout.size.height - contentHeight) + contentHeight = titleHeight + bottomInset + 52.0 + 17.0 + pickerHeight + let width = horizontalContainerFillingSizeForLayout(layout: layout, sideInset: layout.safeInsets.left) let sideInset = floor((layout.size.width - width) / 2.0) @@ -281,11 +284,11 @@ class ChatScheduleTimeControllerNode: ViewControllerTracingNode, UIScrollViewDel transition.updateFrame(node: self.wrappingScrollNode, frame: CGRect(origin: CGPoint(), size: layout.size)) transition.updateFrame(node: self.dimNode, frame: CGRect(origin: CGPoint(), size: layout.size)) - let titleSize = self.titleNode.measure(CGSize(width: width, height: titleAreaHeight)) + let titleSize = self.titleNode.measure(CGSize(width: width, height: titleHeight)) let titleFrame = CGRect(origin: CGPoint(x: floor((contentFrame.width - titleSize.width) / 2.0), y: 16.0), size: titleSize) transition.updateFrame(node: self.titleNode, frame: titleFrame) - let cancelSize = self.cancelButton.measure(CGSize(width: width, height: titleAreaHeight)) + let cancelSize = self.cancelButton.measure(CGSize(width: width, height: titleHeight)) let cancelFrame = CGRect(origin: CGPoint(x: 16.0, y: 16.0), size: cancelSize) transition.updateFrame(node: self.cancelButton, frame: cancelFrame) @@ -293,9 +296,9 @@ class ChatScheduleTimeControllerNode: ViewControllerTracingNode, UIScrollViewDel let buttonHeight = self.doneButton.updateLayout(width: contentFrame.width - buttonInset * 2.0, transition: transition) transition.updateFrame(node: self.doneButton, frame: CGRect(x: buttonInset, y: contentHeight - buttonHeight - insets.bottom - 10.0, width: contentFrame.width, height: buttonHeight)) - self.pickerView.frame = CGRect(origin: CGPoint(x: 0.0, y: 54.0), size: CGSize(width: contentFrame.width, height: 216.0)) + self.pickerView.frame = CGRect(origin: CGPoint(x: 0.0, y: 54.0), size: CGSize(width: contentFrame.width, height: pickerHeight)) transition.updateFrame(node: self.contentContainerNode, frame: contentContainerFrame) - transition.updateFrame(node: self.separatorNode, frame: CGRect(origin: CGPoint(x: 0.0, y: titleAreaHeight), size: CGSize(width: contentContainerFrame.size.width, height: UIScreenPixel))) + transition.updateFrame(node: self.separatorNode, frame: CGRect(origin: CGPoint(x: 0.0, y: titleHeight), size: CGSize(width: contentContainerFrame.size.width, height: UIScreenPixel))) } } diff --git a/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift b/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift index 498479162c..232b7875c7 100644 --- a/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift +++ b/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift @@ -10,6 +10,15 @@ import MusicAlbumArtResources private enum PeerMessagesMediaPlaylistLoadAnchor { case messageId(MessageId) case index(MessageIndex) + + var id: MessageId { + switch self { + case let .messageId(id): + return id + case let .index(index): + return index.id + } + } } private enum PeerMessagesMediaPlaylistNavigation { @@ -477,6 +486,14 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { private func loadItem(anchor: PeerMessagesMediaPlaylistLoadAnchor, navigation: PeerMessagesMediaPlaylistNavigation) { self.loadingItem = true self.updateState() + + let namespaces: HistoryViewNamespaces + if Namespaces.Message.allScheduled.contains(anchor.id.namespace) { + namespaces = .just(Namespaces.Message.allScheduled) + } else { + namespaces = .not(Namespaces.Message.allScheduled) + } + switch anchor { case let .messageId(messageId): if case let .messages(peerId, tagMask, _) = self.messagesLocation { @@ -486,7 +503,8 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { guard let message = message else { return .single(nil) } - return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(message.index), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, excludeNamespaces: [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal], orderStatistics: []) + + return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(message.index), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, namespaces: namespaces, orderStatistics: []) |> mapToSignal { view -> Signal<(Message, [Message])?, NoError> in if let (message, aroundMessages, _) = navigatedMessageFromView(view.0, anchorIndex: message.index, position: .exact) { return .single((message, aroundMessages)) @@ -560,7 +578,7 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { } let historySignal = inputIndex |> mapToSignal { inputIndex -> Signal<(Message, [Message])?, NoError> in - return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(inputIndex), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, excludeNamespaces: [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal], orderStatistics: []) + return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(inputIndex), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, namespaces: namespaces, orderStatistics: []) |> mapToSignal { view -> Signal<(Message, [Message])?, NoError> in let position: NavigatedMessageFromViewPosition switch navigation { @@ -590,7 +608,7 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { } else { viewIndex = .lowerBound } - return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: viewIndex, count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, excludeNamespaces: [Namespaces.Message.ScheduledCloud, Namespaces.Message.ScheduledLocal], orderStatistics: []) + return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: viewIndex, count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, namespaces: namespaces, orderStatistics: []) |> mapToSignal { view -> Signal<(Message, [Message])?, NoError> in let position: NavigatedMessageFromViewPosition switch navigation { diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping index f91d4cd7d8..dfbb09288b 100644 Binary files a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping differ