diff --git a/TelegramUI.xcodeproj/project.pbxproj b/TelegramUI.xcodeproj/project.pbxproj index ac035721cd..0ce9a7dd43 100644 --- a/TelegramUI.xcodeproj/project.pbxproj +++ b/TelegramUI.xcodeproj/project.pbxproj @@ -408,6 +408,7 @@ D0C27B3D1F4B454800A4E170 /* InstantPagePlayableVideoNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0C27B3C1F4B454800A4E170 /* InstantPagePlayableVideoNode.swift */; }; D0C44B641FC64D0500227BE0 /* SwipeToDismissGestureRecognizer.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0C44B631FC64D0500227BE0 /* SwipeToDismissGestureRecognizer.swift */; }; D0C45E9F213FFAFD00988156 /* Lottie.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = D0C45E9E213FFAFD00988156 /* Lottie.framework */; }; + D0C683FC21AD797F00A6CAD5 /* ChatListSelection.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0C683FB21AD797F00A6CAD5 /* ChatListSelection.swift */; }; D0CAD8FB20AE1D1B00ACD96E /* ChannelMemberCategoryListContext.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0CAD8FA20AE1D1B00ACD96E /* ChannelMemberCategoryListContext.swift */; }; D0CAD8FD20AE467D00ACD96E /* PeerChannelMemberCategoriesContextsManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0CAD8FC20AE467D00ACD96E /* PeerChannelMemberCategoriesContextsManager.swift */; }; D0CAD90120AEECAC00ACD96E /* ChatEditInterfaceMessageState.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0CAD90020AEECAC00ACD96E /* ChatEditInterfaceMessageState.swift */; }; @@ -1808,6 +1809,7 @@ D0C50E3D1E93D09200F62E39 /* NotificationItemContainerNode.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = NotificationItemContainerNode.swift; sourceTree = ""; }; D0C50E3F1E93D3B000F62E39 /* ChatMessageNotificationItem.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ChatMessageNotificationItem.swift; sourceTree = ""; }; D0C50E431E93FCD200F62E39 /* notification.caf */ = {isa = PBXFileReference; lastKnownFileType = file; name = notification.caf; path = TelegramUI/Sounds/notification.caf; sourceTree = ""; }; + D0C683FB21AD797F00A6CAD5 /* ChatListSelection.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatListSelection.swift; sourceTree = ""; }; D0C932351E0988C60074F044 /* ChatButtonKeyboardInputNode.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ChatButtonKeyboardInputNode.swift; sourceTree = ""; }; D0C932371E09E0EA0074F044 /* ChatBotInfoItem.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ChatBotInfoItem.swift; sourceTree = ""; }; D0C9323B1E0B4AE90074F044 /* DataAndStorageSettingsController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = DataAndStorageSettingsController.swift; sourceTree = ""; }; @@ -4219,6 +4221,7 @@ D0575AEA1E9FD579006F2541 /* ChatListTitleLockView.swift */, D07E413A208A432100FCA8F0 /* ChatListTitleProxyNode.swift */, D06E4C302134910400088087 /* ChatListEmptyNode.swift */, + D0C683FB21AD797F00A6CAD5 /* ChatListSelection.swift */, D0F69E051D6B8A8B0046BCD6 /* Search */, ); name = "Chat List"; @@ -5283,6 +5286,7 @@ D0EC6D681EB9F58800EBF1C3 /* AuthorizationSequenceController.swift in Sources */, D0EC6D691EB9F58800EBF1C3 /* AuthorizationSequenceSplashController.swift in Sources */, D0EC6D6A1EB9F58800EBF1C3 /* AuthorizationSequenceSplashControllerNode.swift in Sources */, + D0C683FC21AD797F00A6CAD5 /* ChatListSelection.swift in Sources */, D0EC6D6B1EB9F58800EBF1C3 /* AuthorizationSequenceCountrySelectionController.swift in Sources */, D0EC6D6C1EB9F58800EBF1C3 /* AuthorizationSequenceCountrySelectionControllerNode.swift in Sources */, D0BFAE5D20AB426300793CF2 /* PeerTitle.swift in Sources */, diff --git a/TelegramUI/ArhivedStickerPacksController.swift b/TelegramUI/ArhivedStickerPacksController.swift index 75879375e1..30c1c20a92 100644 --- a/TelegramUI/ArhivedStickerPacksController.swift +++ b/TelegramUI/ArhivedStickerPacksController.swift @@ -274,7 +274,7 @@ public func archivedStickerPacksController(account: Account, archived: [Archived if !add { return } - let _ = (loadedStickerPack(postbox: account.postbox, network: account.network, reference: .id(id: info.id.id, accessHash: info.accessHash)) + let _ = (loadedStickerPack(postbox: account.postbox, network: account.network, reference: .id(id: info.id.id, accessHash: info.accessHash), forceActualized: false) |> mapToSignal { result -> Signal in switch result { case let .result(info, items, installed): diff --git a/TelegramUI/ChatInterfaceStateContextMenus.swift b/TelegramUI/ChatInterfaceStateContextMenus.swift index a59b0f8510..064f6037e8 100644 --- a/TelegramUI/ChatInterfaceStateContextMenus.swift +++ b/TelegramUI/ChatInterfaceStateContextMenus.swift @@ -590,7 +590,17 @@ func chatAvailableMessageActions(postbox: Postbox, accountPeerId: PeerId, messag case .creator, .admin: optionsMap[id]!.insert(.deleteGlobally) case .member: - break + var hasMediaToReport = false + for media in message.media { + if let _ = media as? TelegramMediaImage { + hasMediaToReport = true + } else if let file = media as? TelegramMediaFile, file.isVideo { + hasMediaToReport = true + } + } + if hasMediaToReport { + optionsMap[id]!.insert(.report) + } } } } else if let _ = peer as? TelegramUser { diff --git a/TelegramUI/ChatListController.swift b/TelegramUI/ChatListController.swift index 7d5e68b3ea..579c99d4a2 100644 --- a/TelegramUI/ChatListController.swift +++ b/TelegramUI/ChatListController.swift @@ -37,8 +37,11 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie private var didSuggestLocalization = false private var presentationData: PresentationData + private let presentationDataValue = Promise() private var presentationDataDisposable: Disposable? + private let stateDisposable = MetaDisposable() + public init(account: Account, groupId: PeerGroupId?, controlsHistoryPreload: Bool) { self.account = account self.controlsHistoryPreload = controlsHistoryPreload @@ -46,6 +49,7 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie self.groupId = groupId self.presentationData = (account.telegramApplicationContext.currentPresentationData.with { $0 }) + self.presentationDataValue.set(.single(self.presentationData)) self.titleView = NetworkStatusTitleView(theme: self.presentationData.theme) @@ -207,18 +211,19 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie } self.presentationDataDisposable = (account.telegramApplicationContext.presentationData - |> deliverOnMainQueue).start(next: { [weak self] presentationData in - if let strongSelf = self { - let previousTheme = strongSelf.presentationData.theme - let previousStrings = strongSelf.presentationData.strings - - strongSelf.presentationData = presentationData - - if previousTheme !== presentationData.theme || previousStrings !== presentationData.strings { - strongSelf.updateThemeAndStrings() - } + |> deliverOnMainQueue).start(next: { [weak self] presentationData in + if let strongSelf = self { + let previousTheme = strongSelf.presentationData.theme + let previousStrings = strongSelf.presentationData.strings + + strongSelf.presentationData = presentationData + strongSelf.presentationDataValue.set(.single(presentationData)) + + if previousTheme !== presentationData.theme || previousStrings !== presentationData.strings { + strongSelf.updateThemeAndStrings() } - }) + } + }) } required public init(coder aDecoder: NSCoder) { @@ -233,6 +238,7 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie self.passcodeLockTooltipDisposable.dispose() self.suggestLocalizationDisposable.dispose() self.presentationDataDisposable?.dispose() + self.stateDisposable.dispose() } private func updateThemeAndStrings() { @@ -469,6 +475,41 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie } } + let account = self.account + let peerIdsAndOptions: Signal<(ChatListSelectionOptions, Set)?, NoError> = self.chatListDisplayNode.chatListNode.state + |> map { state -> Set? in + if !state.editing { + return nil + } + return state.selectedPeerIds + } + |> distinctUntilChanged + |> mapToSignal { selectedPeerIds -> Signal<(ChatListSelectionOptions, Set)?, NoError> in + if let selectedPeerIds = selectedPeerIds { + return chatListSelectionOptions(postbox: account.postbox, peerIds: selectedPeerIds) + |> map { options -> (ChatListSelectionOptions, Set)? in + return (options, selectedPeerIds) + } + } else { + return .single(nil) + } + } + + self.stateDisposable.set(combineLatest(queue: .mainQueue(), self.presentationDataValue.get(), peerIdsAndOptions).start(next: { [weak self] presentationData, peerIdsAndOptions in + var toolbar: Toolbar? + if let (options, _) = peerIdsAndOptions { + let leftAction: ToolbarAction + switch options.read { + case let .all(enabled): + leftAction = ToolbarAction(title: presentationData.strings.ChatList_ReadAll, isEnabled: enabled) + case let .selective(enabled): + leftAction = ToolbarAction(title: presentationData.strings.ChatList_Read, isEnabled: enabled) + } + toolbar = Toolbar(leftAction: leftAction, rightAction: ToolbarAction(title: presentationData.strings.Common_Delete, isEnabled: options.delete)) + } + self?.setToolbar(toolbar, transition: .animated(duration: 0.3, curve: .easeInOut)) + })) + /*self.badgeIconDisposable = (self.chatListDisplayNode.chatListNode.scrollToTopOption |> distinctUntilChanged |> deliverOnMainQueue).start(next: { [weak self] option in @@ -616,7 +657,9 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie self.navigationItem.rightBarButtonItem = editItem } self.chatListDisplayNode.chatListNode.updateState { state in - return state.withUpdatedEditing(true) + var state = state + state.editing = true + return state } } @@ -628,7 +671,11 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie self.navigationItem.rightBarButtonItem = editItem } self.chatListDisplayNode.chatListNode.updateState { state in - return state.withUpdatedEditing(false).withUpdatedPeerIdWithRevealedOptions(nil) + var state = state + state.editing = false + state.peerIdWithRevealedOptions = nil + state.selectedPeerIds.removeAll() + return state } } @@ -817,4 +864,75 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie KeyShortcut(input: UIKeyInputEscape, modifiers: [], action: toggleSearch) ] } + + override public func toolbarActionSelected(left: Bool) { + let peerIds = self.chatListDisplayNode.chatListNode.currentState.selectedPeerIds + if left { + let signal: Signal + let account = self.account + if !peerIds.isEmpty { + signal = self.account.postbox.transaction { transaction -> Void in + for peerId in peerIds { + togglePeerUnreadMarkInteractively(transaction: transaction, viewTracker: account.viewTracker, peerId: peerId, setToValue: false) + } + } + } else { + signal = self.account.postbox.transaction { transaction -> Void in + markAllChatsAsReadInteractively(transaction: transaction, viewTracker: account.viewTracker) + } + } + let _ = signal.start(completed: { [weak self] in + self?.donePressed() + }) + } else if !peerIds.isEmpty { + let actionSheet = ActionSheetController(presentationTheme: self.presentationData.theme) + var items: [ActionSheetItem] = [] + items.append(ActionSheetButtonItem(title: self.presentationData.strings.Common_Delete, color: .destructive, action: { [weak self, weak actionSheet] in + actionSheet?.dismissAnimated() + + guard let strongSelf = self else { + return + } + + let account = strongSelf.account + let presentationData = strongSelf.presentationData + let progressSignal = Signal { subscriber in + let controller = OverlayStatusController(theme: presentationData.theme, strings: presentationData.strings, type: .loading(cancelled: nil)) + self?.present(controller, in: .window(.root)) + return ActionDisposable { [weak controller] in + Queue.mainQueue().async() { + controller?.dismiss() + } + } + } + |> runOn(Queue.mainQueue()) + |> delay(0.8, queue: Queue.mainQueue()) + let progressDisposable = progressSignal.start() + + let signal: Signal = strongSelf.account.postbox.transaction { transaction -> Void in + for peerId in peerIds { + removePeerChat(transaction: transaction, mediaBox: account.postbox.mediaBox, peerId: peerId, reportChatSpam: false) + } + } + |> afterDisposed { + Queue.mainQueue().async { + progressDisposable.dispose() + } + } + let _ = signal.start(completed: { + self?.donePressed() + }) + })) + + actionSheet.setItemGroups([ + ActionSheetItemGroup(items: items), + ActionSheetItemGroup(items: [ + ActionSheetButtonItem(title: self.presentationData.strings.Common_Cancel, color: .accent, action: { [weak actionSheet] in + actionSheet?.dismissAnimated() + }) + ]) + ]) + self.present(actionSheet, in: .window(.root)) + } + } } diff --git a/TelegramUI/ChatListItem.swift b/TelegramUI/ChatListItem.swift index ce0c1b3276..a42a9492e5 100644 --- a/TelegramUI/ChatListItem.swift +++ b/TelegramUI/ChatListItem.swift @@ -28,6 +28,7 @@ class ChatListItem: ListViewItem { let content: ChatListItemContent let editing: Bool let hasActiveRevealControls: Bool + let selected: Bool let enableContextActions: Bool let interaction: ChatListNodeInteraction @@ -35,7 +36,7 @@ class ChatListItem: ListViewItem { let header: ListViewItemHeader? - init(presentationData: ChatListPresentationData, account: Account, peerGroupId: PeerGroupId?, index: ChatListIndex, content: ChatListItemContent, editing: Bool, hasActiveRevealControls: Bool, header: ListViewItemHeader?, enableContextActions: Bool, interaction: ChatListNodeInteraction) { + init(presentationData: ChatListPresentationData, account: Account, peerGroupId: PeerGroupId?, index: ChatListIndex, content: ChatListItemContent, editing: Bool, hasActiveRevealControls: Bool, selected: Bool, header: ListViewItemHeader?, enableContextActions: Bool, interaction: ChatListNodeInteraction) { self.presentationData = presentationData self.peerGroupId = peerGroupId self.account = account @@ -43,6 +44,7 @@ class ChatListItem: ListViewItem { self.content = content self.editing = editing self.hasActiveRevealControls = hasActiveRevealControls + self.selected = selected self.header = header self.enableContextActions = enableContextActions self.interaction = interaction @@ -51,7 +53,6 @@ class ChatListItem: ListViewItem { func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, () -> Void)) -> Void) { async { let node = ChatListItemNode() - node.setupItem(item: self) let (first, last, firstWithHeader, nextIsPinned) = ChatListItem.mergeType(item: self, previousItem: previousItem, nextItem: nextItem) node.insets = ChatListItemNode.insets(first: first, last: last, firstWithHeader: firstWithHeader) @@ -63,6 +64,7 @@ class ChatListItem: ListViewItem { Queue.mainQueue().async { completion(node, { return (nil, { + node.setupItem(item: self) apply(false) node.updateIsHighlighted(transition: .immediate) }) @@ -231,7 +233,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var verificationIconNode: ASImageNode? let mutedIconNode: ASImageNode - var editableControlNode: ItemListEditableControlNode? + var selectableControlNode: ItemListSelectableControlNode? var reorderControlNode: ItemListEditableReorderControlNode? var layoutParams: (ChatListItem, first: Bool, last: Bool, firstWithHeader: Bool, nextIsPinned: Bool, ListViewItemLayoutParams)? @@ -239,7 +241,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { private var isHighlighted: Bool = false override var canBeSelected: Bool { - if self.editableControlNode != nil { + if self.selectableControlNode != nil { return false } else { return super.canBeSelected @@ -393,6 +395,13 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } } + override func tapped() { + guard let item = self.item, item.editing else { + return + } + item.interaction.togglePeerSelected(item.index.messageIndex.id.peerId) + } + func asyncLayout() -> (_ item: ChatListItem, _ params: ListViewItemLayoutParams, _ first: Bool, _ last: Bool, _ firstWithHeader: Bool, _ nextIsPinned: Bool) -> (ListViewItemNodeLayout, (Bool) -> Void) { let dateLayout = TextNode.asyncLayout(self.dateNode) let textLayout = TextNode.asyncLayout(self.textNode) @@ -400,7 +409,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let authorLayout = TextNode.asyncLayout(self.authorNode) let inputActivitiesLayout = self.inputActivitiesNode.asyncLayout() let badgeTextLayout = TextNode.asyncLayout(self.badgeTextNode) - let editableControlLayout = ItemListEditableControlNode.asyncLayout(self.editableControlNode) + let selectableControlLayout = ItemListSelectableControlNode.asyncLayout(self.selectableControlNode) let reorderControlLayout = ItemListEditableReorderControlNode.asyncLayout(self.reorderControlNode) let currentItem = self.layoutParams?.0 @@ -488,17 +497,17 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var currentVerificationIconImage: UIImage? var currentSecretIconImage: UIImage? - var editableControlSizeAndApply: (CGSize, () -> ItemListEditableControlNode)? + var selectableControlSizeAndApply: (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode)? var reorderControlSizeAndApply: (CGSize, () -> ItemListEditableReorderControlNode)? let editingOffset: CGFloat var reorderInset: CGFloat = 0.0 if item.editing { - let sizeAndApply = editableControlLayout(itemHeight, item.presentationData.theme, isPeerGroup) + let sizeAndApply = selectableControlLayout(item.presentationData.theme.list.itemCheckColors.strokeColor, item.presentationData.theme.list.itemCheckColors.fillColor, item.presentationData.theme.list.itemCheckColors.foregroundColor, item.selected, true) if !isAd { - editableControlSizeAndApply = sizeAndApply + selectableControlSizeAndApply = sizeAndApply } - editingOffset = sizeAndApply.0.width + editingOffset = sizeAndApply.0 if item.index.pinningIndex != nil && !isAd { let sizeAndApply = reorderControlLayout(itemHeight, item.presentationData.theme) @@ -758,32 +767,30 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } var crossfadeContent = false - if let editableControlSizeAndApply = editableControlSizeAndApply { - if strongSelf.editableControlNode == nil { + if let selectableControlSizeAndApply = selectableControlSizeAndApply { + let selectableControlSize = CGSize(width: selectableControlSizeAndApply.0, height: layout.contentSize.height) + let selectableControlFrame = CGRect(origin: CGPoint(x: params.leftInset + revealOffset, y: 0.0), size: selectableControlSize) + if strongSelf.selectableControlNode == nil { crossfadeContent = true - let editableControlNode = editableControlSizeAndApply.1() - editableControlNode.tapped = { - if let strongSelf = self { - strongSelf.setRevealOptionsOpened(true, animated: true) - strongSelf.revealOptionsInteractivelyOpened() - } - } - strongSelf.editableControlNode = editableControlNode - strongSelf.addSubnode(editableControlNode) - let editableControlFrame = CGRect(origin: CGPoint(x: params.leftInset + revealOffset, y: 0.0), size: editableControlSizeAndApply.0) - editableControlNode.frame = editableControlFrame - transition.animatePosition(node: editableControlNode, from: CGPoint(x: -editableControlFrame.size.width / 2.0, y: editableControlFrame.midY)) - editableControlNode.alpha = 0.0 - transition.updateAlpha(node: editableControlNode, alpha: 1.0) + let selectableControlNode = selectableControlSizeAndApply.1(selectableControlSize, false) + strongSelf.selectableControlNode = selectableControlNode + strongSelf.addSubnode(selectableControlNode) + selectableControlNode.frame = selectableControlFrame + transition.animatePosition(node: selectableControlNode, from: CGPoint(x: -selectableControlFrame.size.width / 2.0, y: selectableControlFrame.midY)) + selectableControlNode.alpha = 0.0 + transition.updateAlpha(node: selectableControlNode, alpha: 1.0) + } else if let selectableControlNode = strongSelf.selectableControlNode { + transition.updateFrame(node: selectableControlNode, frame: selectableControlFrame) + let _ = selectableControlSizeAndApply.1(selectableControlSize, transition.isAnimated) } - } else if let editableControlNode = strongSelf.editableControlNode { + } else if let selectableControlNode = strongSelf.selectableControlNode { crossfadeContent = true - var editableControlFrame = editableControlNode.frame - editableControlFrame.origin.x = -editableControlFrame.size.width - strongSelf.editableControlNode = nil - transition.updateAlpha(node: editableControlNode, alpha: 0.0) - transition.updateFrame(node: editableControlNode, frame: editableControlFrame, completion: { [weak editableControlNode] _ in - editableControlNode?.removeFromSupernode() + var selectableControlFrame = selectableControlNode.frame + selectableControlFrame.origin.x = -selectableControlFrame.size.width + strongSelf.selectableControlNode = nil + transition.updateAlpha(node: selectableControlNode, alpha: 0.0) + transition.updateFrame(node: selectableControlNode, frame: selectableControlFrame, completion: { [weak selectableControlNode] _ in + selectableControlNode?.removeFromSupernode() }) } @@ -1010,6 +1017,12 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { transition.animatePosition(node: strongSelf.authorNode, from: CGPoint(x: authorPosition.x - contentDeltaX, y: authorPosition.y)) } + if crossfadeContent { + strongSelf.authorNode.recursivelyEnsureDisplaySynchronously(true) + strongSelf.titleNode.recursivelyEnsureDisplaySynchronously(true) + strongSelf.textNode.recursivelyEnsureDisplaySynchronously(true) + } + let separatorInset: CGFloat if (!nextIsPinned && item.index.pinningIndex != nil) || last { separatorInset = 0.0 @@ -1020,7 +1033,9 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { transition.updateFrame(node: strongSelf.separatorNode, frame: CGRect(origin: CGPoint(x: separatorInset, y: itemHeight - separatorHeight), size: CGSize(width: params.width - separatorInset, height: separatorHeight))) strongSelf.backgroundNode.frame = CGRect(origin: CGPoint(), size: layout.contentSize) - if item.index.pinningIndex != nil { + if item.selected { + strongSelf.backgroundNode.backgroundColor = theme.itemSelectedBackgroundColor + } else if item.index.pinningIndex != nil { strongSelf.backgroundNode.backgroundColor = theme.pinnedItemBackgroundColor } else { strongSelf.backgroundNode.backgroundColor = theme.itemBackgroundColor @@ -1059,11 +1074,11 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { if let _ = self.item, let params = self.layoutParams?.5 { let editingOffset: CGFloat - if let editableControlNode = self.editableControlNode { - editingOffset = editableControlNode.bounds.size.width - var editableControlFrame = editableControlNode.frame - editableControlFrame.origin.x = params.leftInset + offset - transition.updateFrame(node: editableControlNode, frame: editableControlFrame) + if let selectableControlNode = self.selectableControlNode { + editingOffset = selectableControlNode.bounds.size.width + var selectableControlFrame = selectableControlNode.frame + selectableControlFrame.origin.x = params.leftInset + offset + transition.updateFrame(node: selectableControlNode, frame: selectableControlFrame) } else { editingOffset = 0.0 } diff --git a/TelegramUI/ChatListItemStrings.swift b/TelegramUI/ChatListItemStrings.swift index b6c3ca72a7..68ced077f3 100644 --- a/TelegramUI/ChatListItemStrings.swift +++ b/TelegramUI/ChatListItemStrings.swift @@ -75,7 +75,9 @@ public func chatListItemStrings(strings: PresentationStrings, message: Message?, if message.text.isEmpty { isVideo = true } else if #available(iOSApplicationExtension 9.0, *) { - messageText = "📹 \(messageText)" + if !fileMedia.isAnimated { + messageText = "📹 \(messageText)" + } break inner } } diff --git a/TelegramUI/ChatListNode.swift b/TelegramUI/ChatListNode.swift index 988b2f4274..4471c580be 100644 --- a/TelegramUI/ChatListNode.swift +++ b/TelegramUI/ChatListNode.swift @@ -59,6 +59,7 @@ final class ChatListHighlightedLocation { final class ChatListNodeInteraction { let activateSearch: () -> Void let peerSelected: (Peer) -> Void + let togglePeerSelected: (PeerId) -> Void let messageSelected: (Message, Bool) -> Void let groupSelected: (PeerGroupId) -> Void let addContact: (String) -> Void @@ -71,9 +72,10 @@ final class ChatListNodeInteraction { var highlightedChatLocation: ChatListHighlightedLocation? - init(activateSearch: @escaping () -> Void, peerSelected: @escaping (Peer) -> Void, messageSelected: @escaping (Message, Bool) -> Void, groupSelected: @escaping (PeerGroupId) -> Void, addContact: @escaping (String) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, setItemPinned: @escaping (PinnedItemId, Bool) -> Void, setPeerMuted: @escaping (PeerId, Bool) -> Void, deletePeer: @escaping (PeerId) -> Void, updatePeerGrouping: @escaping (PeerId, Bool) -> Void, togglePeerMarkedUnread: @escaping (PeerId, Bool) -> Void) { + init(activateSearch: @escaping () -> Void, peerSelected: @escaping (Peer) -> Void, togglePeerSelected: @escaping (PeerId) -> Void, messageSelected: @escaping (Message, Bool) -> Void, groupSelected: @escaping (PeerGroupId) -> Void, addContact: @escaping (String) -> Void, setPeerIdWithRevealedOptions: @escaping (PeerId?, PeerId?) -> Void, setItemPinned: @escaping (PinnedItemId, Bool) -> Void, setPeerMuted: @escaping (PeerId, Bool) -> Void, deletePeer: @escaping (PeerId) -> Void, updatePeerGrouping: @escaping (PeerId, Bool) -> Void, togglePeerMarkedUnread: @escaping (PeerId, Bool) -> Void) { self.activateSearch = activateSearch self.peerSelected = peerSelected + self.togglePeerSelected = togglePeerSelected self.messageSelected = messageSelected self.groupSelected = groupSelected self.addContact = addContact @@ -95,26 +97,11 @@ final class ChatListNodePeerInputActivities { } struct ChatListNodeState: Equatable { - let presentationData: ChatListPresentationData - let editing: Bool - let peerIdWithRevealedOptions: PeerId? - let peerInputActivities: ChatListNodePeerInputActivities? - - func withUpdatedPresentationData(_ presentationData: ChatListPresentationData) -> ChatListNodeState { - return ChatListNodeState(presentationData: presentationData, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, peerInputActivities: self.peerInputActivities) - } - - func withUpdatedEditing(_ editing: Bool) -> ChatListNodeState { - return ChatListNodeState(presentationData: self.presentationData, editing: editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, peerInputActivities: self.peerInputActivities) - } - - func withUpdatedPeerIdWithRevealedOptions(_ peerIdWithRevealedOptions: PeerId?) -> ChatListNodeState { - return ChatListNodeState(presentationData: self.presentationData, editing: self.editing, peerIdWithRevealedOptions: peerIdWithRevealedOptions, peerInputActivities: self.peerInputActivities) - } - - func withUpdatedPeerInputActivities(_ peerInputActivities: ChatListNodePeerInputActivities?) -> ChatListNodeState { - return ChatListNodeState(presentationData: self.presentationData, editing: self.editing, peerIdWithRevealedOptions: self.peerIdWithRevealedOptions, peerInputActivities: peerInputActivities) - } + var presentationData: ChatListPresentationData + var editing: Bool + var peerIdWithRevealedOptions: PeerId? + var selectedPeerIds: Set + var peerInputActivities: ChatListNodePeerInputActivities? static func ==(lhs: ChatListNodeState, rhs: ChatListNodeState) -> Bool { if lhs.presentationData !== rhs.presentationData { @@ -126,6 +113,9 @@ struct ChatListNodeState: Equatable { if lhs.peerIdWithRevealedOptions != rhs.peerIdWithRevealedOptions { return false } + if lhs.selectedPeerIds != rhs.selectedPeerIds { + return false + } if lhs.peerInputActivities !== rhs.peerInputActivities { return false } @@ -136,14 +126,14 @@ struct ChatListNodeState: Equatable { private func mappedInsertEntries(account: Account, nodeInteraction: ChatListNodeInteraction, peerGroupId: PeerGroupId?, mode: ChatListNodeMode, entries: [ChatListNodeViewTransitionInsertEntry]) -> [ListViewInsertItem] { return entries.map { entry -> ListViewInsertItem in switch entry.entry { - case let .SearchEntry(theme, text): - return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListSearchItem(theme: theme, placeholder: text, activate: { + case let .SearchEntry(theme, text, isEnabled): + return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListSearchItem(theme: theme, isEnabled: isEnabled, placeholder: text, activate: { nodeInteraction.activateSearch() }), directionHint: entry.directionHint) - case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, summaryInfo, editing, hasActiveRevealControls, inputActivities, isAd): + case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, isAd): switch mode { case .chatList: - return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false), editing: editing, hasActiveRevealControls: hasActiveRevealControls, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) case let .peers(filter): let itemPeer = peer.chatMainPeer var chatPeer: Peer? @@ -201,7 +191,7 @@ private func mappedInsertEntries(account: Account, nodeInteraction: ChatListNode case let .HoleEntry(_, theme): return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListHoleItem(theme: theme), directionHint: entry.directionHint) case let .GroupReferenceEntry(index, presentationData, groupId, message, topPeers, counters, editing): - return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .groupReference(groupId: groupId, message: message, topPeers: topPeers, counters: counters), editing: editing, hasActiveRevealControls: false, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .groupReference(groupId: groupId, message: message, topPeers: topPeers, counters: counters), editing: editing, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) } } } @@ -209,14 +199,14 @@ private func mappedInsertEntries(account: Account, nodeInteraction: ChatListNode private func mappedUpdateEntries(account: Account, nodeInteraction: ChatListNodeInteraction, peerGroupId: PeerGroupId?, mode: ChatListNodeMode, entries: [ChatListNodeViewTransitionUpdateEntry]) -> [ListViewUpdateItem] { return entries.map { entry -> ListViewUpdateItem in switch entry.entry { - case let .SearchEntry(theme, text): - return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListSearchItem(theme: theme, placeholder: text, activate: { + case let .SearchEntry(theme, text, isEnabled): + return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListSearchItem(theme: theme, isEnabled: isEnabled, placeholder: text, activate: { nodeInteraction.activateSearch() }), directionHint: entry.directionHint) - case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, summaryInfo, editing, hasActiveRevealControls, inputActivities, isAd): + case let .PeerEntry(index, presentationData, message, combinedReadState, notificationSettings, embeddedState, peer, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, isAd): switch mode { case .chatList: - return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false), editing: editing, hasActiveRevealControls: hasActiveRevealControls, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, notificationSettings: notificationSettings, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, isAd: isAd, ignoreUnreadBadge: false), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) case let .peers(filter): let itemPeer = peer.chatMainPeer var chatPeer: Peer? @@ -242,7 +232,7 @@ private func mappedUpdateEntries(account: Account, nodeInteraction: ChatListNode case let .HoleEntry(_, theme): return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListHoleItem(theme: theme), directionHint: entry.directionHint) case let .GroupReferenceEntry(index, presentationData, groupId, message, topPeers, counters, editing): - return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .groupReference(groupId: groupId, message: message, topPeers: topPeers, counters: counters), editing: editing, hasActiveRevealControls: false, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, account: account, peerGroupId: peerGroupId, index: index, content: .groupReference(groupId: groupId, message: message, topPeers: topPeers, counters: counters), editing: editing, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: true, interaction: nodeInteraction), directionHint: entry.directionHint) } } } @@ -309,8 +299,11 @@ final class ChatListNode: ListView { private var dequeuedInitialTransitionOnLayout = false private var enqueuedTransition: (ChatListNodeListViewTransition, () -> Void)? - private var currentState: ChatListNodeState + private(set) var currentState: ChatListNodeState private let statePromise: ValuePromise + var state: Signal { + return self.statePromise.get() + } private var currentLocation: ChatListNodeLocation? private let chatListLocation = ValuePromise() @@ -348,7 +341,7 @@ final class ChatListNode: ListView { self.controlsHistoryPreload = controlsHistoryPreload self.mode = mode - self.currentState = ChatListNodeState(presentationData: ChatListPresentationData(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations), editing: false, peerIdWithRevealedOptions: nil, peerInputActivities: nil) + self.currentState = ChatListNodeState(presentationData: ChatListPresentationData(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations), editing: false, peerIdWithRevealedOptions: nil, selectedPeerIds: Set(), peerInputActivities: nil) self.statePromise = ValuePromise(self.currentState, ignoreRepeated: true) self.theme = theme @@ -365,6 +358,16 @@ final class ChatListNode: ListView { if let strongSelf = self, let peerSelected = strongSelf.peerSelected { peerSelected(peer.id, true, false) } + }, togglePeerSelected: { [weak self] peerId in + self?.updateState { state in + var state = state + if state.selectedPeerIds.contains(peerId) { + state.selectedPeerIds.remove(peerId) + } else { + state.selectedPeerIds.insert(peerId) + } + return state + } }, messageSelected: { [weak self] message, isAd in if let strongSelf = self, let peerSelected = strongSelf.peerSelected { peerSelected(message.id.peerId, true, isAd) @@ -378,7 +381,9 @@ final class ChatListNode: ListView { if let strongSelf = self { strongSelf.updateState { state in if (peerId == nil && fromPeerId == state.peerIdWithRevealedOptions) || (peerId != nil && fromPeerId == nil) { - return state.withUpdatedPeerIdWithRevealedOptions(peerId) + var state = state + state.peerIdWithRevealedOptions = peerId + return state } else { return state } @@ -398,8 +403,10 @@ final class ChatListNode: ListView { }, setPeerMuted: { [weak self] peerId, _ in let _ = (togglePeerMuted(account: account, peerId: peerId) |> deliverOnMainQueue).start(completed: { - self?.updateState { - return $0.withUpdatedPeerIdWithRevealedOptions(nil) + self?.updateState { state in + var state = state + state.peerIdWithRevealedOptions = nil + return state } }) }, deletePeer: { [weak self] peerId in @@ -413,8 +420,10 @@ final class ChatListNode: ListView { let _ = (togglePeerUnreadMarkInteractively(postbox: account.postbox, viewTracker: account.viewTracker, peerId: peerId) |> deliverOnMainQueue).start(completed: { - self?.updateState { - return $0.withUpdatedPeerIdWithRevealedOptions(nil) + self?.updateState { state in + var state = state + state.peerIdWithRevealedOptions = nil + return state } }) }) @@ -443,13 +452,12 @@ final class ChatListNode: ListView { let entries = chatListNodeEntriesForView(update.view, state: state, savedMessagesPeer: savedMessagesPeer, mode: mode).filter { entry in switch entry { - case let .PeerEntry(_, _, _, _, _, _, peer, _, _, _, _, _): + case let .PeerEntry(_, _, _, _, _, _, peer, _, _, _, _, _, _): //ChatListNodePeersFilter switch mode { case .chatList: return true case let .peers(filter): - guard !filter.contains(.excludeSavedMessages) || peer.peerId != currentPeerId else { return false } guard !filter.contains(.excludeSecretChats) || peer.peerId.namespace != Namespaces.Peer.SecretChat else { return false } guard !filter.contains(.onlyPrivateChats) || peer.peerId.namespace == Namespaces.Peer.CloudUser else { return false } @@ -533,7 +541,7 @@ final class ChatListNode: ListView { var updatedPinnedCount = 0 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 { previousPinnedCount += 1 } @@ -541,7 +549,7 @@ final class ChatListNode: ListView { } } for entry in processedView.filteredEntries { - if case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _) = entry { + if case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _) = entry { if index.pinningIndex != nil { updatedPinnedCount += 1 } @@ -550,6 +558,9 @@ final class ChatListNode: ListView { if previousPinnedCount != updatedPinnedCount { disableAnimations = false } + if previousState.selectedPeerIds != state.selectedPeerIds { + disableAnimations = false + } } return preparedChatListNodeViewTransition(from: previousView, to: processedView, reason: reason, disableAnimations: disableAnimations, account: account, scrollPosition: updatedScrollPosition) @@ -593,7 +604,7 @@ 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 @@ -716,8 +727,10 @@ final class ChatListNode: ListView { } |> deliverOnMainQueue).start(next: { [weak self] activities in if let strongSelf = self { - strongSelf.updateState { current in - return current.withUpdatedPeerInputActivities(activities) + strongSelf.updateState { state in + var state = state + state.peerInputActivities = activities + return state } } }) @@ -725,8 +738,10 @@ final class ChatListNode: ListView { self.beganInteractiveDragging = { [weak self] in if let strongSelf = self { if strongSelf.currentState.peerIdWithRevealedOptions != nil { - strongSelf.updateState { - return $0.withUpdatedPeerIdWithRevealedOptions(nil) + strongSelf.updateState { state in + var state = state + state.peerIdWithRevealedOptions = nil + return state } } } @@ -740,7 +755,7 @@ 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 { @@ -760,7 +775,7 @@ 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) @@ -860,8 +875,10 @@ final class ChatListNode: ListView { self.keepTopItemOverscrollBackground = ListViewKeepTopItemOverscrollBackground(color: theme.chatList.pinnedItemBackgroundColor, direction: true) } - self.updateState { - return $0.withUpdatedPresentationData(ChatListPresentationData(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations)) + self.updateState { state in + var state = state + state.presentationData = ChatListPresentationData(theme: theme, strings: strings, dateTimeFormat: dateTimeFormat, nameSortOrder: nameSortOrder, nameDisplayOrder: nameDisplayOrder, disableAnimations: disableAnimations) + return state } } } @@ -1080,7 +1097,7 @@ 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 @@ -1113,12 +1130,12 @@ final class ChatListNode: ListView { break case .previous(unread: false), .next(unread: false): if current.2 != entryCount - range.firstIndex - 1 && entryCount > 2 { - if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _) = chatListView.filteredEntries[current.2 - 1] { + if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 - 1] { next = (index, peer.peerId) } } if current.2 != entryCount - range.lastIndex - 2 && entryCount > 2 { - if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _) = chatListView.filteredEntries[current.2 + 1] { + if case let .PeerEntry(index, _, _, _, _, _, peer, _, _, _, _, _, _) = chatListView.filteredEntries[current.2 + 1] { previous = (index, peer.peerId) } } @@ -1177,7 +1194,7 @@ final class ChatListNode: ListView { continue } switch chatListView.filteredEntries[entryCount - i - 1] { - case let .PeerEntry(index, _, _, readState, notificationSettings, _, _, _, _, _, _, _): + case let .PeerEntry(index, _, _, readState, notificationSettings, _, _, _, _, _, _, _, _): return index default: break diff --git a/TelegramUI/ChatListNodeEntries.swift b/TelegramUI/ChatListNodeEntries.swift index 5959c5b922..1cd883e5ae 100644 --- a/TelegramUI/ChatListNodeEntries.swift +++ b/TelegramUI/ChatListNodeEntries.swift @@ -52,8 +52,8 @@ enum ChatListNodeEntryId: Hashable { } enum ChatListNodeEntry: Comparable, Identifiable { - case SearchEntry(theme: PresentationTheme, text: String) - case PeerEntry(index: ChatListIndex, presentationData: ChatListPresentationData, message: Message?, readState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, peer: RenderedPeer, summaryInfo: ChatListMessageTagSummaryInfo, editing: Bool, hasActiveRevealControls: Bool, inputActivities: [(Peer, PeerInputActivity)]?, isAd: Bool) + case SearchEntry(theme: PresentationTheme, text: String, isEnabled: Bool) + case PeerEntry(index: ChatListIndex, presentationData: ChatListPresentationData, message: Message?, readState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, peer: RenderedPeer, summaryInfo: ChatListMessageTagSummaryInfo, editing: Bool, hasActiveRevealControls: Bool, selected: Bool, inputActivities: [(Peer, PeerInputActivity)]?, isAd: Bool) case HoleEntry(ChatListHole, theme: PresentationTheme) case GroupReferenceEntry(index: ChatListIndex, presentationData: ChatListPresentationData, groupId: PeerGroupId, message: Message?, topPeers: [Peer], counters: GroupReferenceUnreadCounters, editing: Bool) @@ -61,7 +61,7 @@ enum ChatListNodeEntry: Comparable, Identifiable { switch self { case .SearchEntry: return ChatListIndex.absoluteUpperBound - case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _): + case let .PeerEntry(index, _, _, _, _, _, _, _, _, _, _, _, _): return index case let .HoleEntry(hole, _): return ChatListIndex(pinningIndex: nil, messageIndex: hole.index) @@ -74,7 +74,7 @@ enum ChatListNodeEntry: Comparable, Identifiable { switch self { case .SearchEntry: return .Search - 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)) @@ -89,15 +89,15 @@ enum ChatListNodeEntry: Comparable, Identifiable { static func ==(lhs: ChatListNodeEntry, rhs: ChatListNodeEntry) -> Bool { switch lhs { - case let .SearchEntry(lhsTheme, lhsText): - if case let .SearchEntry(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { + case let .SearchEntry(lhsTheme, lhsText, lhsEnabled): + if case let .SearchEntry(rhsTheme, rhsText, rhsEnabled) = rhs, lhsTheme === rhsTheme, lhsText == rhsText, lhsEnabled == rhsEnabled { return true } else { return false } - case let .PeerEntry(lhsIndex, lhsPresentationData, lhsMessage, lhsUnreadCount, lhsNotificationSettings, lhsEmbeddedState, lhsPeer, lhsSummaryInfo, lhsEditing, lhsHasRevealControls, lhsInputActivities, lhsAd): + case let .PeerEntry(lhsIndex, lhsPresentationData, lhsMessage, lhsUnreadCount, lhsNotificationSettings, lhsEmbeddedState, lhsPeer, lhsSummaryInfo, lhsEditing, lhsHasRevealControls, lhsSelected, lhsInputActivities, lhsAd): switch rhs { - case let .PeerEntry(rhsIndex, rhsPresentationData, rhsMessage, rhsUnreadCount, rhsNotificationSettings, rhsEmbeddedState, rhsPeer, rhsSummaryInfo, rhsEditing, rhsHasRevealControls, rhsInputActivities, rhsAd): + case let .PeerEntry(rhsIndex, rhsPresentationData, rhsMessage, rhsUnreadCount, rhsNotificationSettings, rhsEmbeddedState, rhsPeer, rhsSummaryInfo, rhsEditing, rhsHasRevealControls, rhsSelected, rhsInputActivities, rhsAd): if lhsIndex != rhsIndex { return false } @@ -130,6 +130,9 @@ enum ChatListNodeEntry: Comparable, Identifiable { if lhsHasRevealControls != rhsHasRevealControls { return false } + if lhsSelected != rhsSelected { + return false + } if lhsPeer != rhsPeer { return false } @@ -221,15 +224,13 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, pinnedIndexOffset = UInt16(view.additionalItemEntries.count) } - - loop: for entry in view.entries { switch entry { case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, summaryInfo): if let savedMessagesPeer = savedMessagesPeer, savedMessagesPeer.id == index.messageIndex.id.peerId { continue loop } - result.append(.PeerEntry(index: offsetPinnedIndex(index, offset: pinnedIndexOffset), presentationData: state.presentationData, message: message, readState: combinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], isAd: false)) + result.append(.PeerEntry(index: offsetPinnedIndex(index, offset: pinnedIndexOffset), presentationData: state.presentationData, message: message, readState: combinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, 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)) case let .HoleEntry(hole): result.append(.HoleEntry(hole, theme: state.presentationData.theme)) case let .GroupReferenceEntry(groupId, index, message, topPeers, counters): @@ -240,14 +241,14 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, } if view.laterIndex == nil { 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])), summaryInfo: ChatListMessageTagSummaryInfo(), editing: state.editing, hasActiveRevealControls: 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])), summaryInfo: ChatListMessageTagSummaryInfo(), editing: state.editing, hasActiveRevealControls: false, selected: false, inputActivities: nil, isAd: false)) } else { if !view.additionalItemEntries.isEmpty { var pinningIndex: UInt16 = UInt16(view.additionalItemEntries.count - 1) for entry in view.additionalItemEntries.reversed() { switch entry { case let .MessageEntry(index, message, combinedReadState, notificationSettings, embeddedState, peer, summaryInfo): - result.append(.PeerEntry(index: ChatListIndex(pinningIndex: pinningIndex, messageIndex: index.messageIndex), presentationData: state.presentationData, message: message, readState: combinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], isAd: true)) + result.append(.PeerEntry(index: ChatListIndex(pinningIndex: pinningIndex, messageIndex: index.messageIndex), presentationData: state.presentationData, message: message, readState: combinedReadState, notificationSettings: notificationSettings, embeddedInterfaceState: embeddedState, peer: peer, 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)) if pinningIndex != 0 { pinningIndex -= 1 } @@ -258,10 +259,10 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, } } switch mode { - case .chatList: - result.append(.SearchEntry(theme: state.presentationData.theme, text: view.groupId == nil ? state.presentationData.strings.DialogList_SearchLabel : "Search this feed")) - case .peers: - result.append(.SearchEntry(theme: state.presentationData.theme, text: state.presentationData.strings.Common_Search)) + case .chatList: + result.append(.SearchEntry(theme: state.presentationData.theme, text: view.groupId == nil ? state.presentationData.strings.DialogList_SearchLabel : "Search this feed", isEnabled: !state.editing)) + case .peers: + result.append(.SearchEntry(theme: state.presentationData.theme, text: state.presentationData.strings.Common_Search, isEnabled: !state.editing)) } } if result.count >= 2, case .SearchEntry = result[result.count - 1], case .HoleEntry = result[result.count - 2] { diff --git a/TelegramUI/ChatListSearchContainerNode.swift b/TelegramUI/ChatListSearchContainerNode.swift index 63f94711b1..7edf5d014b 100644 --- a/TelegramUI/ChatListSearchContainerNode.swift +++ b/TelegramUI/ChatListSearchContainerNode.swift @@ -443,7 +443,7 @@ enum ChatListSearchEntry: Comparable, Identifiable { interaction.peerSelected(peer.peer) }) case let .message(message, readState, presentationData): - return ChatListItem(presentationData: presentationData, account: account, peerGroupId: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(message)), content: .peer(message: message, peer: RenderedPeer(message: message), combinedReadState: readState, notificationSettings: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: true), editing: false, hasActiveRevealControls: false, header: enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil, enableContextActions: false, interaction: interaction) + return ChatListItem(presentationData: presentationData, account: account, peerGroupId: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(message)), content: .peer(message: message, peer: RenderedPeer(message: message), combinedReadState: readState, notificationSettings: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, isAd: false, ignoreUnreadBadge: true), editing: false, hasActiveRevealControls: false, selected: false, header: enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil, enableContextActions: 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) @@ -743,6 +743,7 @@ final class ChatListSearchContainerNode: SearchDisplayControllerContentNode { openPeer(peer, false) let _ = addRecentlySearchedPeer(postbox: account.postbox, peerId: peer.id).start() self?.listNode.clearHighlightAnimated(true) + }, togglePeerSelected: { _ in }, messageSelected: { [weak self] message, _ in if let peer = message.peers[message.id.peerId] { openMessage(peer, message.id) diff --git a/TelegramUI/ChatListSearchItem.swift b/TelegramUI/ChatListSearchItem.swift index f2dd2dff77..bb67a5e85a 100644 --- a/TelegramUI/ChatListSearchItem.swift +++ b/TelegramUI/ChatListSearchItem.swift @@ -11,11 +11,13 @@ class ChatListSearchItem: ListViewItem { let selectable: Bool = false let theme: PresentationTheme + let isEnabled: Bool private let placeholder: String private let activate: () -> Void - init(theme: PresentationTheme, placeholder: String, activate: @escaping () -> Void) { + init(theme: PresentationTheme, isEnabled: Bool = true, placeholder: String, activate: @escaping () -> Void) { self.theme = theme + self.isEnabled = isEnabled self.placeholder = placeholder self.activate = activate } @@ -30,7 +32,7 @@ class ChatListSearchItem: ListViewItem { if let nextItem = nextItem as? ChatListItem, nextItem.index.pinningIndex != nil { nextIsPinned = true } - let (layout, apply) = makeLayout(self, params, nextIsPinned) + let (layout, apply) = makeLayout(self, params, nextIsPinned, self.isEnabled) node.contentSize = layout.contentSize node.insets = layout.insets @@ -56,7 +58,7 @@ class ChatListSearchItem: ListViewItem { if let nextItem = nextItem as? ChatListItem, nextItem.index.pinningIndex != nil { nextIsPinned = true } - let (nodeLayout, apply) = layout(self, params, nextIsPinned) + let (nodeLayout, apply) = layout(self, params, nextIsPinned, self.isEnabled) Queue.mainQueue().async { completion(nodeLayout, { apply(animation.isAnimated) @@ -70,6 +72,7 @@ class ChatListSearchItem: ListViewItem { class ChatListSearchItemNode: ListViewItemNode { let searchBarNode: SearchBarPlaceholderNode + private var disabledOverlay: ASDisplayNode? var placeholder: String? fileprivate var activate: (() -> Void)? { @@ -92,17 +95,17 @@ class ChatListSearchItemNode: ListViewItemNode { if let nextItem = nextItem as? ChatListItem, nextItem.index.pinningIndex != nil { nextIsPinned = true } - let (layout, apply) = makeLayout(item as! ChatListSearchItem, params, nextIsPinned) + let (layout, apply) = makeLayout(item as! ChatListSearchItem, params, nextIsPinned, (item as! ChatListSearchItem).isEnabled) apply(false) self.contentSize = layout.contentSize self.insets = layout.insets } - func asyncLayout() -> (_ item: ChatListSearchItem, _ params: ListViewItemLayoutParams, _ nextIsPinned: Bool) -> (ListViewItemNodeLayout, (Bool) -> Void) { + func asyncLayout() -> (_ item: ChatListSearchItem, _ params: ListViewItemLayoutParams, _ nextIsPinned: Bool, _ isEnabled: Bool) -> (ListViewItemNodeLayout, (Bool) -> Void) { let searchBarNodeLayout = self.searchBarNode.asyncLayout() let placeholder = self.placeholder - return { item, params, nextIsPinned in + return { item, params, nextIsPinned, isEnabled in let baseWidth = params.width - params.leftInset - params.rightInset let backgroundColor = nextIsPinned ? item.theme.chatList.pinnedItemBackgroundColor : item.theme.chatList.itemBackgroundColor @@ -120,11 +123,36 @@ class ChatListSearchItemNode: ListViewItemNode { transition = .immediate } - strongSelf.searchBarNode.frame = CGRect(origin: CGPoint(x: params.leftInset + 8.0, y: 8.0), size: CGSize(width: baseWidth - 16.0, height: 28.0)) + let searchBarFrame = CGRect(origin: CGPoint(x: params.leftInset + 8.0, y: 8.0), size: CGSize(width: baseWidth - 16.0, height: 28.0)) + strongSelf.searchBarNode.frame = searchBarFrame searchBarApply() strongSelf.searchBarNode.bounds = CGRect(origin: CGPoint(), size: CGSize(width: baseWidth - 16.0, height: 28.0)) + if !item.isEnabled { + if strongSelf.disabledOverlay == nil { + let disabledOverlay = ASDisplayNode() + strongSelf.addSubnode(disabledOverlay) + strongSelf.disabledOverlay = disabledOverlay + if animated { + disabledOverlay.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.25) + } + } + if let disabledOverlay = strongSelf.disabledOverlay { + disabledOverlay.backgroundColor = backgroundColor.withAlphaComponent(0.4) + disabledOverlay.frame = searchBarFrame + } + } else if let disabledOverlay = strongSelf.disabledOverlay { + strongSelf.disabledOverlay = nil + if animated { + disabledOverlay.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.3, removeOnCompletion: false, completion: { [weak disabledOverlay] _ in + disabledOverlay?.removeFromSupernode() + }) + } else { + disabledOverlay.removeFromSupernode() + } + } + transition.updateBackgroundColor(node: strongSelf, color: backgroundColor) } }) diff --git a/TelegramUI/ChatListSelection.swift b/TelegramUI/ChatListSelection.swift new file mode 100644 index 0000000000..4f041483ea --- /dev/null +++ b/TelegramUI/ChatListSelection.swift @@ -0,0 +1,56 @@ +import Foundation +import SwiftSignalKit +import Postbox +import TelegramCore + +enum ChatListSelectionReadOption: Equatable { + case all(enabled: Bool) + case selective(enabled: Bool) +} + +struct ChatListSelectionOptions: Equatable { + let read: ChatListSelectionReadOption + let delete: Bool +} + +func chatListSelectionOptions(postbox: Postbox, peerIds: Set) -> Signal { + if peerIds.isEmpty { + let key = PostboxViewKey.unreadCounts(items: [.total(nil)]) + return postbox.combinedView(keys: [key]) + |> map { view -> ChatListSelectionOptions in + var hasUnread = false + if let unreadCounts = view.views[key] as? UnreadMessageCountsView, let total = unreadCounts.total() { + for (_, counter) in total.1.absoluteCounters { + if counter.messageCount != 0 { + hasUnread = true + break + } + } + } + return ChatListSelectionOptions(read: .all(enabled: hasUnread), delete: false) + } + |> distinctUntilChanged + } else { + let items: [UnreadMessageCountsItem] = peerIds.map(UnreadMessageCountsItem.peer) + let key = PostboxViewKey.unreadCounts(items: items) + return postbox.combinedView(keys: [key]) + |> map { view -> ChatListSelectionOptions in + var hasUnread = false + if let unreadCounts = view.views[key] as? UnreadMessageCountsView { + loop: for entry in unreadCounts.entries { + switch entry { + case let .peer(_, count): + if count != 0 { + hasUnread = true + break loop + } + default: + break + } + } + } + return ChatListSelectionOptions(read: .selective(enabled: hasUnread), delete: true) + } + |> distinctUntilChanged + } +} diff --git a/TelegramUI/ChatMediaInputTrendingPane.swift b/TelegramUI/ChatMediaInputTrendingPane.swift index c1fd0a1b37..2f0ec5e611 100644 --- a/TelegramUI/ChatMediaInputTrendingPane.swift +++ b/TelegramUI/ChatMediaInputTrendingPane.swift @@ -137,7 +137,7 @@ final class ChatMediaInputTrendingPane: ChatMediaInputPane { let interaction = TrendingPaneInteraction(installPack: { [weak self] info in if let strongSelf = self, let info = info as? StickerPackCollectionInfo { - let _ = (loadedStickerPack(postbox: strongSelf.account.postbox, network: strongSelf.account.network, reference: .id(id: info.id.id, accessHash: info.accessHash)) + let _ = (loadedStickerPack(postbox: strongSelf.account.postbox, network: strongSelf.account.network, reference: .id(id: info.id.id, accessHash: info.accessHash), forceActualized: false) |> mapToSignal { result -> Signal in switch result { case let .result(info, items, installed): diff --git a/TelegramUI/ChatMessageInteractiveMediaNode.swift b/TelegramUI/ChatMessageInteractiveMediaNode.swift index 75920c1bc5..ce3f24738a 100644 --- a/TelegramUI/ChatMessageInteractiveMediaNode.swift +++ b/TelegramUI/ChatMessageInteractiveMediaNode.swift @@ -178,7 +178,14 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode { var unboundSize: CGSize if let image = media as? TelegramMediaImage, let dimensions = largestImageRepresentation(image.representations)?.dimensions { unboundSize = CGSize(width: floor(dimensions.width * 0.5), height: floor(dimensions.height * 0.5)) - } else if let file = media as? TelegramMediaFile, let dimensions = file.dimensions { + } else if let file = media as? TelegramMediaFile, var dimensions = file.dimensions { + if let thumbnail = file.previewRepresentations.first { + let dimensionsVertical = dimensions.width < dimensions.height + let thumbnailVertical = thumbnail.dimensions.width < thumbnail.dimensions.height + if dimensionsVertical != thumbnailVertical { + dimensions = CGSize(width: dimensions.height, height: dimensions.width) + } + } unboundSize = CGSize(width: floor(dimensions.width * 0.5), height: floor(dimensions.height * 0.5)) if file.isAnimated { unboundSize = unboundSize.aspectFilled(CGSize(width: 480.0, height: 480.0)) diff --git a/TelegramUI/DefaultDarkAccentPresentationTheme.swift b/TelegramUI/DefaultDarkAccentPresentationTheme.swift index 16ba3932e1..87fe8896da 100644 --- a/TelegramUI/DefaultDarkAccentPresentationTheme.swift +++ b/TelegramUI/DefaultDarkAccentPresentationTheme.swift @@ -109,7 +109,8 @@ private let chatList = PresentationThemeChatList( itemSeparatorColor: UIColor(rgb: 0x131A23), itemBackgroundColor: UIColor(rgb: 0x18222D), pinnedItemBackgroundColor: UIColor(rgb: 0x213040), - itemHighlightedBackgroundColor: UIColor(rgb: 0x10171F), //!!! + itemHighlightedBackgroundColor: UIColor(rgb: 0x10171F), + itemSelectedBackgroundColor: UIColor(rgb: 0x10171F), titleColor: UIColor(rgb: 0xffffff), secretTitleColor: secretColor, dateTextColor: UIColor(rgb: 0xDBF5FF, alpha: 0.5), diff --git a/TelegramUI/DefaultDarkPresentationTheme.swift b/TelegramUI/DefaultDarkPresentationTheme.swift index 22c7129cbf..7b111dba6b 100644 --- a/TelegramUI/DefaultDarkPresentationTheme.swift +++ b/TelegramUI/DefaultDarkPresentationTheme.swift @@ -110,6 +110,7 @@ private let chatList = PresentationThemeChatList( itemBackgroundColor: UIColor(rgb: 0x000000), pinnedItemBackgroundColor: UIColor(rgb: 0x1c1c1d), itemHighlightedBackgroundColor: UIColor(rgb: 0x191919), + itemSelectedBackgroundColor: UIColor(rgb: 0x191919), titleColor: UIColor(rgb: 0xffffff), secretTitleColor: UIColor(rgb: 0xb2b2b2), //!!! dateTextColor: UIColor(rgb: 0x8e8e93), diff --git a/TelegramUI/DefaultPresentationTheme.swift b/TelegramUI/DefaultPresentationTheme.swift index 39628d4fc6..efa58b8fd9 100644 --- a/TelegramUI/DefaultPresentationTheme.swift +++ b/TelegramUI/DefaultPresentationTheme.swift @@ -110,6 +110,7 @@ private func makeDefaultPresentationTheme(accentColor: UIColor, day: Bool) -> Pr itemBackgroundColor: .white, pinnedItemBackgroundColor: UIColor(rgb: 0xf7f7f7), itemHighlightedBackgroundColor: UIColor(rgb: 0xd9d9d9), + itemSelectedBackgroundColor: UIColor(rgb: 0xe9f0fa), titleColor: .black, secretTitleColor: secretColor, dateTextColor: UIColor(rgb: 0x8e8e93), @@ -140,6 +141,7 @@ private func makeDefaultPresentationTheme(accentColor: UIColor, day: Bool) -> Pr itemBackgroundColor: .white, pinnedItemBackgroundColor: UIColor(rgb: 0xf7f7f7), itemHighlightedBackgroundColor: UIColor(rgb: 0xd9d9d9), + itemSelectedBackgroundColor: UIColor(rgb: 0xe9f0fa), titleColor: .black, secretTitleColor: secretColor, dateTextColor: UIColor(rgb: 0x8e8e93), diff --git a/TelegramUI/FeaturedStickerPacksController.swift b/TelegramUI/FeaturedStickerPacksController.swift index 08fa0f42e3..4192bbc149 100644 --- a/TelegramUI/FeaturedStickerPacksController.swift +++ b/TelegramUI/FeaturedStickerPacksController.swift @@ -171,7 +171,7 @@ public func featuredStickerPacksController(account: Account) -> ViewController { let arguments = FeaturedStickerPacksControllerArguments(account: account, openStickerPack: { info in presentStickerPackController?(info) }, addPack: { info in - let _ = (loadedStickerPack(postbox: account.postbox, network: account.network, reference: .id(id: info.id.id, accessHash: info.accessHash)) + let _ = (loadedStickerPack(postbox: account.postbox, network: account.network, reference: .id(id: info.id.id, accessHash: info.accessHash), forceActualized: false) |> mapToSignal { result -> Signal in switch result { case let .result(info, items, installed): diff --git a/TelegramUI/GroupStickerPackSetupController.swift b/TelegramUI/GroupStickerPackSetupController.swift index 2f3b14c4bd..28b4ed59ac 100644 --- a/TelegramUI/GroupStickerPackSetupController.swift +++ b/TelegramUI/GroupStickerPackSetupController.swift @@ -309,7 +309,7 @@ public func groupStickerPackSetupController(account: Account, peerId: PeerId, cu let initialData = Promise() if let currentPackInfo = currentPackInfo { - initialData.set(cachedStickerPack(postbox: account.postbox, network: account.network, reference: .id(id: currentPackInfo.id.id, accessHash: currentPackInfo.accessHash)) + initialData.set(cachedStickerPack(postbox: account.postbox, network: account.network, reference: .id(id: currentPackInfo.id.id, accessHash: currentPackInfo.accessHash), forceRemote: false) |> map { result -> InitialStickerPackData? in switch result { case .none: @@ -349,7 +349,7 @@ public func groupStickerPackSetupController(account: Account, peerId: PeerId, cu } } return .single((searchText, .searching)) - |> then((loadedStickerPack(postbox: account.postbox, network: account.network, reference: .name(searchText.lowercased())) |> delay(0.3, queue: Queue.concurrentDefaultQueue())) + |> then((loadedStickerPack(postbox: account.postbox, network: account.network, reference: .name(searchText.lowercased()), forceActualized: false) |> delay(0.3, queue: Queue.concurrentDefaultQueue())) |> mapToSignal { value -> Signal<(String, GroupStickerPackSearchState), NoError> in switch value { case .fetching: diff --git a/TelegramUI/HashtagSearchController.swift b/TelegramUI/HashtagSearchController.swift index 6d2967e416..8895b5f01c 100644 --- a/TelegramUI/HashtagSearchController.swift +++ b/TelegramUI/HashtagSearchController.swift @@ -43,7 +43,7 @@ final class HashtagSearchController: TelegramController { } let interaction = ChatListNodeInteraction(activateSearch: { }, peerSelected: { peer in - + }, togglePeerSelected: { _ in }, messageSelected: { [weak self] message, _ in if let strongSelf = self { if let peer = message.peers[message.id.peerId] { diff --git a/TelegramUI/ItemListSelectableControlNode.swift b/TelegramUI/ItemListSelectableControlNode.swift index af40c06f2a..166e05ca59 100644 --- a/TelegramUI/ItemListSelectableControlNode.swift +++ b/TelegramUI/ItemListSelectableControlNode.swift @@ -14,8 +14,8 @@ final class ItemListSelectableControlNode: ASDisplayNode { self.addSubnode(self.checkNode) } - static func asyncLayout(_ node: ItemListSelectableControlNode?) -> (_ strokeColor: UIColor, _ fillColor: UIColor, _ foregroundColor: UIColor, _ selected: Bool) -> (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode) { - return { strokeColor, fillColor, foregroundColor, selected in + static func asyncLayout(_ node: ItemListSelectableControlNode?) -> (_ strokeColor: UIColor, _ fillColor: UIColor, _ foregroundColor: UIColor, _ selected: Bool, _ compact: Bool) -> (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode) { + return { strokeColor, fillColor, foregroundColor, selected, compact in let resultNode: ItemListSelectableControlNode if let node = node { resultNode = node @@ -23,10 +23,9 @@ final class ItemListSelectableControlNode: ASDisplayNode { resultNode = ItemListSelectableControlNode(strokeColor: strokeColor, fillColor: fillColor, foregroundColor: foregroundColor) } - return (45.0, { size, animated in - + return (compact ? 38.0 : 45.0, { size, animated in let checkSize = CGSize(width: 32.0, height: 32.0) - resultNode.checkNode.frame = CGRect(origin: CGPoint(x: 12.0, y: floor((size.height - checkSize.height) / 2.0)), size: checkSize) + resultNode.checkNode.frame = CGRect(origin: CGPoint(x: compact ? 9 : 12.0, y: floor((size.height - checkSize.height) / 2.0)), size: checkSize) resultNode.checkNode.setIsChecked(selected, animated: animated) return resultNode }) diff --git a/TelegramUI/ItemListTextWithLabelItem.swift b/TelegramUI/ItemListTextWithLabelItem.swift index a46ba3a578..6cf15b0744 100644 --- a/TelegramUI/ItemListTextWithLabelItem.swift +++ b/TelegramUI/ItemListTextWithLabelItem.swift @@ -176,7 +176,7 @@ class ItemListTextWithLabelItemNode: ListViewItemNode { var leftOffset: CGFloat = 0.0 var selectionNodeWidthAndApply: (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode)? if let selected = item.selected { - let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected) + let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected, false) selectionNodeWidthAndApply = (selectionWidth, selectionApply) leftOffset += selectionWidth - 8.0 } diff --git a/TelegramUI/ListMessageFileItemNode.swift b/TelegramUI/ListMessageFileItemNode.swift index 89cba32928..fdc08dd3f9 100644 --- a/TelegramUI/ListMessageFileItemNode.swift +++ b/TelegramUI/ListMessageFileItemNode.swift @@ -304,7 +304,7 @@ final class ListMessageFileItemNode: ListMessageNode { var leftOffset: CGFloat = 0.0 var selectionNodeWidthAndApply: (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode)? if case let .selectable(selected) = item.selection { - let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected) + let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected, false) selectionNodeWidthAndApply = (selectionWidth, selectionApply) leftOffset += selectionWidth } diff --git a/TelegramUI/ListMessageSnippetItemNode.swift b/TelegramUI/ListMessageSnippetItemNode.swift index e9982d0ea4..a08c889b8e 100644 --- a/TelegramUI/ListMessageSnippetItemNode.swift +++ b/TelegramUI/ListMessageSnippetItemNode.swift @@ -153,7 +153,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { var leftOffset: CGFloat = 0.0 var selectionNodeWidthAndApply: (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode)? if case let .selectable(selected) = item.selection { - let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected) + let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected, false) selectionNodeWidthAndApply = (selectionWidth, selectionApply) leftOffset += selectionWidth } diff --git a/TelegramUI/NativeVideoContent.swift b/TelegramUI/NativeVideoContent.swift index 6ce7f4fff7..8a125d23bd 100644 --- a/TelegramUI/NativeVideoContent.swift +++ b/TelegramUI/NativeVideoContent.swift @@ -55,7 +55,19 @@ final class NativeVideoContent: UniversalVideoContent { self.nativeId = id self.fileReference = fileReference self.imageReference = imageReference - self.dimensions = fileReference.media.dimensions ?? CGSize(width: 128.0, height: 128.0) + if var dimensions = fileReference.media.dimensions { + if let thumbnail = fileReference.media.previewRepresentations.first { + let dimensionsVertical = dimensions.width < dimensions.height + let thumbnailVertical = thumbnail.dimensions.width < thumbnail.dimensions.height + if dimensionsVertical != thumbnailVertical { + dimensions = CGSize(width: dimensions.height, height: dimensions.width) + } + } + self.dimensions = dimensions + } else { + self.dimensions = CGSize(width: 128.0, height: 128.0) + } + self.duration = fileReference.media.duration ?? 0 self.streamVideo = streamVideo self.loopVideo = loopVideo diff --git a/TelegramUI/OverlayInstantVideoDecoration.swift b/TelegramUI/OverlayInstantVideoDecoration.swift index 883fceef6d..571ad40ab5 100644 --- a/TelegramUI/OverlayInstantVideoDecoration.swift +++ b/TelegramUI/OverlayInstantVideoDecoration.swift @@ -71,7 +71,7 @@ final class OverlayInstantVideoDecoration: UniversalVideoDecoration { if let snapshot = snapshot { self.contentContainerNode.view.addSubview(snapshot) if let validLayoutSize = self.validLayoutSize { - snapshot.frame = CGRect(origin: CGPoint(), size: validLayoutSize) + snapshot.frame = CGRect(origin: CGPoint(), size: snapshot.frame.size) } } } diff --git a/TelegramUI/OverlayPlayerControlsNode.swift b/TelegramUI/OverlayPlayerControlsNode.swift index 2d55a0da55..73796c0373 100644 --- a/TelegramUI/OverlayPlayerControlsNode.swift +++ b/TelegramUI/OverlayPlayerControlsNode.swift @@ -129,7 +129,9 @@ final class OverlayPlayerControlsNode: ASDisplayNode { self.scrubberNode = MediaPlayerScrubbingNode(content: .standard(lineHeight: 3.0, lineCap: .round, scrubberHandle: .circle, backgroundColor: theme.list.controlSecondaryColor, foregroundColor: theme.list.itemAccentColor)) self.leftDurationLabel = MediaPlayerTimeTextNode(textColor: theme.list.itemSecondaryTextColor) + self.leftDurationLabel.displaysAsynchronously = false self.rightDurationLabel = MediaPlayerTimeTextNode(textColor: theme.list.itemSecondaryTextColor) + self.rightDurationLabel.displaysAsynchronously = false self.rightDurationLabel.mode = .reversed self.rightDurationLabel.alignment = .right diff --git a/TelegramUI/PeerReportController.swift b/TelegramUI/PeerReportController.swift index d0fb8a9b90..b48827e297 100644 --- a/TelegramUI/PeerReportController.swift +++ b/TelegramUI/PeerReportController.swift @@ -14,6 +14,7 @@ private enum PeerReportOption { case violence case copyright case pornoghraphy + case childAbuse case other } @@ -25,6 +26,7 @@ func peerReportOptionsController(account: Account, subject: PeerReportSubject, p .spam, .violence, .pornoghraphy, + .childAbuse, .copyright, .other ] @@ -32,6 +34,7 @@ func peerReportOptionsController(account: Account, subject: PeerReportSubject, p var items: [ActionSheetItem] = [] for option in options { let title: String + var color: ActionSheetButtonColor = .accent switch option { case .spam: title = presentationData.strings.ReportPeer_ReasonSpam @@ -39,13 +42,15 @@ func peerReportOptionsController(account: Account, subject: PeerReportSubject, p title = presentationData.strings.ReportPeer_ReasonViolence case .pornoghraphy: title = presentationData.strings.ReportPeer_ReasonPornography + case .childAbuse: + title = presentationData.strings.ReportPeer_ReasonChildAbuse + color = .destructive case .copyright: title = presentationData.strings.ReportPeer_ReasonCopyright case .other: title = presentationData.strings.ReportPeer_ReasonOther } - items.append(ActionSheetButtonItem(title: title, action: { [weak controller] in - //account.reportPeer#ae189d5f peer:InputPeer reason:ReportReason = Bool; + items.append(ActionSheetButtonItem(title: title, color: color, action: { [weak controller] in var reportReason: ReportReason? switch option { case .spam: @@ -54,8 +59,10 @@ func peerReportOptionsController(account: Account, subject: PeerReportSubject, p reportReason = .violence case .pornoghraphy: reportReason = .porno - case .copyright: - reportReason = .copyright + case .childAbuse: + reportReason = .childAbuse + case .copyright: + reportReason = .copyright case .other: break } diff --git a/TelegramUI/PeerSelectionControllerNode.swift b/TelegramUI/PeerSelectionControllerNode.swift index eaa805da41..ba8b71fdbf 100644 --- a/TelegramUI/PeerSelectionControllerNode.swift +++ b/TelegramUI/PeerSelectionControllerNode.swift @@ -312,6 +312,7 @@ final class PeerSelectionControllerNode: ASDisplayNode { } func animateOut(completion: (() -> Void)? = nil) { + self.clipsToBounds = true self.layer.animatePosition(from: CGPoint(), to: CGPoint(x: 0.0, y: self.layer.bounds.size.height), duration: 0.2, timingFunction: kCAMediaTimingFunctionEaseInEaseOut, removeOnCompletion: false, additive: true, completion: { [weak self] _ in if let strongSelf = self { strongSelf.dismiss() diff --git a/TelegramUI/PresentationStrings.swift b/TelegramUI/PresentationStrings.swift index 1d41271f2f..80205f98ee 100644 --- a/TelegramUI/PresentationStrings.swift +++ b/TelegramUI/PresentationStrings.swift @@ -1204,370 +1204,370 @@ public final class PresentationStrings { public var Settings_About_Title: String { return self._s[1009]! } public var PhoneNumberHelp_Help: String { return self._s[1010]! } public var Channel_LinkItem: String { return self._s[1012]! } - public var Camera_Retake: String { return self._s[1013]! } - public var StickerPack_ShowStickers: String { return self._s[1014]! } - public var Conversation_RestrictedText: String { return self._s[1015]! } - public var Channel_Stickers_YourStickers: String { return self._s[1016]! } + public var ChatList_Read: String { return self._s[1013]! } + public var Camera_Retake: String { return self._s[1014]! } + public var StickerPack_ShowStickers: String { return self._s[1015]! } + public var Conversation_RestrictedText: String { return self._s[1016]! } + public var Channel_Stickers_YourStickers: String { return self._s[1017]! } public func CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1020]!, self._r[1020]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1021]!, self._r[1021]!, [_1, _2]) } - public var LastSeen_WithinAMonth: String { return self._s[1021]! } + public var LastSeen_WithinAMonth: String { return self._s[1022]! } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1022]!, self._r[1022]!, [_0]) + return formatWithArgumentRanges(self._s[1023]!, self._r[1023]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[1023]! } - public var ChangePhoneNumberNumber_NewNumber: String { return self._s[1025]! } - public var Compose_NewChannel: String { return self._s[1026]! } - public var NotificationsSound_Circles: String { return self._s[1027]! } - public var Login_TermsOfServiceAgree: String { return self._s[1029]! } - public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1030]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[1024]! } + public var ChangePhoneNumberNumber_NewNumber: String { return self._s[1026]! } + public var Compose_NewChannel: String { return self._s[1027]! } + public var NotificationsSound_Circles: String { return self._s[1028]! } + public var Login_TermsOfServiceAgree: String { return self._s[1030]! } + public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1031]! } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1031]!, self._r[1031]!, [_0]) + return formatWithArgumentRanges(self._s[1032]!, self._r[1032]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1032]!, self._r[1032]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1033]!, self._r[1033]!, [_1, _2]) } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[1034]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[1035]! } public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1036]!, self._r[1036]!, [_0]) - } - public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1037]!, self._r[1037]!, [_0]) } - public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[1038]! } - public var Privacy_Calls_P2PNever: String { return self._s[1039]! } - public var GroupInfo_DeleteAndExit: String { return self._s[1040]! } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[1041]! } - public var Weekday_Friday: String { return self._s[1043]! } - public var Login_ResetAccountProtected_Title: String { return self._s[1044]! } - public var Settings_SetProfilePhoto: String { return self._s[1045]! } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[1046]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1047]! } - public var Your_card_has_expired: String { return self._s[1048]! } + public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1038]!, self._r[1038]!, [_0]) + } + public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[1039]! } + public var Privacy_Calls_P2PNever: String { return self._s[1040]! } + public var GroupInfo_DeleteAndExit: String { return self._s[1041]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[1042]! } + public var Weekday_Friday: String { return self._s[1044]! } + public var Login_ResetAccountProtected_Title: String { return self._s[1045]! } + public var Settings_SetProfilePhoto: String { return self._s[1046]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[1047]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1048]! } + public var Your_card_has_expired: String { return self._s[1049]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1051]!, self._r[1051]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1052]!, self._r[1052]!, [_1, _2, _3]) } - public var ChannelInfo_ConfirmLeave: String { return self._s[1052]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[1053]! } - public var ReportPeer_ReasonOther: String { return self._s[1055]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[1053]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[1054]! } + public var ReportPeer_ReasonOther: String { return self._s[1056]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1056]!, self._r[1056]!, [_0]) + return formatWithArgumentRanges(self._s[1057]!, self._r[1057]!, [_0]) } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1058]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1059]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1059]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1060]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1061]!, self._r[1061]!, [_0]) + return formatWithArgumentRanges(self._s[1062]!, self._r[1062]!, [_0]) } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1062]!, self._r[1062]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1063]!, self._r[1063]!, [_1, _2]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1064]! } - public var DialogList_Pin: String { return self._s[1065]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1065]! } + public var DialogList_Pin: String { return self._s[1066]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_0]) + return formatWithArgumentRanges(self._s[1067]!, self._r[1067]!, [_0]) } - public var Channel_ErrorAddTooMuch: String { return self._s[1067]! } - public var GroupInfo_SharedMediaNone: String { return self._s[1068]! } - public var ChatSettings_TextSizeUnits: String { return self._s[1069]! } - public var ChatSettings_AutoPlayAnimations: String { return self._s[1070]! } - public var Conversation_FileOpenIn: String { return self._s[1071]! } - public var Channel_Setup_TypePublic: String { return self._s[1072]! } + public var Channel_ErrorAddTooMuch: String { return self._s[1068]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1069]! } + public var ChatSettings_TextSizeUnits: String { return self._s[1070]! } + public var ChatSettings_AutoPlayAnimations: String { return self._s[1071]! } + public var Conversation_FileOpenIn: String { return self._s[1072]! } + public var Channel_Setup_TypePublic: String { return self._s[1073]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1073]!, self._r[1073]!, [_0]) + return formatWithArgumentRanges(self._s[1074]!, self._r[1074]!, [_0]) } - public var ContactInfo_PhoneLabelMain: String { return self._s[1074]! } - public var Clipboard_SendPhoto: String { return self._s[1075]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[1076]! } - public var KeyCommand_ChatInfo: String { return self._s[1077]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[1078]! } - public var PhotoEditor_HighlightsTint: String { return self._s[1079]! } - public var Passport_Address_Region: String { return self._s[1081]! } - public var Watch_Compose_AddContact: String { return self._s[1082]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1075]! } + public var Clipboard_SendPhoto: String { return self._s[1076]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[1077]! } + public var KeyCommand_ChatInfo: String { return self._s[1078]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[1079]! } + public var PhotoEditor_HighlightsTint: String { return self._s[1080]! } + public var Passport_Address_Region: String { return self._s[1082]! } + public var Watch_Compose_AddContact: String { return self._s[1083]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1083]!, self._r[1083]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1084]!, self._r[1084]!, [_1, _2, _3]) } public func Channel_AdminLog_MessageKickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1084]!, self._r[1084]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1085]!, self._r[1085]!, [_1, _2]) } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1085]!, self._r[1085]!, [_0]) + return formatWithArgumentRanges(self._s[1086]!, self._r[1086]!, [_0]) } - public var Coub_TapForSound: String { return self._s[1086]! } + public var Coub_TapForSound: String { return self._s[1087]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1088]!, self._r[1088]!, [_0]) + return formatWithArgumentRanges(self._s[1089]!, self._r[1089]!, [_0]) } - public var Compose_NewEncryptedChat: String { return self._s[1090]! } - public var PhotoEditor_CropReset: String { return self._s[1091]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1093]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[1094]! } - public var Login_InvalidLastNameError: String { return self._s[1095]! } - public var Channel_Members_AddMembers: String { return self._s[1096]! } - public var Tour_Title2: String { return self._s[1097]! } - public var Login_TermsOfServiceHeader: String { return self._s[1099]! } - public var Channel_AdminLog_BanSendGifs: String { return self._s[1100]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[1102]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1103]! } - public var AuthSessions_OtherSessions: String { return self._s[1104]! } - public var Watch_UserInfo_Title: String { return self._s[1105]! } - public var InstantPage_FeedbackButton: String { return self._s[1106]! } + public var Compose_NewEncryptedChat: String { return self._s[1091]! } + public var PhotoEditor_CropReset: String { return self._s[1092]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1094]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[1095]! } + public var Login_InvalidLastNameError: String { return self._s[1096]! } + public var Channel_Members_AddMembers: String { return self._s[1097]! } + public var Tour_Title2: String { return self._s[1098]! } + public var Login_TermsOfServiceHeader: String { return self._s[1100]! } + public var Channel_AdminLog_BanSendGifs: String { return self._s[1101]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[1103]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1104]! } + public var AuthSessions_OtherSessions: String { return self._s[1105]! } + public var Watch_UserInfo_Title: String { return self._s[1106]! } + public var InstantPage_FeedbackButton: String { return self._s[1107]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1107]!, self._r[1107]!, [_0]) + return formatWithArgumentRanges(self._s[1108]!, self._r[1108]!, [_0]) } - public var Conversation_Contact: String { return self._s[1108]! } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[1109]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[1112]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1113]! } - public var Passport_Language_sk: String { return self._s[1114]! } - public var InstantPage_AutoNightTheme: String { return self._s[1115]! } - public var CloudStorage_Title: String { return self._s[1116]! } - public var Month_ShortOctober: String { return self._s[1117]! } - public var Settings_FAQ: String { return self._s[1119]! } - public var PrivacySettings_LastSeen: String { return self._s[1120]! } - public var DialogList_SearchSectionRecent: String { return self._s[1121]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[1122]! } - public var Conversation_ContextMenuDelete: String { return self._s[1123]! } - public var Tour_Text6: String { return self._s[1124]! } - public var PhotoEditor_WarmthTool: String { return self._s[1125]! } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1127]! } - public var Common_TakePhoto: String { return self._s[1128]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[1129]! } - public var UserInfo_CreateNewContact: String { return self._s[1131]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[1132]! } - public var Login_CodeSentCall: String { return self._s[1133]! } - public var Watch_PhotoView_Title: String { return self._s[1134]! } + public var Conversation_Contact: String { return self._s[1109]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[1110]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[1113]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1114]! } + public var Passport_Language_sk: String { return self._s[1115]! } + public var InstantPage_AutoNightTheme: String { return self._s[1116]! } + public var CloudStorage_Title: String { return self._s[1117]! } + public var Month_ShortOctober: String { return self._s[1118]! } + public var Settings_FAQ: String { return self._s[1120]! } + public var PrivacySettings_LastSeen: String { return self._s[1121]! } + public var DialogList_SearchSectionRecent: String { return self._s[1122]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[1123]! } + public var Conversation_ContextMenuDelete: String { return self._s[1124]! } + public var Tour_Text6: String { return self._s[1125]! } + public var PhotoEditor_WarmthTool: String { return self._s[1126]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1128]! } + public var Common_TakePhoto: String { return self._s[1129]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[1130]! } + public var UserInfo_CreateNewContact: String { return self._s[1132]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[1133]! } + public var Login_CodeSentCall: String { return self._s[1134]! } + public var Watch_PhotoView_Title: String { return self._s[1135]! } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1135]!, self._r[1135]!, [_0]) + return formatWithArgumentRanges(self._s[1136]!, self._r[1136]!, [_0]) } - public var ShareMenu_SelectChats: String { return self._s[1137]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[1138]! } - public var Group_Setup_HistoryVisible: String { return self._s[1139]! } - public var Channel_EditAdmin_PermissinAddAdminOff: String { return self._s[1140]! } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[1142]! } - public var Cache_Files: String { return self._s[1143]! } - public var PhotoEditor_EnhanceTool: String { return self._s[1145]! } - public var Conversation_SearchPlaceholder: String { return self._s[1146]! } - public var Channel_Stickers_NotFound: String { return self._s[1147]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[1151]! } - public var Login_CodeExpired: String { return self._s[1152]! } - public var WatchRemote_AlertText: String { return self._s[1153]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[1155]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[1157]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[1158]! } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1159]! } - public var Month_ShortMarch: String { return self._s[1160]! } - public var GroupInfo_InviteLink_Title: String { return self._s[1161]! } - public var Watch_LastSeen_JustNow: String { return self._s[1162]! } - public var PhoneLabel_Title: String { return self._s[1163]! } - public var PrivacySettings_Passcode: String { return self._s[1165]! } - public var Paint_ClearConfirm: String { return self._s[1167]! } - public var SocksProxySetup_Secret: String { return self._s[1168]! } + public var ShareMenu_SelectChats: String { return self._s[1138]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[1139]! } + public var Group_Setup_HistoryVisible: String { return self._s[1140]! } + public var Channel_EditAdmin_PermissinAddAdminOff: String { return self._s[1141]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[1143]! } + public var Cache_Files: String { return self._s[1144]! } + public var PhotoEditor_EnhanceTool: String { return self._s[1146]! } + public var Conversation_SearchPlaceholder: String { return self._s[1147]! } + public var Channel_Stickers_NotFound: String { return self._s[1148]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[1152]! } + public var Login_CodeExpired: String { return self._s[1153]! } + public var WatchRemote_AlertText: String { return self._s[1154]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[1156]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[1158]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[1159]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1160]! } + public var Month_ShortMarch: String { return self._s[1161]! } + public var GroupInfo_InviteLink_Title: String { return self._s[1162]! } + public var Watch_LastSeen_JustNow: String { return self._s[1163]! } + public var PhoneLabel_Title: String { return self._s[1164]! } + public var PrivacySettings_Passcode: String { return self._s[1166]! } + public var Paint_ClearConfirm: String { return self._s[1168]! } + public var SocksProxySetup_Secret: String { return self._s[1169]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1169]!, self._r[1169]!, [_0]) + return formatWithArgumentRanges(self._s[1170]!, self._r[1170]!, [_0]) } - public var PhotoEditor_BlurToolOff: String { return self._s[1170]! } - public var AccessDenied_VideoMicrophone: String { return self._s[1171]! } - public var Weekday_ShortThursday: String { return self._s[1172]! } - public var UserInfo_ShareContact: String { return self._s[1173]! } - public var LoginPassword_InvalidPasswordError: String { return self._s[1174]! } - public var NotificationsSound_Calypso: String { return self._s[1176]! } + public var PhotoEditor_BlurToolOff: String { return self._s[1171]! } + public var AccessDenied_VideoMicrophone: String { return self._s[1172]! } + public var Weekday_ShortThursday: String { return self._s[1173]! } + public var UserInfo_ShareContact: String { return self._s[1174]! } + public var LoginPassword_InvalidPasswordError: String { return self._s[1175]! } + public var NotificationsSound_Calypso: String { return self._s[1177]! } public func MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1177]!, self._r[1177]!, [_1]) + return formatWithArgumentRanges(self._s[1178]!, self._r[1178]!, [_1]) } - public var Login_PhoneAndCountryHelp: String { return self._s[1178]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[1179]! } - public var NotificationsSound_Popcorn: String { return self._s[1181]! } + public var Login_PhoneAndCountryHelp: String { return self._s[1179]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[1180]! } + public var NotificationsSound_Popcorn: String { return self._s[1182]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1182]!, self._r[1182]!, [_0]) + return formatWithArgumentRanges(self._s[1183]!, self._r[1183]!, [_0]) } - public var Weekday_Yesterday: String { return self._s[1183]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[1184]! } - public var Embed_PlayingInPIP: String { return self._s[1185]! } - public var Localization_EnglishLanguageName: String { return self._s[1186]! } - public var Call_StatusIncoming: String { return self._s[1187]! } - public var Settings_Appearance: String { return self._s[1188]! } + public var Weekday_Yesterday: String { return self._s[1184]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[1185]! } + public var Embed_PlayingInPIP: String { return self._s[1186]! } + public var Localization_EnglishLanguageName: String { return self._s[1187]! } + public var Call_StatusIncoming: String { return self._s[1188]! } + public var Settings_Appearance: String { return self._s[1189]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1190]!, self._r[1190]!, [_1]) + return formatWithArgumentRanges(self._s[1191]!, self._r[1191]!, [_1]) } - public var Settings_PrivacySettings: String { return self._s[1191]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[1192]! } + public var Settings_PrivacySettings: String { return self._s[1192]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[1193]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1193]!, self._r[1193]!, [_0]) + return formatWithArgumentRanges(self._s[1194]!, self._r[1194]!, [_0]) } public func CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1194]!, self._r[1194]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1195]!, self._r[1195]!, [_1, _2]) } - public var DialogList_SearchLabel: String { return self._s[1196]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[1197]! } - public var Login_CodeSentInternal: String { return self._s[1198]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1200]! } - public var Channel_MessagePhotoRemoved: String { return self._s[1201]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1202]! } - public var GroupInfo_ChatAdmins: String { return self._s[1203]! } - public var PhotoEditor_CurvesAll: String { return self._s[1204]! } + public var DialogList_SearchLabel: String { return self._s[1197]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[1198]! } + public var Login_CodeSentInternal: String { return self._s[1199]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1201]! } + public var Channel_MessagePhotoRemoved: String { return self._s[1202]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1203]! } + public var GroupInfo_ChatAdmins: String { return self._s[1204]! } + public var PhotoEditor_CurvesAll: String { return self._s[1205]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1205]!, self._r[1205]!, [_0]) + return formatWithArgumentRanges(self._s[1206]!, self._r[1206]!, [_0]) } - public var Compose_Create: String { return self._s[1206]! } + public var Compose_Create: String { return self._s[1207]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1207]!, self._r[1207]!, [_0]) + return formatWithArgumentRanges(self._s[1208]!, self._r[1208]!, [_0]) } public func LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1208]!, self._r[1208]!, [_1]) + return formatWithArgumentRanges(self._s[1209]!, self._r[1209]!, [_1]) } - public var Conversation_ClearPrivateHistory: String { return self._s[1209]! } - public var Conversation_ContextMenuShare: String { return self._s[1210]! } - public var Notifications_ExceptionsNone: String { return self._s[1211]! } + public var Conversation_ClearPrivateHistory: String { return self._s[1210]! } + public var Conversation_ContextMenuShare: String { return self._s[1211]! } + public var Notifications_ExceptionsNone: String { return self._s[1212]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1212]!, self._r[1212]!, [_0]) + return formatWithArgumentRanges(self._s[1213]!, self._r[1213]!, [_0]) } - public var Conversation_ContextMenuReport: String { return self._s[1213]! } + public var Conversation_ContextMenuReport: String { return self._s[1214]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1215]!, self._r[1215]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1216]!, self._r[1216]!, [_1, _2]) } - public var Forward_ChannelReadOnly: String { return self._s[1216]! } - public var Passport_InfoText: String { return self._s[1218]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1219]! } + public var Forward_ChannelReadOnly: String { return self._s[1217]! } + public var Passport_InfoText: String { return self._s[1219]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1220]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1220]!, self._r[1220]!, [_0]) + return formatWithArgumentRanges(self._s[1221]!, self._r[1221]!, [_0]) } - public var AutoDownloadSettings_Reset: String { return self._s[1221]! } - public var NotificationsSound_Synth: String { return self._s[1222]! } - public var TextFormat_Bold: String { return self._s[1223]! } + public var AutoDownloadSettings_Reset: String { return self._s[1222]! } + public var NotificationsSound_Synth: String { return self._s[1223]! } + public var TextFormat_Bold: String { return self._s[1224]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1224]!, self._r[1224]!, [_1]) + return formatWithArgumentRanges(self._s[1225]!, self._r[1225]!, [_1]) } - public var Conversation_Moderate_Ban: String { return self._s[1227]! } - public var Group_Status: String { return self._s[1229]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[1232]! } - public var Passport_Phone_Delete: String { return self._s[1233]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1234]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1235]! } - public var Passport_Language_lv: String { return self._s[1237]! } - public var TwoStepAuth_RecoveryCode: String { return self._s[1238]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[1239]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1240]! } - public var Passport_Language_hy: String { return self._s[1241]! } - public var SharedMedia_CategoryDocs: String { return self._s[1244]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[1246]! } - public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[1247]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[1248]! } + public var Conversation_Moderate_Ban: String { return self._s[1228]! } + public var Group_Status: String { return self._s[1230]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[1233]! } + public var Passport_Phone_Delete: String { return self._s[1234]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1235]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1236]! } + public var Passport_Language_lv: String { return self._s[1238]! } + public var TwoStepAuth_RecoveryCode: String { return self._s[1239]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[1240]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1241]! } + public var Passport_Language_hy: String { return self._s[1242]! } + public var SharedMedia_CategoryDocs: String { return self._s[1245]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[1247]! } + public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[1248]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[1249]! } public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1249]!, self._r[1249]!, [_0]) + return formatWithArgumentRanges(self._s[1250]!, self._r[1250]!, [_0]) } - public var NotificationsSound_Telegraph: String { return self._s[1250]! } - public var AutoNightTheme_Disabled: String { return self._s[1251]! } - public var Conversation_ContextMenuBan: String { return self._s[1252]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[1253]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[1254]! } + public var NotificationsSound_Telegraph: String { return self._s[1251]! } + public var AutoNightTheme_Disabled: String { return self._s[1252]! } + public var Conversation_ContextMenuBan: String { return self._s[1253]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[1254]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[1255]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1256]!, self._r[1256]!, [_0]) + return formatWithArgumentRanges(self._s[1257]!, self._r[1257]!, [_0]) } - public var Group_UpgradeNoticeHeader: String { return self._s[1257]! } + public var Group_UpgradeNoticeHeader: String { return self._s[1258]! } public func CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1258]!, self._r[1258]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1259]!, self._r[1259]!, [_1, _2]) } public func MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1259]!, self._r[1259]!, [_1]) + return formatWithArgumentRanges(self._s[1260]!, self._r[1260]!, [_1]) } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1260]!, self._r[1260]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1261]!, self._r[1261]!, [_1, _2]) } public func CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1262]!, self._r[1262]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1263]!, self._r[1263]!, [_1, _2]) } - public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[1263]! } - public var Channel_Info_Members: String { return self._s[1264]! } - public var ShareFileTip_CloseTip: String { return self._s[1265]! } - public var KeyCommand_Find: String { return self._s[1266]! } - public var SecretVideo_Title: String { return self._s[1267]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1268]! } - public var Passport_DiscardMessageAction: String { return self._s[1269]! } - public var Passport_Language_dv: String { return self._s[1270]! } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[1271]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[1273]! } + public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[1264]! } + public var Channel_Info_Members: String { return self._s[1265]! } + public var ShareFileTip_CloseTip: String { return self._s[1266]! } + public var KeyCommand_Find: String { return self._s[1267]! } + public var SecretVideo_Title: String { return self._s[1268]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1269]! } + public var Passport_DiscardMessageAction: String { return self._s[1270]! } + public var Passport_Language_dv: String { return self._s[1271]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[1272]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[1274]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1274]!, self._r[1274]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1275]!, self._r[1275]!, [_0, _1, _2]) } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[1275]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[1276]! } - public var WebSearch_GIFs: String { return self._s[1277]! } - public var Privacy_ChatsTitle: String { return self._s[1278]! } - public var Conversation_SavedMessages: String { return self._s[1279]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[1280]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[1276]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[1277]! } + public var WebSearch_GIFs: String { return self._s[1278]! } + public var Privacy_ChatsTitle: String { return self._s[1279]! } + public var Conversation_SavedMessages: String { return self._s[1280]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[1281]! } public func CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1281]!, self._r[1281]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1282]!, self._r[1282]!, [_1, _2]) } - public var Channel_Subscribers_Title: String { return self._s[1282]! } - public var AccessDenied_CallMicrophone: String { return self._s[1283]! } - public var Conversation_DeleteMessagesForEveryone: String { return self._s[1284]! } - public var AuthSessions_Terminate: String { return self._s[1285]! } - public var UserInfo_TapToCall: String { return self._s[1286]! } - public var Common_Edit: String { return self._s[1287]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[1289]! } - public var Conversation_OpenFile: String { return self._s[1290]! } - public var PrivacyPolicy_Decline: String { return self._s[1292]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1293]! } - public var Message_PinnedDocumentMessage: String { return self._s[1294]! } - public var AuthSessions_LogOut: String { return self._s[1296]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[1298]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1299]! } - public var Checkout_TotalPaidAmount: String { return self._s[1300]! } - public var Conversation_UnsupportedMedia: String { return self._s[1301]! } - public var Passport_InvalidPasswordError: String { return self._s[1302]! } + public var Channel_Subscribers_Title: String { return self._s[1283]! } + public var AccessDenied_CallMicrophone: String { return self._s[1284]! } + public var Conversation_DeleteMessagesForEveryone: String { return self._s[1285]! } + public var AuthSessions_Terminate: String { return self._s[1286]! } + public var UserInfo_TapToCall: String { return self._s[1287]! } + public var Common_Edit: String { return self._s[1288]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[1290]! } + public var Conversation_OpenFile: String { return self._s[1291]! } + public var PrivacyPolicy_Decline: String { return self._s[1293]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1294]! } + public var Message_PinnedDocumentMessage: String { return self._s[1295]! } + public var AuthSessions_LogOut: String { return self._s[1297]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1299]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1300]! } + public var Checkout_TotalPaidAmount: String { return self._s[1301]! } + public var Conversation_UnsupportedMedia: String { return self._s[1302]! } + public var Passport_InvalidPasswordError: String { return self._s[1303]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1304]!, self._r[1304]!, [_0]) + return formatWithArgumentRanges(self._s[1305]!, self._r[1305]!, [_0]) } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1305]!, self._r[1305]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1306]!, self._r[1306]!, [_1, _2, _3]) } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[1306]! } - public var Call_AudioRouteHide: String { return self._s[1307]! } - public var CallSettings_OnMobile: String { return self._s[1309]! } - public var Conversation_GifTooltip: String { return self._s[1310]! } - public var Passport_Address_EditBankStatement: String { return self._s[1311]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[1313]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[1307]! } + public var Call_AudioRouteHide: String { return self._s[1308]! } + public var CallSettings_OnMobile: String { return self._s[1310]! } + public var Conversation_GifTooltip: String { return self._s[1311]! } + public var Passport_Address_EditBankStatement: String { return self._s[1312]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[1314]! } public func CHANNEL_MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1314]!, self._r[1314]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1315]!, self._r[1315]!, [_1, _2]) } - public var Profile_CreateEncryptedChatError: String { return self._s[1315]! } - public var Map_LocationTitle: String { return self._s[1316]! } - public var Call_RateCall: String { return self._s[1317]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[1318]! } - public var Passport_Address_City: String { return self._s[1319]! } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[1320]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1322]! } - public var PhotoEditor_ShadowsTool: String { return self._s[1323]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[1325]! } - public var Cache_Title: String { return self._s[1327]! } - public var Passport_Email_Title: String { return self._s[1328]! } - public var Month_GenMay: String { return self._s[1329]! } - public var PasscodeSettings_HelpBottom: String { return self._s[1330]! } + public var Profile_CreateEncryptedChatError: String { return self._s[1316]! } + public var Map_LocationTitle: String { return self._s[1317]! } + public var Call_RateCall: String { return self._s[1318]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[1319]! } + public var Passport_Address_City: String { return self._s[1320]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[1321]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1323]! } + public var PhotoEditor_ShadowsTool: String { return self._s[1324]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[1326]! } + public var Cache_Title: String { return self._s[1328]! } + public var Passport_Email_Title: String { return self._s[1329]! } + public var Month_GenMay: String { return self._s[1330]! } + public var PasscodeSettings_HelpBottom: String { return self._s[1331]! } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1331]!, self._r[1331]!, [_0]) + return formatWithArgumentRanges(self._s[1332]!, self._r[1332]!, [_0]) } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[1332]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[1333]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1334]! } - public var Watch_UserInfo_Block: String { return self._s[1335]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[1336]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[1337]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[1338]! } - public var SearchImages_Title: String { return self._s[1339]! } - public var Channel_BlackList_Title: String { return self._s[1340]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[1333]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[1334]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1335]! } + public var Watch_UserInfo_Block: String { return self._s[1336]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[1337]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[1338]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[1339]! } + public var SearchImages_Title: String { return self._s[1340]! } + public var Channel_BlackList_Title: String { return self._s[1341]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1342]!, self._r[1342]!, [_0]) + return formatWithArgumentRanges(self._s[1343]!, self._r[1343]!, [_0]) } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1343]! } - public var Checkout_NewCard_SaveInfo: String { return self._s[1344]! } - public var Notification_CallMissed: String { return self._s[1345]! } - public var Profile_ShareContactButton: String { return self._s[1346]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[1347]! } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[1348]! } - public var Notification_Mute1h: String { return self._s[1349]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1344]! } + public var Checkout_NewCard_SaveInfo: String { return self._s[1345]! } + public var Notification_CallMissed: String { return self._s[1346]! } + public var Profile_ShareContactButton: String { return self._s[1347]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[1348]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[1349]! } + public var Notification_Mute1h: String { return self._s[1350]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1350]!, self._r[1350]!, [_1]) + return formatWithArgumentRanges(self._s[1351]!, self._r[1351]!, [_1]) } - public var Settings_TabTitle: String { return self._s[1351]! } public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1353]! } public var NetworkUsageSettings_MediaAudioDataSection: String { return self._s[1354]! } public var GroupInfo_DeactivatedStatus: String { return self._s[1355]! } @@ -1895,1577 +1895,1579 @@ public final class PresentationStrings { public var Passport_Address_EditRentalAgreement: String { return self._s[1622]! } public var Conversation_DeleteManyMessages: String { return self._s[1624]! } public var CancelResetAccount_Title: String { return self._s[1625]! } - public var Notification_CallOutgoingShort: String { return self._s[1626]! } - public var SharedMedia_TitleAll: String { return self._s[1628]! } - public var Conversation_SlideToCancel: String { return self._s[1629]! } - public var AuthSessions_TerminateSession: String { return self._s[1630]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[1631]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[1632]! } - public var Channel_Members_Title: String { return self._s[1633]! } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[1634]! } - public var Privacy_DeleteDrafts: String { return self._s[1635]! } - public var Group_Setup_TypePrivateHelp: String { return self._s[1636]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[1626]! } + public var Notification_CallOutgoingShort: String { return self._s[1627]! } + public var SharedMedia_TitleAll: String { return self._s[1629]! } + public var Conversation_SlideToCancel: String { return self._s[1630]! } + public var AuthSessions_TerminateSession: String { return self._s[1631]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[1632]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[1633]! } + public var Channel_Members_Title: String { return self._s[1634]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[1635]! } + public var Privacy_DeleteDrafts: String { return self._s[1636]! } + public var Group_Setup_TypePrivateHelp: String { return self._s[1637]! } public func Notification_PinnedVideoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1637]!, self._r[1637]!, [_0]) + return formatWithArgumentRanges(self._s[1638]!, self._r[1638]!, [_0]) } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[1638]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1639]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[1641]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[1639]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1640]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[1642]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1643]!, self._r[1643]!, [_0]) + return formatWithArgumentRanges(self._s[1644]!, self._r[1644]!, [_0]) } - public var SharedMedia_CategoryOther: String { return self._s[1644]! } - public var Passport_Address_Address: String { return self._s[1645]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[1646]! } - public var Preview_DeletePhoto: String { return self._s[1649]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[1650]! } - public var PasscodeSettings_TurnPasscodeOn: String { return self._s[1651]! } - public var AuthSessions_LogOutApplicationsHelp: String { return self._s[1652]! } - public var Notification_Exceptions_AddException: String { return self._s[1654]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[1655]! } + public var SharedMedia_CategoryOther: String { return self._s[1645]! } + public var Passport_Address_Address: String { return self._s[1646]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[1647]! } + public var Preview_DeletePhoto: String { return self._s[1650]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[1651]! } + public var PasscodeSettings_TurnPasscodeOn: String { return self._s[1652]! } + public var AuthSessions_LogOutApplicationsHelp: String { return self._s[1653]! } + public var Notification_Exceptions_AddException: String { return self._s[1655]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1656]! } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1656]!, self._r[1656]!, [_0]) + return formatWithArgumentRanges(self._s[1657]!, self._r[1657]!, [_0]) } - public var DialogList_Unpin: String { return self._s[1657]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1659]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1660]! } - public var ConvertToSupergroup_Title: String { return self._s[1662]! } + public var DialogList_Unpin: String { return self._s[1658]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1660]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1661]! } + public var ConvertToSupergroup_Title: String { return self._s[1663]! } public func CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1663]!, self._r[1663]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1664]!, self._r[1664]!, [_1, _2]) } - public var Notification_CallCanceledShort: String { return self._s[1664]! } - public var Channel_Setup_TypeHeader: String { return self._s[1665]! } + public var Notification_CallCanceledShort: String { return self._s[1665]! } + public var Channel_Setup_TypeHeader: String { return self._s[1666]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1666]!, self._r[1666]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1667]!, self._r[1667]!, [_1, _2, _3, _4, _5, _6]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1667]!, self._r[1667]!, [_0]) + return formatWithArgumentRanges(self._s[1668]!, self._r[1668]!, [_0]) } - public var PrivacyPolicy_DeclineTitle: String { return self._s[1670]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[1671]! } - public var Privacy_ContactsSyncHelp: String { return self._s[1672]! } - public var Conversation_Search: String { return self._s[1674]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[1671]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[1672]! } + public var Privacy_ContactsSyncHelp: String { return self._s[1673]! } + public var Conversation_Search: String { return self._s[1675]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1675]!, self._r[1675]!, [_0]) - } - public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1676]!, self._r[1676]!, [_0]) } - public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { + public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1677]!, self._r[1677]!, [_0]) } - public var SecretImage_Title: String { return self._s[1678]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1679]! } - public var Call_StatusRequesting: String { return self._s[1680]! } + public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1678]!, self._r[1678]!, [_0]) + } + public var SecretImage_Title: String { return self._s[1679]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1680]! } + public var Call_StatusRequesting: String { return self._s[1681]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1681]!, self._r[1681]!, [_0]) + return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_0]) } public func CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1683]!, self._r[1683]!, [_1, _2]) } - public var SocksProxySetup_UseProxy: String { return self._s[1683]! } - public var Group_UpgradeNoticeText1: String { return self._s[1684]! } - public var ChatSettings_Other: String { return self._s[1685]! } + public var SocksProxySetup_UseProxy: String { return self._s[1684]! } + public var Group_UpgradeNoticeText1: String { return self._s[1685]! } + public var ChatSettings_Other: String { return self._s[1686]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1686]!, self._r[1686]!, [_0]) + return formatWithArgumentRanges(self._s[1687]!, self._r[1687]!, [_0]) } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1687]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1688]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1689]!, self._r[1689]!, [_0]) + return formatWithArgumentRanges(self._s[1690]!, self._r[1690]!, [_0]) } - public var Settings_SaveIncomingPhotos: String { return self._s[1690]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[1691]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1691]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[1692]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1692]!, self._r[1692]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1693]!, self._r[1693]!, ["\(_0)"]) } - public var GroupInfo_InviteLink_Help: String { return self._s[1693]! } - public var Calls_Missed: String { return self._s[1694]! } - public var Conversation_ContextMenuForward: String { return self._s[1697]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1698]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[1699]! } - public var Call_StatusRinging: String { return self._s[1700]! } - public var Passport_Language_pl: String { return self._s[1701]! } - public var Invitation_JoinGroup: String { return self._s[1702]! } - public var Notification_PinnedMessage: String { return self._s[1703]! } - public var AutoDownloadSettings_WiFi: String { return self._s[1705]! } - public var Conversation_ClearSelfHistory: String { return self._s[1706]! } - public var Message_Location: String { return self._s[1707]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1694]! } + public var Calls_Missed: String { return self._s[1695]! } + public var Conversation_ContextMenuForward: String { return self._s[1698]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1699]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[1700]! } + public var Call_StatusRinging: String { return self._s[1701]! } + public var Passport_Language_pl: String { return self._s[1702]! } + public var Invitation_JoinGroup: String { return self._s[1703]! } + public var Notification_PinnedMessage: String { return self._s[1704]! } + public var AutoDownloadSettings_WiFi: String { return self._s[1706]! } + public var Conversation_ClearSelfHistory: String { return self._s[1707]! } + public var Message_Location: String { return self._s[1708]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1708]!, self._r[1708]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1709]!, self._r[1709]!, [_1, _2]) } - public var Message_Contact: String { return self._s[1709]! } - public var Passport_Language_lo: String { return self._s[1711]! } - public var UserInfo_BotPrivacy: String { return self._s[1712]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1713]! } - public var Common_More: String { return self._s[1716]! } - public var Preview_OpenInInstagram: String { return self._s[1717]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1720]! } + public var Message_Contact: String { return self._s[1710]! } + public var Passport_Language_lo: String { return self._s[1712]! } + public var UserInfo_BotPrivacy: String { return self._s[1713]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1714]! } + public var Common_More: String { return self._s[1717]! } + public var Preview_OpenInInstagram: String { return self._s[1718]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1721]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1721]!, self._r[1721]!, [_0]) + return formatWithArgumentRanges(self._s[1722]!, self._r[1722]!, [_0]) } public func PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1722]!, self._r[1722]!, [_1]) + return formatWithArgumentRanges(self._s[1723]!, self._r[1723]!, [_1]) } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1723]! } - public var Passport_Language_hr: String { return self._s[1724]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1725]! } - public var Activity_UploadingVideoMessage: String { return self._s[1726]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[1727]! } - public var Login_CodeSentSms: String { return self._s[1730]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1724]! } + public var Passport_Language_hr: String { return self._s[1725]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1726]! } + public var Activity_UploadingVideoMessage: String { return self._s[1727]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[1728]! } + public var Login_CodeSentSms: String { return self._s[1731]! } public func CHANNEL_MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1731]!, self._r[1731]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1732]!, self._r[1732]!, [_1, _2]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[1732]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1733]! } - public var SocksProxySetup_Credentials: String { return self._s[1734]! } - public var CallSettings_UseLessData: String { return self._s[1735]! } - public var MediaPicker_GroupDescription: String { return self._s[1736]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1737]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[1733]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1734]! } + public var SocksProxySetup_Credentials: String { return self._s[1735]! } + public var CallSettings_UseLessData: String { return self._s[1736]! } + public var MediaPicker_GroupDescription: String { return self._s[1737]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1738]! } public func TwoStepAuth_EnterPasswordHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1738]!, self._r[1738]!, [_0]) + return formatWithArgumentRanges(self._s[1739]!, self._r[1739]!, [_0]) } - public var CallSettings_TabIcon: String { return self._s[1739]! } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[1741]! } + public var CallSettings_TabIcon: String { return self._s[1740]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[1742]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1744]!, self._r[1744]!, [_0]) + return formatWithArgumentRanges(self._s[1745]!, self._r[1745]!, [_0]) } - public var Channel_AdminLog_BanSendMedia: String { return self._s[1745]! } - public var Passport_Language_uz: String { return self._s[1746]! } - public var Watch_UserInfo_Unblock: String { return self._s[1747]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[1749]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1750]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1752]! } - public var Message_Animation: String { return self._s[1754]! } - public var Checkout_PaymentMethod: String { return self._s[1755]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[1756]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1757]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[1758]! } - public var Cache_Music: String { return self._s[1759]! } - public var Settings_ProxyDisabled: String { return self._s[1763]! } - public var SocksProxySetup_Connecting: String { return self._s[1764]! } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[1765]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[1746]! } + public var Passport_Language_uz: String { return self._s[1747]! } + public var Watch_UserInfo_Unblock: String { return self._s[1748]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[1750]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1751]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1753]! } + public var Message_Animation: String { return self._s[1755]! } + public var Checkout_PaymentMethod: String { return self._s[1756]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[1757]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1758]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[1759]! } + public var Cache_Music: String { return self._s[1760]! } + public var Settings_ProxyDisabled: String { return self._s[1764]! } + public var SocksProxySetup_Connecting: String { return self._s[1765]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[1766]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1766]!, self._r[1766]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1767]!, self._r[1767]!, [_1, _2, _3]) } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1768]!, self._r[1768]!, [_0]) + return formatWithArgumentRanges(self._s[1769]!, self._r[1769]!, [_0]) } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1771]!, self._r[1771]!, [_0]) + return formatWithArgumentRanges(self._s[1772]!, self._r[1772]!, [_0]) } - public var PhotoEditor_SaturationTool: String { return self._s[1773]! } - public var Channel_BanUser_BlockFor: String { return self._s[1774]! } - public var Call_StatusConnecting: String { return self._s[1775]! } - public var AutoNightTheme_NotAvailable: String { return self._s[1776]! } - public var PrivateDataSettings_Title: String { return self._s[1777]! } - public var Bot_Start: String { return self._s[1779]! } + public var PhotoEditor_SaturationTool: String { return self._s[1774]! } + public var Channel_BanUser_BlockFor: String { return self._s[1775]! } + public var Call_StatusConnecting: String { return self._s[1776]! } + public var AutoNightTheme_NotAvailable: String { return self._s[1777]! } + public var PrivateDataSettings_Title: String { return self._s[1778]! } + public var Bot_Start: String { return self._s[1780]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1780]!, self._r[1780]!, [_0]) + return formatWithArgumentRanges(self._s[1781]!, self._r[1781]!, [_0]) } - public var Appearance_PreviewReplyAuthor: String { return self._s[1781]! } - public var Notifications_TextTone: String { return self._s[1782]! } - public var Settings_CallSettings: String { return self._s[1783]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1782]! } + public var Notifications_TextTone: String { return self._s[1783]! } + public var Settings_CallSettings: String { return self._s[1784]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1784]!, self._r[1784]!, [_0]) + return formatWithArgumentRanges(self._s[1785]!, self._r[1785]!, [_0]) } - public var Contacts_InviteToTelegram: String { return self._s[1785]! } + public var Contacts_InviteToTelegram: String { return self._s[1786]! } public func PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1786]!, self._r[1786]!, [_1]) + return formatWithArgumentRanges(self._s[1787]!, self._r[1787]!, [_1]) } - public var ChatSettings_PrivateChats: String { return self._s[1787]! } - public var DialogList_Draft: String { return self._s[1788]! } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[1789]! } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[1790]! } - public var Conversation_CloudStorageInfo_Title: String { return self._s[1791]! } - public var Conversation_ClearSecretHistory: String { return self._s[1792]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1793]! } - public var Notification_RenamedChannel: String { return self._s[1794]! } - public var BlockedUsers_BlockUser: String { return self._s[1795]! } - public var ChatSettings_TextSize: String { return self._s[1796]! } - public var ChannelInfo_DeleteGroup: String { return self._s[1797]! } - public var PhoneNumberHelp_Alert: String { return self._s[1798]! } + public var ChatSettings_PrivateChats: String { return self._s[1788]! } + public var DialogList_Draft: String { return self._s[1789]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[1790]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[1791]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[1792]! } + public var Conversation_ClearSecretHistory: String { return self._s[1793]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1794]! } + public var Notification_RenamedChannel: String { return self._s[1795]! } + public var BlockedUsers_BlockUser: String { return self._s[1796]! } + public var ChatSettings_TextSize: String { return self._s[1797]! } + public var ChannelInfo_DeleteGroup: String { return self._s[1798]! } + public var PhoneNumberHelp_Alert: String { return self._s[1799]! } public func PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1799]!, self._r[1799]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1800]!, self._r[1800]!, [_1, _2]) } - public var Watch_ChannelInfo_Title: String { return self._s[1800]! } - public var WebSearch_RecentSectionClear: String { return self._s[1801]! } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[1802]! } - public var Channel_Setup_TypePrivate: String { return self._s[1803]! } - public var PhotoEditor_TintTool: String { return self._s[1804]! } - public var Watch_Suggestion_CantTalk: String { return self._s[1805]! } - public var PhotoEditor_QualityHigh: String { return self._s[1806]! } - public var SocksProxySetup_AddProxyTitle: String { return self._s[1808]! } + public var Watch_ChannelInfo_Title: String { return self._s[1801]! } + public var WebSearch_RecentSectionClear: String { return self._s[1802]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[1803]! } + public var Channel_Setup_TypePrivate: String { return self._s[1804]! } + public var PhotoEditor_TintTool: String { return self._s[1805]! } + public var Watch_Suggestion_CantTalk: String { return self._s[1806]! } + public var PhotoEditor_QualityHigh: String { return self._s[1807]! } + public var SocksProxySetup_AddProxyTitle: String { return self._s[1809]! } public func CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1810]!, self._r[1810]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1811]!, self._r[1811]!, [_1, _2, _3]) } - public var Map_ChooseAPlace: String { return self._s[1811]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[1813]! } - public var Passport_ScanPassport: String { return self._s[1814]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[1815]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1816]! } - public var Watch_Bot_Restart: String { return self._s[1818]! } - public var Passport_RequestedInformation: String { return self._s[1819]! } - public var Channel_About_Help: String { return self._s[1820]! } - public var Web_OpenExternal: String { return self._s[1821]! } - public var Passport_Language_mn: String { return self._s[1822]! } - public var UserInfo_AddContact: String { return self._s[1824]! } - public var Privacy_ContactsSync: String { return self._s[1825]! } - public var SocksProxySetup_Connection: String { return self._s[1827]! } - public var Passport_NotLoggedInMessage: String { return self._s[1828]! } - public var Passport_PasswordPlaceholder: String { return self._s[1829]! } - public var Passport_PasswordCreate: String { return self._s[1830]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1832]! } - public var Call_EncryptionKey_Title: String { return self._s[1833]! } - public var PhotoEditor_BlurToolLinear: String { return self._s[1835]! } - public var AuthSessions_EmptyText: String { return self._s[1836]! } - public var Notification_MessageLifetime1m: String { return self._s[1837]! } + public var Map_ChooseAPlace: String { return self._s[1812]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[1814]! } + public var Passport_ScanPassport: String { return self._s[1815]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[1816]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1817]! } + public var Watch_Bot_Restart: String { return self._s[1819]! } + public var Passport_RequestedInformation: String { return self._s[1820]! } + public var Channel_About_Help: String { return self._s[1821]! } + public var Web_OpenExternal: String { return self._s[1822]! } + public var Passport_Language_mn: String { return self._s[1823]! } + public var UserInfo_AddContact: String { return self._s[1825]! } + public var Privacy_ContactsSync: String { return self._s[1826]! } + public var SocksProxySetup_Connection: String { return self._s[1828]! } + public var Passport_NotLoggedInMessage: String { return self._s[1829]! } + public var Passport_PasswordPlaceholder: String { return self._s[1830]! } + public var Passport_PasswordCreate: String { return self._s[1831]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1833]! } + public var Call_EncryptionKey_Title: String { return self._s[1834]! } + public var PhotoEditor_BlurToolLinear: String { return self._s[1836]! } + public var AuthSessions_EmptyText: String { return self._s[1837]! } + public var Notification_MessageLifetime1m: String { return self._s[1838]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_0]) + return formatWithArgumentRanges(self._s[1839]!, self._r[1839]!, [_0]) } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1839]! } - public var NotificationsSound_Tritone: String { return self._s[1840]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[1841]! } - public var Month_ShortJuly: String { return self._s[1842]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[1843]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1844]! } - public var CallSettings_Never: String { return self._s[1845]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[1848]! } - public var TwoStepAuth_EmailSent: String { return self._s[1849]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1840]! } + public var NotificationsSound_Tritone: String { return self._s[1841]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[1842]! } + public var Month_ShortJuly: String { return self._s[1843]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[1844]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1845]! } + public var CallSettings_Never: String { return self._s[1846]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[1849]! } + public var TwoStepAuth_EmailSent: String { return self._s[1850]! } public func Notification_PinnedAnimationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1850]!, self._r[1850]!, [_0]) + return formatWithArgumentRanges(self._s[1851]!, self._r[1851]!, [_0]) } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1853]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[1854]! } - public var WatchRemote_AlertOpen: String { return self._s[1856]! } - public var ExplicitContent_AlertChannel: String { return self._s[1857]! } - public var Notification_PassportValueEmail: String { return self._s[1858]! } - public var ContactInfo_PhoneLabelMobile: String { return self._s[1860]! } - public var Widget_AuthRequired: String { return self._s[1862]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1854]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[1855]! } + public var WatchRemote_AlertOpen: String { return self._s[1857]! } + public var ExplicitContent_AlertChannel: String { return self._s[1858]! } + public var Notification_PassportValueEmail: String { return self._s[1859]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[1861]! } + public var Widget_AuthRequired: String { return self._s[1863]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1863]!, self._r[1863]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1864]!, self._r[1864]!, [_0, _1]) } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1864]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[1865]! } - public var Login_SmsRequestState3: String { return self._s[1866]! } - public var Notifications_AlertTones: String { return self._s[1867]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1865]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[1866]! } + public var Login_SmsRequestState3: String { return self._s[1867]! } + public var Notifications_AlertTones: String { return self._s[1868]! } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1868]!, self._r[1868]!, [_0]) + return formatWithArgumentRanges(self._s[1869]!, self._r[1869]!, [_0]) } - public var Login_InfoAvatarPhoto: String { return self._s[1870]! } - public var Calls_TabTitle: String { return self._s[1873]! } - public var Map_YouAreHere: String { return self._s[1874]! } - public var PhotoEditor_CurvesTool: String { return self._s[1875]! } - public var Map_LiveLocationFor1Hour: String { return self._s[1876]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[1877]! } - public var Stickers_NoStickersFound: String { return self._s[1878]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1880]! } + public var Login_InfoAvatarPhoto: String { return self._s[1871]! } + public var Calls_TabTitle: String { return self._s[1874]! } + public var Map_YouAreHere: String { return self._s[1875]! } + public var PhotoEditor_CurvesTool: String { return self._s[1876]! } + public var Map_LiveLocationFor1Hour: String { return self._s[1877]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[1878]! } + public var Stickers_NoStickersFound: String { return self._s[1879]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1881]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1881]!, self._r[1881]!, [_0]) + return formatWithArgumentRanges(self._s[1882]!, self._r[1882]!, [_0]) } - public var Passport_Language_et: String { return self._s[1882]! } - public var Passport_Language_en: String { return self._s[1883]! } - public var Login_CancelPhoneVerification: String { return self._s[1884]! } - public var GroupInfo_ActionRestrict: String { return self._s[1887]! } - public var Checkout_ShippingOption_Title: String { return self._s[1888]! } - public var Stickers_SuggestStickers: String { return self._s[1890]! } + public var Passport_Language_et: String { return self._s[1883]! } + public var Passport_Language_en: String { return self._s[1884]! } + public var Login_CancelPhoneVerification: String { return self._s[1885]! } + public var GroupInfo_ActionRestrict: String { return self._s[1888]! } + public var Checkout_ShippingOption_Title: String { return self._s[1889]! } + public var Stickers_SuggestStickers: String { return self._s[1891]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1894]!, self._r[1894]!, [_1]) + return formatWithArgumentRanges(self._s[1895]!, self._r[1895]!, [_1]) } - public var Conversation_EncryptionProcessing: String { return self._s[1895]! } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[1896]! } + public var Conversation_EncryptionProcessing: String { return self._s[1896]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[1897]! } public func CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1899]!, self._r[1899]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1900]!, self._r[1900]!, [_1, _2, _3]) } - public var Weekday_ShortSunday: String { return self._s[1902]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[1903]! } - public var Month_ShortJune: String { return self._s[1904]! } - public var Privacy_Calls_Integration: String { return self._s[1905]! } - public var Channel_TypeSetup_Title: String { return self._s[1906]! } - public var Month_GenApril: String { return self._s[1907]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[1908]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1909]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1910]! } - public var Weekday_Tuesday: String { return self._s[1911]! } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[1912]! } + public var Weekday_ShortSunday: String { return self._s[1903]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[1904]! } + public var Month_ShortJune: String { return self._s[1905]! } + public var Privacy_Calls_Integration: String { return self._s[1906]! } + public var Channel_TypeSetup_Title: String { return self._s[1907]! } + public var Month_GenApril: String { return self._s[1908]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[1909]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1910]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1911]! } + public var Weekday_Tuesday: String { return self._s[1912]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[1913]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1913]!, self._r[1913]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1914]!, self._r[1914]!, [_0, _1]) } - public var CallSettings_RecentCalls: String { return self._s[1914]! } + public var CallSettings_RecentCalls: String { return self._s[1915]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1919]!, self._r[1919]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1920]!, self._r[1920]!, ["\(_0)"]) } - public var Conversation_SearchByName_Prefix: String { return self._s[1922]! } - public var TwoStepAuth_FloodError: String { return self._s[1923]! } - public var Paint_Stickers: String { return self._s[1924]! } - public var Login_InvalidCountryCode: String { return self._s[1925]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1926]! } - public var Username_InvalidTooShort: String { return self._s[1927]! } + public var Conversation_SearchByName_Prefix: String { return self._s[1923]! } + public var TwoStepAuth_FloodError: String { return self._s[1924]! } + public var Paint_Stickers: String { return self._s[1925]! } + public var Login_InvalidCountryCode: String { return self._s[1926]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1927]! } + public var Username_InvalidTooShort: String { return self._s[1928]! } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1928]!, self._r[1928]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1929]!, self._r[1929]!, [_1, _2]) } - public var Weekday_ShortFriday: String { return self._s[1929]! } + public var Weekday_ShortFriday: String { return self._s[1930]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1930]!, self._r[1930]!, [_0]) + return formatWithArgumentRanges(self._s[1931]!, self._r[1931]!, [_0]) } - public var Conversation_ClearAll: String { return self._s[1931]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[1932]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[1933]! } - public var Call_ReportIncludeLog: String { return self._s[1934]! } + public var Conversation_ClearAll: String { return self._s[1932]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[1933]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1934]! } + public var Call_ReportIncludeLog: String { return self._s[1935]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1935]!, self._r[1935]!, [_0]) + return formatWithArgumentRanges(self._s[1936]!, self._r[1936]!, [_0]) } - public var SharedMedia_EmptyTitle: String { return self._s[1936]! } - public var Call_PhoneCallInProgressMessage: String { return self._s[1937]! } - public var Notification_GroupActivated: String { return self._s[1938]! } - public var Checkout_Name: String { return self._s[1939]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[1940]! } + public var SharedMedia_EmptyTitle: String { return self._s[1937]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[1938]! } + public var Notification_GroupActivated: String { return self._s[1939]! } + public var Checkout_Name: String { return self._s[1940]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[1941]! } public func AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1941]!, self._r[1941]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1942]!, self._r[1942]!, [_1, _2]) } - public var Settings_NotificationsAndSounds: String { return self._s[1942]! } - public var Conversation_EncryptionCanceled: String { return self._s[1943]! } + public var Settings_NotificationsAndSounds: String { return self._s[1943]! } + public var Conversation_EncryptionCanceled: String { return self._s[1944]! } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1944]!, self._r[1944]!, [_0]) + return formatWithArgumentRanges(self._s[1945]!, self._r[1945]!, [_0]) } - public var AccessDenied_SaveMedia: String { return self._s[1945]! } - public var InviteText_URL: String { return self._s[1946]! } - public var Passport_CorrectErrors: String { return self._s[1947]! } + public var AccessDenied_SaveMedia: String { return self._s[1946]! } + public var InviteText_URL: String { return self._s[1947]! } + public var Passport_CorrectErrors: String { return self._s[1948]! } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1948]!, self._r[1948]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1949]!, self._r[1949]!, [_1, _2]) } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1949]! } - public var Appearance_ReduceMotion: String { return self._s[1950]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[1951]! } - public var Passport_Address_CityPlaceholder: String { return self._s[1952]! } - public var Passport_InfoFAQ_URL: String { return self._s[1953]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[1956]! } - public var InstantPage_TapToOpenLink: String { return self._s[1957]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1958]! } - public var Notifications_GroupNotifications: String { return self._s[1959]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[1960]! } - public var Notification_Mute1hMin: String { return self._s[1961]! } - public var Privacy_TopPeersWarning: String { return self._s[1962]! } - public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[1964]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1966]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[1967]! } - public var Watch_Conversation_UserInfo: String { return self._s[1968]! } - public var Application_Name: String { return self._s[1969]! } - public var Conversation_AddToReadingList: String { return self._s[1970]! } - public var Conversation_FileDropbox: String { return self._s[1971]! } - public var Login_PhonePlaceholder: String { return self._s[1972]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1973]! } - public var Profile_MessageLifetime1d: String { return self._s[1974]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1975]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1976]! } - public var Calls_CallTabDescription: String { return self._s[1977]! } - public var Passport_DeletePersonalDetails: String { return self._s[1978]! } - public var Passport_Address_AddBankStatement: String { return self._s[1979]! } - public var Resolve_ErrorNotFound: String { return self._s[1980]! } - public var Watch_Message_Call: String { return self._s[1981]! } - public var PhotoEditor_FadeTool: String { return self._s[1982]! } - public var Channel_Setup_TypePublicHelp: String { return self._s[1984]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[1987]! } - public var Channel_Setup_PublicNoLink: String { return self._s[1988]! } - public var Privacy_Calls_P2PHelp: String { return self._s[1989]! } - public var Conversation_Info: String { return self._s[1990]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1950]! } + public var Appearance_ReduceMotion: String { return self._s[1951]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[1952]! } + public var Passport_Address_CityPlaceholder: String { return self._s[1953]! } + public var Passport_InfoFAQ_URL: String { return self._s[1954]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[1957]! } + public var InstantPage_TapToOpenLink: String { return self._s[1958]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1959]! } + public var Notifications_GroupNotifications: String { return self._s[1960]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[1961]! } + public var Notification_Mute1hMin: String { return self._s[1962]! } + public var Privacy_TopPeersWarning: String { return self._s[1963]! } + public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[1965]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1967]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[1968]! } + public var Watch_Conversation_UserInfo: String { return self._s[1969]! } + public var Application_Name: String { return self._s[1970]! } + public var Conversation_AddToReadingList: String { return self._s[1971]! } + public var Conversation_FileDropbox: String { return self._s[1972]! } + public var Login_PhonePlaceholder: String { return self._s[1973]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1974]! } + public var Profile_MessageLifetime1d: String { return self._s[1975]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1976]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1977]! } + public var Calls_CallTabDescription: String { return self._s[1978]! } + public var Passport_DeletePersonalDetails: String { return self._s[1979]! } + public var Passport_Address_AddBankStatement: String { return self._s[1980]! } + public var Resolve_ErrorNotFound: String { return self._s[1981]! } + public var Watch_Message_Call: String { return self._s[1982]! } + public var PhotoEditor_FadeTool: String { return self._s[1983]! } + public var Channel_Setup_TypePublicHelp: String { return self._s[1985]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[1988]! } + public var Channel_Setup_PublicNoLink: String { return self._s[1989]! } + public var Privacy_Calls_P2PHelp: String { return self._s[1990]! } + public var Conversation_Info: String { return self._s[1991]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1992]!, self._r[1992]!, [_0]) + return formatWithArgumentRanges(self._s[1993]!, self._r[1993]!, [_0]) } - public var AutoDownloadSettings_VideosTitle: String { return self._s[1993]! } - public var Conversation_Processing: String { return self._s[1994]! } - public var Conversation_RestrictedInline: String { return self._s[1995]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[1994]! } + public var Conversation_Processing: String { return self._s[1995]! } + public var Conversation_RestrictedInline: String { return self._s[1996]! } public func InstantPage_AuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1999]!, self._r[1999]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2000]!, self._r[2000]!, [_1, _2]) } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2000]!, self._r[2000]!, [_0]) + return formatWithArgumentRanges(self._s[2001]!, self._r[2001]!, [_0]) } - public var Conversation_Location: String { return self._s[2001]! } - public var DialogList_PasscodeLockHelp: String { return self._s[2002]! } - public var Channel_Management_Title: String { return self._s[2003]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[2004]! } - public var EnterPasscode_EnterTitle: String { return self._s[2006]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[2007]! } - public var Month_GenJanuary: String { return self._s[2008]! } - public var Conversation_ForwardChats: String { return self._s[2009]! } - public var Channel_UpdatePhotoItem: String { return self._s[2011]! } - public var UserInfo_StartSecretChat: String { return self._s[2012]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[2013]! } + public var Conversation_Location: String { return self._s[2002]! } + public var DialogList_PasscodeLockHelp: String { return self._s[2003]! } + public var Channel_Management_Title: String { return self._s[2004]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[2005]! } + public var EnterPasscode_EnterTitle: String { return self._s[2007]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[2008]! } + public var Month_GenJanuary: String { return self._s[2009]! } + public var Conversation_ForwardChats: String { return self._s[2010]! } + public var Channel_UpdatePhotoItem: String { return self._s[2012]! } + public var UserInfo_StartSecretChat: String { return self._s[2013]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[2014]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2014]!, self._r[2014]!, [_0]) + return formatWithArgumentRanges(self._s[2015]!, self._r[2015]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[2017]! } public var ChatSearch_SearchPlaceholder: String { return self._s[2018]! } - public var FastTwoStepSetup_HintSection: String { return self._s[2019]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[2022]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2024]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[2019]! } + public var FastTwoStepSetup_HintSection: String { return self._s[2020]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[2023]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2025]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2025]!, self._r[2025]!, [_0]) + return formatWithArgumentRanges(self._s[2026]!, self._r[2026]!, [_0]) } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2027]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[2028]! } - public var Localization_LanguageName: String { return self._s[2029]! } - public var Map_OpenIn: String { return self._s[2030]! } - public var Message_File: String { return self._s[2031]! } - public var Call_ReportSend: String { return self._s[2032]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2028]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[2029]! } + public var Localization_LanguageName: String { return self._s[2030]! } + public var Map_OpenIn: String { return self._s[2031]! } + public var Message_File: String { return self._s[2032]! } + public var Call_ReportSend: String { return self._s[2033]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2033]!, self._r[2033]!, [_0]) + return formatWithArgumentRanges(self._s[2034]!, self._r[2034]!, [_0]) } public func CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2034]!, self._r[2034]!, [_1, _2, _3]) - } - public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2035]!, self._r[2035]!, [_1, _2, _3]) } - public var Month_ShortMay: String { return self._s[2038]! } - public var Tour_Text3: String { return self._s[2039]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2040]! } - public var Contacts_GlobalSearch: String { return self._s[2041]! } - public var DialogList_LanguageTooltip: String { return self._s[2042]! } - public var AuthSessions_LogOutApplications: String { return self._s[2043]! } - public var Map_LoadError: String { return self._s[2044]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2045]! } - public var Settings_ProxyConnecting: String { return self._s[2046]! } - public var Passport_Language_fa: String { return self._s[2048]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[2049]! } + public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2036]!, self._r[2036]!, [_1, _2, _3]) + } + public var Month_ShortMay: String { return self._s[2039]! } + public var Tour_Text3: String { return self._s[2040]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2041]! } + public var Contacts_GlobalSearch: String { return self._s[2042]! } + public var DialogList_LanguageTooltip: String { return self._s[2043]! } + public var AuthSessions_LogOutApplications: String { return self._s[2044]! } + public var Map_LoadError: String { return self._s[2045]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2046]! } + public var Settings_ProxyConnecting: String { return self._s[2047]! } + public var Passport_Language_fa: String { return self._s[2049]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[2050]! } public func CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2052]!, self._r[2052]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2053]!, self._r[2053]!, [_1, _2]) } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2053]! } - public var PrivacySettings_Title: String { return self._s[2054]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[2057]! } - public var MediaPicker_AddCaption: String { return self._s[2058]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[2059]! } - public var Channel_Status: String { return self._s[2060]! } - public var Map_ChooseLocationTitle: String { return self._s[2061]! } - public var Notifications_ChannelNotifications: String { return self._s[2062]! } - public var Map_OpenInYandexNavigator: String { return self._s[2063]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2054]! } + public var PrivacySettings_Title: String { return self._s[2055]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[2058]! } + public var MediaPicker_AddCaption: String { return self._s[2059]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[2060]! } + public var Channel_Status: String { return self._s[2061]! } + public var Map_ChooseLocationTitle: String { return self._s[2062]! } + public var Notifications_ChannelNotifications: String { return self._s[2063]! } + public var Map_OpenInYandexNavigator: String { return self._s[2064]! } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2064]!, self._r[2064]!, [_1]) + return formatWithArgumentRanges(self._s[2065]!, self._r[2065]!, [_1]) } - public var AutoNightTheme_PreferredTheme: String { return self._s[2065]! } - public var State_WaitingForNetwork: String { return self._s[2066]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2067]! } - public var Conversation_StopLiveLocation: String { return self._s[2068]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2069]! } - public var PhotoEditor_SharpenTool: String { return self._s[2070]! } - public var Common_of: String { return self._s[2071]! } - public var AuthSessions_Title: String { return self._s[2072]! } - public var Passport_Scans_UploadNew: String { return self._s[2073]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2074]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[2075]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2076]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2077]! } - public var Notifications_Reset: String { return self._s[2078]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[2066]! } + public var State_WaitingForNetwork: String { return self._s[2067]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2068]! } + public var Conversation_StopLiveLocation: String { return self._s[2069]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2070]! } + public var PhotoEditor_SharpenTool: String { return self._s[2071]! } + public var Common_of: String { return self._s[2072]! } + public var AuthSessions_Title: String { return self._s[2073]! } + public var Passport_Scans_UploadNew: String { return self._s[2074]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2075]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[2076]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2077]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2078]! } + public var Notifications_Reset: String { return self._s[2079]! } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2079]!, self._r[2079]!, [_0]) + return formatWithArgumentRanges(self._s[2080]!, self._r[2080]!, [_0]) } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2080]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2081]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2082]!, self._r[2082]!, [_0]) + return formatWithArgumentRanges(self._s[2083]!, self._r[2083]!, [_0]) } public func CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2083]!, self._r[2083]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2084]!, self._r[2084]!, [_1, _2]) } - public var Watch_AppName: String { return self._s[2084]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[2085]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[2086]! } + public var Watch_AppName: String { return self._s[2085]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[2086]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[2087]! } public func MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2088]!, self._r[2088]!, [_1]) + return formatWithArgumentRanges(self._s[2089]!, self._r[2089]!, [_1]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2089]!, self._r[2089]!, [_0]) + return formatWithArgumentRanges(self._s[2090]!, self._r[2090]!, [_0]) } - public var Checkout_PayWithTouchId: String { return self._s[2090]! } - public var Passport_Language_ko: String { return self._s[2091]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2092]! } + public var Checkout_PayWithTouchId: String { return self._s[2091]! } + public var Passport_Language_ko: String { return self._s[2092]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2093]! } public func CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2093]!, self._r[2093]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2094]!, self._r[2094]!, [_1, _2]) } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[2094]! } - public var Group_AdminLog_EmptyText: String { return self._s[2095]! } - public var AutoDownloadSettings_GroupChats: String { return self._s[2096]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[2097]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[2099]! } - public var Notifications_ExceptionsMuted: String { return self._s[2100]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[2101]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[2103]! } - public var Settings_FAQ_Intro: String { return self._s[2104]! } - public var PrivacySettings_AuthSessions: String { return self._s[2105]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[2095]! } + public var Group_AdminLog_EmptyText: String { return self._s[2096]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[2097]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[2098]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[2100]! } + public var Notifications_ExceptionsMuted: String { return self._s[2101]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[2102]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[2104]! } + public var Settings_FAQ_Intro: String { return self._s[2105]! } + public var PrivacySettings_AuthSessions: String { return self._s[2106]! } public func CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2106]!, self._r[2106]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2107]!, self._r[2107]!, [_1, _2]) } - public var Passport_Address_Postcode: String { return self._s[2108]! } - public var Tour_Title5: String { return self._s[2109]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[2110]! } - public var Group_Management_AddModeratorHelp: String { return self._s[2111]! } - public var Channel_Username_CheckingUsername: String { return self._s[2112]! } + public var Passport_Address_Postcode: String { return self._s[2109]! } + public var Tour_Title5: String { return self._s[2110]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[2111]! } + public var Group_Management_AddModeratorHelp: String { return self._s[2112]! } + public var Channel_Username_CheckingUsername: String { return self._s[2113]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2114]!, self._r[2114]!, [_0]) + return formatWithArgumentRanges(self._s[2115]!, self._r[2115]!, [_0]) } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2118]!, self._r[2118]!, [_0]) + return formatWithArgumentRanges(self._s[2119]!, self._r[2119]!, [_0]) } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2119]!, self._r[2119]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[2120]!, self._r[2120]!, [_1, _1, _1, _2]) } - public var Channel_Info_BlackList: String { return self._s[2120]! } - public var Profile_BotInfo: String { return self._s[2121]! } - public var Stickers_SuggestAll: String { return self._s[2122]! } - public var Compose_NewChannel_Members: String { return self._s[2123]! } - public var Notification_Reply: String { return self._s[2124]! } - public var Watch_Stickers_Recents: String { return self._s[2126]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2127]! } - public var Channel_Stickers_Placeholder: String { return self._s[2128]! } - public var AttachmentMenu_File: String { return self._s[2129]! } + public var Channel_Info_BlackList: String { return self._s[2121]! } + public var Profile_BotInfo: String { return self._s[2122]! } + public var Stickers_SuggestAll: String { return self._s[2123]! } + public var Compose_NewChannel_Members: String { return self._s[2124]! } + public var Notification_Reply: String { return self._s[2125]! } + public var Watch_Stickers_Recents: String { return self._s[2127]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2128]! } + public var Channel_Stickers_Placeholder: String { return self._s[2129]! } + public var AttachmentMenu_File: String { return self._s[2130]! } public func MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2130]!, self._r[2130]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2131]!, self._r[2131]!, [_1, _2]) } - public var Profile_MessageLifetime5s: String { return self._s[2131]! } - public var Privacy_ContactsReset: String { return self._s[2133]! } - public var TwoStepAuth_ChangePasswordDescription: String { return self._s[2134]! } + public var Profile_MessageLifetime5s: String { return self._s[2132]! } + public var Privacy_ContactsReset: String { return self._s[2134]! } + public var TwoStepAuth_ChangePasswordDescription: String { return self._s[2135]! } public func PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2135]!, self._r[2135]!, [_1]) + return formatWithArgumentRanges(self._s[2136]!, self._r[2136]!, [_1]) } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[2138]! } - public var TwoStepAuth_SetupHint: String { return self._s[2139]! } - public var Conversation_StatusLeftGroup: String { return self._s[2140]! } - public var Settings_CopyUsername: String { return self._s[2141]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2142]! } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2143]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2144]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[2145]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[2146]! } - public var Notification_PassportValuePersonalDetails: String { return self._s[2147]! } - public var Message_PinnedAnimationMessage: String { return self._s[2148]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2149]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[2150]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[2151]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2152]! } - public var Camera_PhotoMode: String { return self._s[2154]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[2139]! } + public var TwoStepAuth_SetupHint: String { return self._s[2140]! } + public var Conversation_StatusLeftGroup: String { return self._s[2141]! } + public var Settings_CopyUsername: String { return self._s[2142]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2143]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2144]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2145]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[2146]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[2147]! } + public var Notification_PassportValuePersonalDetails: String { return self._s[2148]! } + public var Message_PinnedAnimationMessage: String { return self._s[2149]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2150]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[2151]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[2152]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2153]! } + public var Camera_PhotoMode: String { return self._s[2155]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2156]!, self._r[2156]!, [_0]) + return formatWithArgumentRanges(self._s[2157]!, self._r[2157]!, [_0]) } - public var Channel_About_Placeholder: String { return self._s[2157]! } - public var Map_Directions: String { return self._s[2159]! } - public var Channel_About_Title: String { return self._s[2160]! } + public var Channel_About_Placeholder: String { return self._s[2158]! } + public var Map_Directions: String { return self._s[2160]! } + public var Channel_About_Title: String { return self._s[2161]! } public func MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2161]!, self._r[2161]!, [_1]) + return formatWithArgumentRanges(self._s[2162]!, self._r[2162]!, [_1]) } - public var Calls_RatingTitle: String { return self._s[2162]! } - public var SharedMedia_EmptyText: String { return self._s[2163]! } - public var Channel_Stickers_Searching: String { return self._s[2164]! } - public var Passport_Address_AddUtilityBill: String { return self._s[2165]! } - public var Login_PadPhoneHelp: String { return self._s[2166]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[2168]! } - public var Passport_Language_th: String { return self._s[2169]! } - public var Channel_ErrorAccessDenied: String { return self._s[2170]! } - public var Generic_ErrorMoreInfo: String { return self._s[2172]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[2173]! } - public var Settings_Proxy: String { return self._s[2174]! } - public var Passport_Language_lt: String { return self._s[2175]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[2176]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2178]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[2179]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2180]! } - public var Camera_SquareMode: String { return self._s[2181]! } + public var Calls_RatingTitle: String { return self._s[2163]! } + public var SharedMedia_EmptyText: String { return self._s[2164]! } + public var Channel_Stickers_Searching: String { return self._s[2165]! } + public var Passport_Address_AddUtilityBill: String { return self._s[2166]! } + public var Login_PadPhoneHelp: String { return self._s[2167]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[2169]! } + public var Passport_Language_th: String { return self._s[2170]! } + public var Channel_ErrorAccessDenied: String { return self._s[2171]! } + public var Generic_ErrorMoreInfo: String { return self._s[2173]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[2174]! } + public var Settings_Proxy: String { return self._s[2175]! } + public var Passport_Language_lt: String { return self._s[2176]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[2177]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2179]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[2180]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2181]! } + public var Camera_SquareMode: String { return self._s[2182]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2182]!, self._r[2182]!, [_0]) + return formatWithArgumentRanges(self._s[2183]!, self._r[2183]!, [_0]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2183]! } - public var Login_PadPhoneHelpTitle: String { return self._s[2184]! } - public var Profile_CreateNewContact: String { return self._s[2185]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[2186]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2187]! } - public var PhotoEditor_VignetteTool: String { return self._s[2188]! } - public var LastSeen_WithinAWeek: String { return self._s[2189]! } - public var Widget_NoUsers: String { return self._s[2190]! } - public var Passport_Identity_DocumentNumber: String { return self._s[2192]! } - public var Application_Update: String { return self._s[2193]! } - public var Calls_NewCall: String { return self._s[2194]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2184]! } + public var Login_PadPhoneHelpTitle: String { return self._s[2185]! } + public var Profile_CreateNewContact: String { return self._s[2186]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[2187]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2188]! } + public var PhotoEditor_VignetteTool: String { return self._s[2189]! } + public var LastSeen_WithinAWeek: String { return self._s[2190]! } + public var Widget_NoUsers: String { return self._s[2191]! } + public var Passport_Identity_DocumentNumber: String { return self._s[2193]! } + public var Application_Update: String { return self._s[2194]! } + public var Calls_NewCall: String { return self._s[2195]! } public func CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2195]!, self._r[2195]!, [_1]) + return formatWithArgumentRanges(self._s[2196]!, self._r[2196]!, [_1]) } - public var DialogList_NoMessagesText: String { return self._s[2196]! } - public var MaskStickerSettings_Info: String { return self._s[2197]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2198]! } - public var Passport_FieldAddressHelp: String { return self._s[2199]! } - public var Passport_Language_dz: String { return self._s[2200]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[2201]! } - public var Channel_AdminLog_BanSendStickers: String { return self._s[2202]! } - public var Common_Next: String { return self._s[2203]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2204]! } - public var Watch_Notification_Joined: String { return self._s[2205]! } + public var DialogList_NoMessagesText: String { return self._s[2197]! } + public var MaskStickerSettings_Info: String { return self._s[2198]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2199]! } + public var Passport_FieldAddressHelp: String { return self._s[2200]! } + public var Passport_Language_dz: String { return self._s[2201]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[2202]! } + public var Channel_AdminLog_BanSendStickers: String { return self._s[2203]! } + public var Common_Next: String { return self._s[2204]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2205]! } + public var Watch_Notification_Joined: String { return self._s[2206]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, [_0]) + return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, [_0]) } - public var Passport_DeleteAddress: String { return self._s[2207]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2208]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[2209]! } - public var NotificationsSound_Tremolo: String { return self._s[2210]! } - public var TwoStepAuth_EmailInvalid: String { return self._s[2211]! } - public var Privacy_ContactsTitle: String { return self._s[2212]! } - public var Passport_Address_TypeBankStatement: String { return self._s[2214]! } + public var Passport_DeleteAddress: String { return self._s[2208]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2209]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[2210]! } + public var NotificationsSound_Tremolo: String { return self._s[2211]! } + public var TwoStepAuth_EmailInvalid: String { return self._s[2212]! } + public var Privacy_ContactsTitle: String { return self._s[2213]! } + public var Passport_Address_TypeBankStatement: String { return self._s[2215]! } public func CHAT_MESSAGE_VIDEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2215]!, self._r[2215]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2216]!, self._r[2216]!, [_1, _2]) } - public var Month_GenJune: String { return self._s[2216]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2217]! } + public var Month_GenJune: String { return self._s[2217]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2218]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2218]!, self._r[2218]!, [_0]) + return formatWithArgumentRanges(self._s[2219]!, self._r[2219]!, [_0]) } public func CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2219]!, self._r[2219]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2220]!, self._r[2220]!, [_1, _2]) } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2220]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2221]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2221]!, self._r[2221]!, [_0]) + return formatWithArgumentRanges(self._s[2222]!, self._r[2222]!, [_0]) } - public var Watch_LastSeen_Lately: String { return self._s[2222]! } - public var Watch_Compose_CurrentLocation: String { return self._s[2223]! } - public var DialogList_RecentTitlePeople: String { return self._s[2225]! } - public var GroupInfo_Notifications: String { return self._s[2226]! } - public var Call_ReportPlaceholder: String { return self._s[2227]! } + public var Watch_LastSeen_Lately: String { return self._s[2223]! } + public var Watch_Compose_CurrentLocation: String { return self._s[2224]! } + public var DialogList_RecentTitlePeople: String { return self._s[2226]! } + public var GroupInfo_Notifications: String { return self._s[2227]! } + public var Call_ReportPlaceholder: String { return self._s[2228]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2228]!, self._r[2228]!, [_0]) + return formatWithArgumentRanges(self._s[2229]!, self._r[2229]!, [_0]) } public func MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2229]!, self._r[2229]!, [_1]) + return formatWithArgumentRanges(self._s[2230]!, self._r[2230]!, [_1]) } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[2230]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2231]! } - public var AuthSessions_EmptyTitle: String { return self._s[2232]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[2234]! } - public var Passport_Language_he: String { return self._s[2235]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[2231]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2232]! } + public var AuthSessions_EmptyTitle: String { return self._s[2233]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[2235]! } + public var Passport_Language_he: String { return self._s[2236]! } public func MediaPicker_Nof(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2236]!, self._r[2236]!, [_0]) + return formatWithArgumentRanges(self._s[2237]!, self._r[2237]!, [_0]) } - public var Common_Create: String { return self._s[2237]! } - public var Contacts_TopSection: String { return self._s[2238]! } + public var Common_Create: String { return self._s[2238]! } + public var Contacts_TopSection: String { return self._s[2239]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2239]!, self._r[2239]!, [_0]) + return formatWithArgumentRanges(self._s[2240]!, self._r[2240]!, [_0]) } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2240]! } - public var Your_cards_number_is_invalid: String { return self._s[2241]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2241]! } + public var Your_cards_number_is_invalid: String { return self._s[2242]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2242]!, self._r[2242]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2243]!, self._r[2243]!, [_1, _2]) } - public var Localization_LanguageCustom: String { return self._s[2243]! } + public var Localization_LanguageCustom: String { return self._s[2244]! } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2244]!, self._r[2244]!, [_0]) + return formatWithArgumentRanges(self._s[2245]!, self._r[2245]!, [_0]) } - public var Group_MessagePhotoRemoved: String { return self._s[2245]! } - public var Appearance_Animations: String { return self._s[2246]! } - public var UserInfo_AddToExisting: String { return self._s[2247]! } - public var NotificationsSound_Aurora: String { return self._s[2248]! } + public var Group_MessagePhotoRemoved: String { return self._s[2246]! } + public var Appearance_Animations: String { return self._s[2247]! } + public var UserInfo_AddToExisting: String { return self._s[2248]! } + public var NotificationsSound_Aurora: String { return self._s[2249]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2251]!, self._r[2251]!, [_0]) + return formatWithArgumentRanges(self._s[2252]!, self._r[2252]!, [_0]) } - public var Conversation_MessageDialogRetry: String { return self._s[2252]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[2253]! } - public var Passport_Language_my: String { return self._s[2254]! } - public var Stickers_GroupStickers: String { return self._s[2256]! } - public var BlockedUsers_Title: String { return self._s[2258]! } + public var Conversation_MessageDialogRetry: String { return self._s[2253]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[2254]! } + public var Passport_Language_my: String { return self._s[2255]! } + public var Stickers_GroupStickers: String { return self._s[2257]! } + public var BlockedUsers_Title: String { return self._s[2259]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2259]!, self._r[2259]!, [_0]) + return formatWithArgumentRanges(self._s[2260]!, self._r[2260]!, [_0]) } - public var ContactInfo_PhoneLabelWork: String { return self._s[2260]! } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2261]! } - public var Passport_FieldAddressTranslationHelp: String { return self._s[2262]! } - public var Cache_ClearNone: String { return self._s[2263]! } - public var SecretTimer_VideoDescription: String { return self._s[2265]! } - public var Login_InvalidCodeError: String { return self._s[2266]! } - public var Channel_BanList_BlockedTitle: String { return self._s[2268]! } - public var Passport_PasswordHelp: String { return self._s[2269]! } - public var NetworkUsageSettings_Cellular: String { return self._s[2270]! } - public var Watch_Location_Access: String { return self._s[2271]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[2273]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[2274]! } - public var Channel_AdminLog_EmptyText: String { return self._s[2275]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[2276]! } - public var Passport_Language_ms: String { return self._s[2277]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2278]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[2261]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2262]! } + public var Passport_FieldAddressTranslationHelp: String { return self._s[2263]! } + public var Cache_ClearNone: String { return self._s[2264]! } + public var SecretTimer_VideoDescription: String { return self._s[2266]! } + public var Login_InvalidCodeError: String { return self._s[2267]! } + public var Channel_BanList_BlockedTitle: String { return self._s[2269]! } + public var Passport_PasswordHelp: String { return self._s[2270]! } + public var NetworkUsageSettings_Cellular: String { return self._s[2271]! } + public var Watch_Location_Access: String { return self._s[2272]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[2274]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[2275]! } + public var Channel_AdminLog_EmptyText: String { return self._s[2276]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[2277]! } + public var Passport_Language_ms: String { return self._s[2278]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2279]! } public func ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2279]!, self._r[2279]!, [_1]) + return formatWithArgumentRanges(self._s[2280]!, self._r[2280]!, [_1]) } - public var Watch_LastSeen_WithinAMonth: String { return self._s[2280]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2281]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2282]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[2283]! } - public var Bot_Stop: String { return self._s[2284]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2285]! } - public var UserInfo_BotSettings: String { return self._s[2286]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2287]! } - public var Passport_FieldIdentity: String { return self._s[2288]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2289]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[2290]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[2281]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2282]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2283]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[2284]! } + public var Bot_Stop: String { return self._s[2285]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2286]! } + public var UserInfo_BotSettings: String { return self._s[2287]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2288]! } + public var Passport_FieldIdentity: String { return self._s[2289]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2290]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[2291]! } public func CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2292]!, self._r[2292]!, [_1]) + return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_1]) } - public var Passport_Identity_LatinNameHelp: String { return self._s[2293]! } - public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[2294]! } - public var SocksProxySetup_Port: String { return self._s[2295]! } - public var Message_VideoMessage: String { return self._s[2297]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[2298]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2299]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[2294]! } + public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[2295]! } + public var SocksProxySetup_Port: String { return self._s[2296]! } + public var Message_VideoMessage: String { return self._s[2298]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[2299]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2300]! } public func CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2301]!, self._r[2301]!, [_1, _2, _3]) } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[2301]! } - public var Camera_Title: String { return self._s[2302]! } - public var Passport_Identity_IssueDate: String { return self._s[2303]! } - public var PhotoEditor_CurvesBlue: String { return self._s[2305]! } - public var Message_PinnedVideoMessage: String { return self._s[2306]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[2302]! } + public var Camera_Title: String { return self._s[2303]! } + public var Passport_Identity_IssueDate: String { return self._s[2304]! } + public var PhotoEditor_CurvesBlue: String { return self._s[2306]! } + public var Message_PinnedVideoMessage: String { return self._s[2307]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2307]!, self._r[2307]!, [_0]) + return formatWithArgumentRanges(self._s[2308]!, self._r[2308]!, [_0]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[2309]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2310]! } - public var TwoStepAuth_Email: String { return self._s[2311]! } - public var Stickers_SuggestNone: String { return self._s[2312]! } - public var Map_SendMyCurrentLocation: String { return self._s[2314]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[2310]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2311]! } + public var TwoStepAuth_Email: String { return self._s[2312]! } + public var Stickers_SuggestNone: String { return self._s[2313]! } + public var Map_SendMyCurrentLocation: String { return self._s[2315]! } public func MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_1]) + return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_1]) } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2316]! } - public var Watch_Message_Invoice: String { return self._s[2317]! } - public var Map_Unknown: String { return self._s[2319]! } - public var Wallpaper_Set: String { return self._s[2321]! } - public var AccessDenied_Title: String { return self._s[2322]! } - public var SharedMedia_CategoryLinks: String { return self._s[2323]! } - public var Localization_LanguageOther: String { return self._s[2324]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2317]! } + public var Watch_Message_Invoice: String { return self._s[2318]! } + public var Map_Unknown: String { return self._s[2320]! } + public var Wallpaper_Set: String { return self._s[2322]! } + public var AccessDenied_Title: String { return self._s[2323]! } + public var SharedMedia_CategoryLinks: String { return self._s[2324]! } + public var Localization_LanguageOther: String { return self._s[2325]! } public func CHAT_MESSAGES(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_1, _2, _3]) } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2326]! } - public var Passport_Identity_TypeDriversLicense: String { return self._s[2327]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[2328]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[2329]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[2330]! } - public var ChatSettings_Stickers: String { return self._s[2331]! } - public var Camera_FlashOff: String { return self._s[2332]! } - public var TwoStepAuth_Title: String { return self._s[2334]! } - public var Passport_Identity_Translation: String { return self._s[2335]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[2336]! } - public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[2337]! } - public var WebSearch_Images: String { return self._s[2338]! } - public var Conversation_typing: String { return self._s[2339]! } - public var Common_Back: String { return self._s[2340]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[2342]! } - public var Passport_Language_es: String { return self._s[2343]! } - public var Common_Search: String { return self._s[2344]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2327]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[2328]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[2329]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[2330]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[2331]! } + public var ChatSettings_Stickers: String { return self._s[2332]! } + public var Camera_FlashOff: String { return self._s[2333]! } + public var TwoStepAuth_Title: String { return self._s[2335]! } + public var Passport_Identity_Translation: String { return self._s[2336]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[2337]! } + public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[2338]! } + public var WebSearch_Images: String { return self._s[2339]! } + public var Conversation_typing: String { return self._s[2340]! } + public var Common_Back: String { return self._s[2341]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[2343]! } + public var Passport_Language_es: String { return self._s[2344]! } + public var Common_Search: String { return self._s[2345]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2345]!, self._r[2345]!, [_0]) + return formatWithArgumentRanges(self._s[2346]!, self._r[2346]!, [_0]) } - public var Common_No: String { return self._s[2346]! } - public var Login_EmailNotConfiguredError: String { return self._s[2347]! } - public var Watch_Suggestion_OK: String { return self._s[2348]! } - public var Profile_AddToExisting: String { return self._s[2349]! } + public var Common_No: String { return self._s[2347]! } + public var Login_EmailNotConfiguredError: String { return self._s[2348]! } + public var Watch_Suggestion_OK: String { return self._s[2349]! } + public var Profile_AddToExisting: String { return self._s[2350]! } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2351]!, self._r[2351]!, [_0]) + return formatWithArgumentRanges(self._s[2352]!, self._r[2352]!, [_0]) } public func PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2352]!, self._r[2352]!, [_1]) + return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_1]) } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_0]) + return formatWithArgumentRanges(self._s[2354]!, self._r[2354]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[2354]! } - public var Passport_Phone_Title: String { return self._s[2356]! } - public var Profile_About: String { return self._s[2357]! } + public var NotificationsSound_Keys: String { return self._s[2355]! } + public var Passport_Phone_Title: String { return self._s[2357]! } + public var Profile_About: String { return self._s[2358]! } public func EncryptionKey_Description(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2358]!, self._r[2358]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2359]!, self._r[2359]!, [_1, _2]) } - public var Conversation_UnreadMessages: String { return self._s[2359]! } + public var Conversation_UnreadMessages: String { return self._s[2360]! } public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2360]!, self._r[2360]!, [_0]) + return formatWithArgumentRanges(self._s[2361]!, self._r[2361]!, [_0]) } - public var Tour_Title3: String { return self._s[2361]! } - public var Passport_Identity_FrontSide: String { return self._s[2362]! } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[2363]! } - public var Watch_Contacts_NoResults: String { return self._s[2364]! } - public var Passport_Language_id: String { return self._s[2365]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2366]! } - public var Watch_UserInfo_MuteTitle: String { return self._s[2367]! } + public var Tour_Title3: String { return self._s[2362]! } + public var Passport_Identity_FrontSide: String { return self._s[2363]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[2364]! } + public var Watch_Contacts_NoResults: String { return self._s[2365]! } + public var Passport_Language_id: String { return self._s[2366]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2367]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[2368]! } public func Privacy_GroupsAndChannels_InviteToGroupError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2370]!, self._r[2370]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2371]!, self._r[2371]!, [_0, _1]) } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2372]!, self._r[2372]!, [_0]) + return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2374]!, self._r[2374]!, [_1, _2]) } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2374]! } - public var DialogList_Typing: String { return self._s[2375]! } - public var Notification_CallBack: String { return self._s[2376]! } - public var Passport_Language_ru: String { return self._s[2377]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2378]! } - public var Map_LocatingError: String { return self._s[2379]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2381]! } - public var MediaPicker_Send: String { return self._s[2382]! } - public var ChannelIntro_Title: String { return self._s[2383]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2385]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2375]! } + public var DialogList_Typing: String { return self._s[2376]! } + public var Notification_CallBack: String { return self._s[2377]! } + public var Passport_Language_ru: String { return self._s[2378]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2379]! } + public var Map_LocatingError: String { return self._s[2380]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2382]! } + public var MediaPicker_Send: String { return self._s[2383]! } + public var ChannelIntro_Title: String { return self._s[2384]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2386]! } public func PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2386]!, self._r[2386]!, [_1]) + return formatWithArgumentRanges(self._s[2387]!, self._r[2387]!, [_1]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2387]!, self._r[2387]!, [_0]) + return formatWithArgumentRanges(self._s[2388]!, self._r[2388]!, [_0]) } - public var Passport_Address_TypePassportRegistration: String { return self._s[2388]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[2391]! } - public var LoginPassword_PasswordHelp: String { return self._s[2393]! } - public var BlockedUsers_Unblock: String { return self._s[2394]! } - public var AutoDownloadSettings_Cellular: String { return self._s[2395]! } - public var Passport_Language_ro: String { return self._s[2396]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[2389]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[2392]! } + public var LoginPassword_PasswordHelp: String { return self._s[2394]! } + public var BlockedUsers_Unblock: String { return self._s[2395]! } + public var AutoDownloadSettings_Cellular: String { return self._s[2396]! } + public var Passport_Language_ro: String { return self._s[2397]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2397]!, self._r[2397]!, [_0]) + return formatWithArgumentRanges(self._s[2398]!, self._r[2398]!, [_0]) } - public var Appearance_PreviewIncomingText: String { return self._s[2398]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2399]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[2400]! } - public var Notifications_GroupNotificationsAlert: String { return self._s[2401]! } - public var Paint_Masks: String { return self._s[2402]! } - public var Appearance_ThemeDayClassic: String { return self._s[2404]! } - public var StickerPack_ErrorNotFound: String { return self._s[2405]! } - public var Appearance_ThemeNight: String { return self._s[2406]! } - public var SecretTimer_ImageDescription: String { return self._s[2407]! } + public var Appearance_PreviewIncomingText: String { return self._s[2399]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2400]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[2401]! } + public var Notifications_GroupNotificationsAlert: String { return self._s[2402]! } + public var Paint_Masks: String { return self._s[2403]! } + public var Appearance_ThemeDayClassic: String { return self._s[2405]! } + public var StickerPack_ErrorNotFound: String { return self._s[2406]! } + public var Appearance_ThemeNight: String { return self._s[2407]! } + public var SecretTimer_ImageDescription: String { return self._s[2408]! } public func PINNED_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2408]!, self._r[2408]!, [_1]) + return formatWithArgumentRanges(self._s[2409]!, self._r[2409]!, [_1]) } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2409]!, self._r[2409]!, [_0]) + return formatWithArgumentRanges(self._s[2410]!, self._r[2410]!, [_0]) } - public var Map_LiveLocationTitle: String { return self._s[2410]! } - public var Watch_GroupInfo_Title: String { return self._s[2411]! } - public var Channel_AdminLog_EmptyTitle: String { return self._s[2412]! } - public var PhotoEditor_Set: String { return self._s[2414]! } - public var LiveLocation_MenuStopAll: String { return self._s[2415]! } - public var SocksProxySetup_AddProxy: String { return self._s[2416]! } + public var Map_LiveLocationTitle: String { return self._s[2411]! } + public var Watch_GroupInfo_Title: String { return self._s[2412]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[2413]! } + public var PhotoEditor_Set: String { return self._s[2415]! } + public var LiveLocation_MenuStopAll: String { return self._s[2416]! } + public var SocksProxySetup_AddProxy: String { return self._s[2417]! } public func Notification_Invited(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2417]!, self._r[2417]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2418]!, self._r[2418]!, [_0, _1]) } - public var Watch_AuthRequired: String { return self._s[2418]! } - public var Conversation_EncryptedDescription1: String { return self._s[2419]! } - public var AppleWatch_ReplyPresets: String { return self._s[2420]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[2421]! } - public var Conversation_EncryptedDescription2: String { return self._s[2422]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2423]! } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[2424]! } - public var Paint_Edit: String { return self._s[2425]! } - public var Passport_Language_nl: String { return self._s[2426]! } - public var LastSeen_Offline: String { return self._s[2427]! } - public var Login_CodeFloodError: String { return self._s[2428]! } - public var Conversation_EncryptedDescription3: String { return self._s[2429]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[2431]! } - public var Conversation_EncryptedDescription4: String { return self._s[2432]! } - public var AppleWatch_Title: String { return self._s[2434]! } - public var Contacts_AccessDeniedError: String { return self._s[2435]! } - public var Conversation_StatusTyping: String { return self._s[2436]! } - public var Share_Title: String { return self._s[2437]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[2438]! } - public var Passport_Identity_FilesTitle: String { return self._s[2439]! } - public var ChatSettings_Title: String { return self._s[2440]! } - public var AuthSessions_CurrentSession: String { return self._s[2441]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[2442]! } + public var Watch_AuthRequired: String { return self._s[2419]! } + public var Conversation_EncryptedDescription1: String { return self._s[2420]! } + public var AppleWatch_ReplyPresets: String { return self._s[2421]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[2422]! } + public var Conversation_EncryptedDescription2: String { return self._s[2423]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2424]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[2425]! } + public var Paint_Edit: String { return self._s[2426]! } + public var Passport_Language_nl: String { return self._s[2427]! } + public var LastSeen_Offline: String { return self._s[2428]! } + public var Login_CodeFloodError: String { return self._s[2429]! } + public var Conversation_EncryptedDescription3: String { return self._s[2430]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[2432]! } + public var Conversation_EncryptedDescription4: String { return self._s[2433]! } + public var AppleWatch_Title: String { return self._s[2435]! } + public var Contacts_AccessDeniedError: String { return self._s[2436]! } + public var Conversation_StatusTyping: String { return self._s[2437]! } + public var Share_Title: String { return self._s[2438]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[2439]! } + public var Passport_Identity_FilesTitle: String { return self._s[2440]! } + public var ChatSettings_Title: String { return self._s[2441]! } + public var AuthSessions_CurrentSession: String { return self._s[2442]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[2443]! } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2443]!, self._r[2443]!, [_0]) + return formatWithArgumentRanges(self._s[2444]!, self._r[2444]!, [_0]) } - public var Watch_Microphone_Access: String { return self._s[2444]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2445]! } - public var Conversation_LiveLocation: String { return self._s[2446]! } - public var UserInfo_Title: String { return self._s[2448]! } - public var Passport_Language_fr: String { return self._s[2449]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[2450]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2451]! } - public var Login_InfoHelp: String { return self._s[2452]! } - public var ShareMenu_ShareTo: String { return self._s[2454]! } - public var Message_PinnedGame: String { return self._s[2458]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[2459]! } + public var Watch_Microphone_Access: String { return self._s[2445]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2446]! } + public var Conversation_LiveLocation: String { return self._s[2447]! } + public var UserInfo_Title: String { return self._s[2449]! } + public var Passport_Language_fr: String { return self._s[2450]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[2451]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2452]! } + public var Login_InfoHelp: String { return self._s[2453]! } + public var ShareMenu_ShareTo: String { return self._s[2455]! } + public var Message_PinnedGame: String { return self._s[2459]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[2460]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2460]!, self._r[2460]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2461]!, self._r[2461]!, [_0, _1]) } - public var Notification_RenamedGroup: String { return self._s[2461]! } + public var Notification_RenamedGroup: String { return self._s[2462]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2462]!, self._r[2462]!, [_0]) + return formatWithArgumentRanges(self._s[2463]!, self._r[2463]!, [_0]) } - public var Passport_Address_Street: String { return self._s[2463]! } - public var Weekday_Thursday: String { return self._s[2464]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2465]! } - public var PrivacySettings_DataSettings: String { return self._s[2466]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[2467]! } - public var NotificationsSound_Bell: String { return self._s[2468]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[2470]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2472]! } - public var DialogList_SearchSectionMessages: String { return self._s[2473]! } - public var Media_ShareThisVideo: String { return self._s[2474]! } - public var Call_ReportIncludeLogDescription: String { return self._s[2475]! } - public var Preview_DeleteGif: String { return self._s[2476]! } - public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[2477]! } - public var Weekday_Saturday: String { return self._s[2478]! } - public var UserInfo_DeleteContact: String { return self._s[2479]! } - public var Notifications_ResetAllNotifications: String { return self._s[2480]! } - public var SocksProxySetup_SaveProxy: String { return self._s[2481]! } - public var Passport_Identity_Country: String { return self._s[2482]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[2483]! } - public var Login_ContinueWithLocalization: String { return self._s[2484]! } - public var GroupInfo_AddParticipant: String { return self._s[2485]! } - public var Watch_Location_Current: String { return self._s[2486]! } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2487]! } + public var Passport_Address_Street: String { return self._s[2464]! } + public var Weekday_Thursday: String { return self._s[2465]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2466]! } + public var PrivacySettings_DataSettings: String { return self._s[2467]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[2468]! } + public var NotificationsSound_Bell: String { return self._s[2469]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[2471]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2473]! } + public var DialogList_SearchSectionMessages: String { return self._s[2474]! } + public var Media_ShareThisVideo: String { return self._s[2475]! } + public var Call_ReportIncludeLogDescription: String { return self._s[2476]! } + public var Preview_DeleteGif: String { return self._s[2477]! } + public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[2478]! } + public var Weekday_Saturday: String { return self._s[2479]! } + public var UserInfo_DeleteContact: String { return self._s[2480]! } + public var Notifications_ResetAllNotifications: String { return self._s[2481]! } + public var SocksProxySetup_SaveProxy: String { return self._s[2482]! } + public var Passport_Identity_Country: String { return self._s[2483]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[2484]! } + public var Login_ContinueWithLocalization: String { return self._s[2485]! } + public var GroupInfo_AddParticipant: String { return self._s[2486]! } + public var Watch_Location_Current: String { return self._s[2487]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2488]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2490]!, self._r[2490]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_1, _2, _3, _4]) } - public var MediaPicker_CameraRoll: String { return self._s[2491]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[2492]! } - public var KeyCommand_NewMessage: String { return self._s[2493]! } + public var MediaPicker_CameraRoll: String { return self._s[2492]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[2493]! } + public var KeyCommand_NewMessage: String { return self._s[2494]! } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2495]!, self._r[2495]!, [_0]) + return formatWithArgumentRanges(self._s[2496]!, self._r[2496]!, [_0]) } - public var NetworkUsageSettings_TotalSection: String { return self._s[2496]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[2497]! } public func PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2497]!, self._r[2497]!, [_1]) + return formatWithArgumentRanges(self._s[2498]!, self._r[2498]!, [_1]) } - public var Privacy_GroupsAndChannels: String { return self._s[2498]! } + public var Privacy_GroupsAndChannels: String { return self._s[2499]! } public func Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2500]!, self._r[2500]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2501]!, self._r[2501]!, [_1, _2, _3]) } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[2503]! } - public var Passport_Address_ScansHelp: String { return self._s[2504]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[2504]! } + public var Passport_Address_ScansHelp: String { return self._s[2505]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2505]!, self._r[2505]!, [_0]) + return formatWithArgumentRanges(self._s[2506]!, self._r[2506]!, [_0]) } - public var TwoStepAuth_RemovePassword: String { return self._s[2507]! } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2509]! } - public var Passport_Identity_Gender: String { return self._s[2510]! } - public var UserInfo_NotificationsDisable: String { return self._s[2511]! } - public var Watch_UserInfo_Service: String { return self._s[2512]! } - public var Privacy_Calls_CustomHelp: String { return self._s[2514]! } - public var ChangePhoneNumberCode_Code: String { return self._s[2515]! } - public var UserInfo_Invite: String { return self._s[2516]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[2517]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[2519]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[2521]! } - public var Month_GenNovember: String { return self._s[2522]! } - public var UserInfo_NotificationsEnable: String { return self._s[2523]! } + public var TwoStepAuth_RemovePassword: String { return self._s[2508]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2510]! } + public var Passport_Identity_Gender: String { return self._s[2511]! } + public var UserInfo_NotificationsDisable: String { return self._s[2512]! } + public var Watch_UserInfo_Service: String { return self._s[2513]! } + public var Privacy_Calls_CustomHelp: String { return self._s[2515]! } + public var ChangePhoneNumberCode_Code: String { return self._s[2516]! } + public var UserInfo_Invite: String { return self._s[2517]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[2518]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[2520]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[2522]! } + public var Month_GenNovember: String { return self._s[2523]! } + public var UserInfo_NotificationsEnable: String { return self._s[2524]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2525]!, self._r[2525]!, [_0]) + return formatWithArgumentRanges(self._s[2526]!, self._r[2526]!, [_0]) } - public var Map_Map: String { return self._s[2526]! } - public var Map_OpenInMaps: String { return self._s[2527]! } - public var Common_OK: String { return self._s[2528]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[2529]! } - public var GroupInfo_LeftStatus: String { return self._s[2530]! } - public var Cache_ClearProgress: String { return self._s[2531]! } - public var Login_InvalidPhoneError: String { return self._s[2532]! } - public var Passport_Authorize: String { return self._s[2533]! } - public var Cache_ClearEmpty: String { return self._s[2534]! } - public var Map_Search: String { return self._s[2535]! } - public var Passport_Identity_Translations: String { return self._s[2536]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2538]! } + public var Map_Map: String { return self._s[2527]! } + public var ChatList_ReadAll: String { return self._s[2528]! } + public var Map_OpenInMaps: String { return self._s[2529]! } + public var Common_OK: String { return self._s[2530]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[2531]! } + public var GroupInfo_LeftStatus: String { return self._s[2532]! } + public var Cache_ClearProgress: String { return self._s[2533]! } + public var Login_InvalidPhoneError: String { return self._s[2534]! } + public var Passport_Authorize: String { return self._s[2535]! } + public var Cache_ClearEmpty: String { return self._s[2536]! } + public var Map_Search: String { return self._s[2537]! } + public var Passport_Identity_Translations: String { return self._s[2538]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2540]! } public func Channel_AdminLog_MessageRemovedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2539]!, self._r[2539]!, [_0]) + return formatWithArgumentRanges(self._s[2541]!, self._r[2541]!, [_0]) } public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2540]!, self._r[2540]!, [_1]) + return formatWithArgumentRanges(self._s[2542]!, self._r[2542]!, [_1]) } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[2541]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[2543]! } - public var SocksProxySetup_Password: String { return self._s[2545]! } - public var Login_SelectCountry_Title: String { return self._s[2546]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[2543]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[2545]! } + public var SocksProxySetup_Password: String { return self._s[2547]! } + public var Login_SelectCountry_Title: String { return self._s[2548]! } public func MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2547]!, self._r[2547]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_1, _2]) } - public var Notifications_GroupNotificationsHelp: String { return self._s[2548]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2549]! } - public var Notification_CallOutgoing: String { return self._s[2550]! } - public var UserInfo_NotificationsDefault: String { return self._s[2551]! } - public var Weekday_ShortMonday: String { return self._s[2552]! } - public var Channel_Edit_AboutItem: String { return self._s[2553]! } - public var Checkout_Receipt_Title: String { return self._s[2554]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[2555]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2557]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[2550]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2551]! } + public var Notification_CallOutgoing: String { return self._s[2552]! } + public var UserInfo_NotificationsDefault: String { return self._s[2553]! } + public var Weekday_ShortMonday: String { return self._s[2554]! } + public var Channel_Edit_AboutItem: String { return self._s[2555]! } + public var Checkout_Receipt_Title: String { return self._s[2556]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[2557]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2559]! } public func MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2558]!, self._r[2558]!, [_1]) + return formatWithArgumentRanges(self._s[2560]!, self._r[2560]!, [_1]) } - public var Settings_CopyPhoneNumber: String { return self._s[2559]! } - public var ReportPeer_Report: String { return self._s[2560]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[2561]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[2562]! } - public var LoginPassword_FloodError: String { return self._s[2563]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2565]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2566]! } - public var Group_UpgradeNoticeText2: String { return self._s[2567]! } + public var Settings_CopyPhoneNumber: String { return self._s[2561]! } + public var ReportPeer_Report: String { return self._s[2562]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[2563]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[2564]! } + public var LoginPassword_FloodError: String { return self._s[2565]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2567]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2568]! } + public var Group_UpgradeNoticeText2: String { return self._s[2569]! } public func PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2568]!, self._r[2568]!, [_1]) + return formatWithArgumentRanges(self._s[2570]!, self._r[2570]!, [_1]) } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2569]!, self._r[2569]!, [_0]) + return formatWithArgumentRanges(self._s[2571]!, self._r[2571]!, [_0]) } - public var Conversation_ShareMyContactInfo: String { return self._s[2570]! } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2571]! } + public var Conversation_ShareMyContactInfo: String { return self._s[2572]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2573]! } public func CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2572]!, self._r[2572]!, [_1]) + return formatWithArgumentRanges(self._s[2574]!, self._r[2574]!, [_1]) } - public var Contacts_PhoneNumber: String { return self._s[2573]! } - public var Group_Info_AdminLog: String { return self._s[2574]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2575]! } - public var ChatSettings_AutoDownloadEnabled: String { return self._s[2576]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[2577]! } - public var AuthSessions_LoggedIn: String { return self._s[2578]! } - public var Month_GenAugust: String { return self._s[2579]! } - public var Notification_CallCanceled: String { return self._s[2580]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2581]! } - public var StickerPack_Send: String { return self._s[2582]! } - public var StickerSettings_MaskContextInfo: String { return self._s[2583]! } - public var Watch_Suggestion_HoldOn: String { return self._s[2584]! } + public var Contacts_PhoneNumber: String { return self._s[2575]! } + public var Group_Info_AdminLog: String { return self._s[2576]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2577]! } + public var ChatSettings_AutoDownloadEnabled: String { return self._s[2578]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[2579]! } + public var AuthSessions_LoggedIn: String { return self._s[2580]! } + public var Month_GenAugust: String { return self._s[2581]! } + public var Notification_CallCanceled: String { return self._s[2582]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2583]! } + public var StickerPack_Send: String { return self._s[2584]! } + public var StickerSettings_MaskContextInfo: String { return self._s[2585]! } + public var Watch_Suggestion_HoldOn: String { return self._s[2586]! } public func PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2585]!, self._r[2585]!, [_1]) + return formatWithArgumentRanges(self._s[2587]!, self._r[2587]!, [_1]) } - public var PasscodeSettings_EncryptData: String { return self._s[2586]! } - public var Common_NotNow: String { return self._s[2587]! } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2589]! } - public var PasscodeSettings_Title: String { return self._s[2590]! } - public var StickerPack_BuiltinPackName: String { return self._s[2591]! } - public var Appearance_AccentColor: String { return self._s[2593]! } - public var Watch_Suggestion_BRB: String { return self._s[2594]! } + public var PasscodeSettings_EncryptData: String { return self._s[2588]! } + public var Common_NotNow: String { return self._s[2589]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2591]! } + public var PasscodeSettings_Title: String { return self._s[2592]! } + public var StickerPack_BuiltinPackName: String { return self._s[2593]! } + public var Appearance_AccentColor: String { return self._s[2595]! } + public var Watch_Suggestion_BRB: String { return self._s[2596]! } public func CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2595]!, self._r[2595]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2597]!, self._r[2597]!, [_1, _2]) } - public var Notifications_MessageNotificationsAlert: String { return self._s[2596]! } - public var Username_InvalidCharacters: String { return self._s[2597]! } - public var GroupInfo_LabelAdmin: String { return self._s[2598]! } - public var GroupInfo_Sound: String { return self._s[2599]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[2600]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[2601]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[2602]! } - public var Wallpaper_PhotoLibrary: String { return self._s[2603]! } - public var Settings_About: String { return self._s[2604]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[2605]! } - public var ContactInfo_Job: String { return self._s[2606]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[2598]! } + public var Username_InvalidCharacters: String { return self._s[2599]! } + public var GroupInfo_LabelAdmin: String { return self._s[2600]! } + public var GroupInfo_Sound: String { return self._s[2601]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[2602]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[2603]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[2604]! } + public var Wallpaper_PhotoLibrary: String { return self._s[2605]! } + public var Settings_About: String { return self._s[2606]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[2607]! } + public var ContactInfo_Job: String { return self._s[2608]! } public func CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2607]!, self._r[2607]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2609]!, self._r[2609]!, [_1, _2]) } - public var LoginPassword_ForgotPassword: String { return self._s[2608]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[2610]! } + public var LoginPassword_ForgotPassword: String { return self._s[2610]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[2612]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2611]!, self._r[2611]!, [_0]) - } - public var Appearance_Preview: String { return self._s[2612]! } - public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2613]!, self._r[2613]!, [_0]) } - public var Passport_Identity_TypePassport: String { return self._s[2614]! } - public var ChatSettings_Appearance: String { return self._s[2615]! } - public var Tour_Title1: String { return self._s[2616]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[2618]! } - public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2619]!, self._r[2619]!, [_0]) + public var Appearance_Preview: String { return self._s[2614]! } + public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2615]!, self._r[2615]!, [_0]) } - public var Conversation_LinkDialogCopy: String { return self._s[2620]! } - public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Passport_Identity_TypePassport: String { return self._s[2616]! } + public var ChatSettings_Appearance: String { return self._s[2617]! } + public var Tour_Title1: String { return self._s[2618]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[2620]! } + public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2621]!, self._r[2621]!, [_0]) } + public var Conversation_LinkDialogCopy: String { return self._s[2622]! } + public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2623]!, self._r[2623]!, [_0]) + } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2622]!, self._r[2622]!, [_0]) + return formatWithArgumentRanges(self._s[2624]!, self._r[2624]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2623]!, self._r[2623]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2625]!, self._r[2625]!, [_0, _1]) } - public var Calls_All: String { return self._s[2624]! } + public var Calls_All: String { return self._s[2626]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2625]!, self._r[2625]!, [_0]) + return formatWithArgumentRanges(self._s[2627]!, self._r[2627]!, [_0]) } - public var Call_CallAgain: String { return self._s[2626]! } - public var Message_VideoExpired: String { return self._s[2627]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2628]! } + public var Call_CallAgain: String { return self._s[2628]! } + public var Message_VideoExpired: String { return self._s[2629]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2630]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2629]!, self._r[2629]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2631]!, self._r[2631]!, [_1, _2]) } - public var UserInfo_SendMessage: String { return self._s[2630]! } + public var UserInfo_SendMessage: String { return self._s[2632]! } public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2631]!, self._r[2631]!, [_0]) + return formatWithArgumentRanges(self._s[2633]!, self._r[2633]!, [_0]) } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_0]) + return formatWithArgumentRanges(self._s[2634]!, self._r[2634]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[2633]! } - public var Paint_RecentStickers: String { return self._s[2634]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[2635]! } + public var Settings_ViewPhoto: String { return self._s[2635]! } + public var Paint_RecentStickers: String { return self._s[2636]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[2637]! } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2636]!, self._r[2636]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2638]!, self._r[2638]!, [_1, _2]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[2637]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[2638]! } - public var Login_CallRequestState3: String { return self._s[2639]! } - public var Channel_Edit_LinkItem: String { return self._s[2640]! } - public var CallSettings_Title: String { return self._s[2642]! } - public var ChangePhoneNumberNumber_Help: String { return self._s[2643]! } - public var Passport_InfoTitle: String { return self._s[2644]! } - public var Watch_Suggestion_Thanks: String { return self._s[2645]! } - public var Channel_Moderator_Title: String { return self._s[2646]! } - public var Message_PinnedPhotoMessage: String { return self._s[2647]! } - public var Notification_SecretChatScreenshot: String { return self._s[2648]! } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[2639]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[2640]! } + public var Login_CallRequestState3: String { return self._s[2641]! } + public var Channel_Edit_LinkItem: String { return self._s[2642]! } + public var CallSettings_Title: String { return self._s[2644]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[2645]! } + public var Passport_InfoTitle: String { return self._s[2646]! } + public var Watch_Suggestion_Thanks: String { return self._s[2647]! } + public var Channel_Moderator_Title: String { return self._s[2648]! } + public var Message_PinnedPhotoMessage: String { return self._s[2649]! } + public var Notification_SecretChatScreenshot: String { return self._s[2650]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2649]!, self._r[2649]!, [_0]) + return formatWithArgumentRanges(self._s[2651]!, self._r[2651]!, [_0]) } - public var Activity_UploadingDocument: String { return self._s[2650]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2651]! } - public var ReportPeer_AlertSuccess: String { return self._s[2652]! } - public var Tour_Text4: String { return self._s[2653]! } - public var Channel_Info_Description: String { return self._s[2654]! } - public var AccessDenied_LocationTracking: String { return self._s[2656]! } - public var Watch_Compose_Send: String { return self._s[2657]! } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[2658]! } - public var Preview_CopyAddress: String { return self._s[2659]! } - public var Settings_BlockedUsers: String { return self._s[2660]! } - public var Month_ShortAugust: String { return self._s[2661]! } - public var Passport_Identity_MainPage: String { return self._s[2662]! } - public var Passport_FieldAddress: String { return self._s[2664]! } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[2665]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2666]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[2667]! } - public var DialogList_EncryptionRejected: String { return self._s[2668]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2670]! } - public var AccessDenied_CameraRestricted: String { return self._s[2671]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2672]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[2674]! } - public var Channel_AboutItem: String { return self._s[2675]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2676]! } - public var Month_GenJuly: String { return self._s[2677]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[2678]! } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2679]! } + public var Activity_UploadingDocument: String { return self._s[2652]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2653]! } + public var ReportPeer_AlertSuccess: String { return self._s[2654]! } + public var Tour_Text4: String { return self._s[2655]! } + public var Channel_Info_Description: String { return self._s[2656]! } + public var AccessDenied_LocationTracking: String { return self._s[2658]! } + public var Watch_Compose_Send: String { return self._s[2659]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[2660]! } + public var Preview_CopyAddress: String { return self._s[2661]! } + public var Settings_BlockedUsers: String { return self._s[2662]! } + public var Month_ShortAugust: String { return self._s[2663]! } + public var Passport_Identity_MainPage: String { return self._s[2664]! } + public var Passport_FieldAddress: String { return self._s[2666]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[2667]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2668]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[2669]! } + public var DialogList_EncryptionRejected: String { return self._s[2670]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2672]! } + public var AccessDenied_CameraRestricted: String { return self._s[2673]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2674]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[2676]! } + public var Channel_AboutItem: String { return self._s[2677]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2678]! } + public var Month_GenJuly: String { return self._s[2679]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[2680]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2681]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2681]!, self._r[2681]!, [_0]) + return formatWithArgumentRanges(self._s[2683]!, self._r[2683]!, [_0]) } - public var ChannelIntro_CreateChannel: String { return self._s[2683]! } - public var Channel_Management_AddModerator: String { return self._s[2684]! } - public var Common_ChoosePhoto: String { return self._s[2685]! } - public var Conversation_Pin: String { return self._s[2686]! } + public var ChannelIntro_CreateChannel: String { return self._s[2685]! } + public var Channel_Management_AddModerator: String { return self._s[2686]! } + public var Common_ChoosePhoto: String { return self._s[2687]! } + public var Conversation_Pin: String { return self._s[2688]! } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2688]!, self._r[2688]!, [_0]) + return formatWithArgumentRanges(self._s[2690]!, self._r[2690]!, [_0]) } public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2689]!, self._r[2689]!, [_0]) + return formatWithArgumentRanges(self._s[2691]!, self._r[2691]!, [_0]) } - public var Camera_TapAndHoldForVideo: String { return self._s[2690]! } - public var Notification_Exceptions_AlwaysOn: String { return self._s[2691]! } - public var Bot_DescriptionTitle: String { return self._s[2692]! } - public var FeaturedStickerPacks_Title: String { return self._s[2693]! } - public var Map_OpenInGoogleMaps: String { return self._s[2695]! } - public var Notification_MessageLifetime5s: String { return self._s[2696]! } - public var Contacts_Title: String { return self._s[2699]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2700]! } + public var Camera_TapAndHoldForVideo: String { return self._s[2692]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[2693]! } + public var Bot_DescriptionTitle: String { return self._s[2694]! } + public var FeaturedStickerPacks_Title: String { return self._s[2695]! } + public var Map_OpenInGoogleMaps: String { return self._s[2697]! } + public var Notification_MessageLifetime5s: String { return self._s[2698]! } + public var Contacts_Title: String { return self._s[2701]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2702]! } public func MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2701]!, self._r[2701]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2703]!, self._r[2703]!, [_1, _2]) } - public var Channel_Management_AddModeratorHelp: String { return self._s[2704]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[2706]! } public func CHAT_MESSAGE_FWDS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_1, _2, _3]) } - public var Conversation_MessageDialogEdit: String { return self._s[2706]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[2707]! } - public var Notifications_ClassicTones: String { return self._s[2709]! } - public var Conversation_LinkDialogOpen: String { return self._s[2710]! } - public var Channel_Info_Subscribers: String { return self._s[2711]! } - public var NotificationsSound_Input: String { return self._s[2712]! } - public var Conversation_ClousStorageInfo_Description4: String { return self._s[2713]! } - public var Privacy_Calls_AlwaysAllow: String { return self._s[2714]! } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2716]! } - public var Notification_MessageLifetime1h: String { return self._s[2717]! } + public var Conversation_MessageDialogEdit: String { return self._s[2708]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[2709]! } + public var Notifications_ClassicTones: String { return self._s[2711]! } + public var Conversation_LinkDialogOpen: String { return self._s[2712]! } + public var Channel_Info_Subscribers: String { return self._s[2713]! } + public var NotificationsSound_Input: String { return self._s[2714]! } + public var Conversation_ClousStorageInfo_Description4: String { return self._s[2715]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[2716]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2718]! } + public var Notification_MessageLifetime1h: String { return self._s[2719]! } public func Notification_CreatedChatWithTitle(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2718]!, self._r[2718]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2720]!, self._r[2720]!, [_0, _1]) } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[2719]! } - public var LastSeen_Lately: String { return self._s[2720]! } - public var Month_ShortApril: String { return self._s[2721]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2722]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[2721]! } + public var LastSeen_Lately: String { return self._s[2722]! } + public var Month_ShortApril: String { return self._s[2723]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2724]! } public func PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2723]!, self._r[2723]!, [_1]) + return formatWithArgumentRanges(self._s[2725]!, self._r[2725]!, [_1]) } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2724]!, self._r[2724]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2726]!, self._r[2726]!, ["\(_0)"]) } - public var Group_ErrorAddBlocked: String { return self._s[2725]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[2727]! } - public var MediaPicker_Videos: String { return self._s[2728]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[2729]! } - public var BlockedUsers_AddNew: String { return self._s[2730]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[2731]! } - public var Channel_NotificationLoading: String { return self._s[2732]! } - public var Passport_Language_da: String { return self._s[2734]! } - public var Passport_Address_Country: String { return self._s[2735]! } + public var Group_ErrorAddBlocked: String { return self._s[2727]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[2729]! } + public var MediaPicker_Videos: String { return self._s[2730]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[2731]! } + public var BlockedUsers_AddNew: String { return self._s[2732]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[2733]! } + public var Channel_NotificationLoading: String { return self._s[2734]! } + public var Passport_Language_da: String { return self._s[2736]! } + public var Passport_Address_Country: String { return self._s[2737]! } public func CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2736]!, self._r[2736]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2738]!, self._r[2738]!, [_1, _2]) } - public var PhotoEditor_ShadowsTint: String { return self._s[2738]! } - public var ExplicitContent_AlertTitle: String { return self._s[2740]! } - public var Channel_AdminLogFilter_EventsLeaving: String { return self._s[2741]! } - public var Map_LiveLocationFor8Hours: String { return self._s[2742]! } - public var StickerPack_HideStickers: String { return self._s[2743]! } - public var Checkout_EnterPassword: String { return self._s[2744]! } - public var UserInfo_NotificationsEnabled: String { return self._s[2745]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2746]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2747]! } - public var Appearance_ReduceMotionInfo: String { return self._s[2748]! } - public var Weekday_ShortTuesday: String { return self._s[2749]! } - public var Notification_CallIncomingShort: String { return self._s[2750]! } - public var ConvertToSupergroup_Note: String { return self._s[2751]! } - public var Login_SendCodeViaSms: String { return self._s[2752]! } - public var DialogList_Read: String { return self._s[2753]! } - public var Conversation_EmptyPlaceholder: String { return self._s[2754]! } + public var PhotoEditor_ShadowsTint: String { return self._s[2740]! } + public var ExplicitContent_AlertTitle: String { return self._s[2742]! } + public var Channel_AdminLogFilter_EventsLeaving: String { return self._s[2743]! } + public var Map_LiveLocationFor8Hours: String { return self._s[2744]! } + public var StickerPack_HideStickers: String { return self._s[2745]! } + public var Checkout_EnterPassword: String { return self._s[2746]! } + public var UserInfo_NotificationsEnabled: String { return self._s[2747]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2748]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2749]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2750]! } + public var Weekday_ShortTuesday: String { return self._s[2751]! } + public var Notification_CallIncomingShort: String { return self._s[2752]! } + public var ConvertToSupergroup_Note: String { return self._s[2753]! } + public var Login_SendCodeViaSms: String { return self._s[2754]! } + public var DialogList_Read: String { return self._s[2755]! } + public var Conversation_EmptyPlaceholder: String { return self._s[2756]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2755]!, self._r[2755]!, [_0]) + return formatWithArgumentRanges(self._s[2757]!, self._r[2757]!, [_0]) } - public var Username_Help: String { return self._s[2756]! } - public var StickerSettings_ContextHide: String { return self._s[2757]! } - public var Media_ShareThisPhoto: String { return self._s[2760]! } - public var Contacts_ShareTelegram: String { return self._s[2761]! } - public var AutoNightTheme_Scheduled: String { return self._s[2762]! } - public var Weekday_Sunday: String { return self._s[2763]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2765]! } - public var Settings_ChatBackground: String { return self._s[2766]! } - public var Login_TermsOfServiceDecline: String { return self._s[2768]! } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public var Username_Help: String { return self._s[2758]! } + public var StickerSettings_ContextHide: String { return self._s[2759]! } + public var Media_ShareThisPhoto: String { return self._s[2762]! } + public var Contacts_ShareTelegram: String { return self._s[2763]! } + public var AutoNightTheme_Scheduled: String { return self._s[2764]! } + public var Weekday_Sunday: String { return self._s[2765]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2767]! } + public var Settings_ChatBackground: String { return self._s[2768]! } + public var Login_TermsOfServiceDecline: String { return self._s[2770]! } + public func Media_ShareItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedStickers(_ value: Int32) -> String { + public func ForwardedPhotos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Days(_ value: Int32) -> String { + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Hours(_ value: Int32) -> String { + public func Call_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, "\(value)") } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public func Media_ShareVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func SharedMedia_Link(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_File(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Passport_Scans(_ value: Int32) -> String { + public func Call_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortMinutes(_ value: Int32) -> String { + public func StickerPack_StickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_SharePhoto(_ value: Int32) -> String { + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_Minutes(_ value: Int32) -> String { + public func ForwardedVideoMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedPhotos(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, "\(value)") } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, "\(value)") } - public func QuickSend_Photos(_ value: Int32) -> String { + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + public func ForwardedGifs(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Months(_ value: Int32) -> String { + public func UserCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedGifs(_ value: Int32) -> String { + public func Contacts_ImportersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + public func ForwardedMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareVideo(_ value: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Days(_ value: Int32) -> String { + public func MuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedMessages(_ value: Int32) -> String { + public func StickerPack_AddStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, "\(value)") } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + public func ForwardedStickers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_Seconds(_ value: Int32) -> String { + public func MessageTimer_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + public func Notification_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_StickerCount(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, "\(value)") } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func ForwardedLocations(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Minutes(_ value: Int32) -> String { + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Days(_ value: Int32) -> String { + public func SharedMedia_File(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Link(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedContacts(_ value: Int32) -> String { + public func Media_SharePhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareItem(_ value: Int32) -> String { + public func Map_ETAMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { + public func ForwardedVideos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideos(_ value: Int32) -> String { + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func ForwardedAudios(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSimple(_ value: Int32) -> String { + public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + public func Conversation_StatusMembers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Years(_ value: Int32) -> String { + public func MessageTimer_ShortDays(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Hours(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAMinutes(_ value: Int32) -> String { + public func ForwardedAuthorsOthers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAudios(_ value: Int32) -> String { + public func Notifications_Exceptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedFiles(_ value: Int32) -> String { + public func SharedMedia_Generic(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Video(_ value: Int32) -> String { + public func Invitation_Members(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { + public func InviteText_ContactsCountText(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusMembers(_ value: Int32) -> String { + public func MuteFor_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAHours(_ value: Int32) -> String { + public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + public func ForwardedFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Hours(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, "\(value)") } - public func UserCount(_ value: Int32) -> String { + public func MuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortHours(_ value: Int32) -> String { + public func Map_ETAHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAuthorsOthers(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LastSeen_HoursAgo(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, "\(value)") } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + public func MessageTimer_Weeks(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Invitation_Members(_ value: Int32) -> String { + public func Passport_Scans(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreExtended(_ value: Int32) -> String { + public func QuickSend_Photos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedLocations(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_Exceptions(_ value: Int32) -> String { + public func MessageTimer_ShortHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, "\(value)") } diff --git a/TelegramUI/PresentationTheme.swift b/TelegramUI/PresentationTheme.swift index cd69d07289..8deb98bc08 100644 --- a/TelegramUI/PresentationTheme.swift +++ b/TelegramUI/PresentationTheme.swift @@ -333,6 +333,7 @@ public final class PresentationThemeChatList { public let itemBackgroundColor: UIColor public let pinnedItemBackgroundColor: UIColor public let itemHighlightedBackgroundColor: UIColor + public let itemSelectedBackgroundColor: UIColor public let titleColor: UIColor public let secretTitleColor: UIColor public let dateTextColor: UIColor @@ -356,12 +357,13 @@ public final class PresentationThemeChatList { public let verifiedIconForegroundColor: UIColor public let secretIconColor: UIColor - init(backgroundColor: UIColor, itemSeparatorColor: UIColor, itemBackgroundColor: UIColor, pinnedItemBackgroundColor: UIColor, itemHighlightedBackgroundColor: UIColor, titleColor: UIColor, secretTitleColor: UIColor, dateTextColor: UIColor, authorNameColor: UIColor, messageTextColor: UIColor, messageDraftTextColor: UIColor, checkmarkColor: UIColor, pendingIndicatorColor: UIColor, muteIconColor: UIColor, unreadBadgeActiveBackgroundColor: UIColor, unreadBadgeActiveTextColor: UIColor, unreadBadgeInactiveBackgroundColor: UIColor, unreadBadgeInactiveTextColor: UIColor, pinnedBadgeColor: UIColor, pinnedSearchBarColor: UIColor, regularSearchBarColor: UIColor, sectionHeaderFillColor: UIColor, sectionHeaderTextColor: UIColor, searchBarKeyboardColor: PresentationThemeKeyboardColor, verifiedIconFillColor: UIColor, verifiedIconForegroundColor: UIColor, secretIconColor: UIColor) { + init(backgroundColor: UIColor, itemSeparatorColor: UIColor, itemBackgroundColor: UIColor, pinnedItemBackgroundColor: UIColor, itemHighlightedBackgroundColor: UIColor, itemSelectedBackgroundColor: UIColor, titleColor: UIColor, secretTitleColor: UIColor, dateTextColor: UIColor, authorNameColor: UIColor, messageTextColor: UIColor, messageDraftTextColor: UIColor, checkmarkColor: UIColor, pendingIndicatorColor: UIColor, muteIconColor: UIColor, unreadBadgeActiveBackgroundColor: UIColor, unreadBadgeActiveTextColor: UIColor, unreadBadgeInactiveBackgroundColor: UIColor, unreadBadgeInactiveTextColor: UIColor, pinnedBadgeColor: UIColor, pinnedSearchBarColor: UIColor, regularSearchBarColor: UIColor, sectionHeaderFillColor: UIColor, sectionHeaderTextColor: UIColor, searchBarKeyboardColor: PresentationThemeKeyboardColor, verifiedIconFillColor: UIColor, verifiedIconForegroundColor: UIColor, secretIconColor: UIColor) { self.backgroundColor = backgroundColor self.itemSeparatorColor = itemSeparatorColor self.itemBackgroundColor = itemBackgroundColor self.pinnedItemBackgroundColor = pinnedItemBackgroundColor self.itemHighlightedBackgroundColor = itemHighlightedBackgroundColor + self.itemSelectedBackgroundColor = itemSelectedBackgroundColor self.titleColor = titleColor self.secretTitleColor = secretTitleColor self.dateTextColor = dateTextColor diff --git a/TelegramUI/Resources/PresentationStrings.mapping b/TelegramUI/Resources/PresentationStrings.mapping index a004905a1d..e8ea4ecaa3 100644 Binary files a/TelegramUI/Resources/PresentationStrings.mapping and b/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/TelegramUI/StickerPackPreviewController.swift b/TelegramUI/StickerPackPreviewController.swift index e61d61668a..e301bd862c 100644 --- a/TelegramUI/StickerPackPreviewController.swift +++ b/TelegramUI/StickerPackPreviewController.swift @@ -56,7 +56,7 @@ final class StickerPackPreviewController: ViewController { self.statusBar.statusBarStyle = .Ignore - self.stickerPackContents.set(loadedStickerPack(postbox: account.postbox, network: account.network, reference: stickerPack)) + self.stickerPackContents.set(loadedStickerPack(postbox: account.postbox, network: account.network, reference: stickerPack, forceActualized: true)) } required init(coder aDecoder: NSCoder) { diff --git a/TelegramUI/StickerPackPreviewControllerNode.swift b/TelegramUI/StickerPackPreviewControllerNode.swift index 355c6f88f6..f5681788f2 100644 --- a/TelegramUI/StickerPackPreviewControllerNode.swift +++ b/TelegramUI/StickerPackPreviewControllerNode.swift @@ -5,6 +5,37 @@ import SwiftSignalKit import Postbox import TelegramCore +private struct StickerPackPreviewGridEntry: Comparable, Identifiable { + let index: Int + let stickerItem: StickerPackItem + + var stableId: MediaId { + return self.stickerItem.file.fileId + } + + static func <(lhs: StickerPackPreviewGridEntry, rhs: StickerPackPreviewGridEntry) -> Bool { + return lhs.index < rhs.index + } + + func item(account: Account, interaction: StickerPackPreviewInteraction) -> StickerPackPreviewGridItem { + return StickerPackPreviewGridItem(account: account, stickerItem: self.stickerItem, interaction: interaction) + } +} + +private struct StickerPackPreviewGridTransaction { + let deletions: [Int] + let insertions: [GridNodeInsertItem] + let updates: [GridNodeUpdateItem] + + init(previousList: [StickerPackPreviewGridEntry], list: [StickerPackPreviewGridEntry], account: Account, interaction: StickerPackPreviewInteraction) { + let (deleteIndices, indicesAndItems, updateIndices) = mergeListsStableWithUpdates(leftList: previousList, rightList: list) + + self.deletions = deleteIndices + self.insertions = indicesAndItems.map { GridNodeInsertItem(index: $0.0, item: $0.1.item(account: account, interaction: interaction), previousIndex: $0.2) } + self.updates = updateIndices.map { GridNodeUpdateItem(index: $0.0, previousIndex: $0.2, item: $0.1.item(account: account, interaction: interaction)) } + } +} + final class StickerPackPreviewControllerNode: ViewControllerTracingNode, UIScrollViewDelegate { private let account: Account private let openShare: () -> Void @@ -42,7 +73,7 @@ final class StickerPackPreviewControllerNode: ViewControllerTracingNode, UIScrol private var stickerPackUpdated = false private var stickerPackInitiallyInstalled : Bool? - private var didSetItems = false + private var currentItems: [StickerPackPreviewGridEntry] = [] private var hapticFeedback: HapticFeedback? @@ -267,7 +298,7 @@ final class StickerPackPreviewControllerNode: ViewControllerTracingNode, UIScrol let contentContainerFrame = CGRect(origin: CGPoint(x: sideInset, y: insets.top), size: CGSize(width: width, height: maximumContentHeight)) let contentFrame = contentContainerFrame.insetBy(dx: 12.0, dy: 0.0) - var insertItems: [GridNodeInsertItem] = [] + var transaction: StickerPackPreviewGridTransaction? var itemCount = 0 var animateIn = false @@ -286,16 +317,21 @@ final class StickerPackPreviewControllerNode: ViewControllerTracingNode, UIScrol self.activityIndicator = nil } itemCount = items.count - if !self.didSetItems { - let entities = generateTextEntities(info.title, enabledTypes: [.mention]) - self.contentTitleNode.attributedText = stringWithAppliedEntities(info.title, entities: entities, baseColor: self.presentationData.theme.actionSheet.primaryTextColor, linkColor: self.presentationData.theme.actionSheet.controlAccentColor, baseFont: Font.medium(20.0), linkFont: Font.medium(20.0), boldFont: Font.medium(20.0), italicFont: Font.medium(20.0), fixedFont: Font.medium(20.0)) - - self.didSetItems = true - animateIn = true - for i in 0 ..< items.count { - insertItems.append(GridNodeInsertItem(index: i, item: StickerPackPreviewGridItem(account: self.account, stickerItem: items[i] as! StickerPackItem, interaction: self.interaction), previousIndex: nil)) + + var updatedItems: [StickerPackPreviewGridEntry] = [] + for item in items { + if let item = item as? StickerPackItem { + updatedItems.append(StickerPackPreviewGridEntry(index: updatedItems.count, stickerItem: item)) } } + + if self.currentItems.isEmpty && !updatedItems.isEmpty { + let entities = generateTextEntities(info.title, enabledTypes: [.mention]) + self.contentTitleNode.attributedText = stringWithAppliedEntities(info.title, entities: entities, baseColor: self.presentationData.theme.actionSheet.primaryTextColor, linkColor: self.presentationData.theme.actionSheet.controlAccentColor, baseFont: Font.medium(20.0), linkFont: Font.medium(20.0), boldFont: Font.medium(20.0), italicFont: Font.medium(20.0), fixedFont: Font.medium(20.0)) + animateIn = true + } + transaction = StickerPackPreviewGridTransaction(previousList: self.currentItems, list: updatedItems, account: self.account, interaction: self.interaction) + self.currentItems = updatedItems } } @@ -335,7 +371,7 @@ final class StickerPackPreviewControllerNode: ViewControllerTracingNode, UIScrol let gridSize = CGSize(width: contentFrame.size.width, height: max(32.0, contentFrame.size.height - titleAreaHeight)) - self.contentGridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: insertItems, updateItems: [], scrollToItem: nil, updateLayout: GridNodeUpdateLayout(layout: GridNodeLayout(size: gridSize, insets: UIEdgeInsets(top: topInset, left: 0.0, bottom: bottomGridInset, right: 0.0), preloadSize: 80.0, type: .fixed(itemSize: CGSize(width: itemWidth, height: itemWidth), lineSpacing: 0.0)), transition: transition), itemTransition: .immediate, stationaryItems: .none, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + self.contentGridNode.transaction(GridNodeTransaction(deleteItems: transaction?.deletions ?? [], insertItems: transaction?.insertions ?? [], updateItems: transaction?.updates ?? [], scrollToItem: nil, updateLayout: GridNodeUpdateLayout(layout: GridNodeLayout(size: gridSize, insets: UIEdgeInsets(top: topInset, left: 0.0, bottom: bottomGridInset, right: 0.0), preloadSize: 80.0, type: .fixed(itemSize: CGSize(width: itemWidth, height: itemWidth), lineSpacing: 0.0)), transition: transition), itemTransition: .immediate, stationaryItems: .none, updateFirstIndexInSectionOffset: nil), completion: { _ in }) transition.updateFrame(node: self.contentGridNode, frame: CGRect(origin: CGPoint(x: floor((contentContainerFrame.size.width - contentFrame.size.width) / 2.0), y: titleAreaHeight), size: gridSize)) if animateIn { diff --git a/TelegramUI/StickerPaneSearchContainerNode.swift b/TelegramUI/StickerPaneSearchContainerNode.swift index a8e7bbde00..2f2d8cce58 100644 --- a/TelegramUI/StickerPaneSearchContainerNode.swift +++ b/TelegramUI/StickerPaneSearchContainerNode.swift @@ -217,7 +217,7 @@ final class StickerPaneSearchContainerNode: ASDisplayNode { } }, install: { [weak self] info in if let strongSelf = self { - let _ = (loadedStickerPack(postbox: strongSelf.account.postbox, network: strongSelf.account.network, reference: .id(id: info.id.id, accessHash: info.accessHash)) + let _ = (loadedStickerPack(postbox: strongSelf.account.postbox, network: strongSelf.account.network, reference: .id(id: info.id.id, accessHash: info.accessHash), forceActualized: false) |> mapToSignal { result -> Signal in switch result { case let .result(info, items, installed): diff --git a/TelegramUI/UrlHandling.swift b/TelegramUI/UrlHandling.swift index 0b9d5a7e40..c727736c6c 100644 --- a/TelegramUI/UrlHandling.swift +++ b/TelegramUI/UrlHandling.swift @@ -147,19 +147,32 @@ private func resolveInternalUrl(account: Account, url: ParsedInternalUrl) -> Sig case let .peerName(name, parameter): return resolvePeerByName(account: account, name: name) |> take(1) - |> map { peerId -> ResolvedUrl? in - if let peerId = peerId { + |> mapToSignal { peerId -> Signal in + return account.postbox.transaction { transaction -> Peer? in + if let peerId = peerId { + return transaction.getPeer(peerId) + } else { + return nil + } + } + } + |> map { peer -> ResolvedUrl? in + if let peer = peer { if let parameter = parameter { switch parameter { case let .botStart(payload): - return .botStart(peerId: peerId, payload: payload) + return .botStart(peerId: peer.id, payload: payload) case let .groupBotStart(payload): - return .groupBotStart(peerId: peerId, payload: payload) + return .groupBotStart(peerId: peer.id, payload: payload) case let .channelMessage(id): - return .channelMessage(peerId: peerId, messageId: MessageId(peerId: peerId, namespace: Namespaces.Message.Cloud, id: id)) + return .channelMessage(peerId: peer.id, messageId: MessageId(peerId: peer.id, namespace: Namespaces.Message.Cloud, id: id)) } } else { - return .peer(peerId, .chat(textInputState: nil, messageId: nil)) + if let peer = peer as? TelegramUser, peer.botInfo != nil { + return .peer(peer.id, .info) + } else { + return .peer(peer.id, .chat(textInputState: nil, messageId: nil)) + } } } else { return nil