diff --git a/SiriIntents/IntentMessages.swift b/SiriIntents/IntentMessages.swift index d8a8831fd6..f8add17d11 100644 --- a/SiriIntents/IntentMessages.swift +++ b/SiriIntents/IntentMessages.swift @@ -37,7 +37,7 @@ func unreadMessages(account: Account) -> Signal<[INMessage], NoError> { |> mapToSignal { view -> Signal<[INMessage], NoError> in var signals: [Signal<[INMessage], NoError>] = [] for entry in view.0.entries { - if case let .MessageEntry(index, _, readState, notificationSettings, _, _, _, _) = entry { + if case let .MessageEntry(index, _, readState, notificationSettings, _, _, _, _, _) = entry { if index.messageIndex.id.peerId.namespace != Namespaces.Peer.CloudUser { continue } diff --git a/Telegram-iOS/en.lproj/Localizable.strings b/Telegram-iOS/en.lproj/Localizable.strings index 51780c7e60..4864b8b265 100644 --- a/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram-iOS/en.lproj/Localizable.strings @@ -5169,3 +5169,5 @@ Any member of this group will be able to see messages in the channel."; "AuthSessions.OtherDevices" = "The official Telegram App is available for iPhone, iPad, Android, macOS, Windows and Linux. [Learn More]()"; "AuthSessions.AddDevice.UrlLoginHint" = "This code can be used to allow someone to log in to your Telegram account.\n\nTo confirm Telegram login, please go to Settings > Devices > Scan QR and scan the code."; + +"ChatContextMenu.TextSelectionTip" = "Hold a word, then move cursor to select more| text to copy."; diff --git a/submodules/ChatListUI/Sources/ChatListController.swift b/submodules/ChatListUI/Sources/ChatListController.swift index 882937f766..d11fe58613 100644 --- a/submodules/ChatListUI/Sources/ChatListController.swift +++ b/submodules/ChatListUI/Sources/ChatListController.swift @@ -1053,7 +1053,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, var sourceRect = selectedNode.view.superview!.convert(selectedNode.frame, to: sourceView) sourceRect.size.height -= UIScreenPixel switch item.content { - case let .peer(_, peer, _, _, _, _, _, _, _, _, _): + case let .peer(_, peer, _, _, _, _, _, _, _, _, _, _): if peer.peerId.namespace != Namespaces.Peer.SecretChat { let chatController = self.context.sharedContext.makeChatController(context: self.context, chatLocation: .peer(peer.peerId), subject: nil, botStart: nil, mode: .standard(previewing: true)) chatController.canReadHistory.set(false) diff --git a/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift b/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift index 0d8e4941ac..919ebc9f5f 100644 --- a/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift @@ -444,7 +444,7 @@ public enum ChatListSearchEntry: Comparable, Identifiable { } }) case let .message(message, peer, readState, presentationData): - return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(message: message, peer: peer, combinedReadState: readState, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: true, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) + return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(message: message, peer: peer, combinedReadState: readState, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: true, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) case let .addContact(phoneNumber, theme, strings): return ContactsAddItem(theme: theme, strings: strings, phoneNumber: phoneNumber, header: ChatListSearchItemHeader(type: .phoneNumber, theme: theme, strings: strings, actionTitle: nil, action: nil), action: { interaction.addContact(phoneNumber) @@ -1213,7 +1213,7 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo bounds = selectedItemNode.bounds } switch item.content { - case let .peer(message, peer, _, _, _, _, _, _, _, _, _): + case let .peer(message, peer, _, _, _, _, _, _, _, _, _, _): return (selectedItemNode.view, bounds, message?.id ?? peer.peerId) case let .groupReference(groupId, _, _, _, _): return (selectedItemNode.view, bounds, groupId) diff --git a/submodules/ChatListUI/Sources/Node/ChatListItem.swift b/submodules/ChatListUI/Sources/Node/ChatListItem.swift index 2b033d64a4..38226faa3b 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListItem.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListItem.swift @@ -20,12 +20,12 @@ import ChatListSearchItemNode import ContextUI public enum ChatListItemContent { - case peer(message: Message?, peer: RenderedPeer, combinedReadState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, embeddedState: PeerChatListEmbeddedInterfaceState?, inputActivities: [(Peer, PeerInputActivity)]?, isAd: Bool, ignoreUnreadBadge: Bool, displayAsMessage: Bool) + case peer(message: Message?, peer: RenderedPeer, combinedReadState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, embeddedState: PeerChatListEmbeddedInterfaceState?, inputActivities: [(Peer, PeerInputActivity)]?, isAd: Bool, ignoreUnreadBadge: Bool, displayAsMessage: Bool, hasFailedMessages: Bool) case groupReference(groupId: PeerGroupId, peers: [ChatListGroupReferencePeer], message: Message?, unreadState: PeerGroupUnreadCountersCombinedSummary, hiddenByDefault: Bool) public var chatLocation: ChatLocation? { switch self { - case let .peer(_, peer, _, _, _, _, _, _, _, _, _): + case let .peer(_, peer, _, _, _, _, _, _, _, _, _, _): return .peer(peer.peerId) case .groupReference: return nil @@ -38,7 +38,7 @@ public class ChatListItem: ListViewItem, ChatListSearchItemNeighbour { let context: AccountContext let peerGroupId: PeerGroupId let index: ChatListIndex - let content: ChatListItemContent + public let content: ChatListItemContent let editing: Bool let hasActiveRevealControls: Bool let selected: Bool @@ -122,7 +122,7 @@ public class ChatListItem: ListViewItem, ChatListSearchItemNeighbour { public func selected(listView: ListView) { switch self.content { - case let .peer(message, peer, _, _, _, _, _, _, isAd, _, _): + case let .peer(message, peer, _, _, _, _, _, _, isAd, _, _, _): if let message = message, let peer = peer.peer { self.interaction.messageSelected(peer, message, isAd) } else if let peer = peer.peer { @@ -522,7 +522,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var displayAsMessage = false var enablePreview = true switch item.content { - case let .peer(message, peerValue, _, _, _, _, _, _, _, _, displayAsMessageValue): + case let .peer(message, peerValue, _, _, _, _, _, _, _, _, displayAsMessageValue, _): displayAsMessage = displayAsMessageValue if displayAsMessage, let author = message?.author as? TelegramUser { peer = author @@ -673,11 +673,12 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let isPeerGroup: Bool let isAd: Bool let displayAsMessage: Bool + let hasFailedMessages: Bool var groupHiddenByDefault = false switch item.content { - case let .peer(messageValue, peerValue, combinedReadStateValue, notificationSettingsValue, peerPresenceValue, summaryInfoValue, embeddedStateValue, inputActivitiesValue, isAdValue, ignoreUnreadBadge, displayAsMessageValue): + case let .peer(messageValue, peerValue, combinedReadStateValue, notificationSettingsValue, peerPresenceValue, summaryInfoValue, embeddedStateValue, inputActivitiesValue, isAdValue, ignoreUnreadBadge, displayAsMessageValue, hasFailedMessagesValue): message = messageValue contentPeer = .chat(peerValue) combinedReadState = combinedReadStateValue @@ -698,6 +699,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { isPeerGroup = false isAd = isAdValue displayAsMessage = displayAsMessageValue + hasFailedMessages = hasFailedMessagesValue case let .groupReference(_, peers, messageValue, unreadState, hiddenByDefault): if let _ = messageValue, !peers.isEmpty { contentPeer = .chat(peers[0].peer) @@ -717,6 +719,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { peerPresence = nil isAd = false displayAsMessage = false + hasFailedMessages = false } if let messageValue = message { @@ -975,7 +978,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { if message.flags.isSending && !message.isSentOrAcknowledged { statusState = .clock(PresentationResourcesChatList.clockFrameImage(item.presentationData.theme), PresentationResourcesChatList.clockMinImage(item.presentationData.theme)) } else if message.id.peerId != account.peerId { - if message.flags.contains(.Failed) { + if hasFailedMessages { statusState = .failed(item.presentationData.theme.chatList.failedFillColor, item.presentationData.theme.chatList.failedForegroundColor) } else { if let combinedReadState = combinedReadState, combinedReadState.isOutgoingMessageIndexRead(message.index) { @@ -1061,7 +1064,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var credibilityIconOffset: CGFloat = 0.0 if displayAsMessage { switch item.content { - case let .peer(message, _, _, _, _, _, _, _, _, _, _): + case let .peer(message, _, _, _, _, _, _, _, _, _, _, _): if let peer = message?.author { if peer.isScam { currentCredibilityIconImage = PresentationResourcesChatList.scamIcon(item.presentationData.theme, type: .regular) @@ -1153,7 +1156,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let peerRevealOptions: [ItemListRevealOption] let peerLeftRevealOptions: [ItemListRevealOption] switch item.content { - case let .peer(_, renderedPeer, _, _, presence, _ ,_ ,_, _, _, displayAsMessage): + case let .peer(_, renderedPeer, _, _, presence, _ ,_ ,_, _, _, displayAsMessage, _): if !displayAsMessage, let peer = renderedPeer.peer as? TelegramUser, let presence = presence as? TelegramUserPresence, !isServicePeer(peer) && !peer.flags.contains(.isSupport) && peer.id != item.context.account.peerId { let relativeStatus = relativeUserPresenceStatus(presence, relativeTo: timestamp) if case .online = relativeStatus { diff --git a/submodules/ChatListUI/Sources/Node/ChatListNode.swift b/submodules/ChatListUI/Sources/Node/ChatListNode.swift index 425ea4b2b2..ad2e877601 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNode.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNode.swift @@ -141,10 +141,10 @@ public struct ChatListNodeState: Equatable { private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatListNodeInteraction, peerGroupId: PeerGroupId, mode: ChatListNodeMode, entries: [ChatListNodeViewTransitionInsertEntry]) -> [ListViewInsertItem] { return entries.map { entry -> ListViewInsertItem in switch entry.entry { - case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, isAd): + case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, isAd, hasFailedMessages): switch mode { case .chatList: - return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) case let .peers(filter): let itemPeer = peer.chatMainPeer var chatPeer: Peer? @@ -222,10 +222,10 @@ private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatL private func mappedUpdateEntries(context: AccountContext, nodeInteraction: ChatListNodeInteraction, peerGroupId: PeerGroupId, mode: ChatListNodeMode, entries: [ChatListNodeViewTransitionUpdateEntry]) -> [ListViewUpdateItem] { return entries.map { entry -> ListViewUpdateItem in switch entry.entry { - case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, isAd): + case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, isAd, hasFailedMessages): switch mode { case .chatList: - return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) case let .peers(filter): let itemPeer = peer.chatMainPeer var chatPeer: Peer? @@ -549,7 +549,7 @@ public final class ChatListNode: ListView { let (rawEntries, isLoading) = chatListNodeEntriesForView(update.view, state: state, savedMessagesPeer: savedMessagesPeer, hideArchivedFolderByDefault: hideArchivedFolderByDefault, displayArchiveIntro: displayArchiveIntro, mode: mode) let entries = rawEntries.filter { entry in switch entry { - case let .PeerEntry(_, _, _, _, _, _, peer, _, _, _, _, _, _, _): + case let .PeerEntry(_, _, _, _, _, _, peer, _, _, _, _, _, _, _, _): switch mode { case .chatList: return true @@ -654,7 +654,7 @@ public final class ChatListNode: ListView { var didIncludeHiddenByDefaultArchive = false if let previous = previousView { for entry in previous.filteredEntries { - if case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _) = entry { + if case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _, _) = entry { if index.pinningIndex != nil { previousPinnedChats.append(index.messageIndex.id.peerId) } @@ -670,11 +670,11 @@ public final class ChatListNode: ListView { var doesIncludeArchive = false var doesIncludeHiddenByDefaultArchive = false for entry in processedView.filteredEntries { - if case let .PeerEntry(index, _, _, _, _, _, _, _, _ , _, _, _, _, _) = entry { - if index.pinningIndex != nil { - updatedPinnedChats.append(index.messageIndex.id.peerId) + if case let .PeerEntry(peerEntry) = entry { + if peerEntry.index.pinningIndex != nil { + updatedPinnedChats.append(peerEntry.index.messageIndex.id.peerId) } - if index.messageIndex.id.peerId == removingPeerId { + if peerEntry.index.messageIndex.id.peerId == removingPeerId { doesIncludeRemovingPeerId = true } } else if case let .GroupReferenceEntry(entry) = entry { @@ -749,7 +749,7 @@ public final class ChatListNode: ListView { continue } switch chatListView.filteredEntries[entryCount - i - 1] { - case let .PeerEntry(_, _, _, readState, notificationSettings, _, _, _, _, _, _, _, _, _): + case let .PeerEntry(_, _, _, readState, notificationSettings, _, _, _, _, _, _, _, _, _, _): if let readState = readState { let count = readState.count rawUnreadCount += count @@ -895,7 +895,7 @@ public final class ChatListNode: ListView { var referenceId: PinnedItemId? var beforeAll = false switch toEntry { - case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, isAd): + case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, isAd, _): if isAd { beforeAll = true } else { @@ -913,7 +913,7 @@ public final class ChatListNode: ListView { var itemId: PinnedItemId? switch fromEntry { - case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _): + case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _, _): itemId = .peer(index.messageIndex.id.peerId) /*case let .GroupReferenceEntry(_, _, groupId, _, _, _, _): itemId = .group(groupId)*/ @@ -1338,7 +1338,7 @@ public final class ChatListNode: ListView { continue } switch chatListView.filteredEntries[entryCount - i - 1] { - case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _): + case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _): if interaction.highlightedChatLocation?.location == ChatLocation.peer(peer.peerId) { current = (index, peer.peerId, entryCount - i - 1) break outer @@ -1371,10 +1371,10 @@ public final class ChatListNode: ListView { case .previous(unread: false), .next(unread: false): var target: (ChatListIndex, PeerId)? = nil if let current = current, entryCount > 1 { - if current.2 > 0, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 - 1] { + if current.2 > 0, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 - 1] { next = (index, peer.peerId) } - if current.2 <= entryCount - 2, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 + 1] { + if current.2 <= entryCount - 2, case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 + 1] { previous = (index, peer.peerId) } if case .previous = option { @@ -1383,7 +1383,7 @@ public final class ChatListNode: ListView { target = next } } else if entryCount > 0 { - if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _) = chatListView.filteredEntries[entryCount - 1] { + if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _, _, _) = chatListView.filteredEntries[entryCount - 1] { target = (index, peer.peerId) } } @@ -1402,7 +1402,7 @@ public final class ChatListNode: ListView { |> take(1) |> deliverOnMainQueue).start(next: { update in let entries = update.view.entries - if entries.count > index, case let .MessageEntry(index, _, _, _, _, renderedPeer, _, _) = entries[10 - index - 1] { + if entries.count > index, case let .MessageEntry(index, _, _, _, _, renderedPeer, _, _, _) = entries[10 - index - 1] { let location: ChatListNodeLocation = .scroll(index: index, sourceIndex: .absoluteLowerBound, scrollPosition: .center(.top), animated: true) self.setChatListLocation(location) self.peerSelected?(renderedPeer.peerId, false, false) @@ -1445,7 +1445,7 @@ public final class ChatListNode: ListView { continue } switch chatListView.filteredEntries[entryCount - i - 1] { - case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _): + case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _, _): return index default: break diff --git a/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift b/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift index b0da7f230d..1548b5a67f 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift @@ -13,14 +13,14 @@ enum ChatListNodeEntryId: Hashable { } enum ChatListNodeEntry: Comparable, Identifiable { - case PeerEntry(index: ChatListIndex, presentationData: ChatListPresentationData, message: Message?, readState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, peer: RenderedPeer, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, editing: Bool, hasActiveRevealControls: Bool, selected: Bool, inputActivities: [(Peer, PeerInputActivity)]?, isAd: Bool) + case PeerEntry(index: ChatListIndex, presentationData: ChatListPresentationData, message: Message?, readState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, peer: RenderedPeer, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, editing: Bool, hasActiveRevealControls: Bool, selected: Bool, inputActivities: [(Peer, PeerInputActivity)]?, isAd: Bool, hasFailedMessages: Bool) case HoleEntry(ChatListHole, theme: PresentationTheme) case GroupReferenceEntry(index: ChatListIndex, presentationData: ChatListPresentationData, groupId: PeerGroupId, peers: [ChatListGroupReferencePeer], message: Message?, editing: Bool, unreadState: PeerGroupUnreadCountersCombinedSummary, revealed: Bool, hiddenByDefault: Bool) case ArchiveIntro(presentationData: ChatListPresentationData) var sortIndex: ChatListIndex { switch self { - case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _): + case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _, _): return index case let .HoleEntry(hole, _): return ChatListIndex(pinningIndex: nil, messageIndex: hole.index) @@ -33,7 +33,7 @@ enum ChatListNodeEntry: Comparable, Identifiable { var stableId: ChatListNodeEntryId { switch self { - case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _): + case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _, _, _): return .PeerId(index.messageIndex.id.peerId.toInt64()) case let .HoleEntry(hole, _): return .Hole(Int64(hole.index.id.id)) @@ -50,9 +50,9 @@ enum ChatListNodeEntry: Comparable, Identifiable { static func ==(lhs: ChatListNodeEntry, rhs: ChatListNodeEntry) -> Bool { switch lhs { - case let .PeerEntry(lhsIndex, lhsPresentationData, lhsMessage, lhsUnreadCount, lhsNotificationSettings, lhsEmbeddedState, lhsPeer, lhsPresence, lhsSummaryInfo, lhsEditing, lhsHasRevealControls, lhsSelected, lhsInputActivities, lhsAd): + case let .PeerEntry(lhsIndex, lhsPresentationData, lhsMessage, lhsUnreadCount, lhsNotificationSettings, lhsEmbeddedState, lhsPeer, lhsPresence, lhsSummaryInfo, lhsEditing, lhsHasRevealControls, lhsSelected, lhsInputActivities, lhsAd, lhsHasFailedMessages): switch rhs { - case let .PeerEntry(rhsIndex, rhsPresentationData, rhsMessage, rhsUnreadCount, rhsNotificationSettings, rhsEmbeddedState, rhsPeer, rhsPresence, rhsSummaryInfo, rhsEditing, rhsHasRevealControls, rhsSelected, rhsInputActivities, rhsAd): + case let .PeerEntry(rhsIndex, rhsPresentationData, rhsMessage, rhsUnreadCount, rhsNotificationSettings, rhsEmbeddedState, rhsPeer, rhsPresence, rhsSummaryInfo, rhsEditing, rhsHasRevealControls, rhsSelected, rhsInputActivities, rhsAd, rhsHasFailedMessages): if lhsIndex != rhsIndex { return false } @@ -119,7 +119,9 @@ enum ChatListNodeEntry: Comparable, Identifiable { if lhsAd != rhsAd { return false } - + if lhsHasFailedMessages != rhsHasFailedMessages { + return false + } return true default: return false @@ -203,7 +205,7 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, } loop: for entry in view.entries { switch entry { - case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo): + case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed): if let savedMessagesPeer = savedMessagesPeer, savedMessagesPeer.id == index.messageIndex.id.peerId { continue loop } @@ -216,7 +218,7 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, updatedMessage = nil updatedCombinedReadState = nil } - result.append(.PeerEntry(index: offsetPinnedIndex(index, offset: pinnedIndexOffset), presentationData: state.presentationData, message: updatedMessage, readState: updatedCombinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], isAd: false)) + result.append(.PeerEntry(index: offsetPinnedIndex(index, offset: pinnedIndexOffset), presentationData: state.presentationData, message: updatedMessage, readState: updatedCombinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], isAd: false, hasFailedMessages: hasFailed)) case let .HoleEntry(hole): if hole.index.timestamp == Int32.max - 1 { return ([], true) @@ -228,13 +230,13 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, var pinningIndex: UInt16 = UInt16(pinnedIndexOffset == 0 ? 0 : (pinnedIndexOffset - 1)) if let savedMessagesPeer = savedMessagesPeer { - result.append(.PeerEntry(index: ChatListIndex.absoluteUpperBound.predecessor, presentationData: state.presentationData, message: nil, readState: nil, notificationSettings: nil, embeddedInterfaceState: nil, peer: RenderedPeer(peerId: savedMessagesPeer.id, peers: SimpleDictionary([savedMessagesPeer.id: savedMessagesPeer])), presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), editing: state.editing, hasActiveRevealControls: false, selected: false, inputActivities: nil, isAd: false)) + result.append(.PeerEntry(index: ChatListIndex.absoluteUpperBound.predecessor, presentationData: state.presentationData, message: nil, readState: nil, notificationSettings: nil, embeddedInterfaceState: nil, peer: RenderedPeer(peerId: savedMessagesPeer.id, peers: SimpleDictionary([savedMessagesPeer.id: savedMessagesPeer])), presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), editing: state.editing, hasActiveRevealControls: false, selected: false, inputActivities: nil, isAd: false, hasFailedMessages: false)) } else { if !view.additionalItemEntries.isEmpty { for entry in view.additionalItemEntries.reversed() { switch entry { - case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo): - result.append(.PeerEntry(index: ChatListIndex(pinningIndex: pinningIndex, messageIndex: index.messageIndex), presentationData: state.presentationData, message: message, readState: combinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], isAd: true)) + case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed): + result.append(.PeerEntry(index: ChatListIndex(pinningIndex: pinningIndex, messageIndex: index.messageIndex), presentationData: state.presentationData, message: message, readState: combinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], isAd: true, hasFailedMessages: hasFailed)) if pinningIndex != 0 { pinningIndex -= 1 } diff --git a/submodules/ContextUI/BUCK b/submodules/ContextUI/BUCK index dd389963ff..9249d703dd 100644 --- a/submodules/ContextUI/BUCK +++ b/submodules/ContextUI/BUCK @@ -12,6 +12,7 @@ static_library( "//submodules/TelegramPresentationData:TelegramPresentationData", "//submodules/TextSelectionNode:TextSelectionNode", "//submodules/ReactionSelectionNode:ReactionSelectionNode", + "//submodules/AppBundle:AppBundle", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/ContextUI/Sources/ContextActionsContainerNode.swift b/submodules/ContextUI/Sources/ContextActionsContainerNode.swift index ebc6bf1d49..5da7473809 100644 --- a/submodules/ContextUI/Sources/ContextActionsContainerNode.swift +++ b/submodules/ContextUI/Sources/ContextActionsContainerNode.swift @@ -2,6 +2,8 @@ import Foundation import AsyncDisplayKit import Display import TelegramPresentationData +import TextSelectionNode +import AppBundle private final class ContextActionsSelectionGestureRecognizer: UIPanGestureRecognizer { var updateLocation: ((CGPoint, Bool) -> Void)? @@ -38,7 +40,7 @@ private enum ContextItemNode { case separator(ASDisplayNode) } -final class ContextActionsContainerNode: ASDisplayNode { +private final class InnerActionsContainerNode: ASDisplayNode { private let presentationData: PresentationData private var effectView: UIVisualEffectView? private var itemNodes: [ContextItemNode] @@ -242,3 +244,179 @@ final class ContextActionsContainerNode: ASDisplayNode { return nil } } + +private final class InnerTextSelectionTipContainerNode: ASDisplayNode { + private let presentationData: PresentationData + private var effectView: UIVisualEffectView? + private let textNode: TextNode + private var textSelectionNode: TextSelectionNode? + private let iconNode: ASImageNode + + private let text: String + private let targetSelectionIndex: Int + + init(presentationData: PresentationData) { + self.presentationData = presentationData + self.textNode = TextNode() + + var rawText = self.presentationData.strings.ChatContextMenu_TextSelectionTip + if let range = rawText.range(of: "|") { + rawText.removeSubrange(range) + self.text = rawText + self.targetSelectionIndex = NSRange(range, in: rawText).lowerBound + } else { + self.text = rawText + self.targetSelectionIndex = 1 + } + + self.iconNode = ASImageNode() + self.iconNode.displaysAsynchronously = false + self.iconNode.displayWithoutProcessing = true + self.iconNode.image = generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Tip"), color: presentationData.theme.contextMenu.primaryColor) + + super.init() + + self.clipsToBounds = true + self.cornerRadius = 14.0 + + self.backgroundColor = presentationData.theme.contextMenu.backgroundColor + + let textSelectionNode = TextSelectionNode(theme: TextSelectionTheme(selection: presentationData.theme.contextMenu.primaryColor.withAlphaComponent(0.15), knob: presentationData.theme.contextMenu.primaryColor, knobDiameter: 8.0), strings: presentationData.strings, textNode: self.textNode, updateIsActive: { _ in + }, present: { _, _ in + }, rootNode: self, performAction: { _, _ in + }) + self.textSelectionNode = textSelectionNode + + self.addSubnode(self.textNode) + self.addSubnode(self.iconNode) + + self.textSelectionNode.flatMap(self.addSubnode) + + self.addSubnode(textSelectionNode.highlightAreaNode) + } + + func updateLayout(widthClass: ContainerViewLayoutSizeClass, width: CGFloat, transition: ContainedViewLayoutTransition) -> CGSize { + switch widthClass { + case .compact: + if let effectView = self.effectView { + self.effectView = nil + effectView.removeFromSuperview() + } + case .regular: + if self.effectView == nil { + let effectView: UIVisualEffectView + if #available(iOS 13.0, *) { + if self.presentationData.theme.overallDarkAppearance { + effectView = UIVisualEffectView(effect: UIBlurEffect(style: .systemMaterialDark)) + } else { + effectView = UIVisualEffectView(effect: UIBlurEffect(style: .systemMaterialLight)) + } + } else if #available(iOS 10.0, *) { + effectView = UIVisualEffectView(effect: UIBlurEffect(style: .regular)) + } else { + effectView = UIVisualEffectView(effect: UIBlurEffect(style: .light)) + } + self.effectView = effectView + self.view.insertSubview(effectView, at: 0) + } + } + + let verticalInset: CGFloat = 10.0 + let horizontalInset: CGFloat = 16.0 + let standardIconWidth: CGFloat = 32.0 + let iconSideInset: CGFloat = 12.0 + + let textFont = Font.regular(floor(presentationData.fontSize.baseDisplaySize * 14.0 / 17.0)) + + let iconSize = self.iconNode.image?.size ?? CGSize(width: 16.0, height: 16.0) + + let makeTextLayout = TextNode.asyncLayout(self.textNode) + let (textLayout, textApply) = makeTextLayout(TextNodeLayoutArguments(attributedString: NSAttributedString(string: self.text, font: textFont, textColor: self.presentationData.theme.contextMenu.primaryColor), backgroundColor: nil, minimumNumberOfLines: 0, maximumNumberOfLines: 0, truncationType: .end, constrainedSize: CGSize(width: width - horizontalInset * 2.0 - iconSize.width - 8.0, height: .greatestFiniteMagnitude), alignment: .left, lineSpacing: 0.0, cutout: nil, insets: UIEdgeInsets(), lineColor: nil, textShadowColor: nil, textStroke: nil)) + let _ = textApply() + + let textFrame = CGRect(origin: CGPoint(x: horizontalInset, y: verticalInset), size: textLayout.size) + transition.updateFrame(node: self.textNode, frame: textFrame) + + let size = CGSize(width: width, height: textLayout.size.height + verticalInset * 2.0) + + let iconFrame = CGRect(origin: CGPoint(x: size.width - standardIconWidth - iconSideInset + floor((standardIconWidth - iconSize.width) / 2.0), y: floor((size.height - iconSize.height) / 2.0)), size: iconSize) + transition.updateFrame(node: self.iconNode, frame: iconFrame) + + if let textSelectionNode = self.textSelectionNode { + transition.updateFrame(node: textSelectionNode, frame: textFrame) + textSelectionNode.highlightAreaNode.frame = textFrame + } + + if let effectView = self.effectView { + transition.updateFrame(view: effectView, frame: CGRect(origin: CGPoint(), size: size)) + } + + return size + } + + func updateTheme(presentationData: PresentationData) { + self.backgroundColor = presentationData.theme.contextMenu.backgroundColor + } + + func animateIn() { + if let textSelectionNode = self.textSelectionNode { + textSelectionNode.pretendInitiateSelection() + DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 0.5, execute: { [weak self] in + guard let strongSelf = self else { + return + } + strongSelf.textSelectionNode?.pretendExtendSelection(to: strongSelf.targetSelectionIndex) + }) + } + } +} + +final class ContextActionsContainerNode: ASDisplayNode { + private let actionsNode: InnerActionsContainerNode + private let textSelectionTipNode: InnerTextSelectionTipContainerNode? + + init(presentationData: PresentationData, items: [ContextMenuItem], getController: @escaping () -> ContextController?, actionSelected: @escaping (ContextMenuActionResult) -> Void, feedbackTap: @escaping () -> Void, displayTextSelectionTip: Bool) { + self.actionsNode = InnerActionsContainerNode(presentationData: presentationData, items: items, getController: getController, actionSelected: actionSelected, feedbackTap: feedbackTap) + if displayTextSelectionTip { + let textSelectionTipNode = InnerTextSelectionTipContainerNode(presentationData: presentationData) + textSelectionTipNode.isUserInteractionEnabled = false + self.textSelectionTipNode = textSelectionTipNode + } else { + self.textSelectionTipNode = nil + } + + super.init() + + self.addSubnode(self.actionsNode) + self.textSelectionTipNode.flatMap(self.addSubnode) + } + + func updateLayout(widthClass: ContainerViewLayoutSizeClass, constrainedWidth: CGFloat, transition: ContainedViewLayoutTransition) -> CGSize { + let actionsSize = self.actionsNode.updateLayout(widthClass: widthClass, constrainedWidth: constrainedWidth, transition: transition) + + var contentSize = actionsSize + transition.updateFrame(node: self.actionsNode, frame: CGRect(origin: CGPoint(x: 0.0, y: 0.0), size: actionsSize)) + + if let textSelectionTipNode = self.textSelectionTipNode { + contentSize.height += 8.0 + let textSelectionTipSize = textSelectionTipNode.updateLayout(widthClass: widthClass, width: actionsSize.width, transition: transition) + transition.updateFrame(node: textSelectionTipNode, frame: CGRect(origin: CGPoint(x: 0.0, y: contentSize.height), size: textSelectionTipSize)) + contentSize.height += textSelectionTipSize.height + } + + return contentSize + } + + func actionNode(at point: CGPoint) -> ContextActionNode? { + return self.actionsNode.actionNode(at: self.view.convert(point, to: self.actionsNode.view)) + } + + func updateTheme(presentationData: PresentationData) { + self.actionsNode.updateTheme(presentationData: presentationData) + self.textSelectionTipNode?.updateTheme(presentationData: presentationData) + } + + func animateIn() { + self.textSelectionTipNode?.animateIn() + } +} diff --git a/submodules/ContextUI/Sources/ContextController.swift b/submodules/ContextUI/Sources/ContextController.swift index 7a3ef594cf..76f7754665 100644 --- a/submodules/ContextUI/Sources/ContextController.swift +++ b/submodules/ContextUI/Sources/ContextController.swift @@ -69,6 +69,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi private let attemptTransitionControllerIntoNavigation: () -> Void private let getController: () -> ContextController? private weak var gesture: ContextGesture? + private var displayTextSelectionTip: Bool private var didSetItemsReady = false let itemsReady = Promise() @@ -107,7 +108,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi private let itemsDisposable = MetaDisposable() - init(account: Account, controller: ContextController, presentationData: PresentationData, source: ContextContentSource, items: Signal<[ContextMenuItem], NoError>, reactionItems: [ReactionContextItem], beginDismiss: @escaping (ContextMenuActionResult) -> Void, recognizer: TapLongTapOrDoubleTapGestureRecognizer?, gesture: ContextGesture?, reactionSelected: @escaping (String) -> Void, beganAnimatingOut: @escaping () -> Void, attemptTransitionControllerIntoNavigation: @escaping () -> Void) { + init(account: Account, controller: ContextController, presentationData: PresentationData, source: ContextContentSource, items: Signal<[ContextMenuItem], NoError>, reactionItems: [ReactionContextItem], beginDismiss: @escaping (ContextMenuActionResult) -> Void, recognizer: TapLongTapOrDoubleTapGestureRecognizer?, gesture: ContextGesture?, reactionSelected: @escaping (String) -> Void, beganAnimatingOut: @escaping () -> Void, attemptTransitionControllerIntoNavigation: @escaping () -> Void, displayTextSelectionTip: Bool) { self.presentationData = presentationData self.source = source self.items = items @@ -116,6 +117,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi self.beganAnimatingOut = beganAnimatingOut self.attemptTransitionControllerIntoNavigation = attemptTransitionControllerIntoNavigation self.gesture = gesture + self.displayTextSelectionTip = displayTextSelectionTip self.getController = { [weak controller] in return controller @@ -163,7 +165,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi beginDismiss(result) }, feedbackTap: { feedbackTap?() - }) + }, displayTextSelectionTip: self.displayTextSelectionTip) if !reactionItems.isEmpty { let reactionContextNode = ReactionContextNode(account: account, theme: presentationData.theme, items: reactionItems) @@ -528,6 +530,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi }, completion: { [weak self] in self?.didCompleteAnimationIn = true self?.hapticFeedback.prepareTap() + self?.actionsContainerNode.animateIn() }) } } else { @@ -535,6 +538,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi self.effectView.effect = makeCustomZoomBlurEffect() }, completion: { [weak self] _ in self?.didCompleteAnimationIn = true + self?.actionsContainerNode.animateIn() }) } @@ -970,7 +974,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi self?.beginDismiss(result) }, feedbackTap: { [weak self] in self?.hapticFeedback.tap() - }) + }, displayTextSelectionTip: self.displayTextSelectionTip) self.scrollNode.insertSubnode(self.actionsContainerNode, aboveSubnode: previousActionsContainerNode) if let layout = self.validLayout { @@ -982,6 +986,7 @@ private final class ContextControllerNode: ViewControllerTracingNode, UIScrollVi if !self.didSetItemsReady { self.didSetItemsReady = true + self.displayTextSelectionTip = false self.itemsReady.set(.single(true)) } } @@ -1374,6 +1379,7 @@ public final class ContextController: ViewController, StandalonePresentableContr private weak var recognizer: TapLongTapOrDoubleTapGestureRecognizer? private weak var gesture: ContextGesture? + private let displayTextSelectionTip: Bool private var animatedDidAppear = false private var wasDismissed = false @@ -1384,7 +1390,7 @@ public final class ContextController: ViewController, StandalonePresentableContr public var reactionSelected: ((String) -> Void)? - public init(account: Account, presentationData: PresentationData, source: ContextContentSource, items: Signal<[ContextMenuItem], NoError>, reactionItems: [ReactionContextItem], recognizer: TapLongTapOrDoubleTapGestureRecognizer? = nil, gesture: ContextGesture? = nil) { + public init(account: Account, presentationData: PresentationData, source: ContextContentSource, items: Signal<[ContextMenuItem], NoError>, reactionItems: [ReactionContextItem], recognizer: TapLongTapOrDoubleTapGestureRecognizer? = nil, gesture: ContextGesture? = nil, displayTextSelectionTip: Bool = false) { self.account = account self.presentationData = presentationData self.source = source @@ -1392,6 +1398,7 @@ public final class ContextController: ViewController, StandalonePresentableContr self.reactionItems = reactionItems self.recognizer = recognizer self.gesture = gesture + self.displayTextSelectionTip = displayTextSelectionTip super.init(navigationBarPresentationData: nil) @@ -1425,7 +1432,7 @@ public final class ContextController: ViewController, StandalonePresentableContr default: break } - }) + }, displayTextSelectionTip: self.displayTextSelectionTip) self.displayNodeDidLoad() diff --git a/submodules/Postbox/Sources/ChatListView.swift b/submodules/Postbox/Sources/ChatListView.swift index 0d9ff1487f..e8b09b758e 100644 --- a/submodules/Postbox/Sources/ChatListView.swift +++ b/submodules/Postbox/Sources/ChatListView.swift @@ -88,12 +88,12 @@ public struct ChatListGroupReferenceEntry: Equatable { } public enum ChatListEntry: Comparable { - case MessageEntry(ChatListIndex, Message?, CombinedPeerReadState?, PeerNotificationSettings?, PeerChatListEmbeddedInterfaceState?, RenderedPeer, PeerPresence?, ChatListMessageTagSummaryInfo) + case MessageEntry(ChatListIndex, Message?, CombinedPeerReadState?, PeerNotificationSettings?, PeerChatListEmbeddedInterfaceState?, RenderedPeer, PeerPresence?, ChatListMessageTagSummaryInfo, Bool) case HoleEntry(ChatListHole) public var index: ChatListIndex { switch self { - case let .MessageEntry(index, _, _, _, _, _, _, _): + case let .MessageEntry(index, _, _, _, _, _, _, _, _): return index case let .HoleEntry(hole): return ChatListIndex(pinningIndex: nil, messageIndex: hole.index) @@ -102,9 +102,9 @@ public enum ChatListEntry: Comparable { public static func ==(lhs: ChatListEntry, rhs: ChatListEntry) -> Bool { switch lhs { - case let .MessageEntry(lhsIndex, lhsMessage, lhsReadState, lhsSettings, lhsEmbeddedState, lhsPeer, lhsPresence, lhsInfo): + case let .MessageEntry(lhsIndex, lhsMessage, lhsReadState, lhsSettings, lhsEmbeddedState, lhsPeer, lhsPresence, lhsInfo, lhsHasFailed): switch rhs { - case let .MessageEntry(rhsIndex, rhsMessage, rhsReadState, rhsSettings, rhsEmbeddedState, rhsPeer, rhsPresence, rhsInfo): + case let .MessageEntry(rhsIndex, rhsMessage, rhsReadState, rhsSettings, rhsEmbeddedState, rhsPeer, rhsPresence, rhsInfo, rhsHasFailed): if lhsIndex != rhsIndex { return false } @@ -141,6 +141,9 @@ public enum ChatListEntry: Comparable { if lhsInfo != rhsInfo { return false } + if lhsHasFailed != rhsHasFailed { + return false + } return true default: return false @@ -178,7 +181,7 @@ private func processedChatListEntry(_ entry: MutableChatListEntry, cachedDataTab enum MutableChatListEntry: Equatable { case IntermediateMessageEntry(ChatListIndex, IntermediateMessage?, CombinedPeerReadState?, PeerChatListEmbeddedInterfaceState?) - case MessageEntry(ChatListIndex, Message?, CombinedPeerReadState?, PeerNotificationSettings?, PeerChatListEmbeddedInterfaceState?, RenderedPeer, PeerPresence?, ChatListMessageTagSummaryInfo) + case MessageEntry(ChatListIndex, Message?, CombinedPeerReadState?, PeerNotificationSettings?, PeerChatListEmbeddedInterfaceState?, RenderedPeer, PeerPresence?, ChatListMessageTagSummaryInfo, Bool) case HoleEntry(ChatListHole) init(_ intermediateEntry: ChatListIntermediateEntry, cachedDataTable: CachedPeerDataTable, readStateTable: MessageHistoryReadStateTable, messageHistoryTable: MessageHistoryTable) { @@ -194,7 +197,7 @@ enum MutableChatListEntry: Equatable { switch self { case let .IntermediateMessageEntry(index, _, _, _): return index - case let .MessageEntry(index, _, _, _, _, _, _, _): + case let .MessageEntry(index, _, _, _, _, _, _, _, _): return index case let .HoleEntry(hole): return ChatListIndex(pinningIndex: nil, messageIndex: hole.index) @@ -488,13 +491,13 @@ final class MutableChatListView { if !updatedPeerNotificationSettings.isEmpty { for i in 0 ..< self.entries.count { switch self.entries[i] { - case let .MessageEntry(index, message, readState, _, embeddedState, peer, peerPresence, summaryInfo): + case let .MessageEntry(index, message, readState, _, embeddedState, peer, peerPresence, summaryInfo, hasFailed): var notificationSettingsPeerId = peer.peerId if let peer = peer.peers[peer.peerId], let associatedPeerId = peer.associatedPeerId { notificationSettingsPeerId = associatedPeerId } if let settings = updatedPeerNotificationSettings[notificationSettingsPeerId] { - self.entries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo) + self.entries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo, hasFailed) hasChanges = true } default: @@ -502,17 +505,35 @@ final class MutableChatListView { } } } + + if !transaction.updatedFailedMessagePeerIds.isEmpty { + for i in 0 ..< self.entries.count { + switch self.entries[i] { + case let .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo, previousHasFailed): + if transaction.updatedFailedMessagePeerIds.contains(index.messageIndex.id.peerId) { + let hasFailed = postbox.messageHistoryFailedTable.contains(peerId: index.messageIndex.id.peerId) + if previousHasFailed != hasFailed { + self.entries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo, hasFailed) + hasChanges = true + } + } + default: + continue + } + } + } + if !updatedPeers.isEmpty { for i in 0 ..< self.entries.count { switch self.entries[i] { - case let .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo): + case let .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo, hasFailed): var updatedMessage: Message? if let message = message { updatedMessage = updateMessagePeers(message, updatedPeers: updatedPeers) } let updatedPeer = updatedRenderedPeer(peer, updatedPeers: updatedPeers) if updatedMessage != nil || updatedPeer != nil { - self.entries[i] = .MessageEntry(index, updatedMessage ?? message, readState, settings, embeddedState, updatedPeer ?? peer, peerPresence, summaryInfo) + self.entries[i] = .MessageEntry(index, updatedMessage ?? message, readState, settings, embeddedState, updatedPeer ?? peer, peerPresence, summaryInfo, hasFailed) hasChanges = true } default: @@ -523,13 +544,13 @@ final class MutableChatListView { if !updatedPeerPresences.isEmpty { for i in 0 ..< self.entries.count { switch self.entries[i] { - case let .MessageEntry(index, message, readState, settings, embeddedState, peer, _, summaryInfo): + case let .MessageEntry(index, message, readState, settings, embeddedState, peer, _, summaryInfo, hasFailed): var presencePeerId = peer.peerId if let peer = peer.peers[peer.peerId], let associatedPeerId = peer.associatedPeerId { presencePeerId = associatedPeerId } if let presence = updatedPeerPresences[presencePeerId] { - self.entries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, presence, summaryInfo) + self.entries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, presence, summaryInfo, hasFailed) hasChanges = true } default: @@ -540,7 +561,7 @@ final class MutableChatListView { if !transaction.currentUpdatedMessageTagSummaries.isEmpty || !transaction.currentUpdatedMessageActionsSummaries.isEmpty { for i in 0 ..< self.entries.count { switch self.entries[i] { - case let .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, currentSummary): + case let .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, currentSummary, hasFailed): var updatedTagSummaryCount: Int32? var updatedActionsSummaryCount: Int32? @@ -561,7 +582,7 @@ final class MutableChatListView { if updatedTagSummaryCount != nil || updatedActionsSummaryCount != nil { let summaryInfo = ChatListMessageTagSummaryInfo(tagSummaryCount: updatedTagSummaryCount ?? currentSummary.tagSummaryCount, actionsSummaryCount: updatedActionsSummaryCount ?? currentSummary.actionsSummaryCount) - self.entries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo) + self.entries[i] = .MessageEntry(index, message, readState, settings, embeddedState, peer, peerPresence, summaryInfo, hasFailed) hasChanges = true } default: @@ -816,51 +837,48 @@ final class MutableChatListView { private func renderEntry(_ entry: MutableChatListEntry, postbox: Postbox, renderMessage: (IntermediateMessage) -> Message, getPeer: (PeerId) -> Peer?, getPeerNotificationSettings: (PeerId) -> PeerNotificationSettings?, getPeerPresence: (PeerId) -> PeerPresence?) -> MutableChatListEntry? { switch entry { - case let .IntermediateMessageEntry(index, message, combinedReadState, embeddedState): - let renderedMessage: Message? - if let message = message { - renderedMessage = renderMessage(message) + case let .IntermediateMessageEntry(index, message, combinedReadState, embeddedState): + let renderedMessage: Message? + if let message = message { + renderedMessage = renderMessage(message) + } else { + renderedMessage = nil + } + var peers = SimpleDictionary() + var notificationSettings: PeerNotificationSettings? + var presence: PeerPresence? + if let peer = getPeer(index.messageIndex.id.peerId) { + peers[peer.id] = peer + if let associatedPeerId = peer.associatedPeerId { + if let associatedPeer = getPeer(associatedPeerId) { + peers[associatedPeer.id] = associatedPeer + } + notificationSettings = getPeerNotificationSettings(associatedPeerId) + presence = getPeerPresence(associatedPeerId) } else { - renderedMessage = nil + notificationSettings = getPeerNotificationSettings(index.messageIndex.id.peerId) + presence = getPeerPresence(index.messageIndex.id.peerId) } - var peers = SimpleDictionary() - var notificationSettings: PeerNotificationSettings? - var presence: PeerPresence? - if let peer = getPeer(index.messageIndex.id.peerId) { - peers[peer.id] = peer - if let associatedPeerId = peer.associatedPeerId { - if let associatedPeer = getPeer(associatedPeerId) { - peers[associatedPeer.id] = associatedPeer - } - notificationSettings = getPeerNotificationSettings(associatedPeerId) - presence = getPeerPresence(associatedPeerId) - } else { - notificationSettings = getPeerNotificationSettings(index.messageIndex.id.peerId) - presence = getPeerPresence(index.messageIndex.id.peerId) - } + } + + var tagSummaryCount: Int32? + var actionsSummaryCount: Int32? + + if let tagSummary = self.summaryComponents.tagSummary { + let key = MessageHistoryTagsSummaryKey(tag: tagSummary.tag, peerId: index.messageIndex.id.peerId, namespace: tagSummary.namespace) + if let summary = postbox.messageHistoryTagsSummaryTable.get(key) { + tagSummaryCount = summary.count } - - var tagSummaryCount: Int32? - var actionsSummaryCount: Int32? - - if let tagSummary = self.summaryComponents.tagSummary { - let key = MessageHistoryTagsSummaryKey(tag: tagSummary.tag, peerId: index.messageIndex.id.peerId, namespace: tagSummary.namespace) - if let summary = postbox.messageHistoryTagsSummaryTable.get(key) { - tagSummaryCount = summary.count - } - } - - if let actionsSummary = self.summaryComponents.actionsSummary { - let key = PendingMessageActionsSummaryKey(type: actionsSummary.type, peerId: index.messageIndex.id.peerId, namespace: actionsSummary.namespace) - actionsSummaryCount = postbox.pendingMessageActionsMetadataTable.getCount(.peerNamespaceAction(key.peerId, key.namespace, key.type)) - } - - return .MessageEntry(index, renderedMessage, combinedReadState, notificationSettings, embeddedState, RenderedPeer(peerId: index.messageIndex.id.peerId, peers: peers), presence, ChatListMessageTagSummaryInfo(tagSummaryCount: tagSummaryCount, actionsSummaryCount: actionsSummaryCount)) - /*case let .IntermediateGroupReferenceEntry(groupId, index, counters): - let message = postbox.messageHistoryTable.getMessage(index.messageIndex).flatMap(postbox.renderIntermediateMessage) - return .GroupReferenceEntry(groupId, index, message, ChatListGroupReferenceTopPeers(postbox: postbox, groupId: groupId), counters ?? ChatListGroupReferenceUnreadCounters(postbox: postbox, groupId: groupId))*/ - default: - return nil + } + + if let actionsSummary = self.summaryComponents.actionsSummary { + let key = PendingMessageActionsSummaryKey(type: actionsSummary.type, peerId: index.messageIndex.id.peerId, namespace: actionsSummary.namespace) + actionsSummaryCount = postbox.pendingMessageActionsMetadataTable.getCount(.peerNamespaceAction(key.peerId, key.namespace, key.type)) + } + + return .MessageEntry(index, renderedMessage, combinedReadState, notificationSettings, embeddedState, RenderedPeer(peerId: index.messageIndex.id.peerId, peers: peers), presence, ChatListMessageTagSummaryInfo(tagSummaryCount: tagSummaryCount, actionsSummaryCount: actionsSummaryCount), postbox.messageHistoryFailedTable.contains(peerId: index.messageIndex.id.peerId)) + default: + return nil } } @@ -892,8 +910,8 @@ public final class ChatListView { var entries: [ChatListEntry] = [] for entry in mutableView.entries { switch entry { - case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo): - entries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo)) + case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed): + entries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) case let .HoleEntry(hole): entries.append(.HoleEntry(hole)) /*case let .GroupReferenceEntry(groupId, index, message, topPeers, counters): @@ -912,8 +930,8 @@ public final class ChatListView { var additionalItemEntries: [ChatListEntry] = [] for entry in mutableView.additionalItemEntries { switch entry { - case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo): - additionalItemEntries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo)) + case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed): + additionalItemEntries.append(.MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, peerPresence, summaryInfo, hasFailed)) case .HoleEntry: assertionFailure() /*case .GroupReferenceEntry: diff --git a/submodules/Postbox/Sources/MessageHistoryFailedTable.swift b/submodules/Postbox/Sources/MessageHistoryFailedTable.swift new file mode 100644 index 0000000000..c1cc3cb8f2 --- /dev/null +++ b/submodules/Postbox/Sources/MessageHistoryFailedTable.swift @@ -0,0 +1,55 @@ +import Foundation + +final class MessageHistoryFailedTable: Table { + static func tableSpec(_ id: Int32) -> ValueBoxTable { + return ValueBoxTable(id: id, keyType: .binary, compactValuesOnCreation: true) + } + + private let sharedKey = ValueBoxKey(length: 8 + 4 + 4) + + private(set) var updatedPeerIds = Set() + + private func key(_ id: MessageId) -> ValueBoxKey { + self.sharedKey.setInt64(0, value: id.peerId.toInt64()) + self.sharedKey.setInt32(8, value: id.namespace) + self.sharedKey.setInt32(8 + 4, value: id.id) + + return self.sharedKey + } + + private func lowerBound(peerId: PeerId) -> ValueBoxKey { + let key = ValueBoxKey(length: 8) + key.setInt64(0, value: peerId.toInt64()) + return key + } + + private func upperBound(peerId: PeerId) -> ValueBoxKey { + let key = ValueBoxKey(length: 8) + key.setInt64(0, value: peerId.toInt64()) + return key.successor + } + + func add(_ id: MessageId) { + self.valueBox.set(self.table, key: self.key(id), value: MemoryBuffer()) + self.updatedPeerIds.insert(id.peerId) + } + + func remove(_ id: MessageId) { + self.valueBox.remove(self.table, key: self.key(id), secure: false) + self.updatedPeerIds.insert(id.peerId) + } + + func contains(peerId: PeerId) -> Bool { + var result = false + self.valueBox.range(self.table, start: self.lowerBound(peerId: peerId), end: self.upperBound(peerId: peerId), keys: { _ in + result = true + return false + }, limit: 1) + return result + } + + override func beforeCommit() { + self.updatedPeerIds.removeAll() + } +} + diff --git a/submodules/Postbox/Sources/MessageHistoryTable.swift b/submodules/Postbox/Sources/MessageHistoryTable.swift index aaa1a50247..2a1537ce64 100644 --- a/submodules/Postbox/Sources/MessageHistoryTable.swift +++ b/submodules/Postbox/Sources/MessageHistoryTable.swift @@ -69,6 +69,7 @@ final class MessageHistoryTable: Table { let historyMetadataTable: MessageHistoryMetadataTable let globallyUniqueMessageIdsTable: MessageGloballyUniqueIdTable let unsentTable: MessageHistoryUnsentTable + let failedTable: MessageHistoryFailedTable let tagsTable: MessageHistoryTagsTable let globalTagsTable: GlobalMessageHistoryTagsTable let localTagsTable: LocalMessageHistoryTagsTable @@ -78,7 +79,7 @@ final class MessageHistoryTable: Table { let summaryTable: MessageHistoryTagsSummaryTable let pendingActionsTable: PendingMessageActionsTable - init(valueBox: ValueBox, table: ValueBoxTable, seedConfiguration: SeedConfiguration, messageHistoryIndexTable: MessageHistoryIndexTable, messageHistoryHoleIndexTable: MessageHistoryHoleIndexTable, messageMediaTable: MessageMediaTable, historyMetadataTable: MessageHistoryMetadataTable, globallyUniqueMessageIdsTable: MessageGloballyUniqueIdTable, unsentTable: MessageHistoryUnsentTable, tagsTable: MessageHistoryTagsTable, globalTagsTable: GlobalMessageHistoryTagsTable, localTagsTable: LocalMessageHistoryTagsTable, readStateTable: MessageHistoryReadStateTable, synchronizeReadStateTable: MessageHistorySynchronizeReadStateTable, textIndexTable: MessageHistoryTextIndexTable, summaryTable: MessageHistoryTagsSummaryTable, pendingActionsTable: PendingMessageActionsTable) { + init(valueBox: ValueBox, table: ValueBoxTable, seedConfiguration: SeedConfiguration, messageHistoryIndexTable: MessageHistoryIndexTable, messageHistoryHoleIndexTable: MessageHistoryHoleIndexTable, messageMediaTable: MessageMediaTable, historyMetadataTable: MessageHistoryMetadataTable, globallyUniqueMessageIdsTable: MessageGloballyUniqueIdTable, unsentTable: MessageHistoryUnsentTable, failedTable: MessageHistoryFailedTable, tagsTable: MessageHistoryTagsTable, globalTagsTable: GlobalMessageHistoryTagsTable, localTagsTable: LocalMessageHistoryTagsTable, readStateTable: MessageHistoryReadStateTable, synchronizeReadStateTable: MessageHistorySynchronizeReadStateTable, textIndexTable: MessageHistoryTextIndexTable, summaryTable: MessageHistoryTagsSummaryTable, pendingActionsTable: PendingMessageActionsTable) { self.seedConfiguration = seedConfiguration self.messageHistoryIndexTable = messageHistoryIndexTable self.messageHistoryHoleIndexTable = messageHistoryHoleIndexTable @@ -86,6 +87,7 @@ final class MessageHistoryTable: Table { self.historyMetadataTable = historyMetadataTable self.globallyUniqueMessageIdsTable = globallyUniqueMessageIdsTable self.unsentTable = unsentTable + self.failedTable = failedTable self.tagsTable = tagsTable self.globalTagsTable = globalTagsTable self.localTagsTable = localTagsTable @@ -249,6 +251,9 @@ final class MessageHistoryTable: Table { if message.flags.contains(.Unsent) && !message.flags.contains(.Failed) { self.unsentTable.add(message.id, operations: &unsentMessageOperations) } + if message.flags.contains(.Failed) { + self.failedTable.add(message.id) + } let tags = message.tags.rawValue if tags != 0 { for i in 0 ..< 32 { @@ -1194,6 +1199,9 @@ final class MessageHistoryTable: Table { if message.flags.contains(.Unsent) && !message.flags.contains(.Failed) { self.unsentTable.remove(index.id, operations: &unsentMessageOperations) } + if message.flags.contains(.Failed) { + self.failedTable.remove(message.id) + } if let globallyUniqueId = message.globallyUniqueId { self.globallyUniqueMessageIdsTable.remove(peerId: message.id.peerId, globallyUniqueId: globallyUniqueId) @@ -1447,6 +1455,23 @@ final class MessageHistoryTable: Table { break } + if previousMessage.id != message.id { + if previousMessage.flags.contains(.Failed) { + self.failedTable.remove(previousMessage.id) + } + if message.flags.contains(.Failed) { + self.failedTable.add(message.id) + } + } else { + if previousMessage.flags.contains(.Failed) != message.flags.contains(.Failed) { + if previousMessage.flags.contains(.Failed) { + self.failedTable.remove(previousMessage.id) + } else { + self.failedTable.add(message.id) + } + } + } + if self.seedConfiguration.peerNamespacesRequiringMessageTextIndex.contains(message.id.peerId.namespace) { if previousMessage.id != message.id || previousMessage.text != message.text || previousMessage.tags != message.tags { self.textIndexTable.remove(messageId: previousMessage.id) diff --git a/submodules/Postbox/Sources/Postbox.swift b/submodules/Postbox/Sources/Postbox.swift index 957668a110..55db3c8a29 100644 --- a/submodules/Postbox/Sources/Postbox.swift +++ b/submodules/Postbox/Sources/Postbox.swift @@ -1134,6 +1134,7 @@ public final class Postbox { let additionalChatListItemsTable: AdditionalChatListItemsTable let messageHistoryMetadataTable: MessageHistoryMetadataTable let messageHistoryUnsentTable: MessageHistoryUnsentTable + let messageHistoryFailedTable: MessageHistoryFailedTable let messageHistoryTagsTable: MessageHistoryTagsTable let globalMessageHistoryTagsTable: GlobalMessageHistoryTagsTable let localMessageHistoryTagsTable: LocalMessageHistoryTagsTable @@ -1211,6 +1212,7 @@ public final class Postbox { self.messageHistoryMetadataTable = MessageHistoryMetadataTable(valueBox: self.valueBox, table: MessageHistoryMetadataTable.tableSpec(10)) self.messageHistoryHoleIndexTable = MessageHistoryHoleIndexTable(valueBox: self.valueBox, table: MessageHistoryHoleIndexTable.tableSpec(56), metadataTable: self.messageHistoryMetadataTable, seedConfiguration: self.seedConfiguration) self.messageHistoryUnsentTable = MessageHistoryUnsentTable(valueBox: self.valueBox, table: MessageHistoryUnsentTable.tableSpec(11)) + self.messageHistoryFailedTable = MessageHistoryFailedTable(valueBox: self.valueBox, table: MessageHistoryFailedTable.tableSpec(49)) self.invalidatedMessageHistoryTagsSummaryTable = InvalidatedMessageHistoryTagsSummaryTable(valueBox: self.valueBox, table: InvalidatedMessageHistoryTagsSummaryTable.tableSpec(47)) self.messageHistoryTagsSummaryTable = MessageHistoryTagsSummaryTable(valueBox: self.valueBox, table: MessageHistoryTagsSummaryTable.tableSpec(44), invalidateTable: self.invalidatedMessageHistoryTagsSummaryTable) self.pendingMessageActionsMetadataTable = PendingMessageActionsMetadataTable(valueBox: self.valueBox, table: PendingMessageActionsMetadataTable.tableSpec(45)) @@ -1227,7 +1229,7 @@ public final class Postbox { self.timestampBasedMessageAttributesTable = TimestampBasedMessageAttributesTable(valueBox: self.valueBox, table: TimestampBasedMessageAttributesTable.tableSpec(34), indexTable: self.timestampBasedMessageAttributesIndexTable) self.textIndexTable = MessageHistoryTextIndexTable(valueBox: self.valueBox, table: MessageHistoryTextIndexTable.tableSpec(41)) self.additionalChatListItemsTable = AdditionalChatListItemsTable(valueBox: self.valueBox, table: AdditionalChatListItemsTable.tableSpec(55)) - self.messageHistoryTable = MessageHistoryTable(valueBox: self.valueBox, table: MessageHistoryTable.tableSpec(7), seedConfiguration: seedConfiguration, messageHistoryIndexTable: self.messageHistoryIndexTable, messageHistoryHoleIndexTable: self.messageHistoryHoleIndexTable, messageMediaTable: self.mediaTable, historyMetadataTable: self.messageHistoryMetadataTable, globallyUniqueMessageIdsTable: self.globallyUniqueMessageIdsTable, unsentTable: self.messageHistoryUnsentTable, tagsTable: self.messageHistoryTagsTable, globalTagsTable: self.globalMessageHistoryTagsTable, localTagsTable: self.localMessageHistoryTagsTable, readStateTable: self.readStateTable, synchronizeReadStateTable: self.synchronizeReadStateTable, textIndexTable: self.textIndexTable, summaryTable: self.messageHistoryTagsSummaryTable, pendingActionsTable: self.pendingMessageActionsTable) + self.messageHistoryTable = MessageHistoryTable(valueBox: self.valueBox, table: MessageHistoryTable.tableSpec(7), seedConfiguration: seedConfiguration, messageHistoryIndexTable: self.messageHistoryIndexTable, messageHistoryHoleIndexTable: self.messageHistoryHoleIndexTable, messageMediaTable: self.mediaTable, historyMetadataTable: self.messageHistoryMetadataTable, globallyUniqueMessageIdsTable: self.globallyUniqueMessageIdsTable, unsentTable: self.messageHistoryUnsentTable, failedTable: self.messageHistoryFailedTable, tagsTable: self.messageHistoryTagsTable, globalTagsTable: self.globalMessageHistoryTagsTable, localTagsTable: self.localMessageHistoryTagsTable, readStateTable: self.readStateTable, synchronizeReadStateTable: self.synchronizeReadStateTable, textIndexTable: self.textIndexTable, summaryTable: self.messageHistoryTagsSummaryTable, pendingActionsTable: self.pendingMessageActionsTable) self.peerChatStateTable = PeerChatStateTable(valueBox: self.valueBox, table: PeerChatStateTable.tableSpec(13)) self.peerNameTokenIndexTable = ReverseIndexReferenceTable(valueBox: self.valueBox, table: ReverseIndexReferenceTable.tableSpec(26)) self.peerNameIndexTable = PeerNameIndexTable(valueBox: self.valueBox, table: PeerNameIndexTable.tableSpec(27), peerTable: self.peerTable, peerNameTokenIndexTable: self.peerNameTokenIndexTable) @@ -1267,6 +1269,7 @@ public final class Postbox { tables.append(self.globallyUniqueMessageIdsTable) tables.append(self.messageHistoryMetadataTable) tables.append(self.messageHistoryUnsentTable) + tables.append(self.messageHistoryFailedTable) tables.append(self.messageHistoryTagsTable) tables.append(self.globalMessageHistoryTagsTable) tables.append(self.localMessageHistoryTagsTable) @@ -1700,7 +1703,7 @@ public final class Postbox { let transactionParticipationInTotalUnreadCountUpdates = self.peerNotificationSettingsTable.transactionParticipationInTotalUnreadCountUpdates(postbox: self) self.chatListIndexTable.commitWithTransaction(postbox: self, alteredInitialPeerCombinedReadStates: alteredInitialPeerCombinedReadStates, updatedPeers: updatedPeers, transactionParticipationInTotalUnreadCountUpdates: transactionParticipationInTotalUnreadCountUpdates, updatedRootUnreadState: &self.currentUpdatedTotalUnreadState, updatedGroupTotalUnreadSummaries: &self.currentUpdatedGroupTotalUnreadSummaries, currentUpdatedGroupSummarySynchronizeOperations: &self.currentUpdatedGroupSummarySynchronizeOperations) - let transaction = PostboxTransaction(currentUpdatedState: self.currentUpdatedState, currentPeerHoleOperations: self.currentPeerHoleOperations, currentOperationsByPeerId: self.currentOperationsByPeerId, chatListOperations: self.currentChatListOperations, currentUpdatedChatListInclusions: self.currentUpdatedChatListInclusions, currentUpdatedPeers: self.currentUpdatedPeers, currentUpdatedPeerNotificationSettings: self.currentUpdatedPeerNotificationSettings, currentUpdatedPeerNotificationBehaviorTimestamps: self.currentUpdatedPeerNotificationBehaviorTimestamps, currentUpdatedCachedPeerData: self.currentUpdatedCachedPeerData, currentUpdatedPeerPresences: currentUpdatedPeerPresences, currentUpdatedPeerChatListEmbeddedStates: self.currentUpdatedPeerChatListEmbeddedStates, currentUpdatedTotalUnreadState: self.currentUpdatedTotalUnreadState, currentUpdatedTotalUnreadSummaries: self.currentUpdatedGroupTotalUnreadSummaries, alteredInitialPeerCombinedReadStates: alteredInitialPeerCombinedReadStates, currentPeerMergedOperationLogOperations: self.currentPeerMergedOperationLogOperations, currentTimestampBasedMessageAttributesOperations: self.currentTimestampBasedMessageAttributesOperations, unsentMessageOperations: self.currentUnsentOperations, updatedSynchronizePeerReadStateOperations: self.currentUpdatedSynchronizeReadStateOperations, currentUpdatedGroupSummarySynchronizeOperations: self.currentUpdatedGroupSummarySynchronizeOperations, currentPreferencesOperations: self.currentPreferencesOperations, currentOrderedItemListOperations: self.currentOrderedItemListOperations, currentItemCollectionItemsOperations: self.currentItemCollectionItemsOperations, currentItemCollectionInfosOperations: self.currentItemCollectionInfosOperations, currentUpdatedPeerChatStates: self.currentUpdatedPeerChatStates, currentGlobalTagsOperations: self.currentGlobalTagsOperations, currentLocalTagsOperations: self.currentLocalTagsOperations, updatedMedia: self.currentUpdatedMedia, replaceRemoteContactCount: self.currentReplaceRemoteContactCount, replaceContactPeerIds: self.currentReplacedContactPeerIds, currentPendingMessageActionsOperations: self.currentPendingMessageActionsOperations, currentUpdatedMessageActionsSummaries: self.currentUpdatedMessageActionsSummaries, currentUpdatedMessageTagSummaries: self.currentUpdatedMessageTagSummaries, currentInvalidateMessageTagSummaries: self.currentInvalidateMessageTagSummaries, currentUpdatedPendingPeerNotificationSettings: self.currentUpdatedPendingPeerNotificationSettings, replacedAdditionalChatListItems: self.currentReplacedAdditionalChatListItems, updatedNoticeEntryKeys: self.currentUpdatedNoticeEntryKeys, updatedCacheEntryKeys: self.currentUpdatedCacheEntryKeys, currentUpdatedMasterClientId: currentUpdatedMasterClientId) + let transaction = PostboxTransaction(currentUpdatedState: self.currentUpdatedState, currentPeerHoleOperations: self.currentPeerHoleOperations, currentOperationsByPeerId: self.currentOperationsByPeerId, chatListOperations: self.currentChatListOperations, currentUpdatedChatListInclusions: self.currentUpdatedChatListInclusions, currentUpdatedPeers: self.currentUpdatedPeers, currentUpdatedPeerNotificationSettings: self.currentUpdatedPeerNotificationSettings, currentUpdatedPeerNotificationBehaviorTimestamps: self.currentUpdatedPeerNotificationBehaviorTimestamps, currentUpdatedCachedPeerData: self.currentUpdatedCachedPeerData, currentUpdatedPeerPresences: currentUpdatedPeerPresences, currentUpdatedPeerChatListEmbeddedStates: self.currentUpdatedPeerChatListEmbeddedStates, currentUpdatedTotalUnreadState: self.currentUpdatedTotalUnreadState, currentUpdatedTotalUnreadSummaries: self.currentUpdatedGroupTotalUnreadSummaries, alteredInitialPeerCombinedReadStates: alteredInitialPeerCombinedReadStates, currentPeerMergedOperationLogOperations: self.currentPeerMergedOperationLogOperations, currentTimestampBasedMessageAttributesOperations: self.currentTimestampBasedMessageAttributesOperations, unsentMessageOperations: self.currentUnsentOperations, updatedSynchronizePeerReadStateOperations: self.currentUpdatedSynchronizeReadStateOperations, currentUpdatedGroupSummarySynchronizeOperations: self.currentUpdatedGroupSummarySynchronizeOperations, currentPreferencesOperations: self.currentPreferencesOperations, currentOrderedItemListOperations: self.currentOrderedItemListOperations, currentItemCollectionItemsOperations: self.currentItemCollectionItemsOperations, currentItemCollectionInfosOperations: self.currentItemCollectionInfosOperations, currentUpdatedPeerChatStates: self.currentUpdatedPeerChatStates, currentGlobalTagsOperations: self.currentGlobalTagsOperations, currentLocalTagsOperations: self.currentLocalTagsOperations, updatedMedia: self.currentUpdatedMedia, replaceRemoteContactCount: self.currentReplaceRemoteContactCount, replaceContactPeerIds: self.currentReplacedContactPeerIds, currentPendingMessageActionsOperations: self.currentPendingMessageActionsOperations, currentUpdatedMessageActionsSummaries: self.currentUpdatedMessageActionsSummaries, currentUpdatedMessageTagSummaries: self.currentUpdatedMessageTagSummaries, currentInvalidateMessageTagSummaries: self.currentInvalidateMessageTagSummaries, currentUpdatedPendingPeerNotificationSettings: self.currentUpdatedPendingPeerNotificationSettings, replacedAdditionalChatListItems: self.currentReplacedAdditionalChatListItems, updatedNoticeEntryKeys: self.currentUpdatedNoticeEntryKeys, updatedCacheEntryKeys: self.currentUpdatedCacheEntryKeys, currentUpdatedMasterClientId: currentUpdatedMasterClientId, updatedFailedMessagePeerIds: self.messageHistoryFailedTable.updatedPeerIds) var updatedTransactionState: Int64? var updatedMasterClientId: Int64? if !transaction.isEmpty { diff --git a/submodules/Postbox/Sources/PostboxTransaction.swift b/submodules/Postbox/Sources/PostboxTransaction.swift index 52401de1aa..056d9523ad 100644 --- a/submodules/Postbox/Sources/PostboxTransaction.swift +++ b/submodules/Postbox/Sources/PostboxTransaction.swift @@ -40,6 +40,7 @@ final class PostboxTransaction { let replacedAdditionalChatListItems: [PeerId]? let updatedNoticeEntryKeys: Set let updatedCacheEntryKeys: Set + let updatedFailedMessagePeerIds: Set var isEmpty: Bool { if currentUpdatedState != nil { @@ -159,10 +160,13 @@ final class PostboxTransaction { if !updatedCacheEntryKeys.isEmpty { return false } + if !updatedFailedMessagePeerIds.isEmpty { + return false + } return true } - init(currentUpdatedState: PostboxCoding?, currentPeerHoleOperations: [MessageHistoryIndexHoleOperationKey: [MessageHistoryIndexHoleOperation]] = [:], currentOperationsByPeerId: [PeerId: [MessageHistoryOperation]], chatListOperations: [PeerGroupId: [ChatListOperation]], currentUpdatedChatListInclusions: [PeerId: PeerChatListInclusion], currentUpdatedPeers: [PeerId: Peer], currentUpdatedPeerNotificationSettings: [PeerId: PeerNotificationSettings], currentUpdatedPeerNotificationBehaviorTimestamps: [PeerId: PeerNotificationSettingsBehaviorTimestamp], currentUpdatedCachedPeerData: [PeerId: CachedPeerData], currentUpdatedPeerPresences: [PeerId: PeerPresence], currentUpdatedPeerChatListEmbeddedStates: [PeerId: PeerChatListEmbeddedInterfaceState?], currentUpdatedTotalUnreadState: ChatListTotalUnreadState?, currentUpdatedTotalUnreadSummaries: [PeerGroupId: PeerGroupUnreadCountersCombinedSummary], alteredInitialPeerCombinedReadStates: [PeerId: CombinedPeerReadState], currentPeerMergedOperationLogOperations: [PeerMergedOperationLogOperation], currentTimestampBasedMessageAttributesOperations: [TimestampBasedMessageAttributesOperation], unsentMessageOperations: [IntermediateMessageHistoryUnsentOperation], updatedSynchronizePeerReadStateOperations: [PeerId: PeerReadStateSynchronizationOperation?], currentUpdatedGroupSummarySynchronizeOperations: [PeerGroupAndNamespace: Bool], currentPreferencesOperations: [PreferencesOperation], currentOrderedItemListOperations: [Int32: [OrderedItemListOperation]], currentItemCollectionItemsOperations: [ItemCollectionId: [ItemCollectionItemsOperation]], currentItemCollectionInfosOperations: [ItemCollectionInfosOperation], currentUpdatedPeerChatStates: Set, currentGlobalTagsOperations: [GlobalMessageHistoryTagsOperation], currentLocalTagsOperations: [IntermediateMessageHistoryLocalTagsOperation], updatedMedia: [MediaId: Media?], replaceRemoteContactCount: Int32?, replaceContactPeerIds: Set?, currentPendingMessageActionsOperations: [PendingMessageActionsOperation], currentUpdatedMessageActionsSummaries: [PendingMessageActionsSummaryKey: Int32], currentUpdatedMessageTagSummaries: [MessageHistoryTagsSummaryKey: MessageHistoryTagNamespaceSummary], currentInvalidateMessageTagSummaries: [InvalidatedMessageHistoryTagsSummaryEntryOperation], currentUpdatedPendingPeerNotificationSettings: Set, replacedAdditionalChatListItems: [PeerId]?, updatedNoticeEntryKeys: Set, updatedCacheEntryKeys: Set, currentUpdatedMasterClientId: Int64?) { + init(currentUpdatedState: PostboxCoding?, currentPeerHoleOperations: [MessageHistoryIndexHoleOperationKey: [MessageHistoryIndexHoleOperation]] = [:], currentOperationsByPeerId: [PeerId: [MessageHistoryOperation]], chatListOperations: [PeerGroupId: [ChatListOperation]], currentUpdatedChatListInclusions: [PeerId: PeerChatListInclusion], currentUpdatedPeers: [PeerId: Peer], currentUpdatedPeerNotificationSettings: [PeerId: PeerNotificationSettings], currentUpdatedPeerNotificationBehaviorTimestamps: [PeerId: PeerNotificationSettingsBehaviorTimestamp], currentUpdatedCachedPeerData: [PeerId: CachedPeerData], currentUpdatedPeerPresences: [PeerId: PeerPresence], currentUpdatedPeerChatListEmbeddedStates: [PeerId: PeerChatListEmbeddedInterfaceState?], currentUpdatedTotalUnreadState: ChatListTotalUnreadState?, currentUpdatedTotalUnreadSummaries: [PeerGroupId: PeerGroupUnreadCountersCombinedSummary], alteredInitialPeerCombinedReadStates: [PeerId: CombinedPeerReadState], currentPeerMergedOperationLogOperations: [PeerMergedOperationLogOperation], currentTimestampBasedMessageAttributesOperations: [TimestampBasedMessageAttributesOperation], unsentMessageOperations: [IntermediateMessageHistoryUnsentOperation], updatedSynchronizePeerReadStateOperations: [PeerId: PeerReadStateSynchronizationOperation?], currentUpdatedGroupSummarySynchronizeOperations: [PeerGroupAndNamespace: Bool], currentPreferencesOperations: [PreferencesOperation], currentOrderedItemListOperations: [Int32: [OrderedItemListOperation]], currentItemCollectionItemsOperations: [ItemCollectionId: [ItemCollectionItemsOperation]], currentItemCollectionInfosOperations: [ItemCollectionInfosOperation], currentUpdatedPeerChatStates: Set, currentGlobalTagsOperations: [GlobalMessageHistoryTagsOperation], currentLocalTagsOperations: [IntermediateMessageHistoryLocalTagsOperation], updatedMedia: [MediaId: Media?], replaceRemoteContactCount: Int32?, replaceContactPeerIds: Set?, currentPendingMessageActionsOperations: [PendingMessageActionsOperation], currentUpdatedMessageActionsSummaries: [PendingMessageActionsSummaryKey: Int32], currentUpdatedMessageTagSummaries: [MessageHistoryTagsSummaryKey: MessageHistoryTagNamespaceSummary], currentInvalidateMessageTagSummaries: [InvalidatedMessageHistoryTagsSummaryEntryOperation], currentUpdatedPendingPeerNotificationSettings: Set, replacedAdditionalChatListItems: [PeerId]?, updatedNoticeEntryKeys: Set, updatedCacheEntryKeys: Set, currentUpdatedMasterClientId: Int64?, updatedFailedMessagePeerIds: Set) { self.currentUpdatedState = currentUpdatedState self.currentPeerHoleOperations = currentPeerHoleOperations self.currentOperationsByPeerId = currentOperationsByPeerId @@ -201,5 +205,6 @@ final class PostboxTransaction { self.replacedAdditionalChatListItems = replacedAdditionalChatListItems self.updatedNoticeEntryKeys = updatedNoticeEntryKeys self.updatedCacheEntryKeys = updatedCacheEntryKeys + self.updatedFailedMessagePeerIds = updatedFailedMessagePeerIds } } diff --git a/submodules/Postbox/Sources/ViewTracker.swift b/submodules/Postbox/Sources/ViewTracker.swift index aa85e15d62..65b058a806 100644 --- a/submodules/Postbox/Sources/ViewTracker.swift +++ b/submodules/Postbox/Sources/ViewTracker.swift @@ -349,7 +349,8 @@ final class ViewTracker { } } - if !transaction.chatListOperations.isEmpty || !transaction.currentUpdatedPeerNotificationSettings.isEmpty || !transaction.currentUpdatedPeers.isEmpty || !transaction.currentInvalidateMessageTagSummaries.isEmpty || !transaction.currentUpdatedMessageTagSummaries.isEmpty || !transaction.currentOperationsByPeerId.isEmpty || transaction.replacedAdditionalChatListItems != nil || !transaction.currentUpdatedPeerPresences.isEmpty { + if !transaction.chatListOperations.isEmpty || !transaction.currentUpdatedPeerNotificationSettings.isEmpty || !transaction.currentUpdatedPeers.isEmpty || !transaction.currentInvalidateMessageTagSummaries.isEmpty || !transaction.currentUpdatedMessageTagSummaries.isEmpty || !transaction.currentOperationsByPeerId.isEmpty || transaction.replacedAdditionalChatListItems != nil || !transaction.currentUpdatedPeerPresences.isEmpty || + !transaction.updatedFailedMessagePeerIds.isEmpty { for (mutableView, pipe) in self.chatListViews.copyItems() { let context = MutableChatListViewReplayContext() if mutableView.replay(postbox: postbox, operations: transaction.chatListOperations, updatedPeerNotificationSettings: transaction.currentUpdatedPeerNotificationSettings, updatedPeers: transaction.currentUpdatedPeers, updatedPeerPresences: transaction.currentUpdatedPeerPresences, transaction: transaction, context: context) { diff --git a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift index 8b5de5ea31..791832af8b 100644 --- a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift +++ b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift @@ -215,22 +215,22 @@ private final class TextSizeSelectionControllerNode: ASDisplayNode, UIScrollView let timestamp = self.referenceTimestamp let timestamp1 = timestamp + 120 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let presenceTimestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 + 60 * 60) let timestamp2 = timestamp + 3660 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: nil, notificationSettings: nil, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: nil, notificationSettings: nil, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp3 = timestamp + 3200 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp4 = timestamp + 3000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp5 = timestamp + 1000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer5), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer5), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let width: CGFloat if case .regular = layout.metrics.widthClass { diff --git a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift index b18d7c1350..d5fba9ca02 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift @@ -439,17 +439,17 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate let timestamp = self.referenceTimestamp let timestamp1 = timestamp + 120 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let presenceTimestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 + 60 * 60) let timestamp2 = timestamp + 3660 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_2_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), notificationSettings: nil, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_2_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), notificationSettings: nil, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp3 = timestamp + 3200 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp4 = timestamp + 3000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let params = ListViewItemLayoutParams(width: layout.size.width, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right, availableHeight: layout.size.height) if let chatNodes = self.chatNodes { diff --git a/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift b/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift index e7d6914a6b..e72b744a91 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift @@ -351,24 +351,24 @@ final class ThemePreviewControllerNode: ASDisplayNode, UIScrollViewDelegate { let timestamp = self.referenceTimestamp let timestamp1 = timestamp + 120 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let presenceTimestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 + 60 * 60) let timestamp2 = timestamp + 3660 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: nil, notificationSettings: nil, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: nil, notificationSettings: nil, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp3 = timestamp + 3200 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp4 = timestamp + 3000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp5 = timestamp + 1000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer5), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer5), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer7.id, namespace: 0, id: 0), timestamp: timestamp - 420)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer7.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 420, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_7_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer7), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer7.id, namespace: 0, id: 0), timestamp: timestamp - 420)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer7.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 420, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_7_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer7), combinedReadState: nil, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let width: CGFloat if case .regular = layout.metrics.widthClass { diff --git a/submodules/ShareController/Sources/ShareController.swift b/submodules/ShareController/Sources/ShareController.swift index 13ba27508e..f6a5058f44 100644 --- a/submodules/ShareController/Sources/ShareController.swift +++ b/submodules/ShareController/Sources/ShareController.swift @@ -804,7 +804,7 @@ public final class ShareController: ViewController { var peers: [RenderedPeer] = [] for entry in view.0.entries.reversed() { switch entry { - case let .MessageEntry(_, _, _, _, _, renderedPeer, _, _): + case let .MessageEntry(_, _, _, _, _, renderedPeer, _, _, _): if let peer = renderedPeer.peers[renderedPeer.peerId], peer.id != accountPeer.id, canSendMessagesToPeer(peer) { peers.append(renderedPeer) } diff --git a/submodules/TelegramCore/Sources/ChatHistoryPreloadManager.swift b/submodules/TelegramCore/Sources/ChatHistoryPreloadManager.swift index fa191f7b8f..6d94467075 100644 --- a/submodules/TelegramCore/Sources/ChatHistoryPreloadManager.swift +++ b/submodules/TelegramCore/Sources/ChatHistoryPreloadManager.swift @@ -336,7 +336,7 @@ final class ChatHistoryPreloadManager { var indices: [(ChatHistoryPreloadIndex, Bool, Bool)] = [] for entry in view.0.entries { - if case let .MessageEntry(index, _, readState, notificationSettings, _, _, _, _) = entry { + if case let .MessageEntry(index, _, readState, notificationSettings, _, _, _, _, _) = entry { var hasUnread = false if let readState = readState { hasUnread = readState.count != 0 diff --git a/submodules/TelegramNotices/Sources/Notices.swift b/submodules/TelegramNotices/Sources/Notices.swift index 7f281eb5c5..4389e7edb2 100644 --- a/submodules/TelegramNotices/Sources/Notices.swift +++ b/submodules/TelegramNotices/Sources/Notices.swift @@ -133,6 +133,7 @@ private enum ApplicationSpecificGlobalNotice: Int32 { case cellularDataPermissionWarning = 13 case chatMessageSearchResultsTip = 14 case chatMessageOptionsTip = 15 + case chatTextSelectionTip = 16 var key: ValueBoxKey { let v = ValueBoxKey(length: 4) @@ -238,6 +239,10 @@ private struct ApplicationSpecificNoticeKeys { static func chatMessageOptionsTip() -> NoticeEntryKey { return NoticeEntryKey(namespace: noticeNamespace(namespace: globalNamespace), key: ApplicationSpecificGlobalNotice.chatMessageOptionsTip.key) } + + static func chatTextSelectionTip() -> NoticeEntryKey { + return NoticeEntryKey(namespace: noticeNamespace(namespace: globalNamespace), key: ApplicationSpecificGlobalNotice.chatTextSelectionTip.key) + } } public struct ApplicationSpecificNotice { @@ -573,6 +578,28 @@ public struct ApplicationSpecificNotice { } } + public static func getChatTextSelectionTips(accountManager: AccountManager) -> Signal { + return accountManager.transaction { transaction -> Int32 in + if let value = transaction.getNotice(ApplicationSpecificNoticeKeys.chatTextSelectionTip()) as? ApplicationSpecificCounterNotice { + return value.value + } else { + return 0 + } + } + } + + public static func incrementChatTextSelectionTips(accountManager: AccountManager, count: Int32 = 1) -> Signal { + return accountManager.transaction { transaction -> Void in + var currentValue: Int32 = 0 + if let value = transaction.getNotice(ApplicationSpecificNoticeKeys.chatTextSelectionTip()) as? ApplicationSpecificCounterNotice { + currentValue = value.value + } + currentValue += count + + transaction.setNotice(ApplicationSpecificNoticeKeys.chatTextSelectionTip(), ApplicationSpecificCounterNotice(value: currentValue)) + } + } + public static func reset(accountManager: AccountManager) -> Signal { return accountManager.transaction { transaction -> Void in } diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 1d1e71c243..f95b28ce8c 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -2776,1944 +2776,1947 @@ public final class PresentationStrings: Equatable { public var LoginPassword_PasswordHelp: String { return self._s[2363]! } public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2364]! } public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2365]! } - public var Checkout_TotalPaidAmount: String { return self._s[2366]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2366]! } + public var Checkout_TotalPaidAmount: String { return self._s[2367]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2367]!, self._r[2367]!, [_0]) + return formatWithArgumentRanges(self._s[2368]!, self._r[2368]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[2368]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2370]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2371]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2369]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2371]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2372]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2372]!, self._r[2372]!, [_1]) + return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2373]! } - public var Contacts_InviteFriends: String { return self._s[2375]! } - public var Map_ChooseLocationTitle: String { return self._s[2376]! } - public var Conversation_StopPoll: String { return self._s[2378]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2374]! } + public var Contacts_InviteFriends: String { return self._s[2376]! } + public var Map_ChooseLocationTitle: String { return self._s[2377]! } + public var Conversation_StopPoll: String { return self._s[2379]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2379]!, self._r[2379]!, [_0]) + return formatWithArgumentRanges(self._s[2380]!, self._r[2380]!, [_0]) } - public var Call_Camera: String { return self._s[2380]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2381]! } - public var AppWallet_Intro_Text: String { return self._s[2382]! } - public var Calls_RatingFeedback: String { return self._s[2383]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2384]! } - public var Wallet_Alert_OK: String { return self._s[2385]! } - public var NotificationsSound_Pulse: String { return self._s[2386]! } - public var Watch_LastSeen_Lately: String { return self._s[2387]! } - public var ReportGroupLocation_Report: String { return self._s[2390]! } - public var Widget_NoUsers: String { return self._s[2391]! } - public var Conversation_UnvotePoll: String { return self._s[2392]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2394]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2395]! } - public var NotificationsSound_Circles: String { return self._s[2396]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2399]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2400]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2401]! } - public var Proxy_TooltipUnavailable: String { return self._s[2402]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2404]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2406]! } - public var Conversation_FileDropbox: String { return self._s[2407]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2408]! } - public var Tour_Text3: String { return self._s[2410]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2412]! } - public var GroupPermission_NoSendMessages: String { return self._s[2413]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2414]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2415]! } + public var Call_Camera: String { return self._s[2381]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2382]! } + public var AppWallet_Intro_Text: String { return self._s[2383]! } + public var Calls_RatingFeedback: String { return self._s[2384]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2385]! } + public var Wallet_Alert_OK: String { return self._s[2386]! } + public var NotificationsSound_Pulse: String { return self._s[2387]! } + public var Watch_LastSeen_Lately: String { return self._s[2388]! } + public var ReportGroupLocation_Report: String { return self._s[2391]! } + public var Widget_NoUsers: String { return self._s[2392]! } + public var Conversation_UnvotePoll: String { return self._s[2393]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2395]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2396]! } + public var NotificationsSound_Circles: String { return self._s[2397]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2400]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2401]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2402]! } + public var Proxy_TooltipUnavailable: String { return self._s[2403]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2405]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2407]! } + public var Conversation_FileDropbox: String { return self._s[2408]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2409]! } + public var Tour_Text3: String { return self._s[2411]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2413]! } + public var GroupPermission_NoSendMessages: String { return self._s[2414]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2415]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2416]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2417]!, self._r[2417]!, [_0]) + return formatWithArgumentRanges(self._s[2418]!, self._r[2418]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2418]! } - public var Checkout_ShippingOption_Title: String { return self._s[2419]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2420]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2419]! } + public var Checkout_ShippingOption_Title: String { return self._s[2420]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2421]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2421]!, self._r[2421]!, [_0]) - } - public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2422]!, self._r[2422]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2423]! } - public var EditTheme_FileReadError: String { return self._s[2424]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2425]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2426]! } - public var AutoDownloadSettings_Photos: String { return self._s[2428]! } - public var Appearance_PreviewIncomingText: String { return self._s[2429]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2430]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2431]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2432]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2433]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2434]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2435]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2436]! } - public var Notification_SecretChatScreenshot: String { return self._s[2437]! } - public var AccessDenied_Wallpapers: String { return self._s[2438]! } - public var ChatList_Context_Mute: String { return self._s[2440]! } - public var Passport_Address_City: String { return self._s[2441]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2442]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2443]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2444]! } - public var AccessDenied_LocationDisabled: String { return self._s[2445]! } - public var Group_Location_Title: String { return self._s[2446]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2448]! } - public var GroupInfo_Sound: String { return self._s[2449]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2450]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2451]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2452]! } - public var Contacts_Title: String { return self._s[2453]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2454]! } - public var Passport_Language_fr: String { return self._s[2455]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2456]! } - public var Notifications_ResetAllNotifications: String { return self._s[2457]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2459]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2461]! } - public var Checkout_NewCard_Title: String { return self._s[2462]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2463]! } - public var Conversation_ForwardChats: String { return self._s[2464]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2466]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2467]! } - public var Settings_FAQ: String { return self._s[2469]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2470]! } - public var Conversation_ContextMenuForward: String { return self._s[2471]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2474]! } - public var PrivacyPolicy_Title: String { return self._s[2477]! } - public var Notifications_TextTone: String { return self._s[2478]! } - public var Profile_CreateNewContact: String { return self._s[2479]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2480]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2482]! } - public var Call_Speaker: String { return self._s[2483]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2484]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2486]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2487]! } + public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2423]!, self._r[2423]!, [_0]) + } + public var Channel_Management_LabelAdministrator: String { return self._s[2424]! } + public var EditTheme_FileReadError: String { return self._s[2425]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2426]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2427]! } + public var AutoDownloadSettings_Photos: String { return self._s[2429]! } + public var Appearance_PreviewIncomingText: String { return self._s[2430]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2431]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2432]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2433]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2434]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2435]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2436]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2437]! } + public var Notification_SecretChatScreenshot: String { return self._s[2438]! } + public var AccessDenied_Wallpapers: String { return self._s[2439]! } + public var ChatList_Context_Mute: String { return self._s[2441]! } + public var Passport_Address_City: String { return self._s[2442]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2443]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2444]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2445]! } + public var AccessDenied_LocationDisabled: String { return self._s[2446]! } + public var Group_Location_Title: String { return self._s[2447]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2449]! } + public var GroupInfo_Sound: String { return self._s[2450]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2451]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2452]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2453]! } + public var Contacts_Title: String { return self._s[2454]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2455]! } + public var Passport_Language_fr: String { return self._s[2456]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2457]! } + public var Notifications_ResetAllNotifications: String { return self._s[2458]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2460]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2462]! } + public var Checkout_NewCard_Title: String { return self._s[2463]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2464]! } + public var Conversation_ForwardChats: String { return self._s[2465]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2467]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2468]! } + public var Settings_FAQ: String { return self._s[2470]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2471]! } + public var Conversation_ContextMenuForward: String { return self._s[2472]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2475]! } + public var PrivacyPolicy_Title: String { return self._s[2478]! } + public var Notifications_TextTone: String { return self._s[2479]! } + public var Profile_CreateNewContact: String { return self._s[2480]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2481]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2483]! } + public var Call_Speaker: String { return self._s[2484]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2485]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2487]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2488]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2488]!, self._r[2488]!, [_0]) + return formatWithArgumentRanges(self._s[2489]!, self._r[2489]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2489]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2490]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2491]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2492]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2493]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2494]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2495]! } - public var Bot_Unblock: String { return self._s[2496]! } - public var TextFormat_Italic: String { return self._s[2497]! } - public var WallpaperSearch_ColorPink: String { return self._s[2498]! } - public var Settings_About_Help: String { return self._s[2499]! } - public var SearchImages_Title: String { return self._s[2500]! } - public var Weekday_Wednesday: String { return self._s[2501]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2502]! } - public var ExplicitContent_AlertTitle: String { return self._s[2503]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2490]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2491]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2492]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2493]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2494]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2495]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2496]! } + public var Bot_Unblock: String { return self._s[2497]! } + public var TextFormat_Italic: String { return self._s[2498]! } + public var WallpaperSearch_ColorPink: String { return self._s[2499]! } + public var Settings_About_Help: String { return self._s[2500]! } + public var SearchImages_Title: String { return self._s[2501]! } + public var Weekday_Wednesday: String { return self._s[2502]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2503]! } + public var ExplicitContent_AlertTitle: String { return self._s[2504]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2504]!, self._r[2504]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2505]!, self._r[2505]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2505]! } - public var Weekday_Thursday: String { return self._s[2506]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2507]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2508]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2506]! } + public var Weekday_Thursday: String { return self._s[2507]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2508]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2509]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2509]!, self._r[2509]!, [_0]) + return formatWithArgumentRanges(self._s[2510]!, self._r[2510]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2510]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2511]! } - public var Passport_RequestedInformation: String { return self._s[2512]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2513]! } - public var Conversation_EncryptionProcessing: String { return self._s[2515]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2516]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2518]! } - public var Channel_Setup_Title: String { return self._s[2519]! } - public var Conversation_SearchPlaceholder: String { return self._s[2520]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2521]! } - public var Checkout_ErrorGeneric: String { return self._s[2522]! } - public var Passport_Language_hu: String { return self._s[2523]! } - public var GroupPermission_EditingDisabled: String { return self._s[2524]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2526]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2511]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2512]! } + public var Passport_RequestedInformation: String { return self._s[2513]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2514]! } + public var Conversation_EncryptionProcessing: String { return self._s[2516]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2517]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2519]! } + public var Channel_Setup_Title: String { return self._s[2520]! } + public var Conversation_SearchPlaceholder: String { return self._s[2521]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2522]! } + public var Checkout_ErrorGeneric: String { return self._s[2523]! } + public var Passport_Language_hu: String { return self._s[2524]! } + public var GroupPermission_EditingDisabled: String { return self._s[2525]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2527]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2527]!, self._r[2527]!, [_0]) + return formatWithArgumentRanges(self._s[2528]!, self._r[2528]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2530]!, self._r[2530]!, [_1]) + return formatWithArgumentRanges(self._s[2531]!, self._r[2531]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2531]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2532]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2532]!, self._r[2532]!, [_0]) + return formatWithArgumentRanges(self._s[2533]!, self._r[2533]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2533]! } - public var Group_Location_Info: String { return self._s[2534]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2535]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2536]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2534]! } + public var Group_Location_Info: String { return self._s[2535]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2536]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2537]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2537]!, self._r[2537]!, [_0]) + return formatWithArgumentRanges(self._s[2538]!, self._r[2538]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2538]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2539]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2540]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2541]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2539]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2540]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2541]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2542]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2542]!, self._r[2542]!, [_0]) + return formatWithArgumentRanges(self._s[2543]!, self._r[2543]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2543]! } - public var Message_PinnedAnimationMessage: String { return self._s[2545]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2547]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2548]! } - public var Wallet_Info_TransactionTo: String { return self._s[2550]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2551]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2552]! } - public var Embed_PlayingInPIP: String { return self._s[2553]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2554]! } + public var Passport_Language_cs: String { return self._s[2544]! } + public var Message_PinnedAnimationMessage: String { return self._s[2546]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2548]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2549]! } + public var Wallet_Info_TransactionTo: String { return self._s[2551]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2552]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2553]! } + public var Embed_PlayingInPIP: String { return self._s[2554]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2555]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2555]!, self._r[2555]!, [_0]) + return formatWithArgumentRanges(self._s[2556]!, self._r[2556]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2556]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2557]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2557]!, self._r[2557]!, [_1]) + return formatWithArgumentRanges(self._s[2558]!, self._r[2558]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2558]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2559]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2560]! } - public var AutoNightTheme_System: String { return self._s[2561]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2562]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2563]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2564]! } + public var Notification_PaymentSent: String { return self._s[2559]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2560]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2561]! } + public var AutoNightTheme_System: String { return self._s[2562]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2563]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2564]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2565]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2567]!, self._r[2567]!, [_1]) - } - public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2568]!, self._r[2568]!, [_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[2569]!, self._r[2569]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2571]! } - public var PasscodeSettings_HelpTop: String { return self._s[2572]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2573]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2574]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2575]! } - public var EditTheme_ShortLink: String { return self._s[2576]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2577]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2578]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2579]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2580]! } - public var Call_Accept: String { return self._s[2582]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2583]! } - public var Month_GenMarch: String { return self._s[2585]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2586]! } - public var LoginPassword_Title: String { return self._s[2587]! } - public var Call_End: String { return self._s[2588]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2589]! } - public var VoiceOver_Chat_Contact: String { return self._s[2590]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2591]! } - public var CallSettings_Always: String { return self._s[2592]! } - public var CallFeedback_Success: String { return self._s[2593]! } - public var TwoStepAuth_SetupHint: String { return self._s[2594]! } + public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2570]!, self._r[2570]!, [_1]) + } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2572]! } + public var PasscodeSettings_HelpTop: String { return self._s[2573]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2574]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2575]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2576]! } + public var EditTheme_ShortLink: String { return self._s[2577]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2578]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2579]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2580]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2581]! } + public var Call_Accept: String { return self._s[2583]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2584]! } + public var Month_GenMarch: String { return self._s[2586]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2587]! } + public var LoginPassword_Title: String { return self._s[2588]! } + public var Call_End: String { return self._s[2589]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2590]! } + public var VoiceOver_Chat_Contact: String { return self._s[2591]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2592]! } + public var CallSettings_Always: String { return self._s[2593]! } + public var CallFeedback_Success: String { return self._s[2594]! } + public var TwoStepAuth_SetupHint: String { return self._s[2595]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2595]!, self._r[2595]!, [_1]) + return formatWithArgumentRanges(self._s[2596]!, self._r[2596]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2596]! } - public var Login_PhoneTitle: String { return self._s[2597]! } - public var Passport_FieldPhoneHelp: String { return self._s[2598]! } - public var Weekday_ShortSunday: String { return self._s[2599]! } - public var Passport_InfoFAQ_URL: String { return self._s[2600]! } - public var ContactInfo_Job: String { return self._s[2602]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2603]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2604]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2605]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2606]! } - public var Invite_ChannelsTooMuch: String { return self._s[2607]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2608]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2609]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2610]! } - public var Wallet_Receive_AmountText: String { return self._s[2611]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2612]! } - public var CallFeedback_ReasonNoise: String { return self._s[2613]! } - public var Appearance_AppIconDefault: String { return self._s[2615]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2616]! } - public var MediaPicker_AddCaption: String { return self._s[2617]! } - public var CallSettings_TabIconDescription: String { return self._s[2618]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2597]! } + public var Login_PhoneTitle: String { return self._s[2598]! } + public var Passport_FieldPhoneHelp: String { return self._s[2599]! } + public var Weekday_ShortSunday: String { return self._s[2600]! } + public var Passport_InfoFAQ_URL: String { return self._s[2601]! } + public var ContactInfo_Job: String { return self._s[2603]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2604]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2605]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2606]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2607]! } + public var Invite_ChannelsTooMuch: String { return self._s[2608]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2609]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2610]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2611]! } + public var Wallet_Receive_AmountText: String { return self._s[2612]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2613]! } + public var CallFeedback_ReasonNoise: String { return self._s[2614]! } + public var Appearance_AppIconDefault: String { return self._s[2616]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2617]! } + public var MediaPicker_AddCaption: String { return self._s[2618]! } + public var CallSettings_TabIconDescription: String { return self._s[2619]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2619]!, self._r[2619]!, [_0]) + return formatWithArgumentRanges(self._s[2620]!, self._r[2620]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2620]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2621]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2621]!, self._r[2621]!, [_0]) + return formatWithArgumentRanges(self._s[2622]!, self._r[2622]!, [_0]) } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2622]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2623]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2624]! } - public var DialogList_SearchSectionRecent: String { return self._s[2625]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2626]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2629]! } - public var LastSeen_WithinAWeek: String { return self._s[2630]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2631]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2633]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2634]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2623]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2624]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2625]! } + public var DialogList_SearchSectionRecent: String { return self._s[2626]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2627]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2630]! } + public var LastSeen_WithinAWeek: String { return self._s[2631]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2632]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2634]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2635]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2635]!, self._r[2635]!, [_0]) + return formatWithArgumentRanges(self._s[2636]!, self._r[2636]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2636]! } - public var Conversation_StatusLeftGroup: String { return self._s[2637]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2638]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2640]! } - public var GroupPermission_AddSuccess: String { return self._s[2641]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2643]! } - public var Conversation_ContextMenuCopy: String { return self._s[2644]! } - public var AccessDenied_CallMicrophone: String { return self._s[2645]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2637]! } + public var Conversation_StatusLeftGroup: String { return self._s[2638]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2639]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2641]! } + public var GroupPermission_AddSuccess: String { return self._s[2642]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2644]! } + public var Conversation_ContextMenuCopy: String { return self._s[2645]! } + public var AccessDenied_CallMicrophone: String { return self._s[2646]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2646]!, self._r[2646]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2647]!, self._r[2647]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2647]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2648]! } - public var Checkout_PaymentMethod_New: String { return self._s[2649]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2650]! } - public var PhotoEditor_QualityTool: String { return self._s[2651]! } - public var Login_SendCodeViaSms: String { return self._s[2652]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2653]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2654]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2655]! } - public var Login_EmailNotConfiguredError: String { return self._s[2656]! } - public var SocksProxySetup_Status: String { return self._s[2657]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2658]! } - public var PrivacyPolicy_Accept: String { return self._s[2659]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2660]! } - public var Appearance_AppIconClassicX: String { return self._s[2661]! } + public var Login_InvalidFirstNameError: String { return self._s[2648]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2649]! } + public var Checkout_PaymentMethod_New: String { return self._s[2650]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2651]! } + public var PhotoEditor_QualityTool: String { return self._s[2652]! } + public var Login_SendCodeViaSms: String { return self._s[2653]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2654]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2655]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2656]! } + public var Login_EmailNotConfiguredError: String { return self._s[2657]! } + public var SocksProxySetup_Status: String { return self._s[2658]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2659]! } + public var PrivacyPolicy_Accept: String { return self._s[2660]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2661]! } + public var Appearance_AppIconClassicX: String { return self._s[2662]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2662]!, self._r[2662]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2663]!, self._r[2663]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2663]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2665]! } - public var AutoNightTheme_Automatic: String { return self._s[2666]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2667]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2668]! } - public var Cache_Help: String { return self._s[2669]! } - public var Group_ErrorAccessDenied: String { return self._s[2670]! } - public var Passport_Language_fa: String { return self._s[2671]! } - public var Wallet_Intro_Text: String { return self._s[2672]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2673]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2674]! } - public var PrivacySettings_LastSeen: String { return self._s[2675]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2664]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2666]! } + public var AutoNightTheme_Automatic: String { return self._s[2667]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2668]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2669]! } + public var Cache_Help: String { return self._s[2670]! } + public var Group_ErrorAccessDenied: String { return self._s[2671]! } + public var Passport_Language_fa: String { return self._s[2672]! } + public var Wallet_Intro_Text: String { return self._s[2673]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2674]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2675]! } + public var PrivacySettings_LastSeen: String { return self._s[2676]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2676]!, self._r[2676]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2677]!, self._r[2677]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2680]! } - public var Preview_SaveGif: String { return self._s[2681]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2682]! } - public var Profile_About: String { return self._s[2683]! } - public var Channel_About_Placeholder: String { return self._s[2684]! } - public var Login_InfoTitle: String { return self._s[2685]! } + public var Wallet_Configuration_Apply: String { return self._s[2681]! } + public var Preview_SaveGif: String { return self._s[2682]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2683]! } + public var Profile_About: String { return self._s[2684]! } + public var Channel_About_Placeholder: String { return self._s[2685]! } + public var Login_InfoTitle: String { return self._s[2686]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2686]!, self._r[2686]!, [_0]) + return formatWithArgumentRanges(self._s[2687]!, self._r[2687]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2687]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2689]! } - public var ContactInfo_Title: String { return self._s[2690]! } - public var Media_ShareThisVideo: String { return self._s[2691]! } - public var Weekday_ShortFriday: String { return self._s[2692]! } - public var AccessDenied_Contacts: String { return self._s[2694]! } - public var Notification_CallIncomingShort: String { return self._s[2695]! } - public var Group_Setup_TypePublic: String { return self._s[2696]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2697]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2698]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2701]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2702]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2703]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2704]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2705]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2688]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2690]! } + public var ContactInfo_Title: String { return self._s[2691]! } + public var Media_ShareThisVideo: String { return self._s[2692]! } + public var Weekday_ShortFriday: String { return self._s[2693]! } + public var AccessDenied_Contacts: String { return self._s[2695]! } + public var Notification_CallIncomingShort: String { return self._s[2696]! } + public var Group_Setup_TypePublic: String { return self._s[2697]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2698]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2699]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2702]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2703]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2704]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2705]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2706]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2706]!, self._r[2706]!, [_0]) + return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_0]) } - public var DialogList_Typing: String { return self._s[2707]! } - public var CallFeedback_IncludeLogs: String { return self._s[2709]! } - public var Checkout_Phone: String { return self._s[2711]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2714]! } - public var Privacy_Calls_Integration: String { return self._s[2715]! } - public var Notifications_PermissionsAllow: String { return self._s[2716]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2720]! } - public var Settings_ChatSettings: String { return self._s[2721]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2722]! } + public var DialogList_Typing: String { return self._s[2708]! } + public var CallFeedback_IncludeLogs: String { return self._s[2710]! } + public var Checkout_Phone: String { return self._s[2712]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2715]! } + public var Privacy_Calls_Integration: String { return self._s[2716]! } + public var Notifications_PermissionsAllow: String { return self._s[2717]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2721]! } + public var Settings_ChatSettings: String { return self._s[2722]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2723]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2723]!, self._r[2723]!, [_0]) + return formatWithArgumentRanges(self._s[2724]!, self._r[2724]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2724]!, self._r[2724]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2725]!, self._r[2725]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2726]! } + public var GroupRemoved_DeleteUser: String { return self._s[2727]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2727]!, self._r[2727]!, [_0]) + return formatWithArgumentRanges(self._s[2728]!, self._r[2728]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2728]!, self._r[2728]!, [_1]) + return formatWithArgumentRanges(self._s[2729]!, self._r[2729]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2729]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2730]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2732]! } - public var Conversation_Unblock: String { return self._s[2733]! } - public var PrivacySettings_DataSettings: String { return self._s[2734]! } - public var Group_PublicLink_Info: String { return self._s[2735]! } + public var Login_ContinueWithLocalization: String { return self._s[2730]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2731]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2733]! } + public var Conversation_Unblock: String { return self._s[2734]! } + public var PrivacySettings_DataSettings: String { return self._s[2735]! } + public var Group_PublicLink_Info: String { return self._s[2736]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2736]!, self._r[2736]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2737]!, self._r[2737]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2737]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2738]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2738]!, self._r[2738]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2739]!, self._r[2739]!, [_0, _1]) } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2740]! } - public var PrivacySettings_Passcode: String { return self._s[2742]! } - public var Call_Mute: String { return self._s[2743]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2744]! } - public var Passport_Language_dz: String { return self._s[2745]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2746]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2747]! } - public var Passport_Language_tk: String { return self._s[2748]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2741]! } + public var PrivacySettings_Passcode: String { return self._s[2743]! } + public var Call_Mute: String { return self._s[2744]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2745]! } + public var Passport_Language_dz: String { return self._s[2746]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2747]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2748]! } + public var Passport_Language_tk: String { return self._s[2749]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2749]!, self._r[2749]!, [_0]) + return formatWithArgumentRanges(self._s[2750]!, self._r[2750]!, [_0]) } - public var Settings_Search: String { return self._s[2750]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2751]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2752]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2753]! } - public var Conversation_ContextMenuReply: String { return self._s[2754]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2755]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2756]! } - public var Tour_Title1: String { return self._s[2757]! } - public var Wallet_Alert_Cancel: String { return self._s[2758]! } - public var Conversation_ClearGroupHistory: String { return self._s[2760]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2761]! } - public var WallpaperPreview_Motion: String { return self._s[2762]! } + public var Settings_Search: String { return self._s[2751]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2752]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2753]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2754]! } + public var Conversation_ContextMenuReply: String { return self._s[2755]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2756]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2757]! } + public var Tour_Title1: String { return self._s[2758]! } + public var Wallet_Alert_Cancel: String { return self._s[2759]! } + public var Conversation_ClearGroupHistory: String { return self._s[2761]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2762]! } + public var WallpaperPreview_Motion: String { return self._s[2763]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2763]!, self._r[2763]!, [_0]) + return formatWithArgumentRanges(self._s[2764]!, self._r[2764]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2764]! } - public var Call_RateCall: String { return self._s[2765]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2766]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2767]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2768]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2770]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2765]! } + public var Call_RateCall: String { return self._s[2766]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2767]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2768]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2769]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2771]! } public func Login_WillCallYou(_ _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 Compose_Create: String { return self._s[2773]! } - public var Contacts_InviteToTelegram: String { return self._s[2774]! } - public var GroupInfo_Notifications: String { return self._s[2775]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2777]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2778]! } - public var Month_GenApril: String { return self._s[2779]! } - public var Appearance_AutoNightTheme: String { return self._s[2780]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2782]! } - public var Login_CodeSentSms: String { return self._s[2784]! } + public var Compose_Create: String { return self._s[2774]! } + public var Contacts_InviteToTelegram: String { return self._s[2775]! } + public var GroupInfo_Notifications: String { return self._s[2776]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2778]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2779]! } + public var Month_GenApril: String { return self._s[2780]! } + public var Appearance_AutoNightTheme: String { return self._s[2781]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2783]! } + public var Login_CodeSentSms: String { return self._s[2785]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2785]!, self._r[2785]!, [_0]) + return formatWithArgumentRanges(self._s[2786]!, self._r[2786]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2786]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2787]! } - public var Passport_Language_hr: String { return self._s[2788]! } - public var Common_ActionNotAllowedError: String { return self._s[2789]! } + public var EmptyGroupInfo_Line3: String { return self._s[2787]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2788]! } + public var Passport_Language_hr: String { return self._s[2789]! } + public var Common_ActionNotAllowedError: String { return self._s[2790]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _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 GroupInfo_InviteLink_CopyLink: String { return self._s[2791]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2792]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2793]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2794]! } - public var Privacy_SecretChatsTitle: String { return self._s[2795]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2797]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2798]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2799]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2800]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2801]! } - public var Preview_DeleteGif: String { return self._s[2802]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2803]! } - public var Group_ErrorNotMutualContact: String { return self._s[2804]! } - public var Notification_MessageLifetime5s: String { return self._s[2805]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[2806]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2792]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2793]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2794]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2795]! } + public var Privacy_SecretChatsTitle: String { return self._s[2796]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2798]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2799]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2800]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2801]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2802]! } + public var Preview_DeleteGif: String { return self._s[2803]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2804]! } + public var Group_ErrorNotMutualContact: String { return self._s[2805]! } + public var Notification_MessageLifetime5s: String { return self._s[2806]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[2807]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2807]!, self._r[2807]!, [_0]) + return formatWithArgumentRanges(self._s[2808]!, self._r[2808]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2808]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2810]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2811]! } - public var Passport_Address_AddBankStatement: String { return self._s[2812]! } - public var Notification_CallIncoming: String { return self._s[2813]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[2814]! } - public var Compose_NewGroupTitle: String { return self._s[2815]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2817]! } - public var Passport_Address_Postcode: String { return self._s[2819]! } + public var VoiceOver_Chat_Video: String { return self._s[2809]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2811]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2812]! } + public var Passport_Address_AddBankStatement: String { return self._s[2813]! } + public var Notification_CallIncoming: String { return self._s[2814]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[2815]! } + public var Compose_NewGroupTitle: String { return self._s[2816]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2818]! } + public var Passport_Address_Postcode: String { return self._s[2820]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2820]!, self._r[2820]!, [_0]) + return formatWithArgumentRanges(self._s[2821]!, self._r[2821]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2821]! } - public var Wallet_Month_ShortOctober: String { return self._s[2822]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2823]! } - public var WallpaperColors_Title: String { return self._s[2824]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2825]! } - public var VoiceOver_MessageContextForward: String { return self._s[2826]! } - public var GroupPermission_Duration: String { return self._s[2827]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2822]! } + public var Wallet_Month_ShortOctober: String { return self._s[2823]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2824]! } + public var WallpaperColors_Title: String { return self._s[2825]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2826]! } + public var VoiceOver_MessageContextForward: String { return self._s[2827]! } + public var GroupPermission_Duration: String { return self._s[2828]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2828]!, self._r[2828]!, [_0]) + return formatWithArgumentRanges(self._s[2829]!, self._r[2829]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2829]! } - public var Username_Placeholder: String { return self._s[2830]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2831]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2832]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2833]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2830]! } + public var Username_Placeholder: String { return self._s[2831]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2832]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2833]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2834]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2835]!, self._r[2835]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2836]!, self._r[2836]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[2836]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2837]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2838]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2839]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2840]! } - public var Conversation_ContextMenuMore: String { return self._s[2841]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2842]! } - public var CallSettings_TabIcon: String { return self._s[2843]! } - public var KeyCommand_Find: String { return self._s[2844]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[2845]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2846]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2847]! } - public var Message_PinnedGame: String { return self._s[2848]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2849]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2851]! } - public var Login_CallRequestState2: String { return self._s[2853]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2855]! } + public var Passport_PasswordDescription: String { return self._s[2837]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2838]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2839]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2840]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2841]! } + public var Conversation_ContextMenuMore: String { return self._s[2842]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2843]! } + public var CallSettings_TabIcon: String { return self._s[2844]! } + public var KeyCommand_Find: String { return self._s[2845]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[2846]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2847]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2848]! } + public var Message_PinnedGame: String { return self._s[2849]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2850]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2852]! } + public var Login_CallRequestState2: String { return self._s[2854]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2856]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2856]!, self._r[2856]!, [_0]) + return formatWithArgumentRanges(self._s[2857]!, self._r[2857]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2858]!, self._r[2858]!, [_0]) + return formatWithArgumentRanges(self._s[2859]!, self._r[2859]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[2859]! } - public var WallpaperPreview_Blurred: String { return self._s[2860]! } - public var Conversation_InstantPagePreview: String { return self._s[2861]! } + public var AuthSessions_AddDevice: String { return self._s[2860]! } + public var WallpaperPreview_Blurred: String { return self._s[2861]! } + public var Conversation_InstantPagePreview: String { return self._s[2862]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2862]!, self._r[2862]!, [_0]) + return formatWithArgumentRanges(self._s[2863]!, self._r[2863]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2865]! } - public var WallpaperSearch_ColorRed: String { return self._s[2866]! } - public var GroupPermission_NoPinMessages: String { return self._s[2867]! } - public var Passport_Language_es: String { return self._s[2868]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2870]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2871]! } + public var SecretTimer_VideoDescription: String { return self._s[2866]! } + public var WallpaperSearch_ColorRed: String { return self._s[2867]! } + public var GroupPermission_NoPinMessages: String { return self._s[2868]! } + public var Passport_Language_es: String { return self._s[2869]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2871]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2872]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2872]!, self._r[2872]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2873]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2874]! } - public var Watch_UserInfo_Unmute: String { return self._s[2875]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2876]! } - public var AccessDenied_CameraRestricted: String { return self._s[2878]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2874]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2875]! } + public var Watch_UserInfo_Unmute: String { return self._s[2876]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2877]! } + public var AccessDenied_CameraRestricted: String { return self._s[2879]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2879]!, self._r[2879]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2880]!, self._r[2880]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2881]! } - public var Settings_CopyUsername: String { return self._s[2882]! } - public var Contacts_SearchLabel: String { return self._s[2883]! } - public var Map_OpenInYandexNavigator: String { return self._s[2885]! } - public var PasscodeSettings_EncryptData: String { return self._s[2886]! } - public var Settings_Wallet: String { return self._s[2887]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2888]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2889]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2890]! } - public var DialogList_AdNoticeAlert: String { return self._s[2891]! } - public var Wallet_Month_GenMay: String { return self._s[2893]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2894]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2895]! } - public var Localization_LanguageCustom: String { return self._s[2896]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2897]! } - public var CallFeedback_Title: String { return self._s[2898]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2901]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2902]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[2903]! } - public var Conversation_InfoGroup: String { return self._s[2904]! } - public var Compose_NewMessage: String { return self._s[2905]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2906]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2907]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[2908]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2909]! } + public var ChatList_ReadAll: String { return self._s[2882]! } + public var Settings_CopyUsername: String { return self._s[2883]! } + public var Contacts_SearchLabel: String { return self._s[2884]! } + public var Map_OpenInYandexNavigator: String { return self._s[2886]! } + public var PasscodeSettings_EncryptData: String { return self._s[2887]! } + public var Settings_Wallet: String { return self._s[2888]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2889]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2890]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2891]! } + public var DialogList_AdNoticeAlert: String { return self._s[2892]! } + public var Wallet_Month_GenMay: String { return self._s[2894]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2895]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2896]! } + public var Localization_LanguageCustom: String { return self._s[2897]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2898]! } + public var CallFeedback_Title: String { return self._s[2899]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2902]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2903]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[2904]! } + public var Conversation_InfoGroup: String { return self._s[2905]! } + public var Compose_NewMessage: String { return self._s[2906]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2907]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2908]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[2909]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2910]! } public func Passport_Scans_ScanIndex(_ _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 Channel_AdminLog_CanDeleteMessages: String { return self._s[2911]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2912]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2913]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2914]! } - public var Channel_BlackList_Title: String { return self._s[2915]! } - public var UserInfo_PhoneCall: String { return self._s[2916]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2918]! } - public var Wallet_Month_ShortJanuary: String { return self._s[2919]! } - public var State_connecting: String { return self._s[2920]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2921]! } - public var Wallet_Month_GenMarch: String { return self._s[2922]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[2923]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2912]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2913]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2914]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2915]! } + public var Channel_BlackList_Title: String { return self._s[2916]! } + public var UserInfo_PhoneCall: String { return self._s[2917]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2919]! } + public var Wallet_Month_ShortJanuary: String { return self._s[2920]! } + public var State_connecting: String { return self._s[2921]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2922]! } + public var Wallet_Month_GenMarch: String { return self._s[2923]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[2924]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2924]!, self._r[2924]!, [_0]) - } - public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2925]!, self._r[2925]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2926]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[2927]! } - public var Passport_Identity_EditPassport: String { return self._s[2928]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2930]! } - public var Localization_EnglishLanguageName: String { return self._s[2931]! } - public var Share_AuthDescription: String { return self._s[2932]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2933]! } - public var Passport_Identity_Surname: String { return self._s[2934]! } - public var Compose_TokenListPlaceholder: String { return self._s[2935]! } - public var Wallet_AccessDenied_Camera: String { return self._s[2936]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2937]! } - public var Settings_AboutEmpty: String { return self._s[2938]! } - public var Conversation_Unmute: String { return self._s[2939]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[2941]! } - public var Wallet_Sending_Text: String { return self._s[2942]! } - public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2943]!, self._r[2943]!, [_1]) + public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2926]!, self._r[2926]!, [_0]) } - public var Login_CodeSentCall: String { return self._s[2944]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2946]! } - public var ChatSettings_Appearance: String { return self._s[2947]! } - public var ClearCache_StorageUsage: String { return self._s[2948]! } - public var Appearance_PickAccentColor: String { return self._s[2949]! } + public var Notifications_GroupNotifications: String { return self._s[2927]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[2928]! } + public var Passport_Identity_EditPassport: String { return self._s[2929]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2931]! } + public var Localization_EnglishLanguageName: String { return self._s[2932]! } + public var Share_AuthDescription: String { return self._s[2933]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2934]! } + public var Passport_Identity_Surname: String { return self._s[2935]! } + public var Compose_TokenListPlaceholder: String { return self._s[2936]! } + public var Wallet_AccessDenied_Camera: String { return self._s[2937]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2938]! } + public var Settings_AboutEmpty: String { return self._s[2939]! } + public var Conversation_Unmute: String { return self._s[2940]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[2942]! } + public var Wallet_Sending_Text: String { return self._s[2943]! } + public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2944]!, self._r[2944]!, [_1]) + } + public var Login_CodeSentCall: String { return self._s[2945]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2947]! } + public var ChatSettings_Appearance: String { return self._s[2948]! } + public var ClearCache_StorageUsage: String { return self._s[2949]! } + public var Appearance_PickAccentColor: String { return self._s[2950]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2950]!, self._r[2950]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2951]!, self._r[2951]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2951]!, self._r[2951]!, [_1]) + return formatWithArgumentRanges(self._s[2952]!, self._r[2952]!, [_1]) } - public var Notification_CallMissed: String { return self._s[2952]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2953]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2954]! } - public var Wallet_Month_GenOctober: String { return self._s[2956]! } - public var ChatAdmins_AdminLabel: String { return self._s[2957]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2958]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2960]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2961]! } - public var Month_GenJune: String { return self._s[2962]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[2963]! } - public var Watch_Location_Current: String { return self._s[2964]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[2965]! } - public var Conversation_TitleMute: String { return self._s[2966]! } + public var Notification_CallMissed: String { return self._s[2953]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2954]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2955]! } + public var Wallet_Month_GenOctober: String { return self._s[2957]! } + public var ChatAdmins_AdminLabel: String { return self._s[2958]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2959]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2961]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2962]! } + public var Month_GenJune: String { return self._s[2963]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[2964]! } + public var Watch_Location_Current: String { return self._s[2965]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[2966]! } + public var Conversation_TitleMute: String { return self._s[2967]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_1]) + return formatWithArgumentRanges(self._s[2968]!, self._r[2968]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2968]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2969]! } public func Conversation_Moderate_DeleteAllMessages(_ _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 Call_ReportPlaceholder: String { return self._s[2970]! } - public var Chat_SlowmodeSendError: String { return self._s[2971]! } - public var MaskStickerSettings_Info: String { return self._s[2972]! } - public var EditTheme_Expand_TopInfo: String { return self._s[2973]! } + public var Call_ReportPlaceholder: String { return self._s[2971]! } + public var Chat_SlowmodeSendError: String { return self._s[2972]! } + public var MaskStickerSettings_Info: String { return self._s[2973]! } + public var EditTheme_Expand_TopInfo: String { return self._s[2974]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2974]!, self._r[2974]!, [_0]) + return formatWithArgumentRanges(self._s[2975]!, self._r[2975]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2975]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2977]! } - public var Contacts_ShareTelegram: String { return self._s[2978]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2979]! } - public var Map_AddressOnMap: String { return self._s[2980]! } - public var Channel_ErrorAccessDenied: String { return self._s[2981]! } - public var UserInfo_ScamBotWarning: String { return self._s[2983]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2984]! } - public var Call_ConnectionErrorTitle: String { return self._s[2985]! } - public var UserInfo_NotificationsEnable: String { return self._s[2986]! } - public var ArchivedChats_IntroText1: String { return self._s[2987]! } - public var Tour_Text4: String { return self._s[2990]! } - public var WallpaperSearch_Recent: String { return self._s[2991]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[2992]! } - public var Profile_MessageLifetime2s: String { return self._s[2994]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[2995]! } - public var Notification_MessageLifetime2s: String { return self._s[2996]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2976]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2978]! } + public var Contacts_ShareTelegram: String { return self._s[2979]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2980]! } + public var Map_AddressOnMap: String { return self._s[2981]! } + public var Channel_ErrorAccessDenied: String { return self._s[2982]! } + public var UserInfo_ScamBotWarning: String { return self._s[2984]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2985]! } + public var Call_ConnectionErrorTitle: String { return self._s[2986]! } + public var UserInfo_NotificationsEnable: String { return self._s[2987]! } + public var ArchivedChats_IntroText1: String { return self._s[2988]! } + public var Tour_Text4: String { return self._s[2991]! } + public var WallpaperSearch_Recent: String { return self._s[2992]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[2993]! } + public var Profile_MessageLifetime2s: String { return self._s[2995]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[2996]! } + public var Notification_MessageLifetime2s: String { return self._s[2997]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2997]!, self._r[2997]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2998]!, self._r[2998]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[2998]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[2999]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3000]! } + public var Cache_ClearCache: String { return self._s[2999]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3000]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3001]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3004]!, self._r[3004]!, [_0]) + return formatWithArgumentRanges(self._s[3005]!, self._r[3005]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3006]!, self._r[3006]!, [_0]) + return formatWithArgumentRanges(self._s[3007]!, self._r[3007]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3007]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3008]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3009]! } - public var ChatList_UnarchiveAction: String { return self._s[3010]! } - public var AutoNightTheme_Title: String { return self._s[3011]! } - public var InstantPage_FeedbackButton: String { return self._s[3012]! } - public var Passport_FieldAddress: String { return self._s[3013]! } + public var LocalGroup_Text: String { return self._s[3008]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3009]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3010]! } + public var ChatList_UnarchiveAction: String { return self._s[3011]! } + public var AutoNightTheme_Title: String { return self._s[3012]! } + public var InstantPage_FeedbackButton: String { return self._s[3013]! } + public var Passport_FieldAddress: String { return self._s[3014]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3014]!, self._r[3014]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3015]!, self._r[3015]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3015]! } + public var Month_ShortMarch: String { return self._s[3016]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3016]!, self._r[3016]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3017]!, self._r[3017]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3017]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3018]! } - public var Passport_FloodError: String { return self._s[3019]! } - public var SecretGif_Title: String { return self._s[3020]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3021]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3022]! } - public var Passport_Language_th: String { return self._s[3024]! } - public var Passport_Address_Address: String { return self._s[3025]! } - public var Login_InvalidLastNameError: String { return self._s[3026]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3027]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3028]! } - public var ChatList_Context_Archive: String { return self._s[3029]! } - public var SettingsSearch_FAQ: String { return self._s[3030]! } - public var ShareMenu_Send: String { return self._s[3031]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3033]! } - public var Month_GenNovember: String { return self._s[3035]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3037]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3018]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3019]! } + public var Passport_FloodError: String { return self._s[3020]! } + public var SecretGif_Title: String { return self._s[3021]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3022]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3023]! } + public var Passport_Language_th: String { return self._s[3025]! } + public var Passport_Address_Address: String { return self._s[3026]! } + public var Login_InvalidLastNameError: String { return self._s[3027]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3028]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3029]! } + public var ChatList_Context_Archive: String { return self._s[3030]! } + public var SettingsSearch_FAQ: String { return self._s[3031]! } + public var ShareMenu_Send: String { return self._s[3032]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3034]! } + public var Month_GenNovember: String { return self._s[3036]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3038]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3038]!, self._r[3038]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3039]!, self._r[3039]!, [_1, _2]) } - public var Conversation_SwipeToReplyHintText: String { return self._s[3039]! } - public var Checkout_Email: String { return self._s[3040]! } - public var NotificationsSound_Tritone: String { return self._s[3041]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3043]! } - public var Wallet_ContextMenuCopy: String { return self._s[3045]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3040]! } + public var Checkout_Email: String { return self._s[3041]! } + public var NotificationsSound_Tritone: String { return self._s[3042]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3044]! } + public var Wallet_ContextMenuCopy: String { return self._s[3046]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3047]!, self._r[3047]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3048]!, self._r[3048]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3048]! } + public var Appearance_TextSize_Automatic: String { return self._s[3049]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3049]!, self._r[3049]!, [_1]) + return formatWithArgumentRanges(self._s[3050]!, self._r[3050]!, [_1]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3050]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3051]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3051]!, self._r[3051]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3052]!, self._r[3052]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3052]! } - public var Notification_Exceptions_Add: String { return self._s[3053]! } - public var DialogList_You: String { return self._s[3054]! } - public var MediaPicker_Send: String { return self._s[3057]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3058]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3059]! } - public var Call_AudioRouteSpeaker: String { return self._s[3060]! } - public var Watch_UserInfo_Title: String { return self._s[3061]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3062]! } - public var Appearance_AccentColor: String { return self._s[3064]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3053]! } + public var Notification_Exceptions_Add: String { return self._s[3054]! } + public var DialogList_You: String { return self._s[3055]! } + public var MediaPicker_Send: String { return self._s[3058]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3059]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3060]! } + public var Call_AudioRouteSpeaker: String { return self._s[3061]! } + public var Watch_UserInfo_Title: String { return self._s[3062]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3063]! } + public var Appearance_AccentColor: String { return self._s[3065]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3065]!, self._r[3065]!, [_0]) + return formatWithArgumentRanges(self._s[3066]!, self._r[3066]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3066]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3067]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3067]!, self._r[3067]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3068]!, self._r[3068]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3068]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3069]! } - public var Notification_CallOutgoing: String { return self._s[3070]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3071]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3072]! } - public var Call_RecordingDisabledMessage: String { return self._s[3073]! } - public var Message_Game: String { return self._s[3074]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3075]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3076]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3077]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3078]! } - public var Date_DialogDateFormat: String { return self._s[3079]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3080]! } - public var Notifications_InAppNotifications: String { return self._s[3081]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3069]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3070]! } + public var Notification_CallOutgoing: String { return self._s[3071]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3072]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3073]! } + public var Call_RecordingDisabledMessage: String { return self._s[3074]! } + public var Message_Game: String { return self._s[3075]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3076]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3077]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3078]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3079]! } + public var Date_DialogDateFormat: String { return self._s[3080]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3081]! } + public var Notifications_InAppNotifications: String { return self._s[3082]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3082]!, self._r[3082]!, [_0]) + return formatWithArgumentRanges(self._s[3083]!, self._r[3083]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3083]!, self._r[3083]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3084]!, self._r[3084]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3084]! } + public var NewContact_Title: String { return self._s[3085]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3085]!, self._r[3085]!, [_0]) + return formatWithArgumentRanges(self._s[3086]!, self._r[3086]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3086]! } + public var Conversation_ViewContactDetails: String { return self._s[3087]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3088]!, self._r[3088]!, [_1]) + return formatWithArgumentRanges(self._s[3089]!, self._r[3089]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3089]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3090]! } - public var PrivacySettings_Title: String { return self._s[3091]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3094]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3095]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3096]! } - public var Contacts_PhoneNumber: String { return self._s[3097]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3099]! } - public var Map_ShowPlaces: String { return self._s[3100]! } - public var ChatAdmins_Title: String { return self._s[3101]! } - public var InstantPage_Reference: String { return self._s[3103]! } - public var Wallet_Info_Updating: String { return self._s[3104]! } - public var ReportGroupLocation_Text: String { return self._s[3105]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3090]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3091]! } + public var PrivacySettings_Title: String { return self._s[3092]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3095]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3096]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3097]! } + public var Contacts_PhoneNumber: String { return self._s[3098]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3100]! } + public var Map_ShowPlaces: String { return self._s[3101]! } + public var ChatAdmins_Title: String { return self._s[3102]! } + public var InstantPage_Reference: String { return self._s[3104]! } + public var Wallet_Info_Updating: String { return self._s[3105]! } + public var ReportGroupLocation_Text: String { return self._s[3106]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3106]!, self._r[3106]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3107]!, self._r[3107]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3107]! } - public var Watch_UserInfo_Block: String { return self._s[3108]! } - public var ChatSettings_Stickers: String { return self._s[3109]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3110]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3111]! } + public var Camera_FlashOff: String { return self._s[3108]! } + public var Watch_UserInfo_Block: String { return self._s[3109]! } + public var ChatSettings_Stickers: String { return self._s[3110]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3111]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3112]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3112]!, self._r[3112]!, [_0]) + return formatWithArgumentRanges(self._s[3113]!, self._r[3113]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3113]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3114]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3115]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3116]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3117]! } - public var VoiceOver_MessageContextShare: String { return self._s[3118]! } + public var Settings_ViewPhoto: String { return self._s[3114]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3115]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3116]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3117]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3118]! } + public var VoiceOver_MessageContextShare: String { return self._s[3119]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3120]!, self._r[3120]!, [_0]) + return formatWithArgumentRanges(self._s[3121]!, self._r[3121]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3121]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3122]! } + public var Privacy_DeleteDrafts: String { return self._s[3122]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3123]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3123]!, self._r[3123]!, [_0]) + return formatWithArgumentRanges(self._s[3124]!, self._r[3124]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3124]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3125]! } - public var DialogList_SavedMessages: String { return self._s[3126]! } - public var GroupInfo_UpgradeButton: String { return self._s[3127]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3129]! } - public var DialogList_Pin: String { return self._s[3130]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3125]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3126]! } + public var DialogList_SavedMessages: String { return self._s[3127]! } + public var GroupInfo_UpgradeButton: String { return self._s[3128]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3130]! } + public var DialogList_Pin: String { return self._s[3131]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3131]!, self._r[3131]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3132]!, self._r[3132]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3132]!, self._r[3132]!, [_0]) + return formatWithArgumentRanges(self._s[3133]!, self._r[3133]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3133]! } - public var UserInfo_NotificationsDisable: String { return self._s[3134]! } - public var Paint_Outlined: String { return self._s[3135]! } - public var Activity_PlayingGame: String { return self._s[3136]! } - public var SearchImages_NoImagesFound: String { return self._s[3137]! } - public var SocksProxySetup_ProxyType: String { return self._s[3138]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3140]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3141]! } - public var Settings_AppLanguage: String { return self._s[3142]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3143]! } - public var Common_ChoosePhoto: String { return self._s[3144]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3145]! } - public var CallFeedback_ReasonEcho: String { return self._s[3146]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3134]! } + public var UserInfo_NotificationsDisable: String { return self._s[3135]! } + public var Paint_Outlined: String { return self._s[3136]! } + public var Activity_PlayingGame: String { return self._s[3137]! } + public var SearchImages_NoImagesFound: String { return self._s[3138]! } + public var SocksProxySetup_ProxyType: String { return self._s[3139]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3141]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3142]! } + public var Settings_AppLanguage: String { return self._s[3143]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3144]! } + public var Common_ChoosePhoto: String { return self._s[3145]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3146]! } + public var CallFeedback_ReasonEcho: String { return self._s[3147]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3147]!, self._r[3147]!, [_1]) + return formatWithArgumentRanges(self._s[3148]!, self._r[3148]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3148]! } - public var Activity_UploadingVideo: String { return self._s[3149]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3150]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3151]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3152]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3153]! } - public var PUSH_SENDER_YOU: String { return self._s[3154]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3155]! } - public var Checkout_PayWithTouchId: String { return self._s[3156]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3157]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3149]! } + public var Activity_UploadingVideo: String { return self._s[3150]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3151]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3152]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3153]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3154]! } + public var PUSH_SENDER_YOU: String { return self._s[3155]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3156]! } + public var Checkout_PayWithTouchId: String { return self._s[3157]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3158]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3159]!, self._r[3159]!, [_1]) + return formatWithArgumentRanges(self._s[3160]!, self._r[3160]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3160]! } + public var Notifications_ExceptionsNone: String { return self._s[3161]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3161]!, self._r[3161]!, [_0]) + return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_1]) + return formatWithArgumentRanges(self._s[3163]!, self._r[3163]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3164]! } - public var Passport_Address_Region: String { return self._s[3167]! } - public var ChatList_DeleteChat: String { return self._s[3168]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3169]! } - public var PhotoEditor_TiltShift: String { return self._s[3170]! } - public var Settings_FAQ_URL: String { return self._s[3171]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3172]! } - public var Passport_Language_sl: String { return self._s[3173]! } - public var Settings_PrivacySettings: String { return self._s[3175]! } - public var SharedMedia_TitleLink: String { return self._s[3176]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3177]! } - public var Settings_SetProfilePhoto: String { return self._s[3178]! } - public var Channel_About_Help: String { return self._s[3179]! } - public var Contacts_PermissionsEnable: String { return self._s[3180]! } - public var Wallet_Sending_Title: String { return self._s[3181]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3182]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3183]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3185]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3186]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3187]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3188]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3189]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3191]! } - public var Map_OpenInYandexMaps: String { return self._s[3193]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3194]! } - public var VoiceOver_MessageContextReply: String { return self._s[3195]! } - public var PhotoEditor_SaturationTool: String { return self._s[3196]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3165]! } + public var Passport_Address_Region: String { return self._s[3168]! } + public var ChatList_DeleteChat: String { return self._s[3169]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3170]! } + public var PhotoEditor_TiltShift: String { return self._s[3171]! } + public var Settings_FAQ_URL: String { return self._s[3172]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3173]! } + public var Passport_Language_sl: String { return self._s[3174]! } + public var Settings_PrivacySettings: String { return self._s[3176]! } + public var SharedMedia_TitleLink: String { return self._s[3177]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3178]! } + public var Settings_SetProfilePhoto: String { return self._s[3179]! } + public var Channel_About_Help: String { return self._s[3180]! } + public var Contacts_PermissionsEnable: String { return self._s[3181]! } + public var Wallet_Sending_Title: String { return self._s[3182]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3183]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3184]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3186]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3187]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3188]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3189]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3190]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3192]! } + public var Map_OpenInYandexMaps: String { return self._s[3194]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3195]! } + public var VoiceOver_MessageContextReply: String { return self._s[3196]! } + public var PhotoEditor_SaturationTool: String { return self._s[3197]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3197]!, self._r[3197]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3198]!, self._r[3198]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3198]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3199]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3200]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3199]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3200]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3201]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3201]!, self._r[3201]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3202]!, self._r[3202]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3202]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3204]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3205]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3203]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3205]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3206]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3206]!, self._r[3206]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3207]!, self._r[3207]!, [_1, _2]) } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3207]!, self._r[3207]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3208]!, self._r[3208]!, [_1, _2, _3]) } - public var GroupInfo_PublicLinkAdd: String { return self._s[3208]! } - public var Passport_PassportInformation: String { return self._s[3211]! } - public var Theme_Unsupported: String { return self._s[3212]! } - public var WatchRemote_AlertTitle: String { return self._s[3213]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3214]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3216]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3209]! } + public var Passport_PassportInformation: String { return self._s[3212]! } + public var Theme_Unsupported: String { return self._s[3213]! } + public var WatchRemote_AlertTitle: String { return self._s[3214]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3215]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3217]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3217]!, self._r[3217]!, [_0]) + return formatWithArgumentRanges(self._s[3218]!, self._r[3218]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3218]!, self._r[3218]!, [_1]) + return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3219]! } - public var Wallet_Navigation_Done: String { return self._s[3221]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3222]! } - public var AccessDenied_CameraDisabled: String { return self._s[3223]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3220]! } + public var Wallet_Navigation_Done: String { return self._s[3222]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3223]! } + public var AccessDenied_CameraDisabled: String { return self._s[3224]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3224]!, self._r[3224]!, [_0]) + return formatWithArgumentRanges(self._s[3225]!, self._r[3225]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3225]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3226]! } - public var PhotoEditor_ContrastTool: String { return self._s[3229]! } + public var ClearCache_Forever: String { return self._s[3226]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3227]! } + public var PhotoEditor_ContrastTool: String { return self._s[3230]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3230]!, self._r[3230]!, [_1]) + return formatWithArgumentRanges(self._s[3231]!, self._r[3231]!, [_1]) } - public var DialogList_Draft: String { return self._s[3231]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3232]! } - public var Privacy_TopPeersDelete: String { return self._s[3234]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3235]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3236]! } - public var WebSearch_RecentSectionClear: String { return self._s[3237]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3238]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3240]! } - public var Common_Done: String { return self._s[3242]! } - public var Shortcut_SwitchAccount: String { return self._s[3243]! } - public var AuthSessions_EmptyText: String { return self._s[3244]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3245]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3246]! } - public var Tour_Title5: String { return self._s[3247]! } - public var Wallet_Settings_Title: String { return self._s[3248]! } + public var DialogList_Draft: String { return self._s[3232]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3233]! } + public var Privacy_TopPeersDelete: String { return self._s[3235]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3236]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3237]! } + public var WebSearch_RecentSectionClear: String { return self._s[3238]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3239]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3241]! } + public var Common_Done: String { return self._s[3243]! } + public var Shortcut_SwitchAccount: String { return self._s[3244]! } + public var AuthSessions_EmptyText: String { return self._s[3245]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3246]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3247]! } + public var Tour_Title5: String { return self._s[3248]! } + public var Wallet_Settings_Title: String { return self._s[3249]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3249]!, self._r[3249]!, [_0]) + return formatWithArgumentRanges(self._s[3250]!, self._r[3250]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3250]! } - public var Conversation_LinkDialogSave: String { return self._s[3251]! } - public var GroupInfo_ActionRestrict: String { return self._s[3252]! } - public var Checkout_Title: String { return self._s[3253]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3255]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3257]! } - public var Notification_RenamedGroup: String { return self._s[3258]! } - public var PeopleNearby_Groups: String { return self._s[3259]! } - public var Checkout_PayWithFaceId: String { return self._s[3260]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3261]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3263]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3264]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3265]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3251]! } + public var Conversation_LinkDialogSave: String { return self._s[3252]! } + public var GroupInfo_ActionRestrict: String { return self._s[3253]! } + public var Checkout_Title: String { return self._s[3254]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3256]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3258]! } + public var Notification_RenamedGroup: String { return self._s[3259]! } + public var PeopleNearby_Groups: String { return self._s[3260]! } + public var Checkout_PayWithFaceId: String { return self._s[3261]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3262]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3264]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3265]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3266]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3266]!, self._r[3266]!, [_0]) + return formatWithArgumentRanges(self._s[3267]!, self._r[3267]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3268]! } + public var Profile_AddToExisting: String { return self._s[3269]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3269]!, self._r[3269]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3270]!, self._r[3270]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3271]! } - public var Permissions_PrivacyPolicy: String { return self._s[3272]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3273]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3274]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3276]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3278]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3279]! } + public var Cache_Files: String { return self._s[3272]! } + public var Permissions_PrivacyPolicy: String { return self._s[3273]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3274]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3275]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3277]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3279]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3280]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3280]!, self._r[3280]!, [_0]) + return formatWithArgumentRanges(self._s[3281]!, self._r[3281]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3281]! } - public var VoiceOver_AttachMedia: String { return self._s[3283]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3284]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3282]! } + public var VoiceOver_AttachMedia: String { return self._s[3284]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3285]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3285]!, self._r[3285]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3286]!, self._r[3286]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3286]! } - public var Conversation_SetReminder_Title: String { return self._s[3287]! } - public var Passport_FieldAddressHelp: String { return self._s[3288]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3289]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3290]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3287]! } + public var Conversation_SetReminder_Title: String { return self._s[3288]! } + public var Passport_FieldAddressHelp: String { return self._s[3289]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3290]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3291]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3291]!, self._r[3291]!, [_0]) + return formatWithArgumentRanges(self._s[3292]!, self._r[3292]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3292]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3293]! } - public var Login_UnknownError: String { return self._s[3294]! } - public var Group_UpgradeNoticeText2: String { return self._s[3297]! } - public var Watch_Compose_AddContact: String { return self._s[3298]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3299]! } - public var Web_Error: String { return self._s[3300]! } - public var Gif_Search: String { return self._s[3301]! } - public var Profile_MessageLifetime1h: String { return self._s[3302]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3303]! } - public var Channel_Username_CheckingUsername: String { return self._s[3304]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3305]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3306]! } - public var Channel_AboutItem: String { return self._s[3307]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3309]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3310]! } - public var GroupInfo_SharedMedia: String { return self._s[3311]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3293]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3294]! } + public var Login_UnknownError: String { return self._s[3295]! } + public var Group_UpgradeNoticeText2: String { return self._s[3298]! } + public var Watch_Compose_AddContact: String { return self._s[3299]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3300]! } + public var Web_Error: String { return self._s[3301]! } + public var Gif_Search: String { return self._s[3302]! } + public var Profile_MessageLifetime1h: String { return self._s[3303]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3304]! } + public var Channel_Username_CheckingUsername: String { return self._s[3305]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3306]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3307]! } + public var Channel_AboutItem: String { return self._s[3308]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3310]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3311]! } + public var GroupInfo_SharedMedia: String { return self._s[3312]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3312]!, self._r[3312]!, [_1]) + return formatWithArgumentRanges(self._s[3313]!, self._r[3313]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3313]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3314]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3314]!, self._r[3314]!, [_1]) + return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3315]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3316]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3317]! } - public var CreatePoll_AddOption: String { return self._s[3318]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3319]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3320]! } - public var Channel_Management_AddModerator: String { return self._s[3321]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3322]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3323]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3324]! } - public var Theme_Colors_Background: String { return self._s[3325]! } - public var NotificationsSound_Hello: String { return self._s[3327]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3328]! } - public var Channel_Stickers_Placeholder: String { return self._s[3330]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3316]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3317]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3318]! } + public var CreatePoll_AddOption: String { return self._s[3319]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3320]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3321]! } + public var Channel_Management_AddModerator: String { return self._s[3322]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3323]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3324]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3325]! } + public var Theme_Colors_Background: String { return self._s[3326]! } + public var NotificationsSound_Hello: String { return self._s[3328]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3329]! } + public var Channel_Stickers_Placeholder: String { return self._s[3331]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3331]!, self._r[3331]!, [_0]) + return formatWithArgumentRanges(self._s[3332]!, self._r[3332]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3332]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3333]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3334]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3335]! } - public var AutoDownloadSettings_Channels: String { return self._s[3336]! } - public var Passport_Language_mn: String { return self._s[3337]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3340]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3341]! } - public var Passport_Language_ja: String { return self._s[3343]! } - public var Settings_About_Title: String { return self._s[3344]! } - public var Settings_NotificationsAndSounds: String { return self._s[3345]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3346]! } - public var Settings_BlockedUsers: String { return self._s[3347]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3333]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3334]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3335]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3336]! } + public var AutoDownloadSettings_Channels: String { return self._s[3337]! } + public var Passport_Language_mn: String { return self._s[3338]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3341]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3342]! } + public var Passport_Language_ja: String { return self._s[3344]! } + public var Settings_About_Title: String { return self._s[3345]! } + public var Settings_NotificationsAndSounds: String { return self._s[3346]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3347]! } + public var Settings_BlockedUsers: String { return self._s[3348]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3348]!, self._r[3348]!, [_0]) + return formatWithArgumentRanges(self._s[3349]!, self._r[3349]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3349]! } - public var Wallet_Weekday_Today: String { return self._s[3350]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3351]! } - public var Widget_ApplicationLocked: String { return self._s[3352]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3353]! } - public var Channel_Username_Title: String { return self._s[3354]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3350]! } + public var Wallet_Weekday_Today: String { return self._s[3351]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3352]! } + public var Widget_ApplicationLocked: String { return self._s[3353]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3354]! } + public var Channel_Username_Title: String { return self._s[3355]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3355]!, self._r[3355]!, [_0]) + return formatWithArgumentRanges(self._s[3356]!, self._r[3356]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3357]! } - public var AppleWatch_Title: String { return self._s[3358]! } - public var Activity_RecordingVideoMessage: String { return self._s[3359]! } + public var AttachmentMenu_File: String { return self._s[3358]! } + public var AppleWatch_Title: String { return self._s[3359]! } + public var Activity_RecordingVideoMessage: String { return self._s[3360]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3360]!, self._r[3360]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3361]!, self._r[3361]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3361]! } - public var Weekday_Saturday: String { return self._s[3362]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3363]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3364]! } - public var Common_Next: String { return self._s[3366]! } - public var Channel_Stickers_YourStickers: String { return self._s[3368]! } - public var Message_Theme: String { return self._s[3369]! } - public var Call_AudioRouteHeadphones: String { return self._s[3370]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3372]! } - public var Watch_Contacts_NoResults: String { return self._s[3374]! } - public var PhotoEditor_TintTool: String { return self._s[3377]! } - public var LoginPassword_ResetAccount: String { return self._s[3379]! } - public var Settings_SavedMessages: String { return self._s[3380]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3381]! } - public var Bot_GenericSupportStatus: String { return self._s[3382]! } - public var StickerPack_Add: String { return self._s[3383]! } - public var Checkout_TotalAmount: String { return self._s[3384]! } - public var Your_cards_number_is_invalid: String { return self._s[3385]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3386]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3387]! } + public var Theme_Colors_Messages: String { return self._s[3362]! } + public var Weekday_Saturday: String { return self._s[3363]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3364]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3365]! } + public var Common_Next: String { return self._s[3367]! } + public var Channel_Stickers_YourStickers: String { return self._s[3369]! } + public var Message_Theme: String { return self._s[3370]! } + public var Call_AudioRouteHeadphones: String { return self._s[3371]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3373]! } + public var Watch_Contacts_NoResults: String { return self._s[3375]! } + public var PhotoEditor_TintTool: String { return self._s[3378]! } + public var LoginPassword_ResetAccount: String { return self._s[3380]! } + public var Settings_SavedMessages: String { return self._s[3381]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3382]! } + public var Bot_GenericSupportStatus: String { return self._s[3383]! } + public var StickerPack_Add: String { return self._s[3384]! } + public var Checkout_TotalAmount: String { return self._s[3385]! } + public var Your_cards_number_is_invalid: String { return self._s[3386]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3387]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3388]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3388]!, self._r[3388]!, [_0]) + return formatWithArgumentRanges(self._s[3389]!, self._r[3389]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3389]!, self._r[3389]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3390]!, self._r[3390]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3390]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3391]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3392]!, self._r[3392]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3393]!, self._r[3393]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _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 GroupInfo_InviteLink_ShareLink: String { return self._s[3394]! } - public var StickerPack_Share: String { return self._s[3395]! } - public var Passport_DeleteAddress: String { return self._s[3396]! } - public var Settings_Passport: String { return self._s[3397]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3398]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3399]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3400]! } - public var Contacts_PermissionsText: String { return self._s[3401]! } - public var Group_Setup_HistoryVisible: String { return self._s[3402]! } - public var Wallet_Month_ShortDecember: String { return self._s[3404]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3405]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3406]! } - public var SocksProxySetup_Title: String { return self._s[3407]! } - public var Notification_Mute1h: String { return self._s[3408]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3395]! } + public var StickerPack_Share: String { return self._s[3396]! } + public var Passport_DeleteAddress: String { return self._s[3397]! } + public var Settings_Passport: String { return self._s[3398]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3399]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3400]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3401]! } + public var Contacts_PermissionsText: String { return self._s[3402]! } + public var Group_Setup_HistoryVisible: String { return self._s[3403]! } + public var Wallet_Month_ShortDecember: String { return self._s[3405]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3406]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3407]! } + public var SocksProxySetup_Title: String { return self._s[3408]! } + public var Notification_Mute1h: String { return self._s[3409]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3409]!, self._r[3409]!, [_0]) + return formatWithArgumentRanges(self._s[3410]!, self._r[3410]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3410]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3411]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3411]!, self._r[3411]!, [_1]) + return formatWithArgumentRanges(self._s[3412]!, self._r[3412]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3412]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3415]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3417]! } - public var DialogList_NoMessagesText: String { return self._s[3418]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3419]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3420]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3422]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3423]! } - public var Common_TakePhotoOrVideo: String { return self._s[3424]! } - public var Wallet_Words_Text: String { return self._s[3425]! } - public var Call_StatusBusy: String { return self._s[3426]! } - public var Conversation_PinnedMessage: String { return self._s[3427]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3428]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3429]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3430]! } - public var Undo_ChatCleared: String { return self._s[3431]! } - public var AppleWatch_ReplyPresets: String { return self._s[3432]! } - public var Passport_DiscardMessageDescription: String { return self._s[3434]! } - public var Login_NetworkError: String { return self._s[3435]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3413]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3416]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3418]! } + public var DialogList_NoMessagesText: String { return self._s[3419]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3420]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3421]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3423]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3424]! } + public var Common_TakePhotoOrVideo: String { return self._s[3425]! } + public var Wallet_Words_Text: String { return self._s[3426]! } + public var Call_StatusBusy: String { return self._s[3427]! } + public var Conversation_PinnedMessage: String { return self._s[3428]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3429]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3430]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3431]! } + public var Undo_ChatCleared: String { return self._s[3432]! } + public var AppleWatch_ReplyPresets: String { return self._s[3433]! } + public var Passport_DiscardMessageDescription: String { return self._s[3435]! } + public var Login_NetworkError: String { return self._s[3436]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_0]) - } - public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3437]!, self._r[3437]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3438]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3440]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3441]! } + public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3438]!, self._r[3438]!, [_0]) + } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3439]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3441]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3442]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3443]!, self._r[3443]!, [_0]) + return formatWithArgumentRanges(self._s[3444]!, self._r[3444]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3444]! } - public var VoiceOver_Chat_Music: String { return self._s[3445]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3446]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3448]! } - public var ConversationMedia_Title: String { return self._s[3449]! } - public var EncryptionKey_Title: String { return self._s[3451]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3452]! } - public var Notification_Exceptions_AddException: String { return self._s[3453]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3454]! } - public var Profile_MessageLifetime1m: String { return self._s[3455]! } + public var Call_ConnectionErrorMessage: String { return self._s[3445]! } + public var VoiceOver_Chat_Music: String { return self._s[3446]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3447]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3449]! } + public var ConversationMedia_Title: String { return self._s[3450]! } + public var EncryptionKey_Title: String { return self._s[3452]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3453]! } + public var Notification_Exceptions_AddException: String { return self._s[3454]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3455]! } + public var Profile_MessageLifetime1m: String { return self._s[3456]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3456]!, self._r[3456]!, [_1]) + return formatWithArgumentRanges(self._s[3457]!, self._r[3457]!, [_1]) } - public var Month_GenMay: String { return self._s[3457]! } + public var Month_GenMay: String { return self._s[3458]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3458]!, self._r[3458]!, [_0]) + return formatWithArgumentRanges(self._s[3459]!, self._r[3459]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3459]! } - public var Wallet_Send_AddressInfo: String { return self._s[3460]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3461]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3462]! } + public var PeopleNearby_Users: String { return self._s[3460]! } + public var Wallet_Send_AddressInfo: String { return self._s[3461]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3462]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3463]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3464]!, self._r[3464]!, [_0]) + return formatWithArgumentRanges(self._s[3465]!, self._r[3465]!, [_0]) } - public var Conversation_EmptyPlaceholder: String { return self._s[3465]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3466]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3467]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3468]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3469]! } - public var Channel_JoinChannel: String { return self._s[3471]! } - public var Appearance_Animations: String { return self._s[3474]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3466]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3467]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3468]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3469]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3470]! } + public var Channel_JoinChannel: String { return self._s[3472]! } + public var Appearance_Animations: String { return self._s[3475]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3475]!, self._r[3475]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3476]!, self._r[3476]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3477]! } - public var Appearance_ShareTheme: String { return self._s[3478]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3479]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3481]! } - public var Passport_Address_Street: String { return self._s[3482]! } - public var Conversation_AddContact: String { return self._s[3483]! } - public var Login_PhonePlaceholder: String { return self._s[3484]! } - public var Channel_Members_InviteLink: String { return self._s[3486]! } - public var Bot_Stop: String { return self._s[3487]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3489]! } - public var Notification_PassportValueAddress: String { return self._s[3490]! } - public var Month_ShortJuly: String { return self._s[3491]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3492]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3493]! } - public var Passport_Identity_ReverseSide: String { return self._s[3494]! } - public var Watch_Stickers_Recents: String { return self._s[3497]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3499]! } - public var Map_SendThisLocation: String { return self._s[3500]! } + public var Stickers_GroupStickers: String { return self._s[3478]! } + public var Appearance_ShareTheme: String { return self._s[3479]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3480]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3482]! } + public var Passport_Address_Street: String { return self._s[3483]! } + public var Conversation_AddContact: String { return self._s[3484]! } + public var Login_PhonePlaceholder: String { return self._s[3485]! } + public var Channel_Members_InviteLink: String { return self._s[3487]! } + public var Bot_Stop: String { return self._s[3488]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3490]! } + public var Notification_PassportValueAddress: String { return self._s[3491]! } + public var Month_ShortJuly: String { return self._s[3492]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3493]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3494]! } + public var Passport_Identity_ReverseSide: String { return self._s[3495]! } + public var Watch_Stickers_Recents: String { return self._s[3498]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3500]! } + public var Map_SendThisLocation: String { return self._s[3501]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3501]!, self._r[3501]!, [_0]) - } - public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3502]!, self._r[3502]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3503]! } - public var Wallet_Intro_NotNow: String { return self._s[3504]! } + public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3503]!, self._r[3503]!, [_0]) + } + public var ConvertToSupergroup_Note: String { return self._s[3504]! } + public var Wallet_Intro_NotNow: String { return self._s[3505]! } public func FileSize_MB(_ _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 NetworkUsageSettings_GeneralDataSection: String { return self._s[3506]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3507]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3507]!, self._r[3507]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3508]!, self._r[3508]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3509]! } - public var Wallpaper_SearchShort: String { return self._s[3510]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3512]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3513]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3514]! } + public var Login_CallRequestState3: String { return self._s[3510]! } + public var Wallpaper_SearchShort: String { return self._s[3511]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3513]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3514]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3515]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3515]!, self._r[3515]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3516]!, self._r[3516]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3516]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3520]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3517]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3521]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3521]!, self._r[3521]!, [_0]) + return formatWithArgumentRanges(self._s[3522]!, self._r[3522]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3522]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3523]! } + public var Passport_CorrectErrors: String { return self._s[3523]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3524]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3524]!, self._r[3524]!, [_0]) + return formatWithArgumentRanges(self._s[3525]!, self._r[3525]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3525]! } - public var Channel_DiscussionGroup: String { return self._s[3526]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3527]! } + public var Map_SendMyCurrentLocation: String { return self._s[3526]! } + public var Channel_DiscussionGroup: String { return self._s[3527]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3528]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3528]!, self._r[3528]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3529]!, self._r[3529]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3529]! } - public var Permissions_NotificationsText_v0: String { return self._s[3530]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3531]! } - public var Appearance_AppIcon: String { return self._s[3532]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3533]! } - public var LoginPassword_FloodError: String { return self._s[3534]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3536]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3537]! } + public var SharedMedia_SearchNoResults: String { return self._s[3530]! } + public var Permissions_NotificationsText_v0: String { return self._s[3531]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3532]! } + public var Appearance_AppIcon: String { return self._s[3533]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3534]! } + public var LoginPassword_FloodError: String { return self._s[3535]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3537]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3538]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3538]!, self._r[3538]!, [_0]) + return formatWithArgumentRanges(self._s[3539]!, self._r[3539]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3539]! } + public var Passport_Language_bn: String { return self._s[3540]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3540]!, self._r[3540]!, [_0]) + return formatWithArgumentRanges(self._s[3541]!, self._r[3541]!, [_0]) } - public var ChatList_Context_Pin: String { return self._s[3541]! } + public var ChatList_Context_Pin: String { return self._s[3542]! } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3542]!, self._r[3542]!, [_0]) - } - public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3543]!, self._r[3543]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3544]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3548]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3550]! } - public var Wallet_Month_GenDecember: String { return self._s[3551]! } - public var Contacts_PermissionsAllow: String { return self._s[3552]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3553]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3554]! } - public var WallpaperPreview_Pattern: String { return self._s[3555]! } - public var Paint_Duplicate: String { return self._s[3556]! } - public var Passport_Address_Country: String { return self._s[3557]! } - public var Notification_RenamedChannel: String { return self._s[3559]! } - public var ChatList_Context_Unmute: String { return self._s[3560]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3561]! } - public var Group_MessagePhotoUpdated: String { return self._s[3562]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3563]! } - public var Conversation_ContextMenuBan: String { return self._s[3564]! } - public var TwoStepAuth_EmailSent: String { return self._s[3565]! } - public var MessagePoll_NoVotes: String { return self._s[3566]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3567]! } - public var Passport_Language_is: String { return self._s[3568]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3570]! } - public var Tour_Text5: String { return self._s[3571]! } + public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3544]!, self._r[3544]!, [_0]) + } + public var Wallet_Navigation_Close: String { return self._s[3545]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3549]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3551]! } + public var Wallet_Month_GenDecember: String { return self._s[3552]! } + public var Contacts_PermissionsAllow: String { return self._s[3553]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3554]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3555]! } + public var WallpaperPreview_Pattern: String { return self._s[3556]! } + public var Paint_Duplicate: String { return self._s[3557]! } + public var Passport_Address_Country: String { return self._s[3558]! } + public var Notification_RenamedChannel: String { return self._s[3560]! } + public var ChatList_Context_Unmute: String { return self._s[3561]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3562]! } + public var Group_MessagePhotoUpdated: String { return self._s[3563]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3564]! } + public var Conversation_ContextMenuBan: String { return self._s[3565]! } + public var TwoStepAuth_EmailSent: String { return self._s[3566]! } + public var MessagePoll_NoVotes: String { return self._s[3567]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3568]! } + public var Passport_Language_is: String { return self._s[3569]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3571]! } + public var Tour_Text5: String { return self._s[3572]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3573]!, self._r[3573]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3574]!, self._r[3574]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3574]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3575]! } + public var Undo_SecretChatDeleted: String { return self._s[3575]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3576]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3576]!, self._r[3576]!, [_0]) + return formatWithArgumentRanges(self._s[3577]!, self._r[3577]!, [_0]) } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3577]! } - public var Paint_Edit: String { return self._s[3579]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3581]! } - public var Undo_DeletedGroup: String { return self._s[3583]! } - public var LoginPassword_ForgotPassword: String { return self._s[3584]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3585]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3586]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3578]! } + public var Paint_Edit: String { return self._s[3580]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3582]! } + public var Undo_DeletedGroup: String { return self._s[3584]! } + public var LoginPassword_ForgotPassword: String { return self._s[3585]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3586]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3587]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3587]!, self._r[3587]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3588]!, self._r[3588]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3588]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3589]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3590]! } - public var Passport_Language_uz: String { return self._s[3591]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3592]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3593]! } - public var Map_StopLiveLocation: String { return self._s[3595]! } - public var VoiceOver_MessageContextSend: String { return self._s[3597]! } - public var PasscodeSettings_Help: String { return self._s[3598]! } - public var NotificationsSound_Input: String { return self._s[3599]! } - public var Share_Title: String { return self._s[3602]! } - public var LogoutOptions_Title: String { return self._s[3603]! } - public var Wallet_Send_AddressText: String { return self._s[3604]! } - public var Login_TermsOfServiceAgree: String { return self._s[3605]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3606]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3607]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3608]! } - public var EnterPasscode_EnterTitle: String { return self._s[3609]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3589]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3590]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3591]! } + public var Passport_Language_uz: String { return self._s[3592]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3593]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3594]! } + public var Map_StopLiveLocation: String { return self._s[3596]! } + public var VoiceOver_MessageContextSend: String { return self._s[3598]! } + public var PasscodeSettings_Help: String { return self._s[3599]! } + public var NotificationsSound_Input: String { return self._s[3600]! } + public var Share_Title: String { return self._s[3603]! } + public var LogoutOptions_Title: String { return self._s[3604]! } + public var Wallet_Send_AddressText: String { return self._s[3605]! } + public var Login_TermsOfServiceAgree: String { return self._s[3606]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3607]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3608]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3609]! } + public var EnterPasscode_EnterTitle: String { return self._s[3610]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3610]!, self._r[3610]!, [_0]) + return formatWithArgumentRanges(self._s[3611]!, self._r[3611]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3611]! } - public var Conversation_AddToContacts: String { return self._s[3612]! } + public var Settings_CopyPhoneNumber: String { return self._s[3612]! } + public var Conversation_AddToContacts: String { return self._s[3613]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3613]!, self._r[3613]!, [_0]) + return formatWithArgumentRanges(self._s[3614]!, self._r[3614]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3614]! } + public var NotificationsSound_Keys: String { return self._s[3615]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3615]!, self._r[3615]!, [_0]) + return formatWithArgumentRanges(self._s[3616]!, self._r[3616]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3616]! } - public var Message_Video: String { return self._s[3617]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3618]! } + public var Notification_MessageLifetime1w: String { return self._s[3617]! } + public var Message_Video: String { return self._s[3618]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3619]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3619]!, self._r[3619]!, [_1]) + return formatWithArgumentRanges(self._s[3620]!, self._r[3620]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3622]! } + public var Wallet_Receive_AmountInfo: String { return self._s[3623]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3623]!, self._r[3623]!, [_0]) - } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3624]!, self._r[3624]!, [_0]) } - public var Passport_Language_mk: String { return self._s[3625]! } - public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3626]!, self._r[3626]!, [_1, _2, _3]) + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3625]!, self._r[3625]!, [_0]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3627]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3629]! } - public var PrivacyPolicy_Decline: String { return self._s[3630]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3631]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3632]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3633]! } - public var Permissions_SiriAllow_v0: String { return self._s[3635]! } - public var Wallet_Month_ShortAugust: String { return self._s[3636]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3637]! } + public var Passport_Language_mk: String { return self._s[3626]! } + public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3627]!, self._r[3627]!, [_1, _2, _3]) + } + public var CreatePoll_CancelConfirmation: String { return self._s[3628]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3630]! } + public var PrivacyPolicy_Decline: String { return self._s[3631]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3632]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3633]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3634]! } + public var Permissions_SiriAllow_v0: String { return self._s[3636]! } + public var Wallet_Month_ShortAugust: String { return self._s[3637]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3638]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3638]!, self._r[3638]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3639]!, self._r[3639]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3639]!, self._r[3639]!, [_0]) + return formatWithArgumentRanges(self._s[3640]!, self._r[3640]!, [_0]) } - public var Paint_Regular: String { return self._s[3640]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3641]! } - public var SocksProxySetup_ShareLink: String { return self._s[3642]! } - public var Wallet_Qr_Title: String { return self._s[3643]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3644]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3646]! } - public var Wallet_Settings_Configuration: String { return self._s[3647]! } - public var GroupInfo_InviteByLink: String { return self._s[3648]! } - public var MessageTimer_Custom: String { return self._s[3649]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3650]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3652]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3653]! } - public var VoiceOver_Chat_Selected: String { return self._s[3654]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3655]! } - public var Channel_Username_InvalidTaken: String { return self._s[3656]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3657]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3658]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3659]! } - public var Settings_ChatBackground: String { return self._s[3660]! } - public var Channel_Subscribers_Title: String { return self._s[3661]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3662]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3663]! } - public var Watch_ConnectionDescription: String { return self._s[3664]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3667]! } - public var IntentsSettings_SuggestBy: String { return self._s[3669]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3670]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3671]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3672]! } - public var EditProfile_Title: String { return self._s[3673]! } - public var NotificationsSound_Bamboo: String { return self._s[3675]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3677]! } - public var Login_SmsRequestState2: String { return self._s[3678]! } - public var Passport_Language_ar: String { return self._s[3679]! } + public var Paint_Regular: String { return self._s[3641]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3642]! } + public var SocksProxySetup_ShareLink: String { return self._s[3643]! } + public var Wallet_Qr_Title: String { return self._s[3644]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3645]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3647]! } + public var Wallet_Settings_Configuration: String { return self._s[3648]! } + public var GroupInfo_InviteByLink: String { return self._s[3649]! } + public var MessageTimer_Custom: String { return self._s[3650]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3651]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3653]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3654]! } + public var VoiceOver_Chat_Selected: String { return self._s[3655]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3656]! } + public var Channel_Username_InvalidTaken: String { return self._s[3657]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3658]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3659]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3660]! } + public var Settings_ChatBackground: String { return self._s[3661]! } + public var Channel_Subscribers_Title: String { return self._s[3662]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3663]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3664]! } + public var Watch_ConnectionDescription: String { return self._s[3665]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3668]! } + public var IntentsSettings_SuggestBy: String { return self._s[3670]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3671]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3672]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3673]! } + public var EditProfile_Title: String { return self._s[3674]! } + public var NotificationsSound_Bamboo: String { return self._s[3676]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3678]! } + public var Login_SmsRequestState2: String { return self._s[3679]! } + public var Passport_Language_ar: String { return self._s[3680]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3680]!, self._r[3680]!, [_0]) + return formatWithArgumentRanges(self._s[3681]!, self._r[3681]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3681]! } - public var Wallet_Created_Text: String { return self._s[3682]! } - public var Conversation_MessageDialogEdit: String { return self._s[3684]! } - public var Wallet_Created_Proceed: String { return self._s[3685]! } - public var Wallet_Words_Done: String { return self._s[3686]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3687]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3682]! } + public var Wallet_Created_Text: String { return self._s[3683]! } + public var Conversation_MessageDialogEdit: String { return self._s[3685]! } + public var Wallet_Created_Proceed: String { return self._s[3686]! } + public var Wallet_Words_Done: String { return self._s[3687]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3688]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3688]!, self._r[3688]!, [_1]) + return formatWithArgumentRanges(self._s[3689]!, self._r[3689]!, [_1]) } - public var Common_Close: String { return self._s[3689]! } - public var GroupInfo_PublicLink: String { return self._s[3690]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3691]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3692]! } + public var Common_Close: String { return self._s[3690]! } + public var GroupInfo_PublicLink: String { return self._s[3691]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3692]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3693]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3696]!, self._r[3696]!, [_0]) + return formatWithArgumentRanges(self._s[3697]!, self._r[3697]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3697]! } + public var UserInfo_About_Placeholder: String { return self._s[3698]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3698]!, self._r[3698]!, [_0]) + return formatWithArgumentRanges(self._s[3699]!, self._r[3699]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3699]! } - public var Channel_Info_Banned: String { return self._s[3701]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3700]! } + public var Channel_Info_Banned: String { return self._s[3702]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3702]!, self._r[3702]!, [_0]) + return formatWithArgumentRanges(self._s[3703]!, self._r[3703]!, [_0]) } - public var Appearance_Other: String { return self._s[3703]! } - public var Passport_Language_my: String { return self._s[3704]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3705]! } + public var Appearance_Other: String { return self._s[3704]! } + public var Passport_Language_my: String { return self._s[3705]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3706]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3706]!, self._r[3706]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3707]!, self._r[3707]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3707]! } - public var Preview_CopyAddress: String { return self._s[3708]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3708]! } + public var Preview_CopyAddress: String { return self._s[3709]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3709]!, self._r[3709]!, [_0]) + return formatWithArgumentRanges(self._s[3710]!, self._r[3710]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3710]! } - public var UserInfo_BotSettings: String { return self._s[3711]! } - public var LiveLocation_MenuStopAll: String { return self._s[3713]! } - public var Passport_PasswordCreate: String { return self._s[3714]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3715]! } - public var Message_PinnedLocationMessage: String { return self._s[3716]! } - public var Map_Satellite: String { return self._s[3717]! } - public var Watch_Message_Unsupported: String { return self._s[3718]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3719]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3720]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3711]! } + public var UserInfo_BotSettings: String { return self._s[3712]! } + public var LiveLocation_MenuStopAll: String { return self._s[3714]! } + public var Passport_PasswordCreate: String { return self._s[3715]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3716]! } + public var Message_PinnedLocationMessage: String { return self._s[3717]! } + public var Map_Satellite: String { return self._s[3718]! } + public var Watch_Message_Unsupported: String { return self._s[3719]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3720]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3721]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3721]!, self._r[3721]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3722]!, self._r[3722]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3722]!, self._r[3722]!, [_0]) + return formatWithArgumentRanges(self._s[3723]!, self._r[3723]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3723]! } + public var Wallet_WordImport_Continue: String { return self._s[3724]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3724]!, self._r[3724]!, [_0]) + return formatWithArgumentRanges(self._s[3725]!, self._r[3725]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3725]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3726]! } - public var NotificationsSound_None: String { return self._s[3727]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3728]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3730]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3731]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3726]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3727]! } + public var NotificationsSound_None: String { return self._s[3728]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3729]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3731]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3732]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3732]!, self._r[3732]!, [_1]) + return formatWithArgumentRanges(self._s[3733]!, self._r[3733]!, [_1]) } - public var Cache_Indexing: String { return self._s[3733]! } - public var DialogList_RecentTitlePeople: String { return self._s[3735]! } - public var DialogList_EncryptionRejected: String { return self._s[3736]! } - public var GroupInfo_Administrators: String { return self._s[3737]! } - public var Passport_ScanPassportHelp: String { return self._s[3738]! } - public var Application_Name: String { return self._s[3739]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3740]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3742]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3743]! } + public var Cache_Indexing: String { return self._s[3734]! } + public var DialogList_RecentTitlePeople: String { return self._s[3736]! } + public var DialogList_EncryptionRejected: String { return self._s[3737]! } + public var GroupInfo_Administrators: String { return self._s[3738]! } + public var Passport_ScanPassportHelp: String { return self._s[3739]! } + public var Application_Name: String { return self._s[3740]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3741]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3743]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3744]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_0]) - } - public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3745]!, self._r[3745]!, [_0]) } - public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3746]!, self._r[3746]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3747]! } - public var Privacy_ChatsTitle: String { return self._s[3748]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3749]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3750]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3751]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3752]! } - public var WebBrowser_Title: String { return self._s[3753]! } - public var Group_LinkedChannel: String { return self._s[3754]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3755]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3756]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3757]! } - public var Appearance_TextSize_UseSystem: String { return self._s[3758]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3759]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[3761]! } - public var Channel_Setup_TypePublic: String { return self._s[3763]! } + public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3747]!, self._r[3747]!, [_0]) + } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3748]! } + public var Privacy_ChatsTitle: String { return self._s[3749]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3750]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3751]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3752]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3753]! } + public var WebBrowser_Title: String { return self._s[3754]! } + public var Group_LinkedChannel: String { return self._s[3755]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3756]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3757]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3758]! } + public var Appearance_TextSize_UseSystem: String { return self._s[3759]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3760]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3762]! } + public var Channel_Setup_TypePublic: String { return self._s[3764]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3764]!, self._r[3764]!, [_0]) + return formatWithArgumentRanges(self._s[3765]!, self._r[3765]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3766]! } - public var Map_OpenInMaps: String { return self._s[3768]! } + public var Channel_TypeSetup_Title: String { return self._s[3767]! } + public var Map_OpenInMaps: String { return self._s[3769]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3769]!, self._r[3769]!, [_1]) + return formatWithArgumentRanges(self._s[3770]!, self._r[3770]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3771]! } + public var NotificationsSound_Tremolo: String { return self._s[3772]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3772]!, self._r[3772]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3773]!, self._r[3773]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3773]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3774]! } - public var Passport_PasswordHelp: String { return self._s[3775]! } - public var Login_CodeExpiredError: String { return self._s[3776]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3777]! } - public var Conversation_TitleUnmute: String { return self._s[3778]! } - public var Passport_Identity_ScansHelp: String { return self._s[3779]! } - public var Passport_Language_lo: String { return self._s[3780]! } - public var Camera_FlashAuto: String { return self._s[3781]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3782]! } - public var Common_Cancel: String { return self._s[3783]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3784]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3785]! } - public var Appearance_TintAllColors: String { return self._s[3786]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3774]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3775]! } + public var Passport_PasswordHelp: String { return self._s[3776]! } + public var Login_CodeExpiredError: String { return self._s[3777]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3778]! } + public var Conversation_TitleUnmute: String { return self._s[3779]! } + public var Passport_Identity_ScansHelp: String { return self._s[3780]! } + public var Passport_Language_lo: String { return self._s[3781]! } + public var Camera_FlashAuto: String { return self._s[3782]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3783]! } + public var Common_Cancel: String { return self._s[3784]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3785]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3786]! } + public var Appearance_TintAllColors: String { return self._s[3787]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3787]!, self._r[3787]!, [_1]) + return formatWithArgumentRanges(self._s[3788]!, self._r[3788]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3788]! } - public var ChatSettings_Title: String { return self._s[3790]! } - public var Passport_PasswordReset: String { return self._s[3791]! } - public var SocksProxySetup_TypeNone: String { return self._s[3792]! } - public var EditTheme_Title: String { return self._s[3794]! } - public var PhoneNumberHelp_Help: String { return self._s[3795]! } - public var Checkout_EnterPassword: String { return self._s[3796]! } - public var Share_AuthTitle: String { return self._s[3798]! } - public var Activity_UploadingDocument: String { return self._s[3799]! } - public var State_Connecting: String { return self._s[3800]! } - public var Profile_MessageLifetime1w: String { return self._s[3801]! } - public var Conversation_ContextMenuReport: String { return self._s[3802]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3803]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3804]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3789]! } + public var ChatSettings_Title: String { return self._s[3791]! } + public var Passport_PasswordReset: String { return self._s[3792]! } + public var SocksProxySetup_TypeNone: String { return self._s[3793]! } + public var EditTheme_Title: String { return self._s[3795]! } + public var PhoneNumberHelp_Help: String { return self._s[3796]! } + public var Checkout_EnterPassword: String { return self._s[3797]! } + public var Share_AuthTitle: String { return self._s[3799]! } + public var Activity_UploadingDocument: String { return self._s[3800]! } + public var State_Connecting: String { return self._s[3801]! } + public var Profile_MessageLifetime1w: String { return self._s[3802]! } + public var Conversation_ContextMenuReport: String { return self._s[3803]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3804]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3805]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3805]!, self._r[3805]!, [_0]) + return formatWithArgumentRanges(self._s[3806]!, self._r[3806]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3806]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[3807]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3809]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3810]! } - public var PhotoEditor_Set: String { return self._s[3811]! } - public var EmptyGroupInfo_Title: String { return self._s[3812]! } - public var Login_PadPhoneHelp: String { return self._s[3813]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3815]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3817]! } - public var NotificationsSound_Complete: String { return self._s[3818]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3819]! } - public var Group_Info_AdminLog: String { return self._s[3820]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3821]! } + public var AuthSessions_Terminate: String { return self._s[3807]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[3808]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3810]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3811]! } + public var PhotoEditor_Set: String { return self._s[3812]! } + public var EmptyGroupInfo_Title: String { return self._s[3813]! } + public var Login_PadPhoneHelp: String { return self._s[3814]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3816]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3818]! } + public var NotificationsSound_Complete: String { return self._s[3819]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3820]! } + public var Group_Info_AdminLog: String { return self._s[3821]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3822]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3822]!, self._r[3822]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3823]!, self._r[3823]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3823]! } - public var Group_Location_CreateInThisPlace: String { return self._s[3825]! } - public var Conversation_Admin: String { return self._s[3826]! } - public var Conversation_GifTooltip: String { return self._s[3827]! } - public var Passport_NotLoggedInMessage: String { return self._s[3828]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3824]! } + public var Group_Location_CreateInThisPlace: String { return self._s[3826]! } + public var Conversation_Admin: String { return self._s[3827]! } + public var Conversation_GifTooltip: String { return self._s[3828]! } + public var Passport_NotLoggedInMessage: String { return self._s[3829]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3830]!, self._r[3830]!, [_0]) + return formatWithArgumentRanges(self._s[3831]!, self._r[3831]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3831]! } - public var SharedMedia_EmptyTitle: String { return self._s[3833]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3835]! } - public var Username_Help: String { return self._s[3836]! } - public var DialogList_LanguageTooltip: String { return self._s[3838]! } - public var Map_LoadError: String { return self._s[3839]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3840]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3841]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3842]! } - public var Notification_Exceptions_NewException: String { return self._s[3843]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3844]! } - public var WatchRemote_AlertText: String { return self._s[3845]! } + public var Profile_MessageLifetimeForever: String { return self._s[3832]! } + public var SharedMedia_EmptyTitle: String { return self._s[3834]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3836]! } + public var Username_Help: String { return self._s[3837]! } + public var DialogList_LanguageTooltip: String { return self._s[3839]! } + public var Map_LoadError: String { return self._s[3840]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3841]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3842]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3843]! } + public var Notification_Exceptions_NewException: String { return self._s[3844]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3845]! } + public var WatchRemote_AlertText: String { return self._s[3846]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3846]!, self._r[3846]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3847]!, self._r[3847]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[3850]! } - public var WebBrowser_DefaultBrowser: String { return self._s[3851]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[3851]! } + public var WebBrowser_DefaultBrowser: String { return self._s[3852]! } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3852]!, self._r[3852]!, [_0]) + return formatWithArgumentRanges(self._s[3853]!, self._r[3853]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3853]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3854]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3854]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3855]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3855]!, self._r[3855]!, [_0]) + return formatWithArgumentRanges(self._s[3856]!, self._r[3856]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3856]!, self._r[3856]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3857]!, self._r[3857]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3857]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3858]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[3860]! } - public var Wallet_Created_ExportErrorText: String { return self._s[3861]! } - public var ChatList_UndoArchiveText1: String { return self._s[3862]! } - public var AccessDenied_VideoMicrophone: String { return self._s[3863]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3864]! } - public var Cache_ClearNone: String { return self._s[3865]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[3866]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[3867]! } + public var Group_AdminLog_EmptyText: String { return self._s[3858]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3859]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[3861]! } + public var Wallet_Created_ExportErrorText: String { return self._s[3862]! } + public var ChatList_UndoArchiveText1: String { return self._s[3863]! } + public var AccessDenied_VideoMicrophone: String { return self._s[3864]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3865]! } + public var Cache_ClearNone: String { return self._s[3866]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[3867]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[3868]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3868]!, self._r[3868]!, [_0]) + return formatWithArgumentRanges(self._s[3869]!, self._r[3869]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[3869]! } + public var Passport_Identity_Country: String { return self._s[3870]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3870]!, self._r[3870]!, [_0]) - } - public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3871]!, self._r[3871]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[3872]! } - public var AccessDenied_Settings: String { return self._s[3873]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3874]! } - public var Month_ShortMay: String { return self._s[3875]! } - public var Compose_NewGroup: String { return self._s[3877]! } - public var Group_Setup_TypePrivate: String { return self._s[3879]! } - public var Login_PadPhoneHelpTitle: String { return self._s[3881]! } - public var Appearance_ThemeDayClassic: String { return self._s[3882]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3883]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[3884]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3885]! } - public var Conversation_typing: String { return self._s[3887]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[3888]! } - public var Paint_Masks: String { return self._s[3889]! } - public var Contacts_DeselectAll: String { return self._s[3890]! } - public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3891]!, self._r[3891]!, [_0]) + public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3872]!, self._r[3872]!, [_0]) } - public var Username_InvalidTaken: String { return self._s[3892]! } - public var Call_StatusNoAnswer: String { return self._s[3893]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[3894]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3895]! } - public var Passport_Identity_Selfie: String { return self._s[3896]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[3897]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3898]! } - public var Conversation_ClearSecretHistory: String { return self._s[3899]! } - public var PeopleNearby_Description: String { return self._s[3901]! } - public var NetworkUsageSettings_Title: String { return self._s[3902]! } - public var Your_cards_security_code_is_invalid: String { return self._s[3904]! } + public var Exceptions_AddToExceptions: String { return self._s[3873]! } + public var AccessDenied_Settings: String { return self._s[3874]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3875]! } + public var Month_ShortMay: String { return self._s[3876]! } + public var Compose_NewGroup: String { return self._s[3878]! } + public var Group_Setup_TypePrivate: String { return self._s[3880]! } + public var Login_PadPhoneHelpTitle: String { return self._s[3882]! } + public var Appearance_ThemeDayClassic: String { return self._s[3883]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3884]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[3885]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3886]! } + public var Conversation_typing: String { return self._s[3888]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[3889]! } + public var Paint_Masks: String { return self._s[3890]! } + public var Contacts_DeselectAll: String { return self._s[3891]! } + public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3892]!, self._r[3892]!, [_0]) + } + public var Username_InvalidTaken: String { return self._s[3893]! } + public var Call_StatusNoAnswer: String { return self._s[3894]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[3895]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3896]! } + public var Passport_Identity_Selfie: String { return self._s[3897]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[3898]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3899]! } + public var Conversation_ClearSecretHistory: String { return self._s[3900]! } + public var PeopleNearby_Description: String { return self._s[3902]! } + public var NetworkUsageSettings_Title: String { return self._s[3903]! } + public var Your_cards_security_code_is_invalid: String { return self._s[3905]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3906]!, self._r[3906]!, [_0]) + return formatWithArgumentRanges(self._s[3907]!, self._r[3907]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3907]!, self._r[3907]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3908]!, self._r[3908]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[3909]! } - public var VoiceOver_Navigation_Search: String { return self._s[3910]! } - public var Map_LiveLocationTitle: String { return self._s[3911]! } - public var Login_InfoAvatarAdd: String { return self._s[3912]! } - public var Passport_Identity_FilesView: String { return self._s[3913]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[3914]! } - public var Privacy_Calls_NeverAllow: String { return self._s[3915]! } - public var VoiceOver_Chat_File: String { return self._s[3916]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3917]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[3910]! } + public var VoiceOver_Navigation_Search: String { return self._s[3911]! } + public var Map_LiveLocationTitle: String { return self._s[3912]! } + public var Login_InfoAvatarAdd: String { return self._s[3913]! } + public var Passport_Identity_FilesView: String { return self._s[3914]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[3915]! } + public var Privacy_Calls_NeverAllow: String { return self._s[3916]! } + public var VoiceOver_Chat_File: String { return self._s[3917]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3918]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3918]!, self._r[3918]!, [_0]) + return formatWithArgumentRanges(self._s[3919]!, self._r[3919]!, [_0]) } - public var ContactInfo_PhoneNumberHidden: String { return self._s[3919]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[3920]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3921]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[3920]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[3921]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3922]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3922]!, self._r[3922]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3923]!, self._r[3923]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3923]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[3924]! } - public var Tour_Title2: String { return self._s[3925]! } - public var Wallet_Sent_ViewWallet: String { return self._s[3926]! } - public var Conversation_FileOpenIn: String { return self._s[3927]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3928]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[3929]! } - public var Wallpaper_Set: String { return self._s[3930]! } - public var Passport_Identity_Translations: String { return self._s[3932]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3924]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[3925]! } + public var Tour_Title2: String { return self._s[3926]! } + public var Wallet_Sent_ViewWallet: String { return self._s[3927]! } + public var Conversation_FileOpenIn: String { return self._s[3928]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3929]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[3930]! } + public var Wallpaper_Set: String { return self._s[3931]! } + public var Passport_Identity_Translations: String { return self._s[3933]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3933]!, self._r[3933]!, [_0]) + return formatWithArgumentRanges(self._s[3934]!, self._r[3934]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[3934]! } + public var Channel_LeaveChannel: String { return self._s[3935]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3935]!, self._r[3935]!, [_1]) + return formatWithArgumentRanges(self._s[3936]!, self._r[3936]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3937]! } - public var PhotoEditor_HighlightsTint: String { return self._s[3938]! } - public var Passport_Email_Delete: String { return self._s[3939]! } - public var Conversation_Mute: String { return self._s[3941]! } - public var Channel_AddBotAsAdmin: String { return self._s[3942]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[3944]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[3945]! } - public var ChatSettings_IntentsSettings: String { return self._s[3947]! } - public var Channel_Management_LabelOwner: String { return self._s[3948]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3938]! } + public var PhotoEditor_HighlightsTint: String { return self._s[3939]! } + public var Passport_Email_Delete: String { return self._s[3940]! } + public var Conversation_Mute: String { return self._s[3942]! } + public var Channel_AddBotAsAdmin: String { return self._s[3943]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[3945]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[3946]! } + public var ChatSettings_IntentsSettings: String { return self._s[3948]! } + public var Channel_Management_LabelOwner: String { return self._s[3949]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3949]!, self._r[3949]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3950]!, self._r[3950]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[3950]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[3951]! } - public var Common_No: String { return self._s[3952]! } - public var Weekday_Sunday: String { return self._s[3953]! } - public var Notification_Reply: String { return self._s[3954]! } - public var Conversation_ViewMessage: String { return self._s[3955]! } + public var Calls_CallTabDescription: String { return self._s[3951]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[3952]! } + public var Common_No: String { return self._s[3953]! } + public var Weekday_Sunday: String { return self._s[3954]! } + public var Notification_Reply: String { return self._s[3955]! } + public var Conversation_ViewMessage: String { return self._s[3956]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3956]!, self._r[3956]!, [_0]) - } - public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3957]!, self._r[3957]!, [_0]) } + public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3958]!, self._r[3958]!, [_0]) + } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3958]!, self._r[3958]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3959]!, self._r[3959]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3959]! } - public var Wallet_Send_Title: String { return self._s[3960]! } - public var Message_PinnedDocumentMessage: String { return self._s[3961]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[3962]! } - public var DialogList_TabTitle: String { return self._s[3964]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[3965]! } - public var Passport_FieldEmail: String { return self._s[3966]! } - public var Conversation_UnpinMessageAlert: String { return self._s[3967]! } - public var Passport_Address_TypeBankStatement: String { return self._s[3968]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[3969]! } - public var Passport_Identity_ExpiryDate: String { return self._s[3970]! } - public var Privacy_Calls_P2P: String { return self._s[3971]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3960]! } + public var Wallet_Send_Title: String { return self._s[3961]! } + public var Message_PinnedDocumentMessage: String { return self._s[3962]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[3963]! } + public var DialogList_TabTitle: String { return self._s[3965]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[3966]! } + public var Passport_FieldEmail: String { return self._s[3967]! } + public var Conversation_UnpinMessageAlert: String { return self._s[3968]! } + public var Passport_Address_TypeBankStatement: String { return self._s[3969]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[3970]! } + public var Passport_Identity_ExpiryDate: String { return self._s[3971]! } + public var Privacy_Calls_P2P: String { return self._s[3972]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3973]!, self._r[3973]!, [_0]) + return formatWithArgumentRanges(self._s[3974]!, self._r[3974]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[3974]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[3975]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3975]!, self._r[3975]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3976]!, self._r[3976]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[3976]! } - public var EnterPasscode_ChangeTitle: String { return self._s[3977]! } - public var TwoFactorSetup_Email_Title: String { return self._s[3978]! } - public var Passport_InfoText: String { return self._s[3979]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3980]! } + public var Stickers_ClearRecent: String { return self._s[3977]! } + public var EnterPasscode_ChangeTitle: String { return self._s[3978]! } + public var TwoFactorSetup_Email_Title: String { return self._s[3979]! } + public var Passport_InfoText: String { return self._s[3980]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3981]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3981]!, self._r[3981]!, [_0]) + return formatWithArgumentRanges(self._s[3982]!, self._r[3982]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3982]!, self._r[3982]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3983]!, self._r[3983]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3983]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[3984]! } - public var VoiceOver_Navigation_Compose: String { return self._s[3985]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[3986]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[3988]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3989]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3984]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[3985]! } + public var VoiceOver_Navigation_Compose: String { return self._s[3986]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[3987]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[3989]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3990]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3990]!, self._r[3990]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3991]!, self._r[3991]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3992]! } - public var ChatSettings_OpenLinksIn: String { return self._s[3993]! } - public var Map_HomeAndWorkTitle: String { return self._s[3994]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3993]! } + public var ChatSettings_OpenLinksIn: String { return self._s[3994]! } + public var Map_HomeAndWorkTitle: String { return self._s[3995]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3996]!, self._r[3996]!, [_0]) + return formatWithArgumentRanges(self._s[3997]!, self._r[3997]!, [_0]) } - public var DialogList_Unread: String { return self._s[3997]! } + public var DialogList_Unread: String { return self._s[3998]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3999]!, self._r[3999]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[3999]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4000]! } + public var User_DeletedAccount: String { return self._s[4000]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4001]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4001]!, self._r[4001]!, [_0]) + return formatWithArgumentRanges(self._s[4002]!, self._r[4002]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4002]! } - public var SharedMedia_CategoryMedia: String { return self._s[4003]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4004]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4005]! } - public var Watch_ChatList_Compose: String { return self._s[4006]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4007]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4008]! } - public var Watch_Microphone_Access: String { return self._s[4009]! } - public var Group_Setup_HistoryHeader: String { return self._s[4010]! } - public var Map_SetThisLocation: String { return self._s[4011]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4012]! } - public var Activity_UploadingPhoto: String { return self._s[4013]! } - public var Conversation_Edit: String { return self._s[4015]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4016]! } - public var Login_TermsOfServiceDecline: String { return self._s[4017]! } - public var Message_PinnedContactMessage: String { return self._s[4018]! } + public var UserInfo_NotificationsDefault: String { return self._s[4003]! } + public var SharedMedia_CategoryMedia: String { return self._s[4004]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4005]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4006]! } + public var Watch_ChatList_Compose: String { return self._s[4007]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4008]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4009]! } + public var Watch_Microphone_Access: String { return self._s[4010]! } + public var Group_Setup_HistoryHeader: String { return self._s[4011]! } + public var Map_SetThisLocation: String { return self._s[4012]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4013]! } + public var Activity_UploadingPhoto: String { return self._s[4014]! } + public var Conversation_Edit: String { return self._s[4016]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4017]! } + public var Login_TermsOfServiceDecline: String { return self._s[4018]! } + public var Message_PinnedContactMessage: String { return self._s[4019]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4019]!, self._r[4019]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4020]!, self._r[4020]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4020]!, self._r[4020]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4021]!, self._r[4021]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4021]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4023]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4024]! } + public var Appearance_LargeEmoji: String { return self._s[4022]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4024]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4025]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4025]!, self._r[4025]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4026]!, self._r[4026]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4026]! } - public var Message_PinnedPhotoMessage: String { return self._s[4027]! } - public var Passport_FieldPhone: String { return self._s[4028]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4029]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4030]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4032]! } - public var Conversation_Call: String { return self._s[4033]! } - public var Common_TakePhoto: String { return self._s[4035]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4036]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4037]! } - public var Channel_NotificationLoading: String { return self._s[4038]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4027]! } + public var Message_PinnedPhotoMessage: String { return self._s[4028]! } + public var Passport_FieldPhone: String { return self._s[4029]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4030]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4031]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4033]! } + public var Conversation_Call: String { return self._s[4034]! } + public var Common_TakePhoto: String { return self._s[4036]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4037]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4038]! } + public var Channel_NotificationLoading: String { return self._s[4039]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4039]!, self._r[4039]!, [_0]) - } - public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4040]!, self._r[4040]!, [_0]) } + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4041]!, self._r[4041]!, [_0]) + } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4041]!, self._r[4041]!, [_1]) + return formatWithArgumentRanges(self._s[4042]!, self._r[4042]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[4042]! } + public var Permissions_SiriTitle_v0: String { return self._s[4043]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4043]!, self._r[4043]!, [_0]) - } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4044]!, self._r[4044]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4045]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4046]! } - public var ClearCache_FreeSpace: String { return self._s[4047]! } - public var Common_edit: String { return self._s[4048]! } - public var PrivacySettings_AuthSessions: String { return self._s[4049]! } - public var Month_ShortJune: String { return self._s[4050]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4051]! } - public var Call_ReportSend: String { return self._s[4052]! } - public var Watch_LastSeen_JustNow: String { return self._s[4053]! } - public var Notifications_MessageNotifications: String { return self._s[4054]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4055]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4057]! } - public var Group_Status: String { return self._s[4058]! } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4045]!, self._r[4045]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[4046]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4047]! } + public var ClearCache_FreeSpace: String { return self._s[4048]! } + public var Common_edit: String { return self._s[4049]! } + public var PrivacySettings_AuthSessions: String { return self._s[4050]! } + public var Month_ShortJune: String { return self._s[4051]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4052]! } + public var Call_ReportSend: String { return self._s[4053]! } + public var Watch_LastSeen_JustNow: String { return self._s[4054]! } + public var Notifications_MessageNotifications: String { return self._s[4055]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4056]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4058]! } + public var Group_Status: String { return self._s[4059]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4059]!, self._r[4059]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4060]!, self._r[4060]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4060]! } - public var ShareMenu_ShareTo: String { return self._s[4061]! } - public var Conversation_Moderate_Ban: String { return self._s[4062]! } + public var TextFormat_AddLinkTitle: String { return self._s[4061]! } + public var ShareMenu_ShareTo: String { return self._s[4062]! } + public var Conversation_Moderate_Ban: String { return self._s[4063]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4063]!, self._r[4063]!, [_0]) + return formatWithArgumentRanges(self._s[4064]!, self._r[4064]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4064]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4065]! } + public var SharedMedia_ViewInChat: String { return self._s[4065]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4066]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4066]!, self._r[4066]!, [_1]) + return formatWithArgumentRanges(self._s[4067]!, self._r[4067]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4067]!, self._r[4067]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4068]!, self._r[4068]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4069]!, self._r[4069]!, [_0]) + return formatWithArgumentRanges(self._s[4070]!, self._r[4070]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4070]! } - public var Appearance_ReduceMotion: String { return self._s[4071]! } + public var Map_OpenInHereMaps: String { return self._s[4071]! } + public var Appearance_ReduceMotion: String { return self._s[4072]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4072]!, self._r[4072]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4073]!, self._r[4073]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4073]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4074]! } - public var PhotoEditor_Skip: String { return self._s[4075]! } - public func ForwardedMessages(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4074]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4075]! } + public var PhotoEditor_Skip: String { return self._s[4076]! } + public func Conversation_StatusMembers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, _2, _1, _3) + public func ForwardedVideos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Minutes(_ value: Int32) -> String { + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_File(_ value: Int32) -> String { + public func MuteFor_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusMembers(_ value: Int32) -> String { + public func SharedMedia_File(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreExtended(_ value: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, _1, _2) } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, _1, _2) + public func Map_ETAHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } - public func QuickSend_Photos(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_SharePhoto(_ value: Int32) -> String { + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, _0, _1) + public func StickerPack_AddStickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Years(_ value: Int32) -> String { + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedStickers(_ value: Int32) -> String { + public func ChatList_DeletedChats(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Hours(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) @@ -4723,469 +4726,467 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } - public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func Map_ETAHours(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, _1, _2) } - public func ForwardedVideos(_ value: Int32) -> String { + public func Media_SharePhoto(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Months(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + public func Conversation_SelectedMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) - } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_SelectedChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_SelectedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Link(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessagePoll_VotedCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedGifs(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortHours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_ShareItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Invitation_Members(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_StickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) - } - public func InviteText_ContactsCountText(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeletedChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedLocations(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, _1, _2) } public func Media_ShareVideo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPolls(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Map_ETAMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func Theme_UsersCount(_ value: Int32) -> String { + public func StickerPack_StickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPhotos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) - } - public func UserCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_Weeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Passport_Scans(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Video(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) } public func ForwardedAudios(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func QuickSend_Photos(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_Exceptions(_ value: Int32) -> String { + public func ForwardedGifs(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) } - public func LastSeen_HoursAgo(_ value: Int32) -> String { + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Call_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + public func UserCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusSubscribers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) } public func ForwardedContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + public func Theme_UsersCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Passport_Scans(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_AddMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteFor_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedLocations(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareItem(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Years(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPolls(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortDays(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedFiles(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) + } + public func InviteText_ContactsCountText(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_ShortSeconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Link(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) + } + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_Exceptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Months(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Weeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideoMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusOnline(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessagePoll_VotedCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Invitation_Members(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_ShortMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Generic(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[114 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, _1, _2) + public func Contacts_ImportersCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, _1, _2) + public func Watch_UserInfo_Mute(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func ForwardedStickers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/Tip.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/Tip.imageset/Contents.json new file mode 100644 index 0000000000..8a66114530 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/Tip.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "ic_lamp.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/Tip.imageset/ic_lamp.pdf b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/Tip.imageset/ic_lamp.pdf new file mode 100644 index 0000000000..4b286ac00c Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat/Context Menu/Tip.imageset/ic_lamp.pdf differ diff --git a/submodules/TelegramUI/TelegramUI/ChatController.swift b/submodules/TelegramUI/TelegramUI/ChatController.swift index 3e07d113cd..6bfd9f7f50 100644 --- a/submodules/TelegramUI/TelegramUI/ChatController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatController.swift @@ -561,7 +561,8 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G break } } - let _ = combineLatest(queue: .mainQueue(), contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: strongSelf.presentationInterfaceState, context: strongSelf.context, messages: updatedMessages, controllerInteraction: strongSelf.controllerInteraction, selectAll: selectAll, interfaceInteraction: strongSelf.interfaceInteraction), loadedStickerPack(postbox: strongSelf.context.account.postbox, network: strongSelf.context.account.network, reference: .animatedEmoji, forceActualized: false)).start(next: { actions, animatedEmojiStickers in + let _ = combineLatest(queue: .mainQueue(), contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: strongSelf.presentationInterfaceState, context: strongSelf.context, messages: updatedMessages, controllerInteraction: strongSelf.controllerInteraction, selectAll: selectAll, interfaceInteraction: strongSelf.interfaceInteraction), loadedStickerPack(postbox: strongSelf.context.account.postbox, network: strongSelf.context.account.network, reference: .animatedEmoji, forceActualized: false), ApplicationSpecificNotice.getChatTextSelectionTips(accountManager: strongSelf.context.sharedContext.accountManager) + ).start(next: { actions, animatedEmojiStickers, chatTextSelectionTips in guard let strongSelf = self, !actions.isEmpty else { return } @@ -590,7 +591,13 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G if Namespaces.Message.allScheduled.contains(message.id.namespace) { reactionItems = [] } - let controller = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .extracted(ChatMessageContextExtractedContentSource(chatNode: strongSelf.chatDisplayNode, message: message)), items: .single(actions), reactionItems: reactionItems, recognizer: recognizer) + + let displayTextSelectionTip = !message.text.isEmpty && chatTextSelectionTips < 3 + if displayTextSelectionTip { + let _ = ApplicationSpecificNotice.incrementChatTextSelectionTips(accountManager: strongSelf.context.sharedContext.accountManager).start() + } + + let controller = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .extracted(ChatMessageContextExtractedContentSource(chatNode: strongSelf.chatDisplayNode, message: message)), items: .single(actions), reactionItems: reactionItems, recognizer: recognizer, displayTextSelectionTip: displayTextSelectionTip) strongSelf.currentContextController = controller controller.reactionSelected = { [weak controller] value in guard let strongSelf = self, let message = updatedMessages.first else { diff --git a/submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift b/submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift index 0a64d185cb..e8c1df5a77 100644 --- a/submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatSearchResultsContollerNode.swift @@ -11,6 +11,7 @@ import TelegramStringFormatting import MergeLists import ChatListUI import AccountContext +import ContextUI private enum ChatListSearchEntryStableId: Hashable { case messageId(MessageId) @@ -76,7 +77,7 @@ private enum ChatListSearchEntry: Comparable, Identifiable { public func item(context: AccountContext, interaction: ChatListNodeInteraction) -> ListViewItem { switch self { case let .message(message, peer, readState, presentationData): - return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(message: message, peer: peer, combinedReadState: readState, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: true, displayAsMessage: true), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) + return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(message: message, peer: peer, combinedReadState: readState, notificationSettings: nil, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: true, displayAsMessage: true, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) } } } @@ -129,7 +130,7 @@ class ChatSearchResultsControllerNode: ViewControllerTracingNode, UIScrollViewDe private let previousEntries = Atomic<[ChatListSearchEntry]?>(value: nil) - init(context: AccountContext, location: SearchMessagesLocation, searchQuery: String, searchResult: SearchMessagesResult, searchState: SearchMessagesState) { + init(context: AccountContext, location: SearchMessagesLocation, searchQuery: String, searchResult: SearchMessagesResult, searchState: SearchMessagesState, presentInGlobalOverlay: @escaping (ViewController) -> Void) { self.context = context self.location = location self.searchQuery = searchQuery @@ -183,7 +184,24 @@ class ChatSearchResultsControllerNode: ViewControllerTracingNode, UIScrollViewDe }, updatePeerGrouping: { _, _ in }, togglePeerMarkedUnread: { _, _ in }, toggleArchivedFolderHiddenByDefault: { - }, activateChatPreview: { _, _, _ in + }, activateChatPreview: { [weak self] item, node, gesture in + guard let strongSelf = self else { + gesture?.cancel() + return + } + switch item.content { + case let .peer(peer): + if let message = peer.message { + let chatController = strongSelf.context.sharedContext.makeChatController(context: strongSelf.context, chatLocation: .peer(peer.peer.peerId), subject: .message(message.id), botStart: nil, mode: .standard(previewing: true)) + chatController.canReadHistory.set(false) + let contextController = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .controller(ContextControllerContentSourceImpl(controller: chatController, sourceNode: node)), items: .single([]), reactionItems: [], gesture: gesture) + presentInGlobalOverlay(contextController) + } else { + gesture?.cancel() + } + default: + gesture?.cancel() + } }) interaction.searchTextHighightState = searchQuery self.interaction = interaction @@ -317,3 +335,32 @@ class ChatSearchResultsControllerNode: ViewControllerTracingNode, UIScrollViewDe } } } + +private final class ContextControllerContentSourceImpl: ContextControllerContentSource { + let controller: ViewController + weak var sourceNode: ASDisplayNode? + + let navigationController: NavigationController? = nil + + let passthroughTouches: Bool = true + + init(controller: ViewController, sourceNode: ASDisplayNode?) { + self.controller = controller + self.sourceNode = sourceNode + } + + func transitionInfo() -> ContextControllerTakeControllerInfo? { + let sourceNode = self.sourceNode + return ContextControllerTakeControllerInfo(contentAreaInScreenSpace: CGRect(origin: CGPoint(), size: CGSize(width: 10.0, height: 10.0)), sourceNode: { [weak sourceNode] in + if let sourceNode = sourceNode { + return (sourceNode, sourceNode.bounds) + } else { + return nil + } + }) + } + + func animatedIn() { + } +} + diff --git a/submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift b/submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift index fc3a3c14c4..313a5eb0dd 100644 --- a/submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatSearchResultsController.swift @@ -64,7 +64,9 @@ final class ChatSearchResultsController: ViewController { } override public func loadDisplayNode() { - self.displayNode = ChatSearchResultsControllerNode(context: self.context, location: self.location, searchQuery: self.searchQuery, searchResult: self.searchResult, searchState: self.searchState) + self.displayNode = ChatSearchResultsControllerNode(context: self.context, location: self.location, searchQuery: self.searchQuery, searchResult: self.searchResult, searchState: self.searchState, presentInGlobalOverlay: { [weak self] c in + self?.presentInGlobalOverlay(c) + }) self.controllerNode.resultSelected = { [weak self] messageIndex in self?.navigateToMessageIndex(messageIndex) self?.dismiss() diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping index c67400be49..cd3c69d9df 100644 Binary files a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TextSelectionNode/Sources/TextSelectionNode.swift b/submodules/TextSelectionNode/Sources/TextSelectionNode.swift index a196e51f00..f1381e0d11 100644 --- a/submodules/TextSelectionNode/Sources/TextSelectionNode.swift +++ b/submodules/TextSelectionNode/Sources/TextSelectionNode.swift @@ -34,12 +34,12 @@ private func cancelScrollViewGestures(view: UIView?) { } } -private func generateKnobImage(color: UIColor, inverted: Bool = false) -> UIImage? { +private func generateKnobImage(color: UIColor, diameter: CGFloat, inverted: Bool = false) -> UIImage? { let f: (CGSize, CGContext) -> Void = { size, context in context.clear(CGRect(origin: CGPoint(), size: size)) context.setFillColor(color.cgColor) context.fill(CGRect(origin: CGPoint(x: (size.width - 2.0) / 2.0, y: size.width / 2.0), size: CGSize(width: 2.0, height: size.height - size.width / 2.0 - 1.0))) - context.fillEllipse(in: CGRect(origin: CGPoint(), size: CGSize(width: size.width, height: size.width))) + context.fillEllipse(in: CGRect(origin: CGPoint(x: floor((size.width - diameter) / 2.0), y: floor((size.width - diameter) / 2.0)), size: CGSize(width: diameter, height: diameter))) context.fillEllipse(in: CGRect(origin: CGPoint(x: (size.width - 2.0) / 2.0, y: size.width + 2.0), size: CGSize(width: 2.0, height: 2.0))) } let size = CGSize(width: 12.0, height: 12.0 + 2.0 + 2.0) @@ -53,10 +53,12 @@ private func generateKnobImage(color: UIColor, inverted: Bool = false) -> UIImag public final class TextSelectionTheme { public let selection: UIColor public let knob: UIColor + public let knobDiameter: CGFloat - public init(selection: UIColor, knob: UIColor) { + public init(selection: UIColor, knob: UIColor, knobDiameter: CGFloat = 12.0) { self.selection = selection self.knob = knob + self.knobDiameter = knobDiameter } } @@ -204,6 +206,9 @@ public final class TextSelectionNode: ASDisplayNode { public let highlightAreaNode: ASDisplayNode + private var recognizer: TextSelectionGetureRecognizer? + private var displayLinkAnimator: DisplayLinkAnimator? + public init(theme: TextSelectionTheme, strings: PresentationStrings, textNode: TextNode, updateIsActive: @escaping (Bool) -> Void, present: @escaping (ViewController, Any?) -> Void, rootNode: ASDisplayNode, performAction: @escaping (String, TextSelectionAction) -> Void) { self.theme = theme self.strings = strings @@ -214,13 +219,13 @@ public final class TextSelectionNode: ASDisplayNode { self.performAction = performAction self.leftKnob = ASImageNode() self.leftKnob.isUserInteractionEnabled = false - self.leftKnob.image = generateKnobImage(color: theme.knob) + self.leftKnob.image = generateKnobImage(color: theme.knob, diameter: theme.knobDiameter) self.leftKnob.displaysAsynchronously = false self.leftKnob.displayWithoutProcessing = true self.leftKnob.alpha = 0.0 self.rightKnob = ASImageNode() self.rightKnob.isUserInteractionEnabled = false - self.rightKnob.image = generateKnobImage(color: theme.knob, inverted: true) + self.rightKnob.image = generateKnobImage(color: theme.knob, diameter: theme.knobDiameter, inverted: true) self.rightKnob.displaysAsynchronously = false self.rightKnob.displayWithoutProcessing = true self.rightKnob.alpha = 0.0 @@ -255,7 +260,6 @@ public final class TextSelectionNode: ASDisplayNode { let mappedPoint = strongSelf.view.convert(point, to: strongSelf.textNode.view) if let stringIndex = strongSelf.textNode.attributesAtPoint(mappedPoint, orNearest: true)?.0 { - //let string = attributedString.string as NSString var updatedMin = currentRange.0 var updatedMax = currentRange.1 switch knob { @@ -324,6 +328,7 @@ public final class TextSelectionNode: ASDisplayNode { self?.dismissSelection() self?.updateIsActive(false) } + self.recognizer = recognizer self.view.addGestureRecognizer(recognizer) } @@ -337,6 +342,60 @@ public final class TextSelectionNode: ASDisplayNode { } } + public func pretendInitiateSelection() { + guard let cachedLayout = self.textNode.cachedLayout, let attributedString = cachedLayout.attributedString else { + return + } + + var resultRange: NSRange? + let stringIndex = 0 + let string = attributedString.string as NSString + + let inputRange = CFRangeMake(0, string.length) + let flag = UInt(kCFStringTokenizerUnitWord) + let locale = CFLocaleCopyCurrent() + let tokenizer = CFStringTokenizerCreate(kCFAllocatorDefault, string as CFString, inputRange, flag, locale) + var tokenType = CFStringTokenizerAdvanceToNextToken(tokenizer) + + while !tokenType.isEmpty { + let currentTokenRange = CFStringTokenizerGetCurrentTokenRange(tokenizer) + if currentTokenRange.location <= stringIndex && currentTokenRange.location + currentTokenRange.length > stringIndex { + resultRange = NSRange(location: currentTokenRange.location, length: currentTokenRange.length) + break + } + tokenType = CFStringTokenizerAdvanceToNextToken(tokenizer) + } + if resultRange == nil { + resultRange = NSRange(location: stringIndex, length: 1) + } + + self.currentRange = resultRange.flatMap { + ($0.lowerBound, $0.upperBound) + } + self.updateSelection(range: resultRange, animateIn: true) + self.updateIsActive(true) + } + + public func pretendExtendSelection(to index: Int) { + guard let cachedLayout = self.textNode.cachedLayout, let attributedString = cachedLayout.attributedString, let endRangeRect = cachedLayout.rangeRects(in: NSRange(location: index, length: 1))?.first else { + return + } + let startPoint = self.rightKnob.frame.center + let endPoint = endRangeRect.center + let displayLinkAnimator = DisplayLinkAnimator(duration: 0.3, from: 0.0, to: 1.0, update: { [weak self] progress in + guard let strongSelf = self else { + return + } + let point = CGPoint(x: (1.0 - progress) * startPoint.x + progress * endPoint.x, y: (1.0 - progress) * startPoint.y + progress * endPoint.y) + strongSelf.recognizer?.moveKnob?(.right, point) + }, completion: { [weak self] in + guard let strongSelf = self else { + return + } + }) + self.displayLinkAnimator = displayLinkAnimator + } + private func updateSelection(range: NSRange?, animateIn: Bool) { var rects: [CGRect]? @@ -362,8 +421,8 @@ public final class TextSelectionNode: ASDisplayNode { highlightOverlay.frame = self.bounds highlightOverlay.updateRects(rects) if let image = self.leftKnob.image { - self.leftKnob.frame = CGRect(origin: CGPoint(x: floor(rects[0].minX - 1.0 - image.size.width / 2.0), y: rects[0].minY - 1.0 - image.size.width), size: CGSize(width: image.size.width, height: image.size.width + rects[0].height + 2.0)) - self.rightKnob.frame = CGRect(origin: CGPoint(x: floor(rects[rects.count - 1].maxX + 1.0 - image.size.width / 2.0), y: rects[rects.count - 1].maxY + 1.0 - (rects[0].height + 2.0)), size: CGSize(width: image.size.width, height: image.size.width + rects[0].height + 2.0)) + self.leftKnob.frame = CGRect(origin: CGPoint(x: floor(rects[0].minX - 1.0 - image.size.width / 2.0), y: rects[0].minY - 1.0 - self.theme.knobDiameter), size: CGSize(width: image.size.width, height: self.theme.knobDiameter + rects[0].height + 2.0)) + self.rightKnob.frame = CGRect(origin: CGPoint(x: floor(rects[rects.count - 1].maxX + 1.0 - image.size.width / 2.0), y: rects[rects.count - 1].maxY + 1.0 - (rects[0].height + 2.0)), size: CGSize(width: image.size.width, height: self.theme.knobDiameter + rects[0].height + 2.0)) } if self.leftKnob.alpha.isZero { highlightOverlay.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3, timingFunction: CAMediaTimingFunctionName.easeOut.rawValue) diff --git a/submodules/WatchBridge/Sources/WatchBridge.swift b/submodules/WatchBridge/Sources/WatchBridge.swift index b074778ab7..b5cfd95ff5 100644 --- a/submodules/WatchBridge/Sources/WatchBridge.swift +++ b/submodules/WatchBridge/Sources/WatchBridge.swift @@ -319,7 +319,7 @@ func makeBridgeMedia(message: Message, strings: PresentationStrings, chatPeer: P } func makeBridgeChat(_ entry: ChatListEntry, strings: PresentationStrings) -> (TGBridgeChat, [Int64 : TGBridgeUser])? { - if case let .MessageEntry(index, message, readState, _, _, renderedPeer, _, _) = entry { + if case let .MessageEntry(index, message, readState, _, _, renderedPeer, _, _, hasFailed) = entry { guard index.messageIndex.id.peerId.namespace != Namespaces.Peer.SecretChat else { return nil } @@ -332,7 +332,7 @@ func makeBridgeChat(_ entry: ChatListEntry, strings: PresentationStrings) -> (TG bridgeChat.text = message.text bridgeChat.outgoing = !message.flags.contains(.Incoming) bridgeChat.deliveryState = makeBridgeDeliveryState(message) - bridgeChat.deliveryError = message.flags.contains(.Failed) + bridgeChat.deliveryError = hasFailed bridgeChat.media = makeBridgeMedia(message: message, strings: strings, filterUnsupportedActions: false) } bridgeChat.unread = readState?.isUnread ?? false