diff --git a/TelegramUI.xcodeproj/project.pbxproj b/TelegramUI.xcodeproj/project.pbxproj index 0635d5f732..40a0afba25 100644 --- a/TelegramUI.xcodeproj/project.pbxproj +++ b/TelegramUI.xcodeproj/project.pbxproj @@ -69,7 +69,6 @@ 09874E592107BD4100E190B8 /* GenericEmbedImplementation.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09874E4021075C1700E190B8 /* GenericEmbedImplementation.swift */; }; 099529AA21CDB27900805E13 /* ShareProxyServerActionSheetController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529A921CDB27900805E13 /* ShareProxyServerActionSheetController.swift */; }; 099529AC21CDBBB200805E13 /* QRCode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529AB21CDBBB200805E13 /* QRCode.swift */; }; - 099529AE21D045C400805E13 /* ThemeGridActionNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529AD21D045C400805E13 /* ThemeGridActionNode.swift */; }; 099529B021D2123E00805E13 /* ChatMessageUnsupportedBubbleContentNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529AF21D2123E00805E13 /* ChatMessageUnsupportedBubbleContentNode.swift */; }; 099529B221D24F5800805E13 /* RadialDownloadContentNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529B121D24F5800805E13 /* RadialDownloadContentNode.swift */; }; 099529B421D3E5D800805E13 /* CheckDiskSpace.swift in Sources */ = {isa = PBXBuildFile; fileRef = 099529B321D3E5D800805E13 /* CheckDiskSpace.swift */; }; @@ -1178,7 +1177,6 @@ 09874E4421075C3F00E190B8 /* StreamableEmbedImplementation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StreamableEmbedImplementation.swift; sourceTree = ""; }; 099529A921CDB27900805E13 /* ShareProxyServerActionSheetController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ShareProxyServerActionSheetController.swift; sourceTree = ""; }; 099529AB21CDBBB200805E13 /* QRCode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = QRCode.swift; sourceTree = ""; }; - 099529AD21D045C400805E13 /* ThemeGridActionNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ThemeGridActionNode.swift; sourceTree = ""; }; 099529AF21D2123E00805E13 /* ChatMessageUnsupportedBubbleContentNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatMessageUnsupportedBubbleContentNode.swift; sourceTree = ""; }; 099529B121D24F5800805E13 /* RadialDownloadContentNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RadialDownloadContentNode.swift; sourceTree = ""; }; 099529B321D3E5D800805E13 /* CheckDiskSpace.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CheckDiskSpace.swift; sourceTree = ""; }; @@ -3081,16 +3079,15 @@ D05174AA1EAA5B4700A1BF36 /* ThemeGalleryToolbarNode.swift */, D0EC6B351EB88D0A00EBF1C3 /* ThemeGridController.swift */, D0EC6B371EB88D1600EBF1C3 /* ThemeGridControllerNode.swift */, - D091C7A51F8ECEA300D7DE13 /* SettingsThemeWallpaperNode.swift */, D0C0B5B61EE1DEF1000F4D2C /* ThemeGridControllerItem.swift */, D0B37C5B1F8D22AE004252DF /* ThemeSettingsController.swift */, D0B37C5D1F8D26A8004252DF /* ThemeSettingsChatPreviewItem.swift */, + D091C7A51F8ECEA300D7DE13 /* SettingsThemeWallpaperNode.swift */, D0B37C5F1F8D286E004252DF /* ThemeSettingsFontSizeItem.swift */, D06E4C322134A59700088087 /* ThemeAccentColorActionSheet.swift */, D06E4C342134AE3C00088087 /* ThemeAutoNightSettingsController.swift */, D06F31E3213597FF001A0F12 /* ThemeAutoNightTimeSelectionActionSheet.swift */, D06F31E52135A41C001A0F12 /* ThemeSettingsBrightnessItem.swift */, - 099529AD21D045C400805E13 /* ThemeGridActionNode.swift */, D005809F21DCF0A200CB7CD3 /* WallpaperListPreviewController.swift */, D00580A121DCF0B700CB7CD3 /* WallpaperListPreviewControllerNode.swift */, ); @@ -5464,7 +5461,6 @@ D0AD02E81FFFDE5F00C1DCFF /* ChatMessageLiveLocationTimerNode.swift in Sources */, D0EC6D7D1EB9F58800EBF1C3 /* ChatListSearchRecentPeersNode.swift in Sources */, D0EC6D7E1EB9F58800EBF1C3 /* ChatListSearchItemHeader.swift in Sources */, - 099529AE21D045C400805E13 /* ThemeGridActionNode.swift in Sources */, D0EC6D7F1EB9F58800EBF1C3 /* HashtagSearchController.swift in Sources */, D0EC6D801EB9F58800EBF1C3 /* HashtagSearchControllerNode.swift in Sources */, D0EC6D811EB9F58800EBF1C3 /* ChatController.swift in Sources */, diff --git a/TelegramUI/AuthorizationSequenceCountrySelectionController.swift b/TelegramUI/AuthorizationSequenceCountrySelectionController.swift index 21662f594e..54f03047d9 100644 --- a/TelegramUI/AuthorizationSequenceCountrySelectionController.swift +++ b/TelegramUI/AuthorizationSequenceCountrySelectionController.swift @@ -95,9 +95,9 @@ private final class AuthorizationSequenceCountrySelectionNavigationContentNode: self.cancel = cancel - self.searchBar = SearchBarNode(theme: theme.searchBar, strings: strings) + self.searchBar = SearchBarNode(theme: theme.searchBar, strings: strings, fieldStyle: .modern) let placeholderText = strings.Common_Search - let searchBarFont = Font.regular(14.0) + let searchBarFont = Font.regular(17.0) self.searchBar.placeholderString = NSAttributedString(string: placeholderText, font: searchBarFont, textColor: theme.searchBar.placeholder) @@ -119,14 +119,14 @@ private final class AuthorizationSequenceCountrySelectionNavigationContentNode: self.queryUpdated = f } - override func layout() { - super.layout() - - let size = self.bounds.size - - let searchBarFrame = CGRect(origin: CGPoint(), size: size) + override var nominalHeight: CGFloat { + return 54.0 + } + + override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { + let searchBarFrame = CGRect(origin: CGPoint(x: 0.0, y: size.height - self.nominalHeight), size: CGSize(width: size.width, height: 54.0)) self.searchBar.frame = searchBarFrame - self.searchBar.updateLayout(boundingSize: size, leftInset: 0.0, rightInset: 0.0, transition: .immediate) + self.searchBar.updateLayout(boundingSize: searchBarFrame.size, leftInset: leftInset, rightInset: rightInset, transition: transition) } func activate() { diff --git a/TelegramUI/ChatListController.swift b/TelegramUI/ChatListController.swift index abb235df54..c4e2230333 100644 --- a/TelegramUI/ChatListController.swift +++ b/TelegramUI/ChatListController.swift @@ -104,6 +104,9 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie if strongSelf.chatListDisplayNode.searchDisplayController != nil { strongSelf.deactivateSearch(animated: true) } else { + if let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateExpansionProgress(1.0, animated: true) + } strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.top) } //.auto for unread navigation @@ -115,6 +118,9 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie if strongSelf.chatListDisplayNode.searchDisplayController != nil { strongSelf.deactivateSearch(animated: true) } else { + if let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateExpansionProgress(1.0, animated: true) + } strongSelf.chatListDisplayNode.chatListNode.scrollToPosition(.auto) } } @@ -513,15 +519,8 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie } self.chatListDisplayNode.chatListNode.contentOffsetChanged = { [weak self] offset in - if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode, searchContentNode.nominalHeight > 0.0 { - var progress: CGFloat = 0.0 - switch offset { - case let .known(offset): - progress = max(0.0, (searchContentNode.nominalHeight - offset)) / searchContentNode.nominalHeight - default: - break - } - searchContentNode.updateExpansionProgress(progress) + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateListVisibleContentOffset(offset) } } @@ -696,7 +695,7 @@ public class ChatListController: TelegramController, KeyShortcutResponder, UIVie self.validLayout = layout - self.chatListDisplayNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.chatListDisplayNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } override public func navigationStackConfigurationUpdated(next: [ViewController]) { diff --git a/TelegramUI/ChatListControllerNode.swift b/TelegramUI/ChatListControllerNode.swift index df409c0e96..920c07e4a2 100644 --- a/TelegramUI/ChatListControllerNode.swift +++ b/TelegramUI/ChatListControllerNode.swift @@ -147,7 +147,7 @@ class ChatListControllerNode: ASDisplayNode { return } - self.searchDisplayController = SearchDisplayController(theme: self.themeAndStrings.0, strings: self.themeAndStrings.1, mode: .navigation, contentNode: ChatListSearchContainerNode(account: self.account, filter: [], groupId: self.groupId, openPeer: { [weak self] peer, dismissSearch in + self.searchDisplayController = SearchDisplayController(theme: self.themeAndStrings.0, strings: self.themeAndStrings.1, contentNode: ChatListSearchContainerNode(account: self.account, filter: [], groupId: self.groupId, openPeer: { [weak self] peer, dismissSearch in self?.requestOpenPeerFromSearch?(peer, dismissSearch) }, openRecentPeerOptions: { [weak self] peer in self?.requestOpenRecentPeerOptions?(peer) diff --git a/TelegramUI/ChatListSearchItem.swift b/TelegramUI/ChatListSearchItem.swift index 0c80907ca3..b48b31090e 100644 --- a/TelegramUI/ChatListSearchItem.swift +++ b/TelegramUI/ChatListSearchItem.swift @@ -5,7 +5,7 @@ import Postbox import Display import SwiftSignalKit -private let searchBarFont = Font.regular(14.0) +private let searchBarFont = Font.regular(17.0) class ChatListSearchItem: ListViewItem { let selectable: Bool = false @@ -82,7 +82,7 @@ class ChatListSearchItemNode: ListViewItemNode { } required init() { - self.searchBarNode = SearchBarPlaceholderNode() + self.searchBarNode = SearchBarPlaceholderNode(fieldStyle: .modern) super.init(layerBacked: false, dynamicBounce: false) @@ -109,10 +109,11 @@ class ChatListSearchItemNode: ListViewItemNode { let baseWidth = params.width - params.leftInset - params.rightInset let backgroundColor = nextIsPinned ? item.theme.chatList.pinnedItemBackgroundColor : item.theme.chatList.itemBackgroundColor + let placeholderColor = item.theme.rootController.activeNavigationSearchBar.inputPlaceholderTextColor - let searchBarApply = searchBarNodeLayout(NSAttributedString(string: placeholder ?? "", font: searchBarFont, textColor: UIColor(rgb: 0x8e8e93)), CGSize(width: baseWidth - 16.0, height: 28.0), 1.0, UIColor(rgb: 0x8e8e93), nextIsPinned ? item.theme.chatList.pinnedSearchBarColor : item.theme.chatList.regularSearchBarColor, backgroundColor, .immediate) + let searchBarApply = searchBarNodeLayout(NSAttributedString(string: placeholder ?? "", font: searchBarFont, textColor: placeholderColor), CGSize(width: baseWidth - 20.0, height: 36.0), 1.0, placeholderColor, nextIsPinned ? item.theme.chatList.pinnedSearchBarColor : item.theme.chatList.regularSearchBarColor, backgroundColor, .immediate) - let layout = ListViewItemNodeLayout(contentSize: CGSize(width: params.width, height: 44.0), insets: UIEdgeInsets()) + let layout = ListViewItemNodeLayout(contentSize: CGSize(width: params.width, height: 54.0), insets: UIEdgeInsets()) return (layout, { [weak self] animated in if let strongSelf = self { @@ -123,11 +124,11 @@ class ChatListSearchItemNode: ListViewItemNode { transition = .immediate } - let searchBarFrame = 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 + 10.0, y: 8.0), size: CGSize(width: baseWidth - 20.0, height: 36.0)) strongSelf.searchBarNode.frame = searchBarFrame searchBarApply() - strongSelf.searchBarNode.bounds = CGRect(origin: CGPoint(), size: CGSize(width: baseWidth - 16.0, height: 28.0)) + strongSelf.searchBarNode.bounds = CGRect(origin: CGPoint(), size: CGSize(width: baseWidth - 20.0, height: 36.0)) if !item.isEnabled { if strongSelf.disabledOverlay == nil { diff --git a/TelegramUI/ChatMessageInteractiveFileNode.swift b/TelegramUI/ChatMessageInteractiveFileNode.swift index e88f7f9231..3101722070 100644 --- a/TelegramUI/ChatMessageInteractiveFileNode.swift +++ b/TelegramUI/ChatMessageInteractiveFileNode.swift @@ -713,7 +713,7 @@ final class ChatMessageInteractiveFileNode: ASDisplayNode { case let .fetchStatus(fetchStatus): self.waveformScrubbingNode?.enableScrubbing = false switch fetchStatus { - case let .Fetching(isActive, progress): + case let .Fetching(_, progress): let adjustedProgress = max(progress, 0.027) state = .progress(color: statusForegroundColor, lineWidth: nil, value: CGFloat(adjustedProgress), cancelEnabled: true) case .Local: diff --git a/TelegramUI/ChatMessageStickerItemNode.swift b/TelegramUI/ChatMessageStickerItemNode.swift index 21d37d3896..a1c82b345c 100644 --- a/TelegramUI/ChatMessageStickerItemNode.swift +++ b/TelegramUI/ChatMessageStickerItemNode.swift @@ -200,12 +200,10 @@ class ChatMessageStickerItemNode: ChatMessageItemView { let displayLeftInset = params.leftInset + layoutConstants.bubble.edgeInset + avatarInset let innerImageInset: CGFloat = 10.0 - let imageInset: CGFloat = 2.0 let innerImageSize = CGSize(width: imageSize.width + innerImageInset * 2.0, height: imageSize.height + innerImageInset * 2.0) - let imageFrame = CGRect(origin: CGPoint(x: 0.0 + (incoming ? (params.leftInset + layoutConstants.bubble.edgeInset + avatarInset + layoutConstants.bubble.contentInsets.left) : (params.width - params.rightInset - innerImageSize.width - layoutConstants.bubble.edgeInset - layoutConstants.bubble.contentInsets.left)), y: -imageInset), size: innerImageSize) + let imageFrame = CGRect(origin: CGPoint(x: 0.0 + (incoming ? (params.leftInset + layoutConstants.bubble.edgeInset + avatarInset + layoutConstants.bubble.contentInsets.left) : (params.width - params.rightInset - innerImageSize.width - layoutConstants.bubble.edgeInset - layoutConstants.bubble.contentInsets.left)), y: -innerImageInset), size: innerImageSize) let arguments = TransformImageArguments(corners: ImageCorners(), imageSize: imageSize, boundingSize: imageSize, intrinsicInsets: UIEdgeInsets(top: innerImageInset, left: innerImageInset, bottom: innerImageInset, right: innerImageInset)) - imageSize.height += imageInset * 2.0 let imageApply = imageLayout(arguments) diff --git a/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift b/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift index 1f27918060..7bc22ed7c4 100644 --- a/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift +++ b/TelegramUI/ChatRecentActionsSearchNavigationContentNode.swift @@ -4,7 +4,7 @@ import Display import Postbox import TelegramCore -private let searchBarFont = Font.regular(14.0) +private let searchBarFont = Font.regular(17.0) final class ChatRecentActionsSearchNavigationContentNode: NavigationBarContentNode { private let theme: PresentationTheme @@ -22,7 +22,7 @@ final class ChatRecentActionsSearchNavigationContentNode: NavigationBarContentNo self.cancel = cancel - self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme), strings: strings) + self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme, hasSeparator: false), strings: strings, fieldStyle: .modern) let placeholderText = strings.Common_Search self.searchBar.placeholderString = NSAttributedString(string: placeholderText, font: searchBarFont, textColor: theme.rootController.activeNavigationSearchBar.inputPlaceholderTextColor) @@ -44,14 +44,14 @@ final class ChatRecentActionsSearchNavigationContentNode: NavigationBarContentNo self.queryUpdated = f } - override func layout() { - super.layout() - - let size = self.bounds.size - - let searchBarFrame = CGRect(origin: CGPoint(), size: size) + override var nominalHeight: CGFloat { + return 54.0 + } + + override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { + let searchBarFrame = CGRect(origin: CGPoint(x: 0.0, y: size.height - self.nominalHeight), size: CGSize(width: size.width, height: 54.0)) self.searchBar.frame = searchBarFrame - self.searchBar.updateLayout(boundingSize: size, leftInset: 0.0, rightInset: 0.0, transition: .immediate) + self.searchBar.updateLayout(boundingSize: searchBarFrame.size, leftInset: leftInset, rightInset: rightInset, transition: transition) } func activate() { diff --git a/TelegramUI/ChatSearchNavigationContentNode.swift b/TelegramUI/ChatSearchNavigationContentNode.swift index c268616fc4..fe29713fb3 100644 --- a/TelegramUI/ChatSearchNavigationContentNode.swift +++ b/TelegramUI/ChatSearchNavigationContentNode.swift @@ -4,7 +4,7 @@ import Display import Postbox import TelegramCore -private let searchBarFont = Font.regular(14.0) +private let searchBarFont = Font.regular(17.0) final class ChatSearchNavigationContentNode: NavigationBarContentNode { private let theme: PresentationTheme @@ -20,7 +20,7 @@ final class ChatSearchNavigationContentNode: NavigationBarContentNode { self.chatLocation = chatLocation self.interaction = interaction - self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme), strings: strings) + self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme, hasSeparator: false), strings: strings, fieldStyle: .modern) let placeholderText: String switch chatLocation { case .peer: @@ -48,14 +48,14 @@ final class ChatSearchNavigationContentNode: NavigationBarContentNode { } } - override func layout() { - super.layout() - - let size = self.bounds.size - - let searchBarFrame = CGRect(origin: CGPoint(), size: size) + override var nominalHeight: CGFloat { + return 54.0 + } + + override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { + let searchBarFrame = CGRect(origin: CGPoint(x: 0.0, y: size.height - self.nominalHeight), size: CGSize(width: size.width, height: 54.0)) self.searchBar.frame = searchBarFrame - self.searchBar.updateLayout(boundingSize: size, leftInset: 0.0, rightInset: 0.0, transition: .immediate) + self.searchBar.updateLayout(boundingSize: searchBarFrame.size, leftInset: leftInset, rightInset: rightInset, transition: transition) } func activate() { @@ -68,7 +68,7 @@ final class ChatSearchNavigationContentNode: NavigationBarContentNode { func update(presentationInterfaceState: ChatPresentationInterfaceState) { if let search = presentationInterfaceState.search { - self.searchBar.updateThemeAndStrings(theme: SearchBarNodeTheme(theme: presentationInterfaceState.theme), strings: presentationInterfaceState.strings) + self.searchBar.updateThemeAndStrings(theme: SearchBarNodeTheme(theme: presentationInterfaceState.theme, hasSeparator: false), strings: presentationInterfaceState.strings) switch search.domain { case .everything: diff --git a/TelegramUI/ComposeController.swift b/TelegramUI/ComposeController.swift index 8710ce647b..4455bf0e8a 100644 --- a/TelegramUI/ComposeController.swift +++ b/TelegramUI/ComposeController.swift @@ -160,6 +160,20 @@ public class ComposeController: ViewController { } } + self.contactsNode.contactListNode.contentOffsetChanged = { [weak self] offset in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateListVisibleContentOffset(offset) + } + } + + self.contactsNode.contactListNode.contentScrollingEnded = { [weak self] listView in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + return fixNavigationSearchableListNodeScrolling(listView, searchNode: searchContentNode) + } else { + return false + } + } + self.displayNodeDidLoad() } @@ -178,7 +192,7 @@ public class ComposeController: ViewController { override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } private func activateSearch() { diff --git a/TelegramUI/ComposeControllerNode.swift b/TelegramUI/ComposeControllerNode.swift index 44493071aa..27f83bc47c 100644 --- a/TelegramUI/ComposeControllerNode.swift +++ b/TelegramUI/ComposeControllerNode.swift @@ -34,7 +34,7 @@ final class ComposeControllerNode: ASDisplayNode { var openCreateNewSecretChatImpl: (() -> Void)? var openCreateNewChannelImpl: (() -> Void)? - self.contactListNode = ContactListNode(account: account, presentation: .single(.natural(displaySearch: true, options: [ + self.contactListNode = ContactListNode(account: account, presentation: .single(.natural(options: [ ContactListAdditionalOption(title: self.presentationData.strings.Compose_NewGroup, icon: .generic(UIImage(bundleImageName: "Contact List/CreateGroupActionIcon")!), action: { openCreateNewGroupImpl?() }), @@ -109,7 +109,7 @@ final class ComposeControllerNode: ASDisplayNode { return } - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: [.cloudContacts, .global], openPeer: { [weak self] peer in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: [.cloudContacts, .global], openPeer: { [weak self] peer in if let requestOpenPeerFromSearch = self?.requestOpenPeerFromSearch, case let .peer(peer, _) = peer { requestOpenPeerFromSearch(peer.id) } diff --git a/TelegramUI/ContactListNode.swift b/TelegramUI/ContactListNode.swift index a7d33cd0ee..45bc57e4bc 100644 --- a/TelegramUI/ContactListNode.swift +++ b/TelegramUI/ContactListNode.swift @@ -433,34 +433,35 @@ private func contactListNodeEntries(accountPeer: Peer?, peers: [ContactListPeer] var orderedPeers: [ContactListPeer] var headers: [ContactListPeerId: ContactListNameIndexHeader] = [:] + if displaySortOptions, let sortOrder = presentation.sortOrder { + entries.append(.sort(theme, strings, sortOrder)) + } + + var addHeader = false + if #available(iOSApplicationExtension 10.0, *) { + let (suppressed, syncDisabled) = warningSuppressed + if !peers.isEmpty && !syncDisabled { + switch authorizationStatus { + case .denied: + entries.append(.permissionInfo(theme, strings, suppressed)) + entries.append(.permissionEnable(theme, strings.Permissions_ContactsAllowInSettings_v0)) + addHeader = true + case .notDetermined: + entries.append(.permissionInfo(theme, strings, false)) + entries.append(.permissionEnable(theme, strings.Permissions_ContactsAllow_v0)) + addHeader = true + default: + break + } + } + } + + if addHeader { + commonHeader = ChatListSearchItemHeader(type: .contacts, theme: theme, strings: strings, actionTitle: nil, action: nil) + } + switch presentation { case let .orderedByPresence(options): - if displaySortOptions, let sortOrder = presentation.sortOrder { - entries.append(.sort(theme, strings, sortOrder)) - } - var addHeader = false - if #available(iOSApplicationExtension 10.0, *) { - let (suppressed, syncDisabled) = warningSuppressed - if !peers.isEmpty && !syncDisabled { - switch authorizationStatus { - case .denied: - entries.append(.permissionInfo(theme, strings, suppressed)) - entries.append(.permissionEnable(theme, strings.Permissions_ContactsAllowInSettings_v0)) - addHeader = true - case .notDetermined: - entries.append(.permissionInfo(theme, strings, false)) - entries.append(.permissionEnable(theme, strings.Permissions_ContactsAllow_v0)) - addHeader = true - default: - break - } - } - } - - if addHeader { - commonHeader = ChatListSearchItemHeader(type: .contacts, theme: theme, strings: strings, actionTitle: nil, action: nil) - } - orderedPeers = peers.sorted(by: { lhs, rhs in if case let .peer(lhsPeer, _) = lhs, case let .peer(rhsPeer, _) = rhs { let lhsPresence = presences[lhsPeer.id] @@ -486,11 +487,7 @@ private func contactListNodeEntries(accountPeer: Peer?, peers: [ContactListPeer] for i in 0 ..< options.count { entries.append(.option(i, options[i], commonHeader, theme, strings)) } - case let .natural(displaySearch, options): - if displaySortOptions, let sortOrder = presentation.sortOrder { - entries.append(.sort(theme, strings, sortOrder)) - } - + case let .natural(options): orderedPeers = peers.sorted(by: { lhs, rhs in let result = lhs.indexName.isLessThan(other: rhs.indexName, ordering: sortOrder) if result == .orderedSame { @@ -546,7 +543,7 @@ private func contactListNodeEntries(accountPeer: Peer?, peers: [ContactListPeer] headers[peer.id] = header } for i in 0 ..< options.count { - entries.append(.option(i, options[i], commonHeader, theme, strings)) + entries.append(.option(i, options[i], nil, theme, strings)) } case .search: orderedPeers = peers @@ -657,7 +654,7 @@ public struct ContactListAdditionalOption: Equatable { enum ContactListPresentation { case orderedByPresence(options: [ContactListAdditionalOption]) - case natural(displaySearch: Bool, options: [ContactListAdditionalOption]) + case natural(options: [ContactListAdditionalOption]) case search(signal: Signal, searchChatList: Bool, searchDeviceContacts: Bool) var sortOrder: ContactsSortOrder? { @@ -749,6 +746,9 @@ final class ContactListNode: ASDisplayNode { } } + var contentOffsetChanged: ((ListViewVisibleContentOffset) -> Void)? + var contentScrollingEnded: ((ListView) -> Bool)? + var activateSearch: (() -> Void)? var openSortMenu: (() -> Void)? var openPeer: ((ContactListPeer) -> Void)? @@ -1006,12 +1006,12 @@ final class ContactListNode: ASDisplayNode { var disabledPeerIds = Set() for filter in filters { switch filter { - case .excludeSelf: - existingPeerIds.insert(account.peerId) - case let .exclude(peerIds): - existingPeerIds = existingPeerIds.union(peerIds) - case let .disable(peerIds): - disabledPeerIds = disabledPeerIds.union(peerIds) + case .excludeSelf: + existingPeerIds.insert(account.peerId) + case let .exclude(peerIds): + existingPeerIds = existingPeerIds.union(peerIds) + case let .disable(peerIds): + disabledPeerIds = disabledPeerIds.union(peerIds) } } @@ -1122,10 +1122,9 @@ final class ContactListNode: ASDisplayNode { }) self.listNode.didEndScrolling = { [weak self] in - guard let strongSelf = self else { - return + if let strongSelf = self { + let _ = strongSelf.contentScrollingEnded?(strongSelf.listNode) } - fixSearchableListNodeScrolling(strongSelf.listNode) } self.listNode.visibleContentOffsetChanged = { [weak self] offset in @@ -1137,6 +1136,7 @@ final class ContactListNode: ASDisplayNode { case let .known(value): atTop = value <= 0.0 } + strongSelf.contentOffsetChanged?(offset) } } diff --git a/TelegramUI/ContactMultiselectionControllerNode.swift b/TelegramUI/ContactMultiselectionControllerNode.swift index 87991b199f..d72e2dfdd1 100644 --- a/TelegramUI/ContactMultiselectionControllerNode.swift +++ b/TelegramUI/ContactMultiselectionControllerNode.swift @@ -56,7 +56,7 @@ final class ContactMultiselectionControllerNode: ASDisplayNode { placeholder = self.presentationData.strings.Compose_TokenListPlaceholder } - self.contactListNode = ContactListNode(account: account, presentation: .single(.natural(displaySearch: false, options: options)), filters: filters, selectionState: ContactListNodeGroupSelectionState()) + self.contactListNode = ContactListNode(account: account, presentation: .single(.natural(options: options)), filters: filters, selectionState: ContactListNodeGroupSelectionState()) self.tokenListNode = EditableTokenListNode(theme: EditableTokenListNodeTheme(backgroundColor: self.presentationData.theme.rootController.navigationBar.backgroundColor, separatorColor: self.presentationData.theme.rootController.navigationBar.separatorColor, placeholderTextColor: self.presentationData.theme.list.itemPlaceholderTextColor, primaryTextColor: self.presentationData.theme.list.itemPrimaryTextColor, selectedTextColor: self.presentationData.theme.list.itemAccentColor, keyboardColor: self.presentationData.theme.chatList.searchBarKeyboardColor), placeholder: placeholder) super.init() diff --git a/TelegramUI/ContactSelectionController.swift b/TelegramUI/ContactSelectionController.swift index 6015b3d611..a8c8ae6094 100644 --- a/TelegramUI/ContactSelectionController.swift +++ b/TelegramUI/ContactSelectionController.swift @@ -155,6 +155,20 @@ class ContactSelectionController: ViewController { self?.presentingViewController?.dismiss(animated: true, completion: nil) } + self.contactsNode.contactListNode.contentOffsetChanged = { [weak self] offset in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateListVisibleContentOffset(offset) + } + } + + self.contactsNode.contactListNode.contentScrollingEnded = { [weak self] listView in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + return fixNavigationSearchableListNodeScrolling(listView, searchNode: searchContentNode) + } else { + return false + } + } + self.displayNodeDidLoad() } @@ -195,7 +209,7 @@ class ContactSelectionController: ViewController { override func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } private func activateSearch() { diff --git a/TelegramUI/ContactSelectionControllerNode.swift b/TelegramUI/ContactSelectionControllerNode.swift index 0567e22421..d3048a6f1b 100644 --- a/TelegramUI/ContactSelectionControllerNode.swift +++ b/TelegramUI/ContactSelectionControllerNode.swift @@ -39,7 +39,7 @@ final class ContactSelectionControllerNode: ASDisplayNode { self.presentationData = account.telegramApplicationContext.currentPresentationData.with { $0 } self.displayDeviceContacts = displayDeviceContacts - self.contactListNode = ContactListNode(account: account, presentation: .single(.natural(displaySearch: true, options: options))) + self.contactListNode = ContactListNode(account: account, presentation: .single(.natural(options: options))) self.dimNode = ASDisplayNode() @@ -112,7 +112,7 @@ final class ContactSelectionControllerNode: ASDisplayNode { } else { categories.insert(.global) } - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: categories, openPeer: { [weak self] peer in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: categories, openPeer: { [weak self] peer in self?.requestOpenPeerFromSearch?(peer) }), cancel: { [weak self] in if let requestDeactivateSearch = self?.requestDeactivateSearch { diff --git a/TelegramUI/ContactsController.swift b/TelegramUI/ContactsController.swift index c502dcf3d6..eb9243713c 100644 --- a/TelegramUI/ContactsController.swift +++ b/TelegramUI/ContactsController.swift @@ -214,6 +214,27 @@ public class ContactsController: ViewController { self?.presentSortMenu() } + self.contactsNode.contactListNode.contentOffsetChanged = { [weak self] offset in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + var progress: CGFloat = 0.0 + switch offset { + case let .known(offset): + progress = max(0.0, (searchContentNode.nominalHeight - max(0.0, offset - 50.0))) / searchContentNode.nominalHeight + default: + break + } + searchContentNode.updateExpansionProgress(progress) + } + } + + self.contactsNode.contactListNode.contentScrollingEnded = { [weak self] listView in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + return fixNavigationSearchableListNodeScrolling(listView, searchNode: searchContentNode) + } else { + return false + } + } + self.displayNodeDidLoad() } @@ -232,7 +253,7 @@ public class ContactsController: ViewController { override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } private func activateSearch() { diff --git a/TelegramUI/ContactsControllerNode.swift b/TelegramUI/ContactsControllerNode.swift index 25b57070ad..89c89d911a 100644 --- a/TelegramUI/ContactsControllerNode.swift +++ b/TelegramUI/ContactsControllerNode.swift @@ -38,7 +38,7 @@ final class ContactsControllerNode: ASDisplayNode { case .presence: return .orderedByPresence(options: options) case .natural: - return .natural(displaySearch: true, options: options) + return .natural(options: options) } } @@ -121,7 +121,7 @@ final class ContactsControllerNode: ASDisplayNode { return } - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: [.cloudContacts, .global, .deviceContacts], openPeer: { [weak self] peer in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: [.cloudContacts, .global, .deviceContacts], openPeer: { [weak self] peer in if let requestOpenPeerFromSearch = self?.requestOpenPeerFromSearch { requestOpenPeerFromSearch(peer) } diff --git a/TelegramUI/EditSettingsController.swift b/TelegramUI/EditSettingsController.swift index 053b50807f..4bf293398d 100644 --- a/TelegramUI/EditSettingsController.swift +++ b/TelegramUI/EditSettingsController.swift @@ -240,7 +240,7 @@ private struct EditSettingsState: Equatable { } } -private func editSettingsEntries(presentationData: PresentationData, state: EditSettingsState, view: PeerView, wallpapers: [TelegramWallpaper]) -> [SettingsEntry] { +private func editSettingsEntries(presentationData: PresentationData, state: EditSettingsState, view: PeerView) -> [SettingsEntry] { var entries: [SettingsEntry] = [] if let peer = peerViewMainPeer(view) as? TelegramUser { @@ -294,10 +294,7 @@ func editSettingsController(account: Account, currentName: ItemListAvatarAndName let avatarAndNameInfoContext = ItemListAvatarAndNameInfoItemContext() var updateHiddenAvatarImpl: (() -> Void)? var changeProfilePhotoImpl: (() -> Void)? - - let wallpapersPromise = Promise<[TelegramWallpaper]>() - wallpapersPromise.set(telegramWallpapers(postbox: account.postbox, network: account.network)) - + let arguments = EditSettingsItemArguments(account: account, accountManager: accountManager, avatarAndNameInfoContext: avatarAndNameInfoContext, avatarTapAction: { var updating = false updateState { @@ -366,8 +363,8 @@ func editSettingsController(account: Account, currentName: ItemListAvatarAndName let peerView = account.viewTracker.peerView(account.peerId) - let signal = combineLatest((account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), peerView, wallpapersPromise.get()) - |> map { presentationData, state, view, wallpapers -> (ItemListControllerState, (ItemListNodeState, SettingsEntry.ItemGenerationArguments)) in + let signal = combineLatest((account.applicationContext as! TelegramApplicationContext).presentationData, statePromise.get(), peerView) + |> map { presentationData, state, view -> (ItemListControllerState, (ItemListNodeState, SettingsEntry.ItemGenerationArguments)) in let rightNavigationButton: ItemListNavigationButton if state.updatingName != nil || state.updatingBioText { rightNavigationButton = ItemListNavigationButton(content: .none, style: .activity, enabled: true, action: {}) @@ -378,7 +375,7 @@ func editSettingsController(account: Account, currentName: ItemListAvatarAndName } let controllerState = ItemListControllerState(theme: presentationData.theme, title: .text(presentationData.strings.EditProfile_Title), leftNavigationButton: nil, rightNavigationButton: rightNavigationButton, backNavigationButton: ItemListBackButton(title: presentationData.strings.Common_Back)) - let listState = ItemListNodeState(entries: editSettingsEntries(presentationData: presentationData, state: state, view: view, wallpapers: wallpapers), style: .blocks) + let listState = ItemListNodeState(entries: editSettingsEntries(presentationData: presentationData, state: state, view: view), style: .blocks) return (controllerState, (listState, arguments)) } |> afterDisposed { diff --git a/TelegramUI/GalleryController.swift b/TelegramUI/GalleryController.swift index d00709d80c..9e8a9faea6 100644 --- a/TelegramUI/GalleryController.swift +++ b/TelegramUI/GalleryController.swift @@ -165,7 +165,7 @@ func galleryItemForEntry(account: Account, presentationData: PresentationData, e if let dimensions = file.dimensions { pixelsCount = Int(dimensions.width) * Int(dimensions.height) } - if (file.size == nil || file.size! < 2 * 1024 * 1024) && pixelsCount < 4096 * 4096 { + if (file.size == nil || file.size! < 4 * 1024 * 1024) && pixelsCount < 4096 * 4096 { return ChatImageGalleryItem(account: account, presentationData: presentationData, message: message, location: location, performAction: performAction, openActionOptions: openActionOptions) } else { return ChatDocumentGalleryItem(account: account, presentationData: presentationData, message: message, location: location) diff --git a/TelegramUI/GroupInfoSearchNavigationContentNode.swift b/TelegramUI/GroupInfoSearchNavigationContentNode.swift index d799351ce0..1c3b9c475b 100644 --- a/TelegramUI/GroupInfoSearchNavigationContentNode.swift +++ b/TelegramUI/GroupInfoSearchNavigationContentNode.swift @@ -4,7 +4,7 @@ import Display import Postbox import TelegramCore -private let searchBarFont = Font.regular(14.0) +private let searchBarFont = Font.regular(17.0) final class GroupInfoSearchNavigationContentNode: NavigationBarContentNode, ItemListControllerSearchNavigationContentNode { private let theme: PresentationTheme @@ -27,7 +27,7 @@ final class GroupInfoSearchNavigationContentNode: NavigationBarContentNode, Item self.cancel = cancel - self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme), strings: strings) + self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme, hasSeparator: false), strings: strings, fieldStyle: .modern) let placeholderText: String switch mode { case .searchBanned: @@ -59,14 +59,14 @@ final class GroupInfoSearchNavigationContentNode: NavigationBarContentNode, Item self.queryUpdated = f } - override func layout() { - super.layout() - - let size = self.bounds.size - - let searchBarFrame = CGRect(origin: CGPoint(), size: size) + override var nominalHeight: CGFloat { + return 54.0 + } + + override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { + let searchBarFrame = CGRect(origin: CGPoint(x: 0.0, y: size.height - self.nominalHeight), size: CGSize(width: size.width, height: 54.0)) self.searchBar.frame = searchBarFrame - self.searchBar.updateLayout(boundingSize: size, leftInset: 0.0, rightInset: 0.0, transition: .immediate) + self.searchBar.updateLayout(boundingSize: searchBarFrame.size, leftInset: leftInset, rightInset: rightInset, transition: transition) } func activate() { diff --git a/TelegramUI/HashtagChatInputContextPanelNode.swift b/TelegramUI/HashtagChatInputContextPanelNode.swift index f2ed2a4747..1f78216040 100644 --- a/TelegramUI/HashtagChatInputContextPanelNode.swift +++ b/TelegramUI/HashtagChatInputContextPanelNode.swift @@ -180,7 +180,7 @@ final class HashtagChatInputContextPanelNode: ChatInputContextPanelNode { } private func topInsetForLayout(size: CGSize) -> CGFloat { - var minimumItemHeights: CGFloat = floor(MentionChatInputPanelItemNode.itemHeight * 3.5) + let minimumItemHeights: CGFloat = floor(MentionChatInputPanelItemNode.itemHeight * 3.5) return max(size.height - minimumItemHeights, 0.0) } diff --git a/TelegramUI/HorizontalStickerGridItem.swift b/TelegramUI/HorizontalStickerGridItem.swift index 5f3276f2b7..a219ae0c2e 100644 --- a/TelegramUI/HorizontalStickerGridItem.swift +++ b/TelegramUI/HorizontalStickerGridItem.swift @@ -60,7 +60,6 @@ final class HorizontalStickerGridItemNode: GridItemNode { super.init() - self.imageNode.transform = CATransform3DMakeRotation(CGFloat.pi / 2.0, 0.0, 0.0, 1.0) self.addSubnode(self.imageNode) } diff --git a/TelegramUI/HorizontalStickersChatContextPanelNode.swift b/TelegramUI/HorizontalStickersChatContextPanelNode.swift index 61bb097854..c193678325 100644 --- a/TelegramUI/HorizontalStickersChatContextPanelNode.swift +++ b/TelegramUI/HorizontalStickersChatContextPanelNode.swift @@ -8,38 +8,6 @@ import SwiftSignalKit final class HorizontalStickersChatContextPanelInteraction { var previewedStickerItem: StickerPackItem? } -private func backgroundCenterImage(_ theme: PresentationTheme) -> UIImage? { - return generateImage(CGSize(width: 30.0, height: 82.0), rotatedContext: { size, context in - context.clear(CGRect(origin: CGPoint(), size: size)) - context.setStrokeColor(theme.list.itemPlainSeparatorColor.cgColor) - context.setFillColor(theme.list.plainBackgroundColor.cgColor) - let lineWidth = UIScreenPixel - context.setLineWidth(lineWidth) - - context.translateBy(x: 460.5, y: 364) - let _ = try? drawSvgPath(context, path: "M-490.476836,-365 L-394.167708,-365 L-394.167708,-291.918214 C-394.167708,-291.918214 -383.538396,-291.918214 -397.691655,-291.918214 C-402.778486,-291.918214 -424.555168,-291.918214 -434.037301,-291.918214 C-440.297129,-291.918214 -440.780682,-283.5 -445.999879,-283.5 C-450.393041,-283.5 -452.491241,-291.918214 -456.502636,-291.918214 C-465.083339,-291.918214 -476.209155,-291.918214 -483.779021,-291.918214 C-503.033963,-291.918214 -490.476836,-291.918214 -490.476836,-291.918214 L-490.476836,-365 ") - context.fillPath() - context.translateBy(x: 0.0, y: lineWidth / 2.0) - let _ = try? drawSvgPath(context, path: "M-490.476836,-365 L-394.167708,-365 L-394.167708,-291.918214 C-394.167708,-291.918214 -383.538396,-291.918214 -397.691655,-291.918214 C-402.778486,-291.918214 -424.555168,-291.918214 -434.037301,-291.918214 C-440.297129,-291.918214 -440.780682,-283.5 -445.999879,-283.5 C-450.393041,-283.5 -452.491241,-291.918214 -456.502636,-291.918214 C-465.083339,-291.918214 -476.209155,-291.918214 -483.779021,-291.918214 C-503.033963,-291.918214 -490.476836,-291.918214 -490.476836,-291.918214 L-490.476836,-365 ") - context.strokePath() - context.translateBy(x: -460.5, y: -lineWidth / 2.0 - 364.0) - context.move(to: CGPoint(x: 0.0, y: lineWidth / 2.0)) - context.addLine(to: CGPoint(x: size.width, y: lineWidth / 2.0)) - context.strokePath() - }) -} -private func backgroundLeftImage(_ theme: PresentationTheme) -> UIImage? { - return generateImage(CGSize(width: 8.0, height: 16.0), rotatedContext: { size, context in - context.clear(CGRect(origin: CGPoint(), size: size)) - context.setStrokeColor(theme.list.itemPlainSeparatorColor.cgColor) - context.setFillColor(theme.list.plainBackgroundColor.cgColor) - let lineWidth = UIScreenPixel - context.setLineWidth(lineWidth) - - context.fillEllipse(in: CGRect(origin: CGPoint(), size: CGSize(width: size.height, height: size.height))) - context.strokeEllipse(in: CGRect(origin: CGPoint(x: lineWidth / 2.0, y: lineWidth / 2.0), size: CGSize(width: size.height - lineWidth, height: size.height - lineWidth))) - })?.stretchableImage(withLeftCapWidth: 8, topCapHeight: 8) -} private struct StickerEntry: Identifiable, Comparable { let index: Int @@ -87,10 +55,6 @@ private func preparedGridEntryTransition(account: Account, from fromEntries: [St final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { private var strings: PresentationStrings - private let backgroundLeftNode: ASImageNode - private let backgroundNode: ASImageNode - private let backgroundRightNode: ASImageNode - private let clippingNode: ASDisplayNode private let gridNode: GridNode private var validLayout: (CGSize, CGFloat, CGFloat, ChatPresentationInterfaceState)? @@ -105,41 +69,17 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { override init(account: Account, theme: PresentationTheme, strings: PresentationStrings) { self.strings = strings - self.backgroundNode = ASImageNode() - self.backgroundNode.displayWithoutProcessing = true - self.backgroundNode.displaysAsynchronously = false - self.backgroundNode.image = backgroundCenterImage(theme) - - self.backgroundLeftNode = ASImageNode() - self.backgroundLeftNode.displayWithoutProcessing = true - self.backgroundLeftNode.displaysAsynchronously = false - self.backgroundLeftNode.image = backgroundLeftImage(theme) - - self.backgroundRightNode = ASImageNode() - self.backgroundRightNode.displayWithoutProcessing = true - self.backgroundRightNode.displaysAsynchronously = false - self.backgroundRightNode.image = backgroundLeftImage(theme) - self.backgroundRightNode.transform = CATransform3DMakeScale(-1.0, 1.0, 1.0) - - self.clippingNode = ASDisplayNode() - self.clippingNode.clipsToBounds = true self.gridNode = GridNode() - self.gridNode.transform = CATransform3DMakeRotation(-CGFloat.pi / 2.0, 0.0, 0.0, 1.0) self.gridNode.view.disablesInteractiveTransitionGestureRecognizer = true self.stickersInteraction = HorizontalStickersChatContextPanelInteraction() super.init(account: account, theme: theme, strings: strings) - self.placement = .overTextInput self.isOpaque = false + self.clipsToBounds = true - self.addSubnode(self.backgroundNode) - self.addSubnode(self.backgroundLeftNode) - self.addSubnode(self.backgroundRightNode) - - self.addSubnode(self.clippingNode) - self.clippingNode.addSubnode(self.gridNode) + self.addSubnode(self.gridNode) } override func didLoad() { @@ -256,36 +196,47 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { } } - override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition, interfaceState: ChatPresentationInterfaceState) { - let sideInsets: CGFloat = 10.0 + leftInset - let contentWidth = min(size.width - sideInsets - sideInsets, max(24.0, CGFloat(self.currentEntries.count) * 66.0 + 6.0)) + private func topInsetForLayout(size: CGSize) -> CGFloat { + let minimumItemHeights: CGFloat = floor(66.0 * 1.5) - var contentLeftInset: CGFloat = 40.0 - var leftOffset: CGFloat = 0.0 - if sideInsets + floor(contentWidth / 2.0) < sideInsets + contentLeftInset + 15.0 { - let updatedLeftInset = sideInsets + floor(contentWidth / 2.0) - 15.0 - sideInsets - leftOffset = contentLeftInset - updatedLeftInset - contentLeftInset = updatedLeftInset + return max(size.height - minimumItemHeights, 0.0) + } + + override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition, interfaceState: ChatPresentationInterfaceState) { + + var insets = UIEdgeInsets() + insets.top = self.topInsetForLayout(size: size) + insets.left = leftInset + insets.right = rightInset + + transition.updateFrame(node: self.gridNode, frame: CGRect(x: 0.0, y: 0.0, width: size.width, height: size.height)) + + var duration: Double = 0.0 + var curve: UInt = 0 + switch transition { + case .immediate: + break + case let .animated(animationDuration, animationCurve): + duration = animationDuration + switch animationCurve { + case .easeInOut: + break + case .spring: + curve = 7 + } } - let backgroundFrame = CGRect(origin: CGPoint(x: sideInsets + leftOffset, y: size.height - 82.0 + 4.0), size: CGSize(width: contentWidth, height: 82.0)) - let backgroundLeftFrame = CGRect(origin: backgroundFrame.origin, size: CGSize(width: contentLeftInset, height: backgroundFrame.size.height - 10.0 + UIScreenPixel)) - let backgroundCenterFrame = CGRect(origin: CGPoint(x: backgroundLeftFrame.maxX, y: backgroundFrame.minY), size: CGSize(width: 30.0, height: 82.0)) - let backgroundRightFrame = CGRect(origin: CGPoint(x: backgroundCenterFrame.maxX, y: backgroundFrame.minY), size: CGSize(width: max(0.0, backgroundFrame.minX + backgroundFrame.size.width - backgroundCenterFrame.maxX), height: backgroundFrame.size.height - 10.0 + UIScreenPixel)) - transition.updateFrame(node: self.backgroundLeftNode, frame: backgroundLeftFrame) - transition.updateFrame(node: self.backgroundNode, frame: backgroundCenterFrame) - transition.updateFrame(node: self.backgroundRightNode, frame: backgroundRightFrame) - - let gridFrame = CGRect(origin: CGPoint(x: backgroundFrame.minX, y: backgroundFrame.minY + 4.0), size: CGSize(width: backgroundFrame.size.width, height: 66.0)) - transition.updateFrame(node: self.clippingNode, frame: gridFrame) - self.gridNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: gridFrame.size.height, height: gridFrame.size.width)) - - let gridBounds = self.gridNode.bounds - self.gridNode.bounds = CGRect(x: gridBounds.minX, y: gridBounds.minY, width: gridFrame.size.height, height: gridFrame.size.width) - self.gridNode.position = CGPoint(x: gridFrame.size.width / 2.0, y: gridFrame.size.height / 2.0) - - self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: nil, updateLayout: GridNodeUpdateLayout(layout: GridNodeLayout(size: CGSize(width: gridFrame.size.height, height: gridFrame.size.width), insets: UIEdgeInsets(top: 3.0, left: 0.0, bottom: 3.0, right: 0.0), preloadSize: 100.0, type: .fixed(itemSize: CGSize(width: 66.0, height: 66.0), fillWidth: nil, lineSpacing: 0.0, itemSpacing: nil)), transition: .immediate), itemTransition: .immediate, stationaryItems: .all, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + let listViewCurve: ListViewAnimationCurve + if curve == 7 { + listViewCurve = .Spring(duration: duration) + } else { + listViewCurve = .Default(duration: duration) + } + //let updateSizeAndInsets = ListViewUpdateSizeAndInsets(size: size, insets: insets, duration: duration, curve: listViewCurve) + + self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: nil, updateLayout: GridNodeUpdateLayout(layout: GridNodeLayout(size: size, insets: insets, preloadSize: 100.0, type: .fixed(itemSize: CGSize(width: 66.0, height: 66.0), fillWidth: nil, lineSpacing: 0.0, itemSpacing: nil)), transition: .immediate), itemTransition: .immediate, stationaryItems: .all, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + let dequeue = self.validLayout == nil self.validLayout = (size, leftInset, rightInset, interfaceState) @@ -296,12 +247,6 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { if self.theme !== interfaceState.theme { self.theme = interfaceState.theme - self.backgroundNode.image = backgroundCenterImage(theme) - self.backgroundLeftNode.image = backgroundLeftImage(theme) - self.backgroundRightNode.image = backgroundLeftImage(theme) - // if let currentEntries = self.currentEntries { - // self.updateToEntries(entries: currentEntries, forceUpdate: true) - // } } } @@ -312,10 +257,8 @@ final class HorizontalStickersChatContextPanelNode: ChatInputContextPanelNode { } override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { - if !self.clippingNode.frame.contains(point) { - return nil - } - return super.hitTest(point, with: event) + let listViewFrame = self.gridNode.frame + return self.gridNode.hitTest(CGPoint(x: point.x - listViewFrame.minX, y: point.y - listViewFrame.minY), with: event) } private func updatePreviewingItem(item: StickerPackItem?, animated: Bool) { diff --git a/TelegramUI/InviteContactsController.swift b/TelegramUI/InviteContactsController.swift index dd11c593b0..773f18754c 100644 --- a/TelegramUI/InviteContactsController.swift +++ b/TelegramUI/InviteContactsController.swift @@ -136,6 +136,18 @@ public class InviteContactsController: ViewController, MFMessageComposeViewContr } } + self.contactsNode.listNode.visibleContentOffsetChanged = { [weak self] offset in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateListVisibleContentOffset(offset) + } + } + + self.contactsNode.listNode.didEndScrolling = { [weak self] in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + let _ = fixNavigationSearchableListNodeScrolling(strongSelf.contactsNode.listNode, searchNode: searchContentNode) + } + } + self.displayNodeDidLoad() } @@ -150,7 +162,7 @@ public class InviteContactsController: ViewController, MFMessageComposeViewContr override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.contactsNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } private func activateSearch() { diff --git a/TelegramUI/InviteContactsControllerNode.swift b/TelegramUI/InviteContactsControllerNode.swift index 87396f0581..1c74ae5e22 100644 --- a/TelegramUI/InviteContactsControllerNode.swift +++ b/TelegramUI/InviteContactsControllerNode.swift @@ -470,13 +470,6 @@ final class InviteContactsControllerNode: ASDisplayNode { } } } - - self.listNode.didEndScrolling = { [weak self] in - guard let strongSelf = self else { - return - } - fixSearchableListNodeScrolling(strongSelf.listNode) - } } deinit { @@ -555,7 +548,7 @@ final class InviteContactsControllerNode: ASDisplayNode { return } - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: [.deviceContacts], openPeer: { [weak self] peerId in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: false, categories: [.deviceContacts], openPeer: { [weak self] peerId in }), cancel: { [weak self] in if let requestDeactivateSearch = self?.requestDeactivateSearch { requestDeactivateSearch() diff --git a/TelegramUI/ListMessageFileItemNode.swift b/TelegramUI/ListMessageFileItemNode.swift index d920e3533b..a278235edd 100644 --- a/TelegramUI/ListMessageFileItemNode.swift +++ b/TelegramUI/ListMessageFileItemNode.swift @@ -560,11 +560,11 @@ final class ListMessageFileItemNode: ListMessageNode { iconFrame = CGRect(origin: CGPoint(x: params.leftInset + leftOffset + 12.0, y: 5.0), size: iconSize) } else { let iconSize = CGSize(width: 42.0, height: 42.0) - iconFrame = CGRect(origin: CGPoint(x: params.leftInset + leftOffset + 12.0, y: 5.0), size: iconSize) + iconFrame = CGRect(origin: CGPoint(x: params.leftInset + leftOffset + 12.0, y: 8.0), size: iconSize) } - transition.updateFrame(node: strongSelf.extensionIconNode, frame: iconFrame) + transition.updateFrame(node: strongSelf.extensionIconNode, frame: iconFrame) strongSelf.extensionIconNode.image = extensionIconImage - transition.updateFrame(node: strongSelf.extensionIconText, frame: CGRect(origin: CGPoint(x: leftOffset + 12.0 + floor((42.0 - extensionTextLayout.size.width) / 2.0), y: 5.0 + floor((42.0 - extensionTextLayout.size.height) / 2.0)), size: extensionTextLayout.size)) + transition.updateFrame(node: strongSelf.extensionIconText, frame: CGRect(origin: CGPoint(x: leftOffset + 12.0 + floor((42.0 - extensionTextLayout.size.width) / 2.0), y: 8.0 + floor((42.0 - extensionTextLayout.size.height) / 2.0)), size: extensionTextLayout.size)) let _ = extensionTextApply() @@ -619,7 +619,7 @@ final class ListMessageFileItemNode: ListMessageNode { })) } - transition.updateFrame(node: strongSelf.downloadStatusIconNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset, y: 31.0), size: CGSize(width: 11.0, height: 11.0))) + transition.updateFrame(node: strongSelf.downloadStatusIconNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset, y: 34.0), size: CGSize(width: 11.0, height: 11.0))) if let updatedFetchControls = updatedFetchControls { let _ = strongSelf.fetchControls.swap(updatedFetchControls) diff --git a/TelegramUI/LocalizationListController.swift b/TelegramUI/LocalizationListController.swift index 2a67959015..585ae759fb 100644 --- a/TelegramUI/LocalizationListController.swift +++ b/TelegramUI/LocalizationListController.swift @@ -42,7 +42,12 @@ public class LocalizationListController: ViewController { self.navigationItem.backBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Back, style: .plain, target: nil, action: nil) self.scrollToTop = { [weak self] in - self?.controllerNode.scrollToTop() + if let strongSelf = self { + if let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateExpansionProgress(1.0, animated: true) + } + strongSelf.controllerNode.scrollToTop() + } } self.presentationDataDisposable = (account.telegramApplicationContext.presentationData @@ -117,12 +122,24 @@ public class LocalizationListController: ViewController { self._ready.set(self.controllerNode._ready.get()) self.displayNodeDidLoad() + + self.controllerNode.listNode.visibleContentOffsetChanged = { [weak self] offset in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateListVisibleContentOffset(offset) + } + } + + self.controllerNode.listNode.didEndScrolling = { [weak self] in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + let _ = fixNavigationSearchableListNodeScrolling(strongSelf.controllerNode.listNode, searchNode: searchContentNode) + } + } } override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } @objc private func editPressed() { diff --git a/TelegramUI/LocalizationListControllerNode.swift b/TelegramUI/LocalizationListControllerNode.swift index 446807434d..abb1f69add 100644 --- a/TelegramUI/LocalizationListControllerNode.swift +++ b/TelegramUI/LocalizationListControllerNode.swift @@ -291,7 +291,7 @@ final class LocalizationListControllerNode: ViewControllerTracingNode { let _ready = ValuePromise() private var containerLayout: (ContainerViewLayout, CGFloat)? - private let listNode: ListView + let listNode: ListView private var queuedTransitions: [LanguageListNodeTransition] = [] private var searchDisplayController: SearchDisplayController? @@ -555,7 +555,7 @@ final class LocalizationListControllerNode: ViewControllerTracingNode { return } - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: LocalizationListSearchContainerNode(account: self.account, listState: self.currentListState ?? LocalizationListState.defaultSettings, selectLocalization: { [weak self] info in self?.selectLocalization(info) }, applyingCode: self.applyingCode.get()), cancel: { [weak self] in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: LocalizationListSearchContainerNode(account: self.account, listState: self.currentListState ?? LocalizationListState.defaultSettings, selectLocalization: { [weak self] info in self?.selectLocalization(info) }, applyingCode: self.applyingCode.get()), cancel: { [weak self] in self?.requestDeactivateSearch() }) diff --git a/TelegramUI/NavigationBarSearchContentNode.swift b/TelegramUI/NavigationBarSearchContentNode.swift index c0cc38c225..0cbcaa5add 100644 --- a/TelegramUI/NavigationBarSearchContentNode.swift +++ b/TelegramUI/NavigationBarSearchContentNode.swift @@ -14,6 +14,8 @@ class NavigationBarSearchContentNode: NavigationBarContentNode { private(set) var expansionProgress: CGFloat = 1.0 + private var validLayout: (CGSize, CGFloat, CGFloat)? + init(theme: PresentationTheme, placeholder: String, activate: @escaping () -> Void) { self.theme = theme self.placeholder = placeholder @@ -31,7 +33,20 @@ class NavigationBarSearchContentNode: NavigationBarContentNode { if let disabledOverlay = self.disabledOverlay { disabledOverlay.backgroundColor = theme.rootController.navigationBar.backgroundColor.withAlphaComponent(0.5) } - self.setNeedsLayout() + if let validLayout = self.validLayout { + self.updatePlaceholder(self.expansionProgress, size: validLayout.0, leftInset: validLayout.1, rightInset: validLayout.2, transition: .immediate) + } + } + + func updateListVisibleContentOffset(_ offset: ListViewVisibleContentOffset) { + var progress: CGFloat = 0.0 + switch offset { + case let .known(offset): + progress = max(0.0, (self.nominalHeight - offset)) / self.nominalHeight + default: + break + } + self.updateExpansionProgress(progress) } func updateExpansionProgress(_ progress: CGFloat, animated: Bool = false) { @@ -40,8 +55,8 @@ class NavigationBarSearchContentNode: NavigationBarContentNode { self.expansionProgress = newProgress let transition: ContainedViewLayoutTransition = animated ? .animated(duration: 0.25, curve: .easeInOut) : .immediate - if animated { - self.updatePlaceholder(self.expansionProgress, transition: transition) + if let validLayout = self.validLayout, animated { + self.updatePlaceholder(self.expansionProgress, size: validLayout.0, leftInset: validLayout.1, rightInset: validLayout.2, transition: transition) } self.requestContainerLayout(transition) } @@ -73,9 +88,9 @@ class NavigationBarSearchContentNode: NavigationBarContentNode { } } - private func updatePlaceholder(_ progress: CGFloat, transition: ContainedViewLayoutTransition) { + private func updatePlaceholder(_ progress: CGFloat, size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { let padding: CGFloat = 10.0 - let baseWidth = self.bounds.width - padding * 2.0 + let baseWidth = self.bounds.width - padding * 2.0 - leftInset - rightInset let fieldHeight: CGFloat = 36.0 let fraction = fieldHeight / self.nominalHeight @@ -85,14 +100,14 @@ class NavigationBarSearchContentNode: NavigationBarContentNode { let applyLayout = makeLayout(NSAttributedString(string: self.placeholder, font: searchBarFont, textColor: self.theme?.rootController.activeNavigationSearchBar.inputPlaceholderTextColor ?? UIColor(rgb: 0x8e8e93)), CGSize(width: baseWidth, height: fieldHeight), visibleProgress, self.theme?.rootController.activeNavigationSearchBar.inputPlaceholderTextColor ?? UIColor(rgb: 0x8e8e93), self.theme?.rootController.activeNavigationSearchBar.inputFillColor ?? .clear, self.theme?.rootController.navigationBar.backgroundColor ?? .clear, transition) applyLayout() - let searchBarFrame = CGRect(origin: CGPoint(x: padding, y: 8.0), size: CGSize(width: baseWidth, height: fieldHeight)) + let searchBarFrame = CGRect(origin: CGPoint(x: padding + leftInset, y: 8.0), size: CGSize(width: baseWidth, height: fieldHeight)) transition.updateFrame(node: self.placeholderNode, frame: searchBarFrame) } - override func layout() { - super.layout() - - self.updatePlaceholder(self.expansionProgress, transition: .immediate) + override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { + self.validLayout = (size, leftInset, rightInset) + + self.updatePlaceholder(self.expansionProgress, size: size, leftInset: leftInset, rightInset: rightInset, transition: transition) } override var height: CGFloat { diff --git a/TelegramUI/NotificationExceptionControllerNode.swift b/TelegramUI/NotificationExceptionControllerNode.swift index b26ba35490..043e568c3f 100644 --- a/TelegramUI/NotificationExceptionControllerNode.swift +++ b/TelegramUI/NotificationExceptionControllerNode.swift @@ -824,7 +824,7 @@ final class NotificationExceptionsControllerNode: ViewControllerTracingNode { return } - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: NotificationExceptionsSearchContainerNode(account: self.account, mode: self.stateValue.modify {$0}.mode, arguments: self.arguments!), cancel: { [weak self] in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: NotificationExceptionsSearchContainerNode(account: self.account, mode: self.stateValue.modify {$0}.mode, arguments: self.arguments!), cancel: { [weak self] in self?.requestDeactivateSearch() }) diff --git a/TelegramUI/NotificationExceptions.swift b/TelegramUI/NotificationExceptions.swift index 4f9e95f6d4..7dfbf1e281 100644 --- a/TelegramUI/NotificationExceptions.swift +++ b/TelegramUI/NotificationExceptions.swift @@ -127,7 +127,7 @@ public class NotificationExceptionsController: ViewController { override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } @objc private func editPressed() { diff --git a/TelegramUI/OpenResolvedUrl.swift b/TelegramUI/OpenResolvedUrl.swift index 7bc7769026..2c0019899f 100644 --- a/TelegramUI/OpenResolvedUrl.swift +++ b/TelegramUI/OpenResolvedUrl.swift @@ -170,7 +170,16 @@ func openResolvedUrl(_ resolvedUrl: ResolvedUrl, account: Account, context: Open } if let to = to { - + let query = to.trimmingCharacters(in: CharacterSet(charactersIn: "0123456789").inverted) + let _ = (account.postbox.searchContacts(query: query) + |> deliverOnMainQueue).start(next: { (peers, _) in + for case let peer as TelegramUser in peers { + if peer.phone == query { + continueWithPeer(peer.id) + break + } + } + }) } else { let controller = PeerSelectionController(account: account) controller.peerSelected = { [weak controller] peerId in diff --git a/TelegramUI/PeerMediaCollectionControllerNode.swift b/TelegramUI/PeerMediaCollectionControllerNode.swift index 42983d1e31..2a549fae05 100644 --- a/TelegramUI/PeerMediaCollectionControllerNode.swift +++ b/TelegramUI/PeerMediaCollectionControllerNode.swift @@ -374,7 +374,7 @@ class PeerMediaCollectionControllerNode: ASDisplayNode { } if let placeholderNode = maybePlaceholderNode { - self.searchDisplayController = SearchDisplayController(theme: self.mediaCollectionInterfaceState.theme, strings: self.mediaCollectionInterfaceState.strings, contentNode: ChatHistorySearchContainerNode(account: self.account, peerId: self.peerId, tagMask: tagMaskForMode(self.mediaCollectionInterfaceState.mode), interfaceInteraction: self.controllerInteraction), cancel: { [weak self] in + self.searchDisplayController = SearchDisplayController(theme: self.mediaCollectionInterfaceState.theme, strings: self.mediaCollectionInterfaceState.strings, mode: .list, contentNode: ChatHistorySearchContainerNode(account: self.account, peerId: self.peerId, tagMask: tagMaskForMode(self.mediaCollectionInterfaceState.mode), interfaceInteraction: self.controllerInteraction), cancel: { [weak self] in self?.requestDeactivateSearch() }) diff --git a/TelegramUI/PeerSelectionController.swift b/TelegramUI/PeerSelectionController.swift index 0dd3472884..201f669dd4 100644 --- a/TelegramUI/PeerSelectionController.swift +++ b/TelegramUI/PeerSelectionController.swift @@ -138,6 +138,20 @@ public final class PeerSelectionController: ViewController { } } + self.peerSelectionNode.contentOffsetChanged = { [weak self] offset in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + searchContentNode.updateListVisibleContentOffset(offset) + } + } + + self.peerSelectionNode.contentScrollingEnded = { [weak self] listView in + if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { + return fixNavigationSearchableListNodeScrolling(listView, searchNode: searchContentNode) + } else { + return false + } + } + self.displayNodeDidLoad() self._ready.set(self.peerSelectionNode.ready) @@ -160,7 +174,7 @@ public final class PeerSelectionController: ViewController { override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.peerSelectionNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.peerSelectionNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) } @objc func cancelPressed() { diff --git a/TelegramUI/PeerSelectionControllerNode.swift b/TelegramUI/PeerSelectionControllerNode.swift index dd7e94110e..b80ac49c2a 100644 --- a/TelegramUI/PeerSelectionControllerNode.swift +++ b/TelegramUI/PeerSelectionControllerNode.swift @@ -22,8 +22,8 @@ final class PeerSelectionControllerNode: ASDisplayNode { private let toolbarSeparatorNode: ASDisplayNode? private let segmentedControl: UISegmentedControl? - private var contactListNode: ContactListNode? - private let chatListNode: ChatListNode + var contactListNode: ContactListNode? + let chatListNode: ChatListNode private var contactListActive = false @@ -31,6 +31,9 @@ final class PeerSelectionControllerNode: ASDisplayNode { private var containerLayout: (ContainerViewLayout, CGFloat)? + var contentOffsetChanged: ((ListViewVisibleContentOffset) -> Void)? + var contentScrollingEnded: ((ListView) -> Bool)? + var requestActivateSearch: (() -> Void)? var requestDeactivateSearch: (() -> Void)? var requestOpenPeer: ((PeerId) -> Void)? @@ -88,6 +91,14 @@ final class PeerSelectionControllerNode: ASDisplayNode { self?.requestOpenPeer?(peerId) } + self.chatListNode.contentOffsetChanged = { [weak self] offset in + self?.contentOffsetChanged?(offset) + } + + self.chatListNode.contentScrollingEnded = { [weak self] listView in + return self?.contentScrollingEnded?(listView) ?? false + } + self.addSubnode(self.chatListNode) self.presentationDataDisposable = (account.telegramApplicationContext.presentationData |> deliverOnMainQueue).start(next: { [weak self] presentationData in @@ -199,7 +210,7 @@ final class PeerSelectionControllerNode: ASDisplayNode { } if self.chatListNode.supernode != nil { - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: ChatListSearchContainerNode(account: self.account, filter: self.filter, groupId: nil, openPeer: { [weak self] peer, _ in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: ChatListSearchContainerNode(account: self.account, filter: self.filter, groupId: nil, openPeer: { [weak self] peer, _ in if let requestOpenPeerFromSearch = self?.requestOpenPeerFromSearch { requestOpenPeerFromSearch(peer) } @@ -226,7 +237,7 @@ final class PeerSelectionControllerNode: ASDisplayNode { }, placeholder: placeholderNode) } else if let contactListNode = self.contactListNode, contactListNode.supernode != nil { - self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, mode: .navigation, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: true, categories: [.cloudContacts, .global], openPeer: { [weak self] peer in + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: ContactsSearchContainerNode(account: self.account, onlyWriteable: true, categories: [.cloudContacts, .global], openPeer: { [weak self] peer in if let strongSelf = self { switch peer { case let .peer(peer, _): @@ -309,7 +320,7 @@ final class PeerSelectionControllerNode: ASDisplayNode { self.recursivelyEnsureDisplaySynchronously(true) contactListNode.enableUpdates = true } else { - let contactListNode = ContactListNode(account: account, presentation: .single(.natural(displaySearch: true, options: []))) + let contactListNode = ContactListNode(account: account, presentation: .single(.natural(options: []))) self.contactListNode = contactListNode contactListNode.enableUpdates = true contactListNode.activateSearch = { [weak self] in @@ -320,7 +331,13 @@ final class PeerSelectionControllerNode: ASDisplayNode { self?.requestOpenPeer?(peer.id) } } + contactListNode.contentOffsetChanged = { [weak self] offset in + self?.contentOffsetChanged?(offset) + } + contactListNode.contentScrollingEnded = { [weak self] listView in + return self?.contentScrollingEnded?(listView) ?? false + } self.containerLayoutUpdated(layout, navigationBarHeight: navigationHeight, transition: .immediate) let _ = (contactListNode.ready |> deliverOnMainQueue).start(next: { [weak self] _ in diff --git a/TelegramUI/PresentationStrings.swift b/TelegramUI/PresentationStrings.swift index ae8c23d475..22d25aee90 100644 --- a/TelegramUI/PresentationStrings.swift +++ b/TelegramUI/PresentationStrings.swift @@ -830,2801 +830,2808 @@ public final class PresentationStrings { public var Conversation_FilePhotoOrVideo: String { return self._s[577]! } public var AccessDenied_Camera: String { return self._s[578]! } public var Watch_Compose_CurrentLocation: String { return self._s[579]! } + public var BackgroundPreview_Still: String { return self._s[581]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[581]!, self._r[581]!, [_0]) + return formatWithArgumentRanges(self._s[582]!, self._r[582]!, [_0]) } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[582]! } - public var Passport_Language_ro: String { return self._s[583]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[584]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[583]! } + public var Passport_Language_ro: String { return self._s[584]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[585]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[585]!, self._r[585]!, [_0]) + return formatWithArgumentRanges(self._s[586]!, self._r[586]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[586]! } - public var State_ConnectingToProxy: String { return self._s[587]! } - public var Calls_RatingTitle: String { return self._s[588]! } - public var Generic_ErrorMoreInfo: String { return self._s[589]! } - public var Appearance_PreviewReplyText: String { return self._s[590]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[591]! } - public var SharedMedia_CategoryLinks: String { return self._s[592]! } - public var Calls_Missed: String { return self._s[593]! } - public var Cache_Photos: String { return self._s[597]! } - public var GroupPermission_NoAddMembers: String { return self._s[598]! } + public var Login_CancelPhoneVerification: String { return self._s[587]! } + public var State_ConnectingToProxy: String { return self._s[588]! } + public var Calls_RatingTitle: String { return self._s[589]! } + public var Generic_ErrorMoreInfo: String { return self._s[590]! } + public var Appearance_PreviewReplyText: String { return self._s[591]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[592]! } + public var SharedMedia_CategoryLinks: String { return self._s[593]! } + public var Calls_Missed: String { return self._s[594]! } + public var Cache_Photos: String { return self._s[598]! } + public var GroupPermission_NoAddMembers: String { return self._s[599]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[599]!, self._r[599]!, [_0]) + return formatWithArgumentRanges(self._s[600]!, self._r[600]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[600]! } - public var Settings_ProxyDisabled: String { return self._s[601]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[601]! } + public var Settings_ProxyDisabled: String { return self._s[602]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[602]!, self._r[602]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[603]!, self._r[603]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[603]!, self._r[603]!, [_0]) + return formatWithArgumentRanges(self._s[604]!, self._r[604]!, [_0]) } - public var Appearance_Title: String { return self._s[604]! } + public var Appearance_Title: String { return self._s[605]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[606]!, self._r[606]!, [_0]) + return formatWithArgumentRanges(self._s[607]!, self._r[607]!, [_0]) } public func CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[607]!, self._r[607]!, [_1]) - } - public func PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[608]!, self._r[608]!, [_1]) } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[609]! } + public func PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[609]!, self._r[609]!, [_1]) + } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[610]! } public func CHANNEL_MESSAGE_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[610]!, self._r[610]!, [_1]) + return formatWithArgumentRanges(self._s[611]!, self._r[611]!, [_1]) } - public var Channel_EditMessageErrorGeneric: String { return self._s[611]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[612]! } - public var Preview_DeletePhoto: String { return self._s[613]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[614]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[612]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[613]! } + public var Preview_DeletePhoto: String { return self._s[614]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[615]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[615]!, self._r[615]!, [_0]) + return formatWithArgumentRanges(self._s[616]!, self._r[616]!, [_0]) } - public var Coub_TapForSound: String { return self._s[617]! } - public var Map_LocatingError: String { return self._s[618]! } + public var Coub_TapForSound: String { return self._s[618]! } + public var Map_LocatingError: String { return self._s[619]! } public func CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[620]!, self._r[620]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[621]!, self._r[621]!, [_1, _2, _3]) } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[621]! } - public var Passport_ForgottenPassword: String { return self._s[622]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[623]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[624]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[622]! } + public var Passport_ForgottenPassword: String { return self._s[623]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[624]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[625]! } public func PINNED_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[626]!, self._r[626]!, [_1, _2]) + return formatWithArgumentRanges(self._s[627]!, self._r[627]!, [_1, _2]) } - public var Login_TermsOfServiceSignupDecline: String { return self._s[627]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[628]! } - public var Message_Location: String { return self._s[629]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[630]! } - public var Channel_Management_Title: String { return self._s[631]! } - public var DialogList_SearchSectionDialogs: String { return self._s[633]! } - public var Compose_NewChannel_Members: String { return self._s[634]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[628]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[629]! } + public var Message_Location: String { return self._s[630]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[631]! } + public var Channel_Management_Title: String { return self._s[632]! } + public var DialogList_SearchSectionDialogs: String { return self._s[634]! } + public var Compose_NewChannel_Members: String { return self._s[635]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[635]!, self._r[635]!, [_0]) + return formatWithArgumentRanges(self._s[636]!, self._r[636]!, [_0]) } - public var AutoNightTheme_ScheduledFrom: String { return self._s[636]! } - public var PhotoEditor_WarmthTool: String { return self._s[637]! } - public var Passport_Language_tr: String { return self._s[638]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[640]! } - public var Watch_PhotoView_Title: String { return self._s[641]! } - public var Passport_Phone_Delete: String { return self._s[643]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[637]! } + public var PhotoEditor_WarmthTool: String { return self._s[638]! } + public var Passport_Language_tr: String { return self._s[639]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[641]! } + public var Watch_PhotoView_Title: String { return self._s[642]! } + public var Passport_Phone_Delete: String { return self._s[644]! } public func MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[644]!, self._r[644]!, [_1, _2]) + return formatWithArgumentRanges(self._s[645]!, self._r[645]!, [_1, _2]) } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[645]! } - public var GroupInfo_Permissions: String { return self._s[646]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[647]! } - public var Profile_ShareContactButton: String { return self._s[648]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[646]! } + public var GroupInfo_Permissions: String { return self._s[647]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[648]! } + public var Profile_ShareContactButton: String { return self._s[649]! } public func CHAT_LEFT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[649]!, self._r[649]!, [_1, _2]) + return formatWithArgumentRanges(self._s[650]!, self._r[650]!, [_1, _2]) } - public var ChatSettings_Other: String { return self._s[650]! } - public var UserInfo_NotificationsDisabled: String { return self._s[651]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[652]! } - public var LastSeen_WithinAMonth: String { return self._s[653]! } - public var Channel_AdminLog_BanSendStickers: String { return self._s[654]! } - public var Conversation_EncryptionCanceled: String { return self._s[655]! } - public var MediaPicker_GroupDescription: String { return self._s[656]! } - public var WebSearch_Images: String { return self._s[657]! } + public var ChatSettings_Other: String { return self._s[651]! } + public var UserInfo_NotificationsDisabled: String { return self._s[652]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[653]! } + public var LastSeen_WithinAMonth: String { return self._s[654]! } + public var Channel_AdminLog_BanSendStickers: String { return self._s[655]! } + public var Conversation_EncryptionCanceled: String { return self._s[656]! } + public var MediaPicker_GroupDescription: String { return self._s[657]! } + public var WebSearch_Images: String { return self._s[658]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[658]!, self._r[658]!, [_0]) + return formatWithArgumentRanges(self._s[659]!, self._r[659]!, [_0]) } - public var Message_Photo: String { return self._s[659]! } - public var PasscodeSettings_HelpBottom: String { return self._s[660]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[661]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[662]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[663]! } - public var NotificationsSound_Calypso: String { return self._s[664]! } - public var Map_Map: String { return self._s[665]! } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[667]! } - public var ChatSettings_TextSizeUnits: String { return self._s[668]! } - public var Common_of: String { return self._s[669]! } - public var Conversation_ForwardContacts: String { return self._s[671]! } - public var Passport_Language_hy: String { return self._s[672]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[673]! } - public var BackgroundPreview_Title: String { return self._s[674]! } - public var AutoDownloadSettings_Reset: String { return self._s[675]! } - public var Paint_ClearConfirm: String { return self._s[676]! } - public var Camera_VideoMode: String { return self._s[677]! } + public var Message_Photo: String { return self._s[660]! } + public var PasscodeSettings_HelpBottom: String { return self._s[661]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[662]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[663]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[664]! } + public var NotificationsSound_Calypso: String { return self._s[665]! } + public var Map_Map: String { return self._s[666]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[668]! } + public var ChatSettings_TextSizeUnits: String { return self._s[669]! } + public var Common_of: String { return self._s[670]! } + public var Conversation_ForwardContacts: String { return self._s[672]! } + public var Passport_Language_hy: String { return self._s[673]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[674]! } + public var BackgroundPreview_Title: String { return self._s[675]! } + public var AutoDownloadSettings_Reset: String { return self._s[676]! } + public var Paint_ClearConfirm: String { return self._s[677]! } + public var Camera_VideoMode: String { return self._s[678]! } public func MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[678]!, self._r[678]!, [_1]) + return formatWithArgumentRanges(self._s[679]!, self._r[679]!, [_1]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[679]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[680]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[680]!, self._r[680]!, [_0]) + return formatWithArgumentRanges(self._s[681]!, self._r[681]!, [_0]) } - public var Passport_Language_el: String { return self._s[681]! } - public var PhotoEditor_Original: String { return self._s[682]! } - public var Settings_FAQ_Button: String { return self._s[683]! } - public var Channel_Setup_PublicNoLink: String { return self._s[685]! } - public var Conversation_UnsupportedMedia: String { return self._s[686]! } - public var Conversation_SlideToCancel: String { return self._s[687]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[688]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[689]! } - public var AutoNightTheme_NotAvailable: String { return self._s[690]! } - public var Common_Create: String { return self._s[691]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[692]! } - public var Localization_ChooseLanguage: String { return self._s[694]! } + public var Passport_Language_el: String { return self._s[682]! } + public var PhotoEditor_Original: String { return self._s[683]! } + public var Settings_FAQ_Button: String { return self._s[684]! } + public var Channel_Setup_PublicNoLink: String { return self._s[686]! } + public var Conversation_UnsupportedMedia: String { return self._s[687]! } + public var Conversation_SlideToCancel: String { return self._s[688]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[689]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[690]! } + public var AutoNightTheme_NotAvailable: String { return self._s[691]! } + public var Common_Create: String { return self._s[692]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[693]! } + public var Localization_ChooseLanguage: String { return self._s[695]! } public func PINNED_ROUND_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[696]!, self._r[696]!, [_1]) + return formatWithArgumentRanges(self._s[697]!, self._r[697]!, [_1]) } - public var Privacy_TopPeersHelp: String { return self._s[698]! } - public var Settings_Proxy: String { return self._s[699]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[700]! } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[701]! } + public var Privacy_TopPeersHelp: String { return self._s[699]! } + public var Settings_Proxy: String { return self._s[700]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[701]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[702]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[703]!, self._r[703]!, [_0]) + return formatWithArgumentRanges(self._s[704]!, self._r[704]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[704]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[705]! } - public var Cache_Title: String { return self._s[706]! } + public var Contacts_SortedByPresence: String { return self._s[705]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[706]! } + public var Cache_Title: String { return self._s[707]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[707]!, self._r[707]!, [_0]) + return formatWithArgumentRanges(self._s[708]!, self._r[708]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[708]! } - public var Channel_Moderator_Title: String { return self._s[709]! } - public var InstantPage_AutoNightTheme: String { return self._s[711]! } - public var Passport_Scans_Upload: String { return self._s[715]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[716]! } - public var TwoStepAuth_RemovePassword: String { return self._s[717]! } - public var Common_Delete: String { return self._s[718]! } - public var Conversation_ContextMenuDelete: String { return self._s[720]! } - public var SocksProxySetup_Credentials: String { return self._s[721]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[723]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[726]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[727]! } - public var Passport_Language_id: String { return self._s[729]! } - public var ChannelIntro_Title: String { return self._s[730]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[709]! } + public var Channel_Moderator_Title: String { return self._s[710]! } + public var InstantPage_AutoNightTheme: String { return self._s[712]! } + public var Passport_Scans_Upload: String { return self._s[716]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[717]! } + public var TwoStepAuth_RemovePassword: String { return self._s[718]! } + public var Common_Delete: String { return self._s[719]! } + public var Conversation_ContextMenuDelete: String { return self._s[721]! } + public var SocksProxySetup_Credentials: String { return self._s[722]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[724]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[727]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[728]! } + public var Passport_Language_id: String { return self._s[730]! } + public var ChannelIntro_Title: String { return self._s[731]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[731]!, self._r[731]!, [_0]) + return formatWithArgumentRanges(self._s[732]!, self._r[732]!, [_0]) } public func PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[733]!, self._r[733]!, [_1]) + return formatWithArgumentRanges(self._s[734]!, self._r[734]!, [_1]) } - public var Channel_Info_Description: String { return self._s[734]! } - public var Stickers_FavoriteStickers: String { return self._s[735]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[736]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[737]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[738]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[739]! } + public var Channel_Info_Description: String { return self._s[735]! } + public var Stickers_FavoriteStickers: String { return self._s[736]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[737]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[738]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[739]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[740]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[740]!, self._r[740]!, [_1, _2]) + return formatWithArgumentRanges(self._s[741]!, self._r[741]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[741]!, self._r[741]!, [_0]) + return formatWithArgumentRanges(self._s[742]!, self._r[742]!, [_0]) } - public var GroupPermission_Delete: String { return self._s[742]! } - public var Passport_Language_uk: String { return self._s[743]! } - public var StickerPack_HideStickers: String { return self._s[745]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[746]! } - public var Activity_UploadingVideoMessage: String { return self._s[747]! } + public var GroupPermission_Delete: String { return self._s[743]! } + public var Passport_Language_uk: String { return self._s[744]! } + public var StickerPack_HideStickers: String { return self._s[746]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[747]! } + public var Activity_UploadingVideoMessage: String { return self._s[748]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[748]!, self._r[748]!, [_0]) + return formatWithArgumentRanges(self._s[749]!, self._r[749]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[749]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[750]! } - public var Settings_CallSettings: String { return self._s[751]! } - public var Camera_SquareMode: String { return self._s[752]! } - public var GroupInfo_SharedMediaNone: String { return self._s[753]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[754]! } - public var Bot_GenericBotStatus: String { return self._s[755]! } + public var Channel_TitleInfo: String { return self._s[750]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[751]! } + public var Settings_CallSettings: String { return self._s[752]! } + public var Camera_SquareMode: String { return self._s[753]! } + public var GroupInfo_SharedMediaNone: String { return self._s[754]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[755]! } + public var Bot_GenericBotStatus: String { return self._s[756]! } public func CHANNEL_MESSAGE_ROUND_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[757]!, self._r[757]!, [_1]) + return formatWithArgumentRanges(self._s[758]!, self._r[758]!, [_1]) } - public var Month_ShortJanuary: String { return self._s[758]! } - public var Application_Update: String { return self._s[759]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[760]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[762]! } - public var Passport_Address_Street2Placeholder: String { return self._s[763]! } + public var Month_ShortJanuary: String { return self._s[759]! } + public var Application_Update: String { return self._s[760]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[761]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[763]! } + public var Passport_Address_Street2Placeholder: String { return self._s[764]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[764]!, self._r[764]!, [_0]) + return formatWithArgumentRanges(self._s[765]!, self._r[765]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[765]! } - public var Appearance_PreviewOutgoingText: String { return self._s[766]! } - public var Notifications_PermissionsAllowInSettings: String { return self._s[767]! } - public var Map_Directions: String { return self._s[768]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[770]! } - public var Appearance_ThemeDay: String { return self._s[771]! } + public var NetworkUsageSettings_Cellular: String { return self._s[766]! } + public var Appearance_PreviewOutgoingText: String { return self._s[767]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[768]! } + public var Map_Directions: String { return self._s[769]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[771]! } + public var Appearance_ThemeDay: String { return self._s[772]! } public func CHAT_MESSAGE_ROUND_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[772]!, self._r[772]!, [_1, _2]) + return formatWithArgumentRanges(self._s[773]!, self._r[773]!, [_1, _2]) } - public var Passport_Identity_AddPassport: String { return self._s[773]! } - public var Call_Message: String { return self._s[774]! } - public var PhotoEditor_ExposureTool: String { return self._s[775]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[777]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[779]! } + public var Passport_Identity_AddPassport: String { return self._s[774]! } + public var Call_Message: String { return self._s[775]! } + public var PhotoEditor_ExposureTool: String { return self._s[776]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[778]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[780]! } public func PINNED_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[780]!, self._r[780]!, [_1]) + return formatWithArgumentRanges(self._s[781]!, self._r[781]!, [_1]) } - public var Appearance_Preview: String { return self._s[781]! } - public var Compose_ChannelMembers: String { return self._s[782]! } - public var Conversation_DeleteManyMessages: String { return self._s[783]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[784]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[785]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[786]! } - public var Conversation_UpdateTelegram: String { return self._s[788]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[789]! } + public var Appearance_Preview: String { return self._s[782]! } + public var Compose_ChannelMembers: String { return self._s[783]! } + public var Conversation_DeleteManyMessages: String { return self._s[784]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[785]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[786]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[787]! } + public var Conversation_UpdateTelegram: String { return self._s[789]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[790]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[790]!, self._r[790]!, [_0]) + return formatWithArgumentRanges(self._s[791]!, self._r[791]!, [_0]) } - public var GroupInfo_Administrators_Title: String { return self._s[791]! } + public var GroupInfo_Administrators_Title: String { return self._s[792]! } public func MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[792]!, self._r[792]!, [_1, _2]) + return formatWithArgumentRanges(self._s[793]!, self._r[793]!, [_1, _2]) } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[793]!, self._r[793]!, [_0]) + return formatWithArgumentRanges(self._s[794]!, self._r[794]!, [_0]) } - public var Tour_Title3: String { return self._s[794]! } - public var Clipboard_SendPhoto: String { return self._s[798]! } - public var MediaPicker_Videos: String { return self._s[799]! } - public var Passport_Email_Title: String { return self._s[800]! } + public var Tour_Title3: String { return self._s[795]! } + public var Clipboard_SendPhoto: String { return self._s[799]! } + public var MediaPicker_Videos: String { return self._s[800]! } + public var Passport_Email_Title: String { return self._s[801]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[801]!, self._r[801]!, [_0]) + return formatWithArgumentRanges(self._s[802]!, self._r[802]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[802]! } - public var Conversation_MessageDialogDelete: String { return self._s[803]! } - public var Privacy_Calls_CustomHelp: String { return self._s[805]! } - public var GroupInfo_SetSound: String { return self._s[806]! } - public var Core_ServiceUserStatus: String { return self._s[807]! } - public var LiveLocationUpdated_JustNow: String { return self._s[808]! } + public var StickerPacksSettings_Title: String { return self._s[803]! } + public var Conversation_MessageDialogDelete: String { return self._s[804]! } + public var Privacy_Calls_CustomHelp: String { return self._s[806]! } + public var GroupInfo_SetSound: String { return self._s[807]! } + public var Core_ServiceUserStatus: String { return self._s[808]! } + public var LiveLocationUpdated_JustNow: String { return self._s[809]! } public func CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[809]!, self._r[809]!, [_1, _2]) + return formatWithArgumentRanges(self._s[810]!, self._r[810]!, [_1, _2]) } - public var Call_StatusFailed: String { return self._s[810]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[811]! } - public var TwoStepAuth_SetPassword: String { return self._s[812]! } + public var Call_StatusFailed: String { return self._s[811]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[812]! } + public var TwoStepAuth_SetPassword: String { return self._s[813]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[814]!, self._r[814]!, [_0]) + return formatWithArgumentRanges(self._s[815]!, self._r[815]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[815]! } - public var Profile_Username: String { return self._s[816]! } - public var Bot_DescriptionTitle: String { return self._s[817]! } - public var MaskStickerSettings_Title: String { return self._s[818]! } - public var SharedMedia_CategoryOther: String { return self._s[819]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[820]! } - public var Common_NotNow: String { return self._s[821]! } - public var Map_Location: String { return self._s[822]! } - public var Invitation_JoinGroup: String { return self._s[823]! } - public var AutoDownloadSettings_Title: String { return self._s[824]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[825]! } - public var Channel_ErrorAddBlocked: String { return self._s[826]! } - public var Conversation_UnblockUser: String { return self._s[827]! } - public var Watch_Bot_Restart: String { return self._s[828]! } - public var TwoStepAuth_Title: String { return self._s[829]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[830]! } - public var Checkout_ShippingMethod: String { return self._s[831]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[832]! } + public var Calls_SubmitRating: String { return self._s[816]! } + public var Profile_Username: String { return self._s[817]! } + public var Bot_DescriptionTitle: String { return self._s[818]! } + public var MaskStickerSettings_Title: String { return self._s[819]! } + public var SharedMedia_CategoryOther: String { return self._s[820]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[821]! } + public var Common_NotNow: String { return self._s[822]! } + public var Map_Location: String { return self._s[823]! } + public var Invitation_JoinGroup: String { return self._s[824]! } + public var AutoDownloadSettings_Title: String { return self._s[825]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[826]! } + public var Channel_ErrorAddBlocked: String { return self._s[827]! } + public var Conversation_UnblockUser: String { return self._s[828]! } + public var Watch_Bot_Restart: String { return self._s[829]! } + public var TwoStepAuth_Title: String { return self._s[830]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[831]! } + public var Checkout_ShippingMethod: String { return self._s[832]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[833]! } public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[834]!, self._r[834]!, [_0]) + return formatWithArgumentRanges(self._s[835]!, self._r[835]!, [_0]) } - public var AuthSessions_TerminateOtherSessions: String { return self._s[835]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[836]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[837]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[838]! } - public var Checkout_PaymentMethod_Title: String { return self._s[839]! } - public var SocksProxySetup_Connection: String { return self._s[840]! } - public var Group_MessagePhotoRemoved: String { return self._s[841]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[836]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[837]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[838]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[839]! } + public var Checkout_PaymentMethod_Title: String { return self._s[840]! } + public var SocksProxySetup_Connection: String { return self._s[841]! } + public var Group_MessagePhotoRemoved: String { return self._s[842]! } public func CHAT_DELETE_YOU_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[843]!, self._r[843]!, [_1, _2]) + return formatWithArgumentRanges(self._s[844]!, self._r[844]!, [_1, _2]) } - public var Channel_Stickers_NotFound: String { return self._s[844]! } - public var Group_About_Help: String { return self._s[845]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[846]! } + public var Channel_Stickers_NotFound: String { return self._s[845]! } + public var Group_About_Help: String { return self._s[846]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[847]! } public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[848]!, self._r[848]!, [_1]) + return formatWithArgumentRanges(self._s[849]!, self._r[849]!, [_1]) } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[850]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[851]! } - public var SocksProxySetup_Password: String { return self._s[852]! } - public var Notifications_PermissionsEnable: String { return self._s[853]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[855]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[851]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[852]! } + public var SocksProxySetup_Password: String { return self._s[853]! } + public var Notifications_PermissionsEnable: String { return self._s[854]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[856]! } public func MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[856]!, self._r[856]!, [_1, _2]) + return formatWithArgumentRanges(self._s[857]!, self._r[857]!, [_1, _2]) } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[857]!, self._r[857]!, [_1]) + return formatWithArgumentRanges(self._s[858]!, self._r[858]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[859]!, self._r[859]!, [_0]) + return formatWithArgumentRanges(self._s[860]!, self._r[860]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[860]! } - public var ArchivedPacksAlert_Title: String { return self._s[861]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[861]! } + public var ArchivedPacksAlert_Title: String { return self._s[862]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[862]!, self._r[862]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[863]!, self._r[863]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[863]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[864]! } - public var Conversation_StatusTyping: String { return self._s[865]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[866]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[867]! } - public var UserInfo_CreateNewContact: String { return self._s[868]! } - public var Passport_Identity_FrontSide: String { return self._s[869]! } - public var Calls_CallTabTitle: String { return self._s[871]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[872]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[864]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[865]! } + public var Conversation_StatusTyping: String { return self._s[866]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[867]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[868]! } + public var UserInfo_CreateNewContact: String { return self._s[869]! } + public var Passport_Identity_FrontSide: String { return self._s[870]! } + public var Calls_CallTabTitle: String { return self._s[872]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[873]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[873]!, self._r[873]!, [_0]) + return formatWithArgumentRanges(self._s[874]!, self._r[874]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[874]! } - public var SharedMedia_EmptyMusicText: String { return self._s[875]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[876]! } - public var Paint_Stickers: String { return self._s[877]! } - public var Privacy_GroupsAndChannels: String { return self._s[878]! } - public var UserInfo_AddContact: String { return self._s[880]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[875]! } + public var SharedMedia_EmptyMusicText: String { return self._s[876]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[877]! } + public var Paint_Stickers: String { return self._s[878]! } + public var Privacy_GroupsAndChannels: String { return self._s[879]! } + public var UserInfo_AddContact: String { return self._s[881]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[881]!, self._r[881]!, [_0]) + return formatWithArgumentRanges(self._s[882]!, self._r[882]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[883]! } - public var DialogList_NoMessagesTitle: String { return self._s[885]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[886]! } - public var BlockedUsers_BlockUser: String { return self._s[887]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[888]! } - public var MediaPicker_UngroupDescription: String { return self._s[889]! } - public var Watch_NoConnection: String { return self._s[890]! } - public var Month_GenSeptember: String { return self._s[891]! } - public var Conversation_ViewGroup: String { return self._s[892]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[895]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[896]! } - public var MediaPicker_CameraRoll: String { return self._s[898]! } - public var Month_GenAugust: String { return self._s[899]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[900]! } - public var SharedMedia_EmptyText: String { return self._s[901]! } - public var Map_ShareLiveLocation: String { return self._s[902]! } - public var Calls_All: String { return self._s[903]! } - public var Appearance_ThemeNight: String { return self._s[906]! } - public var Conversation_HoldForAudio: String { return self._s[907]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[910]! } - public var SocksProxySetup_Secret: String { return self._s[911]! } - public var Channel_BanList_RestrictedTitle: String { return self._s[913]! } - public var Conversation_Location: String { return self._s[914]! } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[916]! } - public var Notifications_PermissionsText: String { return self._s[917]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[918]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[920]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[922]! } - public var Passport_DeletePassportConfirmation: String { return self._s[924]! } - public var Login_InvalidCodeError: String { return self._s[925]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[926]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[884]! } + public var DialogList_NoMessagesTitle: String { return self._s[886]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[887]! } + public var BlockedUsers_BlockUser: String { return self._s[888]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[889]! } + public var MediaPicker_UngroupDescription: String { return self._s[890]! } + public var Watch_NoConnection: String { return self._s[891]! } + public var Month_GenSeptember: String { return self._s[892]! } + public var Conversation_ViewGroup: String { return self._s[893]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[896]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[897]! } + public var MediaPicker_CameraRoll: String { return self._s[899]! } + public var Month_GenAugust: String { return self._s[900]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[901]! } + public var SharedMedia_EmptyText: String { return self._s[902]! } + public var Map_ShareLiveLocation: String { return self._s[903]! } + public var Calls_All: String { return self._s[904]! } + public var Appearance_ThemeNight: String { return self._s[907]! } + public var Conversation_HoldForAudio: String { return self._s[908]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[911]! } + public var SocksProxySetup_Secret: String { return self._s[912]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[914]! } + public var Conversation_Location: String { return self._s[915]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[917]! } + public var Notifications_PermissionsText: String { return self._s[918]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[919]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[921]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[923]! } + public var Passport_DeletePassportConfirmation: String { return self._s[925]! } + public var Login_InvalidCodeError: String { return self._s[926]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[927]! } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[927]!, self._r[927]!, [_0]) + return formatWithArgumentRanges(self._s[928]!, self._r[928]!, [_0]) } - public var Call_CallInProgressTitle: String { return self._s[928]! } - public var Month_ShortSeptember: String { return self._s[929]! } - public var Watch_ChannelInfo_Title: String { return self._s[930]! } - public var DialogList_PasscodeLockHelp: String { return self._s[933]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[934]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[935]! } - public var PhotoEditor_CropReset: String { return self._s[936]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[938]! } - public var Channel_Management_LabelEditor: String { return self._s[939]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[941]! } - public var PhotoEditor_HighlightsTool: String { return self._s[942]! } - public var UserInfo_Title: String { return self._s[943]! } - public var AccessDenied_Title: String { return self._s[944]! } - public var DialogList_SearchLabel: String { return self._s[945]! } - public var Group_Setup_HistoryHidden: String { return self._s[946]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[947]! } - public var State_Updating: String { return self._s[949]! } - public var Contacts_TabTitle: String { return self._s[950]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[952]! } - public var GroupInfo_GroupHistory: String { return self._s[953]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[954]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[955]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[956]! } - public var Contacts_NotRegisteredSection: String { return self._s[957]! } + public var Call_CallInProgressTitle: String { return self._s[929]! } + public var Month_ShortSeptember: String { return self._s[930]! } + public var Watch_ChannelInfo_Title: String { return self._s[931]! } + public var DialogList_PasscodeLockHelp: String { return self._s[934]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[935]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[936]! } + public var PhotoEditor_CropReset: String { return self._s[937]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[939]! } + public var Channel_Management_LabelEditor: String { return self._s[940]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[942]! } + public var PhotoEditor_HighlightsTool: String { return self._s[943]! } + public var UserInfo_Title: String { return self._s[944]! } + public var AccessDenied_Title: String { return self._s[945]! } + public var DialogList_SearchLabel: String { return self._s[946]! } + public var Group_Setup_HistoryHidden: String { return self._s[947]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[948]! } + public var State_Updating: String { return self._s[950]! } + public var Contacts_TabTitle: String { return self._s[951]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[953]! } + public var GroupInfo_GroupHistory: String { return self._s[954]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[955]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[956]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[957]! } + public var Contacts_NotRegisteredSection: String { return self._s[958]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[958]!, self._r[958]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[959]!, self._r[959]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[959]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[960]! } - public var SocksProxySetup_Connecting: String { return self._s[961]! } - public var ExplicitContent_AlertChannel: String { return self._s[962]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[963]! } - public var Conversation_Contact: String { return self._s[964]! } - public var Login_CodeExpired: String { return self._s[965]! } - public var Passport_DiscardMessageAction: String { return self._s[966]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[967]! } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[968]! } - public var Month_ShortApril: String { return self._s[969]! } - public var AuthSessions_CurrentSession: String { return self._s[970]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[974]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[975]! } - public var Channel_Setup_TypePrivate: String { return self._s[977]! } - public var Forward_ChannelReadOnly: String { return self._s[980]! } - public var PhotoEditor_CurvesBlue: String { return self._s[981]! } - public var UserInfo_BotPrivacy: String { return self._s[982]! } - public var Notification_PassportValueEmail: String { return self._s[983]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[984]! } - public var GroupPermission_NewTitle: String { return self._s[985]! } - public var GroupInfo_Permissions_AddException: String { return self._s[986]! } - public var Channel_SignMessages_Help: String { return self._s[988]! } + public var Paint_Clear: String { return self._s[960]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[961]! } + public var SocksProxySetup_Connecting: String { return self._s[962]! } + public var ExplicitContent_AlertChannel: String { return self._s[963]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[964]! } + public var Conversation_Contact: String { return self._s[965]! } + public var Login_CodeExpired: String { return self._s[966]! } + public var Passport_DiscardMessageAction: String { return self._s[967]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[968]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[969]! } + public var Month_ShortApril: String { return self._s[970]! } + public var AuthSessions_CurrentSession: String { return self._s[971]! } + public var BackgroundPreview_Blurred: String { return self._s[972]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[976]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[977]! } + public var Channel_Setup_TypePrivate: String { return self._s[979]! } + public var Forward_ChannelReadOnly: String { return self._s[982]! } + public var PhotoEditor_CurvesBlue: String { return self._s[983]! } + public var UserInfo_BotPrivacy: String { return self._s[984]! } + public var Notification_PassportValueEmail: String { return self._s[985]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[986]! } + public var GroupPermission_NewTitle: String { return self._s[987]! } + public var GroupInfo_Permissions_AddException: String { return self._s[988]! } + public var Channel_SignMessages_Help: String { return self._s[990]! } public func CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[990]!, self._r[990]!, [_1, _2]) + return formatWithArgumentRanges(self._s[992]!, self._r[992]!, [_1, _2]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[991]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[992]! } - public var Passport_Language_pt: String { return self._s[993]! } - public var NotificationsSound_Popcorn: String { return self._s[996]! } - public var AutoNightTheme_Disabled: String { return self._s[997]! } - public var BlockedUsers_LeavePrefix: String { return self._s[998]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[999]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[993]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[994]! } + public var Passport_Language_pt: String { return self._s[995]! } + public var NotificationsSound_Popcorn: String { return self._s[998]! } + public var AutoNightTheme_Disabled: String { return self._s[999]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1000]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1001]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1000]!, self._r[1000]!, [_0]) + return formatWithArgumentRanges(self._s[1002]!, self._r[1002]!, [_0]) } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1001]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1002]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1003]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1003]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1004]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1005]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1004]!, self._r[1004]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1006]!, self._r[1006]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1006]! } - public var Compose_NewEncryptedChat: String { return self._s[1007]! } - public var Login_CodeFloodError: String { return self._s[1008]! } - public var Calls_TabTitle: String { return self._s[1009]! } - public var Passport_Language_he: String { return self._s[1010]! } + public var SocksProxySetup_Hostname: String { return self._s[1008]! } + public var Compose_NewEncryptedChat: String { return self._s[1009]! } + public var Login_CodeFloodError: String { return self._s[1010]! } + public var Calls_TabTitle: String { return self._s[1011]! } + public var Passport_Language_he: String { return self._s[1012]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1012]!, self._r[1012]!, [_0]) + return formatWithArgumentRanges(self._s[1014]!, self._r[1014]!, [_0]) } - public var GroupPermission_Title: String { return self._s[1013]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1014]! } - public var Tour_Text1: String { return self._s[1015]! } - public var Month_ShortFebruary: String { return self._s[1016]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1017]! } - public var NotificationsSound_Glass: String { return self._s[1018]! } - public var Appearance_ThemeNightBlue: String { return self._s[1019]! } - public var CheckoutInfo_Pay: String { return self._s[1020]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1022]! } - public var Call_CallAgain: String { return self._s[1024]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1025]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1026]! } - public var Passport_InvalidPasswordError: String { return self._s[1027]! } - public var Watch_Message_Game: String { return self._s[1028]! } + public var GroupPermission_Title: String { return self._s[1015]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1016]! } + public var Tour_Text1: String { return self._s[1017]! } + public var Month_ShortFebruary: String { return self._s[1018]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1019]! } + public var NotificationsSound_Glass: String { return self._s[1020]! } + public var Appearance_ThemeNightBlue: String { return self._s[1021]! } + public var CheckoutInfo_Pay: String { return self._s[1022]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1024]! } + public var Call_CallAgain: String { return self._s[1026]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1027]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1028]! } + public var Passport_InvalidPasswordError: String { return self._s[1029]! } + public var Watch_Message_Game: String { return self._s[1030]! } public func PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1029]!, self._r[1029]!, [_1]) + return formatWithArgumentRanges(self._s[1031]!, self._r[1031]!, [_1]) } - public var Stickers_Install: String { return self._s[1030]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1031]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1033]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1034]! } - public var AuthSessions_OtherSessions: String { return self._s[1035]! } - public var Channel_Username_Help: String { return self._s[1036]! } - public var Camera_Title: String { return self._s[1037]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1039]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1040]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1041]! } - public var Conversation_RestrictedStickers: String { return self._s[1042]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1044]! } - public var UserInfo_TelegramCall: String { return self._s[1046]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1047]! } - public var CreatePoll_OptionsHeader: String { return self._s[1048]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1049]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1050]! } + public var Stickers_Install: String { return self._s[1032]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1033]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1035]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1036]! } + public var AuthSessions_OtherSessions: String { return self._s[1037]! } + public var Channel_Username_Help: String { return self._s[1038]! } + public var Camera_Title: String { return self._s[1039]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1041]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1042]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1043]! } + public var Conversation_RestrictedStickers: String { return self._s[1044]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1046]! } + public var UserInfo_TelegramCall: String { return self._s[1048]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1049]! } + public var CreatePoll_OptionsHeader: String { return self._s[1050]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1051]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1052]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1051]!, self._r[1051]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1053]!, self._r[1053]!, [_1, _2, _3]) } - public var Settings_SaveEditedPhotos: String { return self._s[1052]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1053]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1054]! } - public var Conversation_MessageDialogRetry: String { return self._s[1055]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1056]! } - public var Group_Setup_TypeHeader: String { return self._s[1057]! } - public var Paint_RecentStickers: String { return self._s[1058]! } - public var PhotoEditor_GrainTool: String { return self._s[1059]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1060]! } - public var EmptyGroupInfo_Line4: String { return self._s[1061]! } - public var Watch_AuthRequired: String { return self._s[1064]! } + public var Settings_SaveEditedPhotos: String { return self._s[1054]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1055]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1056]! } + public var Conversation_MessageDialogRetry: String { return self._s[1057]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1058]! } + public var Group_Setup_TypeHeader: String { return self._s[1059]! } + public var Paint_RecentStickers: String { return self._s[1060]! } + public var PhotoEditor_GrainTool: String { return self._s[1061]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1062]! } + public var EmptyGroupInfo_Line4: String { return self._s[1063]! } + public var Watch_AuthRequired: String { return self._s[1066]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_0]) + return formatWithArgumentRanges(self._s[1068]!, self._r[1068]!, [_0]) } public func CHANNEL_MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1067]!, self._r[1067]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1069]!, self._r[1069]!, [_1, _2]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1068]! } - public var ChannelIntro_Text: String { return self._s[1069]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1070]! } - public var GroupPermission_NoSendMedia: String { return self._s[1071]! } - public var Calls_AddTab: String { return self._s[1072]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1073]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1074]! } - public var Notification_MessageLifetime1d: String { return self._s[1075]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1076]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1077]! } - public var Passport_Identity_GenderFemale: String { return self._s[1078]! } - public var BlockedUsers_BlockTitle: String { return self._s[1079]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1070]! } + public var ChannelIntro_Text: String { return self._s[1071]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1072]! } + public var GroupPermission_NoSendMedia: String { return self._s[1073]! } + public var Calls_AddTab: String { return self._s[1074]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1075]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1076]! } + public var Notification_MessageLifetime1d: String { return self._s[1077]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1078]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1079]! } + public var Passport_Identity_GenderFemale: String { return self._s[1080]! } + public var BlockedUsers_BlockTitle: String { return self._s[1081]! } public func MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1080]!, self._r[1080]!, [_1]) + return formatWithArgumentRanges(self._s[1082]!, self._r[1082]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1081]! } - public var AutoNightTheme_Scheduled: String { return self._s[1082]! } + public var Weekday_Yesterday: String { return self._s[1083]! } + public var AutoNightTheme_Scheduled: String { return self._s[1084]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1083]!, self._r[1083]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1085]!, self._r[1085]!, [_1, _2, _3, _4, _5, _6]) } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1084]! } - public var CreatePoll_Create: String { return self._s[1085]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1086]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1086]! } + public var CreatePoll_Create: String { return self._s[1087]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1088]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1087]!, self._r[1087]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1089]!, self._r[1089]!, [_1, _2]) } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1088]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1089]! } - public var Preview_OpenInInstagram: String { return self._s[1090]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1091]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1090]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1091]! } + public var Preview_OpenInInstagram: String { return self._s[1092]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1093]! } public func CHANNEL_MESSAGE_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1092]!, self._r[1092]!, [_1]) + return formatWithArgumentRanges(self._s[1094]!, self._r[1094]!, [_1]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1093]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1095]! } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1094]!, self._r[1094]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1096]!, self._r[1096]!, [_1, _2]) } - public var NetworkUsageSettings_TotalSection: String { return self._s[1095]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1097]! } public func PINNED_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1096]!, self._r[1096]!, [_1]) + return formatWithArgumentRanges(self._s[1098]!, self._r[1098]!, [_1]) } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1097]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1099]! } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1100]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1099]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1101]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1102]! } public func MESSAGE_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1101]!, self._r[1101]!, [_1]) + return formatWithArgumentRanges(self._s[1103]!, self._r[1103]!, [_1]) } - public var FastTwoStepSetup_HintSection: String { return self._s[1102]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1103]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1104]! } - public var GroupInfo_ActionPromote: String { return self._s[1105]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1106]! } - public var GroupInfo_Permissions_Title: String { return self._s[1107]! } - public var Permissions_ContactsText_v0: String { return self._s[1108]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1111]! } - public var Passport_FieldEmailHelp: String { return self._s[1112]! } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1113]! } - public var Weekday_ShortSaturday: String { return self._s[1114]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1115]! } - public var Watch_Conversation_UserInfo: String { return self._s[1116]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1117]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1118]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1119]! } - public var PhotoEditor_VignetteTool: String { return self._s[1120]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1121]! } - public var Passport_Language_et: String { return self._s[1122]! } - public var Passport_Language_bg: String { return self._s[1124]! } - public var Stickers_NoStickersFound: String { return self._s[1126]! } - public var Settings_About: String { return self._s[1128]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1104]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1105]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1106]! } + public var GroupInfo_ActionPromote: String { return self._s[1107]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1108]! } + public var GroupInfo_Permissions_Title: String { return self._s[1109]! } + public var Permissions_ContactsText_v0: String { return self._s[1110]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1113]! } + public var Passport_FieldEmailHelp: String { return self._s[1114]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1115]! } + public var Weekday_ShortSaturday: String { return self._s[1116]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1117]! } + public var Watch_Conversation_UserInfo: String { return self._s[1118]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1119]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1120]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1121]! } + public var PhotoEditor_VignetteTool: String { return self._s[1122]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1123]! } + public var Passport_Language_et: String { return self._s[1124]! } + public var Passport_Language_bg: String { return self._s[1126]! } + public var Stickers_NoStickersFound: String { return self._s[1128]! } + public var Settings_About: String { return self._s[1130]! } public func CHAT_MESSAGE_POLL_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1129]!, self._r[1129]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1131]!, self._r[1131]!, [_1, _2]) } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1130]!, self._r[1130]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1132]!, self._r[1132]!, [_0, _1, _2]) } - public var KeyCommand_NewMessage: String { return self._s[1132]! } - public var Group_ErrorAddBlocked: String { return self._s[1133]! } + public var KeyCommand_NewMessage: String { return self._s[1134]! } + public var Group_ErrorAddBlocked: String { return self._s[1135]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1134]!, self._r[1134]!, [_0]) + return formatWithArgumentRanges(self._s[1136]!, self._r[1136]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1135]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1136]! } - public var Cache_ClearProgress: String { return self._s[1137]! } + public var Map_LocationTitle: String { return self._s[1137]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1138]! } + public var Cache_ClearProgress: String { return self._s[1139]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1138]!, self._r[1138]!, [_0]) + return formatWithArgumentRanges(self._s[1140]!, self._r[1140]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1139]! } - public var Passport_UpdateRequiredError: String { return self._s[1140]! } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1142]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1143]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1144]! } - public var Passport_Language_ka: String { return self._s[1145]! } - public var Call_Decline: String { return self._s[1146]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1147]! } + public var GroupRemoved_AddToGroup: String { return self._s[1141]! } + public var Passport_UpdateRequiredError: String { return self._s[1142]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1144]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1145]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1146]! } + public var Passport_Language_ka: String { return self._s[1147]! } + public var Call_Decline: String { return self._s[1148]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1149]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1150]!, self._r[1150]!, [_0]) + return formatWithArgumentRanges(self._s[1152]!, self._r[1152]!, [_0]) } public func CHANNEL_MESSAGE_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1151]!, self._r[1151]!, [_1]) + return formatWithArgumentRanges(self._s[1153]!, self._r[1153]!, [_1]) } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1152]!, self._r[1152]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1154]!, self._r[1154]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1153]! } - public var Passport_DeletePassport: String { return self._s[1155]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1156]! } - public var Month_ShortDecember: String { return self._s[1157]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1159]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1155]! } + public var Passport_DeletePassport: String { return self._s[1157]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1158]! } + public var Month_ShortDecember: String { return self._s[1159]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1161]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1160]!, self._r[1160]!, [_0]) + return formatWithArgumentRanges(self._s[1162]!, self._r[1162]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1161]! } - public var Conversation_EncryptedDescription1: String { return self._s[1162]! } - public var Conversation_EncryptedDescription2: String { return self._s[1163]! } - public var Conversation_EncryptedDescription3: String { return self._s[1164]! } - public var PhotoEditor_SharpenTool: String { return self._s[1165]! } + public var Channel_Stickers_Searching: String { return self._s[1163]! } + public var Conversation_EncryptedDescription1: String { return self._s[1164]! } + public var Conversation_EncryptedDescription2: String { return self._s[1165]! } + public var Conversation_EncryptedDescription3: String { return self._s[1166]! } + public var PhotoEditor_SharpenTool: String { return self._s[1167]! } public func ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1166]!, self._r[1166]!, [_1]) + return formatWithArgumentRanges(self._s[1168]!, self._r[1168]!, [_1]) } - public var Conversation_EncryptedDescription4: String { return self._s[1168]! } - public var Channel_Members_AddMembers: String { return self._s[1169]! } + public var Conversation_EncryptedDescription4: String { return self._s[1170]! } + public var Channel_Members_AddMembers: String { return self._s[1171]! } + public var Wallpaper_Search: String { return self._s[1172]! } public func CHANNEL_MESSAGE_GAME_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1170]!, self._r[1170]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1173]!, self._r[1173]!, [_1, _2]) } public func CHAT_MESSAGE_GEOLIVE_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1171]!, self._r[1171]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1174]!, self._r[1174]!, [_1, _2]) } - public var Weekday_Friday: String { return self._s[1172]! } - public var Privacy_ContactsSync: String { return self._s[1173]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1174]! } + public var Weekday_Friday: String { return self._s[1175]! } + public var Privacy_ContactsSync: String { return self._s[1176]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1177]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1175]!, self._r[1175]!, [_0]) - } - public var GroupInfo_Permissions_Removed: String { return self._s[1176]! } - public var Passport_Identity_GenderMale: String { return self._s[1177]! } - public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1178]!, self._r[1178]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1179]! } - public var Conversation_JumpToDate: String { return self._s[1180]! } - public var Contacts_GlobalSearch: String { return self._s[1181]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1182]! } - public var Profile_MessageLifetime1d: String { return self._s[1183]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1179]! } + public var Passport_Identity_GenderMale: String { return self._s[1180]! } + public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1181]!, self._r[1181]!, [_0]) + } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1182]! } + public var Conversation_JumpToDate: String { return self._s[1183]! } + public var Contacts_GlobalSearch: String { return self._s[1184]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1185]! } + public var Profile_MessageLifetime1d: String { return self._s[1186]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1184]!, self._r[1184]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1187]!, self._r[1187]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1187]! } - public var Passport_InfoTitle: String { return self._s[1189]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1190]! } + public var StickerPack_BuiltinPackName: String { return self._s[1190]! } + public var Passport_InfoTitle: String { return self._s[1192]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1193]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1194]!, self._r[1194]!, [_0]) + return formatWithArgumentRanges(self._s[1197]!, self._r[1197]!, [_0]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1195]! } - public var Profile_BotInfo: String { return self._s[1196]! } - public var Watch_Compose_CreateMessage: String { return self._s[1197]! } - public var Month_ShortNovember: String { return self._s[1198]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1198]! } + public var Profile_BotInfo: String { return self._s[1199]! } + public var Watch_Compose_CreateMessage: String { return self._s[1200]! } + public var Month_ShortNovember: String { return self._s[1201]! } public func PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1199]!, self._r[1199]!, [_1]) + return formatWithArgumentRanges(self._s[1202]!, self._r[1202]!, [_1]) } public func ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1200]!, self._r[1200]!, [_1]) + return formatWithArgumentRanges(self._s[1203]!, self._r[1203]!, [_1]) } - public var Passport_Identity_TranslationsHelp: String { return self._s[1201]! } - public var NotificationsSound_Chime: String { return self._s[1202]! } - public var Passport_Language_ko: String { return self._s[1204]! } - public var InviteText_URL: String { return self._s[1205]! } - public var TextFormat_Monospace: String { return self._s[1206]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1204]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1205]! } + public var NotificationsSound_Chime: String { return self._s[1206]! } + public var Passport_Language_ko: String { return self._s[1208]! } + public var InviteText_URL: String { return self._s[1209]! } + public var TextFormat_Monospace: String { return self._s[1210]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1207]!, self._r[1207]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1211]!, self._r[1211]!, [_1, _2, _3]) } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1208]!, self._r[1208]!, [_0]) + return formatWithArgumentRanges(self._s[1212]!, self._r[1212]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1209]!, self._r[1209]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1213]!, self._r[1213]!, [_1, _2]) } - public var Passport_InfoLearnMore: String { return self._s[1211]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1212]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1213]! } - public var Your_card_has_expired: String { return self._s[1214]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1215]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1216]! } - public var Conversation_Report: String { return self._s[1219]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1220]! } - public var Notification_MessageLifetime1m: String { return self._s[1221]! } - public var Privacy_ContactsTitle: String { return self._s[1222]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1223]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1224]! } - public var Channel_Members_Title: String { return self._s[1225]! } - public var Map_OpenInWaze: String { return self._s[1226]! } - public var Login_PhoneBannedError: String { return self._s[1227]! } + public var Passport_InfoLearnMore: String { return self._s[1215]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1216]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1217]! } + public var Your_card_has_expired: String { return self._s[1218]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1219]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1220]! } + public var Conversation_Report: String { return self._s[1223]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1224]! } + public var Notification_MessageLifetime1m: String { return self._s[1225]! } + public var Privacy_ContactsTitle: String { return self._s[1226]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1227]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1228]! } + public var Channel_Members_Title: String { return self._s[1229]! } + public var Map_OpenInWaze: String { return self._s[1230]! } + public var Login_PhoneBannedError: String { return self._s[1231]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1228]!, self._r[1228]!, [_0]) + return formatWithArgumentRanges(self._s[1232]!, self._r[1232]!, [_0]) } public func MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1229]!, self._r[1229]!, [_1]) + return formatWithArgumentRanges(self._s[1233]!, self._r[1233]!, [_1]) } - public var Group_Management_AddModeratorHelp: String { return self._s[1230]! } - public var Common_OK: String { return self._s[1231]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1232]! } - public var Cache_Music: String { return self._s[1233]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1234]! } + public var Common_OK: String { return self._s[1235]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1236]! } + public var Cache_Music: String { return self._s[1237]! } public func CHAT_TITLE_EDITED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1234]!, self._r[1234]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1238]!, self._r[1238]!, [_1, _2]) } public func PINNED_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1235]!, self._r[1235]!, [_1]) + return formatWithArgumentRanges(self._s[1239]!, self._r[1239]!, [_1]) } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1236]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1237]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1240]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1241]! } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1238]!, self._r[1238]!, [_0]) + return formatWithArgumentRanges(self._s[1242]!, self._r[1242]!, [_0]) } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1240]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1241]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1243]! } - public var State_ConnectingToProxyInfo: String { return self._s[1244]! } - public var Message_VideoMessage: String { return self._s[1246]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1247]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1244]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1245]! } + public var BackgroundPreview_SwipeInfo: String { return self._s[1247]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1248]! } + public var State_ConnectingToProxyInfo: String { return self._s[1249]! } + public var Message_VideoMessage: String { return self._s[1251]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1252]! } public func CHAT_MESSAGE_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1248]!, self._r[1248]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1253]!, self._r[1253]!, [_1, _2]) } - public var ContactInfo_PhoneLabelOther: String { return self._s[1249]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1250]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1251]! } - public var Activity_RecordingAudio: String { return self._s[1252]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1253]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1254]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1255]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1256]! } + public var Activity_RecordingAudio: String { return self._s[1257]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1258]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1255]!, self._r[1255]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1260]!, self._r[1260]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1258]!, self._r[1258]!, [_0]) + return formatWithArgumentRanges(self._s[1263]!, self._r[1263]!, [_0]) } - public var Conversation_ApplyLocalization: String { return self._s[1259]! } - public var UserInfo_AddPhone: String { return self._s[1260]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1261]! } + public var Conversation_ApplyLocalization: String { return self._s[1264]! } + public var UserInfo_AddPhone: String { return self._s[1265]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1266]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1262]!, self._r[1262]!, [_0]) + return formatWithArgumentRanges(self._s[1267]!, self._r[1267]!, [_0]) } - public var Passport_Scans: String { return self._s[1264]! } - public var BlockedUsers_Unblock: String { return self._s[1265]! } - public var Channel_Management_LabelCreator: String { return self._s[1266]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1267]! } + public var Passport_Scans: String { return self._s[1269]! } + public var BlockedUsers_Unblock: String { return self._s[1270]! } + public var Channel_Management_LabelCreator: String { return self._s[1271]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1272]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1268]!, self._r[1268]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1273]!, self._r[1273]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1269]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1270]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1271]! } - public var ChannelIntro_CreateChannel: String { return self._s[1272]! } - public var Conversation_UnreadMessages: String { return self._s[1273]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1274]! } - public var Notification_GroupActivated: String { return self._s[1275]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1276]! } + public var Login_PhoneNumberHelp: String { return self._s[1274]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1275]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1276]! } + public var ChannelIntro_CreateChannel: String { return self._s[1277]! } + public var Conversation_UnreadMessages: String { return self._s[1278]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1279]! } + public var Notification_GroupActivated: String { return self._s[1280]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1281]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1277]!, self._r[1277]!, [_0]) + return formatWithArgumentRanges(self._s[1282]!, self._r[1282]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1278]!, self._r[1278]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1283]!, self._r[1283]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1280]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1285]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1281]!, self._r[1281]!, [_0]) + return formatWithArgumentRanges(self._s[1286]!, self._r[1286]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1282]! } + public var Document_TargetConfirmationFormat: String { return self._s[1287]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1283]!, self._r[1283]!, [_0]) + return formatWithArgumentRanges(self._s[1288]!, self._r[1288]!, [_0]) } - public var Contacts_SortByName: String { return self._s[1284]! } + public var Contacts_SortByName: String { return self._s[1289]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1286]!, self._r[1286]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1291]!, self._r[1291]!, [_1, _2, _3]) } - public var Conversation_ClearSelfHistory: String { return self._s[1287]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1288]! } - public var Stickers_SuggestNone: String { return self._s[1289]! } - public var ChatSettings_Cache: String { return self._s[1290]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1291]! } - public var Media_ShareThisPhoto: String { return self._s[1292]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1293]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1294]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1295]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1296]! } - public var Permissions_CellularDataTitle_v0: String { return self._s[1297]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1298]! } - public var Map_OpenIn: String { return self._s[1299]! } + public var Conversation_ClearSelfHistory: String { return self._s[1292]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1293]! } + public var Stickers_SuggestNone: String { return self._s[1294]! } + public var ChatSettings_Cache: String { return self._s[1295]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1296]! } + public var Media_ShareThisPhoto: String { return self._s[1297]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1298]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1299]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1300]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1301]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1302]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1303]! } + public var Map_OpenIn: String { return self._s[1304]! } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1302]!, self._r[1302]!, [_0]) + return formatWithArgumentRanges(self._s[1307]!, self._r[1307]!, [_0]) } - public var MessagePoll_LabelClosed: String { return self._s[1303]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1305]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1306]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1307]! } - public var Login_SelectCountry_Title: String { return self._s[1308]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1309]! } - public var Watch_Suggestion_BRB: String { return self._s[1310]! } - public var Contacts_PermissionsTitle: String { return self._s[1311]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1312]! } - public var Conversation_RestrictedInline: String { return self._s[1313]! } - public var StickerPack_ViewPack: String { return self._s[1315]! } + public var MessagePoll_LabelClosed: String { return self._s[1308]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1310]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1311]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1312]! } + public var Login_SelectCountry_Title: String { return self._s[1313]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1314]! } + public var Watch_Suggestion_BRB: String { return self._s[1315]! } + public var Contacts_PermissionsTitle: String { return self._s[1316]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1317]! } + public var Conversation_RestrictedInline: String { return self._s[1318]! } + public var StickerPack_ViewPack: String { return self._s[1320]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1316]!, self._r[1316]!, [_0]) + return formatWithArgumentRanges(self._s[1321]!, self._r[1321]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1318]! } - public var Channel_Info_Stickers: String { return self._s[1322]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1323]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1324]! } - public var Passport_DeletePersonalDetails: String { return self._s[1325]! } - public var Conversation_SearchNoResults: String { return self._s[1327]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1328]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1329]! } - public var Login_Code: String { return self._s[1330]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1331]! } - public var Weekday_ShortThursday: String { return self._s[1332]! } - public var Resolve_ErrorNotFound: String { return self._s[1334]! } - public var LastSeen_Offline: String { return self._s[1335]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1336]! } - public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1337]! } - public var GroupInfo_Title: String { return self._s[1338]! } - public var NotificationsSound_Note: String { return self._s[1339]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1340]! } - public var Watch_Message_Poll: String { return self._s[1341]! } - public var Privacy_Calls: String { return self._s[1342]! } + public var Compose_NewChannel: String { return self._s[1323]! } + public var Channel_Info_Stickers: String { return self._s[1327]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1328]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1329]! } + public var Passport_DeletePersonalDetails: String { return self._s[1330]! } + public var Conversation_SearchNoResults: String { return self._s[1332]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1333]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1334]! } + public var Login_Code: String { return self._s[1335]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1336]! } + public var Weekday_ShortThursday: String { return self._s[1337]! } + public var Resolve_ErrorNotFound: String { return self._s[1339]! } + public var LastSeen_Offline: String { return self._s[1340]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1341]! } + public var Channel_AdminLog_CanChangeInviteLink: String { return self._s[1342]! } + public var GroupInfo_Title: String { return self._s[1343]! } + public var NotificationsSound_Note: String { return self._s[1344]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1345]! } + public var Watch_Message_Poll: String { return self._s[1346]! } + public var Privacy_Calls: String { return self._s[1347]! } public func CHANNEL_MESSAGE_PHOTO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1343]!, self._r[1343]!, [_1]) + return formatWithArgumentRanges(self._s[1348]!, self._r[1348]!, [_1]) } - public var Month_ShortAugust: String { return self._s[1344]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1345]! } - public var Notifications_Reset: String { return self._s[1346]! } - public var Conversation_Pin: String { return self._s[1347]! } - public var Passport_Language_lv: String { return self._s[1348]! } - public var BlockedUsers_Info: String { return self._s[1349]! } - public var Watch_Conversation_Unblock: String { return self._s[1352]! } + public var Month_ShortAugust: String { return self._s[1349]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1350]! } + public var Notifications_Reset: String { return self._s[1351]! } + public var Conversation_Pin: String { return self._s[1352]! } + public var Passport_Language_lv: String { return self._s[1353]! } + public var BlockedUsers_Info: String { return self._s[1354]! } + public var Watch_Conversation_Unblock: String { return self._s[1357]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1353]!, self._r[1353]!, [_0]) + return formatWithArgumentRanges(self._s[1358]!, self._r[1358]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1354]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1355]! } + public var CloudStorage_Title: String { return self._s[1359]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1360]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1356]!, self._r[1356]!, [_0]) + return formatWithArgumentRanges(self._s[1361]!, self._r[1361]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1357]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1358]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1359]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1362]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1363]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1364]! } public func MESSAGE_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1360]!, self._r[1360]!, [_1]) + return formatWithArgumentRanges(self._s[1365]!, self._r[1365]!, [_1]) } - public var Passport_Address_EditBankStatement: String { return self._s[1361]! } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1362]! } - public var ShareMenu_Comment: String { return self._s[1363]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1364]! } - public var Notifications_PermissionsTitle: String { return self._s[1365]! } - public var GroupPermission_NoSendLinks: String { return self._s[1366]! } - public var Settings_Support: String { return self._s[1367]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1368]! } + public var Passport_Address_EditBankStatement: String { return self._s[1366]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1367]! } + public var ShareMenu_Comment: String { return self._s[1368]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1369]! } + public var Notifications_PermissionsTitle: String { return self._s[1370]! } + public var GroupPermission_NoSendLinks: String { return self._s[1371]! } + public var Settings_Support: String { return self._s[1372]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1373]! } public func CHAT_RETURNED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1369]!, self._r[1369]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1374]!, self._r[1374]!, [_1, _2]) } - public var GroupPermission_ApplyAlertAction: String { return self._s[1370]! } - public var Channel_AdminLog_BanSendGifs: String { return self._s[1371]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1372]! } - public var Common_Select: String { return self._s[1374]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1375]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1377]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1378]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1379]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1380]! } - public var Widget_AuthRequired: String { return self._s[1381]! } - public var Camera_FlashOn: String { return self._s[1382]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1383]! } - public var Watch_Suggestion_OK: String { return self._s[1384]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1375]! } + public var Channel_AdminLog_BanSendGifs: String { return self._s[1376]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1377]! } + public var Common_Select: String { return self._s[1379]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1380]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1382]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1383]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1384]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1385]! } + public var Widget_AuthRequired: String { return self._s[1386]! } + public var Camera_FlashOn: String { return self._s[1387]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1388]! } + public var Watch_Suggestion_OK: String { return self._s[1389]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1386]!, self._r[1386]!, [_0]) + return formatWithArgumentRanges(self._s[1391]!, self._r[1391]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1387]!, self._r[1387]!, [_0]) + return formatWithArgumentRanges(self._s[1392]!, self._r[1392]!, [_0]) } - public var DialogList_AdLabel: String { return self._s[1388]! } - public var WatchRemote_NotificationText: String { return self._s[1389]! } - public var Conversation_ReportSpam: String { return self._s[1390]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1392]! } - public var PhoneLabel_Title: String { return self._s[1393]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1394]! } - public var Notifications_ExceptionsTitle: String { return self._s[1395]! } + public var DialogList_AdLabel: String { return self._s[1393]! } + public var WatchRemote_NotificationText: String { return self._s[1394]! } + public var Conversation_ReportSpam: String { return self._s[1395]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1397]! } + public var PhoneLabel_Title: String { return self._s[1398]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1399]! } + public var Notifications_ExceptionsTitle: String { return self._s[1400]! } public func CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1396]!, self._r[1396]!, [_1]) + return formatWithArgumentRanges(self._s[1401]!, self._r[1401]!, [_1]) } - public var Notifications_AlertTones: String { return self._s[1397]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1398]! } + public var Notifications_AlertTones: String { return self._s[1402]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1403]! } public func CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1399]!, self._r[1399]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1404]!, self._r[1404]!, [_1, _2, _3]) } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1400]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1402]! } - public var ReportPeer_ReasonOther: String { return self._s[1403]! } - public var KeyCommand_ScrollDown: String { return self._s[1405]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1405]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1407]! } + public var ReportPeer_ReasonOther: String { return self._s[1408]! } + public var KeyCommand_ScrollDown: String { return self._s[1410]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1406]!, self._r[1406]!, [_0]) + return formatWithArgumentRanges(self._s[1411]!, self._r[1411]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1407]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1408]! } - public var AuthSessions_LogOut: String { return self._s[1409]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1412]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1413]! } + public var AuthSessions_LogOut: String { return self._s[1414]! } public func CHAT_PHOTO_EDITED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1410]!, self._r[1410]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1415]!, self._r[1415]!, [_1, _2]) } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1411]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1412]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1416]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1417]! } public func CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1413]!, self._r[1413]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1418]!, self._r[1418]!, [_1, _2]) } - public var Passport_Phone_Title: String { return self._s[1414]! } - public var Settings_PhoneNumber: String { return self._s[1415]! } - public var NotificationsSound_Alert: String { return self._s[1416]! } - public var PhotoEditor_CurvesTool: String { return self._s[1418]! } - public var Checkout_PaymentMethod: String { return self._s[1420]! } - public var Contacts_AccessDeniedError: String { return self._s[1421]! } - public var Camera_PhotoMode: String { return self._s[1424]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1425]! } - public var CallSettings_OnMobile: String { return self._s[1426]! } - public var Tour_Text2: String { return self._s[1427]! } + public var Passport_Phone_Title: String { return self._s[1419]! } + public var Settings_PhoneNumber: String { return self._s[1420]! } + public var NotificationsSound_Alert: String { return self._s[1421]! } + public var PhotoEditor_CurvesTool: String { return self._s[1423]! } + public var Checkout_PaymentMethod: String { return self._s[1425]! } + public var Contacts_AccessDeniedError: String { return self._s[1426]! } + public var Camera_PhotoMode: String { return self._s[1429]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1430]! } + public var CallSettings_OnMobile: String { return self._s[1431]! } + public var Tour_Text2: String { return self._s[1432]! } public func MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1429]!, self._r[1429]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1434]!, self._r[1434]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1430]! } - public var Permissions_Skip: String { return self._s[1431]! } - public var SecretImage_Title: String { return self._s[1432]! } - public var Watch_MessageView_Title: String { return self._s[1433]! } - public var AttachmentMenu_Poll: String { return self._s[1434]! } + public var DialogList_EncryptionProcessing: String { return self._s[1435]! } + public var Permissions_Skip: String { return self._s[1436]! } + public var SecretImage_Title: String { return self._s[1437]! } + public var Watch_MessageView_Title: String { return self._s[1438]! } + public var AttachmentMenu_Poll: String { return self._s[1439]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1435]!, self._r[1435]!, [_0]) + return formatWithArgumentRanges(self._s[1440]!, self._r[1440]!, [_0]) } - public var Notification_CallCanceled: String { return self._s[1436]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1437]! } + public var Notification_CallCanceled: String { return self._s[1441]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1442]! } public func MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1438]!, self._r[1438]!, [_1]) + return formatWithArgumentRanges(self._s[1443]!, self._r[1443]!, [_1]) } public func CHAT_JOINED_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1439]!, self._r[1439]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1444]!, self._r[1444]!, [_1, _2]) } - public var Settings_ProxyConnecting: String { return self._s[1440]! } - public var Profile_MessageLifetime5s: String { return self._s[1442]! } - public var Username_InvalidCharacters: String { return self._s[1443]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1444]! } + public var Settings_ProxyConnecting: String { return self._s[1445]! } + public var Profile_MessageLifetime5s: String { return self._s[1447]! } + public var Username_InvalidCharacters: String { return self._s[1448]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1449]! } public func CHAT_MESSAGE_GAME_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1445]!, self._r[1445]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1450]!, self._r[1450]!, [_1, _2, _3]) } - public var Notification_CreatedChannel: String { return self._s[1447]! } - public var Passcode_AppLockedAlert: String { return self._s[1449]! } - public var Contacts_TopSection: String { return self._s[1450]! } + public var Notification_CreatedChannel: String { return self._s[1452]! } + public var Passcode_AppLockedAlert: String { return self._s[1454]! } + public var Contacts_TopSection: String { return self._s[1455]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1451]!, self._r[1451]!, [_0]) + return formatWithArgumentRanges(self._s[1456]!, self._r[1456]!, [_0]) } public func CHAT_MESSAGE_DOC_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1457]!, self._r[1457]!, [_1, _2]) } - public var ReportPeer_ReasonSpam: String { return self._s[1453]! } - public var UserInfo_TapToCall: String { return self._s[1454]! } - public var Common_Search: String { return self._s[1456]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1457]! } - public var Message_InvoiceLabel: String { return self._s[1458]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1459]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1460]! } + public var ReportPeer_ReasonSpam: String { return self._s[1458]! } + public var UserInfo_TapToCall: String { return self._s[1459]! } + public var Common_Search: String { return self._s[1461]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1462]! } + public var Message_InvoiceLabel: String { return self._s[1463]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1464]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1465]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1461]!, self._r[1461]!, [_0]) + return formatWithArgumentRanges(self._s[1466]!, self._r[1466]!, [_0]) } public func MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1462]!, self._r[1462]!, [_1]) + return formatWithArgumentRanges(self._s[1467]!, self._r[1467]!, [_1]) } - public var Conversation_Info: String { return self._s[1463]! } - public var Login_InfoDeletePhoto: String { return self._s[1464]! } - public var Passport_Language_vi: String { return self._s[1466]! } - public var Conversation_Search: String { return self._s[1467]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1468]! } + public var Conversation_Info: String { return self._s[1468]! } + public var Login_InfoDeletePhoto: String { return self._s[1469]! } + public var Passport_Language_vi: String { return self._s[1471]! } + public var Conversation_Search: String { return self._s[1472]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1473]! } public func MESSAGE_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1469]!, self._r[1469]!, [_1]) + return formatWithArgumentRanges(self._s[1474]!, self._r[1474]!, [_1]) } - public var ReportPeer_ReasonPornography: String { return self._s[1470]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[1471]! } + public var ReportPeer_ReasonPornography: String { return self._s[1475]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[1476]! } public func CHAT_MESSAGE_PHOTO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1472]!, self._r[1472]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_1, _2]) } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1473]! } - public var Map_LiveLocationGroupDescription: String { return self._s[1474]! } - public var Channel_Setup_TypeHeader: String { return self._s[1475]! } - public var AuthSessions_LoggedIn: String { return self._s[1476]! } - public var Login_SmsRequestState3: String { return self._s[1477]! } - public var Passport_Address_EditUtilityBill: String { return self._s[1478]! } - public var Appearance_ReduceMotionInfo: String { return self._s[1479]! } - public var Channel_Edit_LinkItem: String { return self._s[1480]! } - public var Privacy_Calls_P2PNever: String { return self._s[1481]! } - public var Conversation_AddToReadingList: String { return self._s[1483]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1478]! } + public var Map_LiveLocationGroupDescription: String { return self._s[1479]! } + public var Channel_Setup_TypeHeader: String { return self._s[1480]! } + public var AuthSessions_LoggedIn: String { return self._s[1481]! } + public var Login_SmsRequestState3: String { return self._s[1482]! } + public var Passport_Address_EditUtilityBill: String { return self._s[1483]! } + public var Appearance_ReduceMotionInfo: String { return self._s[1484]! } + public var Channel_Edit_LinkItem: String { return self._s[1485]! } + public var Privacy_Calls_P2PNever: String { return self._s[1486]! } + public var Conversation_AddToReadingList: String { return self._s[1488]! } public func MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1484]!, self._r[1484]!, [_1]) + return formatWithArgumentRanges(self._s[1489]!, self._r[1489]!, [_1]) } - public var Message_Animation: String { return self._s[1485]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[1486]! } - public var Map_Unknown: String { return self._s[1487]! } - public var Call_StatusRequesting: String { return self._s[1488]! } + public var Message_Animation: String { return self._s[1490]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[1491]! } + public var Map_Unknown: String { return self._s[1492]! } + public var Call_StatusRequesting: String { return self._s[1493]! } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1489]!, self._r[1489]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1494]!, self._r[1494]!, [_1, _2]) } - public var Conversation_SecretChatContextBotAlert: String { return self._s[1490]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1491]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[1495]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1496]! } public func MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1492]!, self._r[1492]!, [_1]) + return formatWithArgumentRanges(self._s[1497]!, self._r[1497]!, [_1]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1493]!, self._r[1493]!, [_0]) + return formatWithArgumentRanges(self._s[1498]!, self._r[1498]!, [_0]) } - public var Update_Skip: String { return self._s[1494]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1495]! } - public var Message_PinnedPollMessage: String { return self._s[1496]! } - public var BlockedUsers_Title: String { return self._s[1497]! } - public var Weekday_Monday: String { return self._s[1498]! } - public var Username_CheckingUsername: String { return self._s[1499]! } - public var NotificationsSound_Bell: String { return self._s[1500]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[1501]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1502]! } - public var ChatSettings_Groups: String { return self._s[1503]! } - public var Your_card_was_declined: String { return self._s[1504]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1506]! } - public var ChatList_Unmute: String { return self._s[1507]! } + public var Update_Skip: String { return self._s[1499]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1500]! } + public var Message_PinnedPollMessage: String { return self._s[1501]! } + public var BlockedUsers_Title: String { return self._s[1502]! } + public var Weekday_Monday: String { return self._s[1503]! } + public var Username_CheckingUsername: String { return self._s[1504]! } + public var NotificationsSound_Bell: String { return self._s[1505]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[1506]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1507]! } + public var ChatSettings_Groups: String { return self._s[1508]! } + public var Your_card_was_declined: String { return self._s[1509]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1511]! } + public var ChatList_Unmute: String { return self._s[1512]! } public func PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1508]!, self._r[1508]!, [_1]) + return formatWithArgumentRanges(self._s[1513]!, self._r[1513]!, [_1]) } - public var PhotoEditor_CurvesAll: String { return self._s[1509]! } - public var Weekday_ShortTuesday: String { return self._s[1510]! } - public var DialogList_Read: String { return self._s[1511]! } + public var PhotoEditor_CurvesAll: String { return self._s[1514]! } + public var Weekday_ShortTuesday: String { return self._s[1515]! } + public var DialogList_Read: String { return self._s[1516]! } public func PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1512]!, self._r[1512]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1517]!, self._r[1517]!, [_1, _2]) } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1513]! } - public var Passport_Identity_Gender: String { return self._s[1514]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1518]! } + public var Passport_Identity_Gender: String { return self._s[1519]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1515]!, self._r[1515]!, [_0]) + return formatWithArgumentRanges(self._s[1520]!, self._r[1520]!, [_0]) } - public var Target_SelectGroup: String { return self._s[1516]! } + public var Target_SelectGroup: String { return self._s[1521]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1518]!, self._r[1518]!, [_0]) + return formatWithArgumentRanges(self._s[1523]!, self._r[1523]!, [_0]) } - public var Passport_Language_en: String { return self._s[1519]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1520]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[1521]! } + public var Passport_Language_en: String { return self._s[1524]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1525]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[1526]! } public func AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1522]!, self._r[1522]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1527]!, self._r[1527]!, [_1, _2]) } - public var Checkout_NewCard_PaymentCard: String { return self._s[1524]! } - public var Login_InfoHelp: String { return self._s[1525]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1526]! } - public var SocksProxySetup_AddProxy: String { return self._s[1529]! } - public var CreatePoll_Title: String { return self._s[1530]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1531]! } - public var UserInfo_GroupsInCommon: String { return self._s[1532]! } - public var Call_AudioRouteHide: String { return self._s[1533]! } - public var ContactInfo_PhoneLabelMobile: String { return self._s[1535]! } - public var TextFormat_Bold: String { return self._s[1536]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[1537]! } - public var Notifications_Title: String { return self._s[1538]! } - public var Group_Username_InvalidTooShort: String { return self._s[1539]! } - public var Channel_ErrorAddTooMuch: String { return self._s[1540]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[1529]! } + public var Login_InfoHelp: String { return self._s[1530]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1531]! } + public var SocksProxySetup_AddProxy: String { return self._s[1534]! } + public var CreatePoll_Title: String { return self._s[1535]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1536]! } + public var UserInfo_GroupsInCommon: String { return self._s[1537]! } + public var Call_AudioRouteHide: String { return self._s[1538]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[1540]! } + public var TextFormat_Bold: String { return self._s[1541]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[1542]! } + public var Notifications_Title: String { return self._s[1543]! } + public var Group_Username_InvalidTooShort: String { return self._s[1544]! } + public var Channel_ErrorAddTooMuch: String { return self._s[1545]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1541]!, self._r[1541]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1546]!, self._r[1546]!, ["\(_0)"]) } - public var Stickers_SuggestAdded: String { return self._s[1543]! } - public var Login_CountryCode: String { return self._s[1544]! } - public var Map_GetDirections: String { return self._s[1545]! } - public var Login_PhoneFloodError: String { return self._s[1546]! } + public var Stickers_SuggestAdded: String { return self._s[1548]! } + public var Login_CountryCode: String { return self._s[1549]! } + public var Map_GetDirections: String { return self._s[1550]! } + public var Login_PhoneFloodError: String { return self._s[1551]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1547]!, self._r[1547]!, [_0]) + return formatWithArgumentRanges(self._s[1552]!, self._r[1552]!, [_0]) } - public var Settings_SetUsername: String { return self._s[1549]! } + public var Settings_SetUsername: String { return self._s[1554]! } public func CHAT_MESSAGE_NOTEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1550]!, self._r[1550]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1555]!, self._r[1555]!, [_1, _2]) } - public var Notification_GroupInviterSelf: String { return self._s[1551]! } - public var InstantPage_TapToOpenLink: String { return self._s[1552]! } + public var Notification_GroupInviterSelf: String { return self._s[1556]! } + public var InstantPage_TapToOpenLink: String { return self._s[1557]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1553]!, self._r[1553]!, [_0]) + return formatWithArgumentRanges(self._s[1558]!, self._r[1558]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[1554]! } - public var SecretChat_Title: String { return self._s[1555]! } - public var Group_UpgradeNoticeText1: String { return self._s[1556]! } - public var AuthSessions_Title: String { return self._s[1557]! } - public var PhotoEditor_CropAuto: String { return self._s[1558]! } - public var Channel_About_Title: String { return self._s[1559]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[1560]! } + public var Watch_Suggestion_TalkLater: String { return self._s[1559]! } + public var SecretChat_Title: String { return self._s[1560]! } + public var Group_UpgradeNoticeText1: String { return self._s[1561]! } + public var AuthSessions_Title: String { return self._s[1562]! } + public var PhotoEditor_CropAuto: String { return self._s[1563]! } + public var Channel_About_Title: String { return self._s[1564]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[1565]! } public func CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1561]!, self._r[1561]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1566]!, self._r[1566]!, [_1, _2]) } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1562]!, self._r[1562]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1567]!, self._r[1567]!, ["\(_0)"]) } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1565]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[1566]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1570]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[1571]! } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1568]!, self._r[1568]!, [_0]) + return formatWithArgumentRanges(self._s[1573]!, self._r[1573]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1569]!, self._r[1569]!, [_0]) + return formatWithArgumentRanges(self._s[1574]!, self._r[1574]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[1570]! } - public var Presence_online: String { return self._s[1572]! } - public var PasscodeSettings_Title: String { return self._s[1573]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1574]! } - public var Web_OpenExternal: String { return self._s[1575]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[1575]! } + public var Presence_online: String { return self._s[1577]! } + public var PasscodeSettings_Title: String { return self._s[1578]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1579]! } + public var Web_OpenExternal: String { return self._s[1580]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1577]!, self._r[1577]!, [_0]) + return formatWithArgumentRanges(self._s[1582]!, self._r[1582]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1578]! } - public var Map_YouAreHere: String { return self._s[1579]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1583]! } + public var Map_YouAreHere: String { return self._s[1584]! } public func MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1580]!, self._r[1580]!, [_1]) - } - public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1581]!, self._r[1581]!, [_0]) - } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1582]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1583]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1584]!, self._r[1584]!, [_0]) - } - public func CHANNEL_MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1585]!, self._r[1585]!, [_1]) } - public var SocksProxySetup_Username: String { return self._s[1586]! } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1587]!, self._r[1587]!, [_0]) + public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1586]!, self._r[1586]!, [_0]) } - public var Bot_Start: String { return self._s[1588]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1587]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1588]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1589]!, self._r[1589]!, [_0]) } + public func CHANNEL_MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1590]!, self._r[1590]!, [_1]) + } + public var SocksProxySetup_Username: String { return self._s[1591]! } + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1592]!, self._r[1592]!, [_0]) + } + public var Bot_Start: String { return self._s[1593]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1594]!, self._r[1594]!, [_0]) + } public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1590]!, self._r[1590]!, [_0]) - } - public var Contacts_SortByPresence: String { return self._s[1591]! } - public func PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1593]!, self._r[1593]!, [_1]) - } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1594]! } - public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1595]!, self._r[1595]!, [_0]) } + public var Contacts_SortByPresence: String { return self._s[1596]! } + public func PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1598]!, self._r[1598]!, [_1]) + } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1599]! } + public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1600]!, self._r[1600]!, [_0]) + } public func MESSAGE_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1596]!, self._r[1596]!, [_1]) + return formatWithArgumentRanges(self._s[1601]!, self._r[1601]!, [_1]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[1597]! } - public var Login_InfoAvatarPhoto: String { return self._s[1598]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1599]! } - public var Tour_Title4: String { return self._s[1600]! } - public var Passport_Identity_Translation: String { return self._s[1601]! } - public var Login_TermsOfServiceLabel: String { return self._s[1603]! } - public var Passport_Language_it: String { return self._s[1604]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1605]! } - public var Passport_Identity_SelfieHelp: String { return self._s[1606]! } - public var Conversation_ClearAll: String { return self._s[1608]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[1602]! } + public var Login_InfoAvatarPhoto: String { return self._s[1603]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1604]! } + public var Tour_Title4: String { return self._s[1605]! } + public var Passport_Identity_Translation: String { return self._s[1606]! } + public var Login_TermsOfServiceLabel: String { return self._s[1608]! } + public var Passport_Language_it: String { return self._s[1609]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1610]! } + public var Passport_Identity_SelfieHelp: String { return self._s[1611]! } + public var Conversation_ClearAll: String { return self._s[1613]! } public func MESSAGE_PHOTOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1610]!, self._r[1610]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1615]!, self._r[1615]!, [_1, _2]) } - public var TwoStepAuth_FloodError: String { return self._s[1611]! } - public var Paint_Delete: String { return self._s[1612]! } + public var TwoStepAuth_FloodError: String { return self._s[1616]! } + public var Paint_Delete: String { return self._s[1617]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1613]!, self._r[1613]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1618]!, self._r[1618]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[1614]! } + public var Message_PinnedAudioMessage: String { return self._s[1619]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1615]!, self._r[1615]!, [_0]) + return formatWithArgumentRanges(self._s[1620]!, self._r[1620]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[1616]! } - public var Notifications_GroupNotificationsSound: String { return self._s[1617]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[1618]! } - public var Conversation_MessageEditedLabel: String { return self._s[1619]! } - public var Notification_Exceptions_AlwaysOff: String { return self._s[1620]! } + public var Notification_Mute1hMin: String { return self._s[1621]! } + public var Notifications_GroupNotificationsSound: String { return self._s[1622]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[1623]! } + public var Conversation_MessageEditedLabel: String { return self._s[1624]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[1625]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1621]!, self._r[1621]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1626]!, self._r[1626]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[1622]! } - public var AccessDenied_LocationTracking: String { return self._s[1623]! } - public var Month_GenOctober: String { return self._s[1624]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1625]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[1627]! } + public var AccessDenied_LocationTracking: String { return self._s[1628]! } + public var Month_GenOctober: String { return self._s[1629]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1630]! } public func CHAT_MESSAGE_INVOICE_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1626]!, self._r[1626]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1631]!, self._r[1631]!, [_1, _2, _3]) } - public var EnterPasscode_EnterPasscode: String { return self._s[1628]! } - public var MediaPicker_TimerTooltip: String { return self._s[1629]! } - public var SharedMedia_TitleAll: String { return self._s[1630]! } - public var Conversation_RestrictedMedia: String { return self._s[1632]! } - public var AccessDenied_PhotosRestricted: String { return self._s[1633]! } - public var ChangePhoneNumberCode_Called: String { return self._s[1635]! } + public var EnterPasscode_EnterPasscode: String { return self._s[1633]! } + public var MediaPicker_TimerTooltip: String { return self._s[1634]! } + public var SharedMedia_TitleAll: String { return self._s[1635]! } + public var Conversation_RestrictedMedia: String { return self._s[1637]! } + public var AccessDenied_PhotosRestricted: String { return self._s[1638]! } + public var ChangePhoneNumberCode_Called: String { return self._s[1640]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1636]!, self._r[1636]!, [_0]) + return formatWithArgumentRanges(self._s[1641]!, self._r[1641]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[1639]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[1641]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1642]! } + public var Conversation_SavedMessages: String { return self._s[1644]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[1646]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1647]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1644]!, self._r[1644]!, [_0]) + return formatWithArgumentRanges(self._s[1649]!, self._r[1649]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[1645]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1646]! } + public var ReportPeer_AlertSuccess: String { return self._s[1650]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1651]! } public func MESSAGE_PHOTO_SECRET_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1647]!, self._r[1647]!, [_1]) + return formatWithArgumentRanges(self._s[1652]!, self._r[1652]!, [_1]) } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1648]!, self._r[1648]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1653]!, self._r[1653]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[1649]! } - public var PhotoEditor_FadeTool: String { return self._s[1650]! } - public var Privacy_ContactsReset: String { return self._s[1651]! } + public var Checkout_PasswordEntry_Title: String { return self._s[1654]! } + public var PhotoEditor_FadeTool: String { return self._s[1655]! } + public var Privacy_ContactsReset: String { return self._s[1656]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1653]!, self._r[1653]!, [_0]) + return formatWithArgumentRanges(self._s[1658]!, self._r[1658]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[1654]! } - public var ChatList_Mute: String { return self._s[1655]! } - public var Permissions_CellularDataText_v0: String { return self._s[1656]! } - public var ShareMenu_SelectChats: String { return self._s[1658]! } - public var MusicPlayer_VoiceNote: String { return self._s[1659]! } - public var Conversation_RestrictedText: String { return self._s[1660]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[1661]! } - public var Cache_Videos: String { return self._s[1662]! } - public var FeatureDisabled_Oops: String { return self._s[1664]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[1665]! } + public var Message_PinnedVideoMessage: String { return self._s[1659]! } + public var ChatList_Mute: String { return self._s[1660]! } + public var Permissions_CellularDataText_v0: String { return self._s[1661]! } + public var ShareMenu_SelectChats: String { return self._s[1663]! } + public var MusicPlayer_VoiceNote: String { return self._s[1664]! } + public var Conversation_RestrictedText: String { return self._s[1665]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[1666]! } + public var Cache_Videos: String { return self._s[1667]! } + public var FeatureDisabled_Oops: String { return self._s[1669]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[1670]! } public func CHAT_MESSAGE_VIDEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1666]!, self._r[1666]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1671]!, self._r[1671]!, [_1, _2]) } - public var Stickers_GroupStickersHelp: String { return self._s[1667]! } - public var GroupPermission_NoSendPolls: String { return self._s[1668]! } - public var Message_VideoExpired: String { return self._s[1670]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[1671]! } - public var Notifications_Badge: String { return self._s[1672]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[1673]! } - public var Username_InvalidTooShort: String { return self._s[1674]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1675]! } + public var BackgroundPreview_Perspective: String { return self._s[1672]! } + public var Stickers_GroupStickersHelp: String { return self._s[1673]! } + public var GroupPermission_NoSendPolls: String { return self._s[1674]! } + public var Message_VideoExpired: String { return self._s[1676]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[1677]! } + public var Notifications_Badge: String { return self._s[1678]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[1679]! } + public var Username_InvalidTooShort: String { return self._s[1680]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1681]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1676]!, self._r[1676]!, [_1]) + return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[1677]! } - public var Conversation_DefaultRestrictedText: String { return self._s[1678]! } - public var SharedMedia_CategoryDocs: String { return self._s[1681]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[1683]! } + public var Conversation_DefaultRestrictedText: String { return self._s[1684]! } + public var SharedMedia_CategoryDocs: String { return self._s[1687]! } public func CHAT_MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1688]!, self._r[1688]!, [_1, _2, _3]) } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1684]!, self._r[1684]!, [_1]) + return formatWithArgumentRanges(self._s[1690]!, self._r[1690]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1685]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1691]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1686]!, self._r[1686]!, [_0]) + return formatWithArgumentRanges(self._s[1692]!, self._r[1692]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[1687]! } - public var Channel_UpdatePhotoItem: String { return self._s[1688]! } - public var GroupInfo_LeftStatus: String { return self._s[1689]! } - public var Watch_MessageView_Forward: String { return self._s[1691]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[1692]! } - public var Cache_ClearEmpty: String { return self._s[1694]! } + public var ChatSettings_PrivateChats: String { return self._s[1693]! } + public var Channel_UpdatePhotoItem: String { return self._s[1694]! } + public var GroupInfo_LeftStatus: String { return self._s[1695]! } + public var Watch_MessageView_Forward: String { return self._s[1697]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[1698]! } + public var Cache_ClearEmpty: String { return self._s[1700]! } public func MESSAGE_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1695]!, self._r[1695]!, [_1]) + return formatWithArgumentRanges(self._s[1701]!, self._r[1701]!, [_1]) } - public var Localization_LanguageName: String { return self._s[1696]! } - public var WebSearch_GIFs: String { return self._s[1697]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1698]! } - public var Username_InvalidStartsWithNumber: String { return self._s[1699]! } - public var Common_Back: String { return self._s[1700]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1701]! } + public var Localization_LanguageName: String { return self._s[1702]! } + public var WebSearch_GIFs: String { return self._s[1703]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1704]! } + public var Username_InvalidStartsWithNumber: String { return self._s[1705]! } + public var Common_Back: String { return self._s[1706]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1707]! } public func CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1702]!, self._r[1702]!, [_1]) + return formatWithArgumentRanges(self._s[1708]!, self._r[1708]!, [_1]) } public func CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1703]!, self._r[1703]!, [_1]) + return formatWithArgumentRanges(self._s[1709]!, self._r[1709]!, [_1]) } - public var Passport_Email_Help: String { return self._s[1704]! } - public var Watch_Conversation_Reply: String { return self._s[1705]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[1707]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1708]! } - public var Channel_BanUser_Unban: String { return self._s[1710]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1711]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[1712]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1714]! } - public var Passport_Identity_Name: String { return self._s[1715]! } - public var GroupRemoved_ViewUserInfo: String { return self._s[1716]! } - public var Conversation_BlockUser: String { return self._s[1717]! } - public var Month_GenJanuary: String { return self._s[1718]! } - public var ChatSettings_TextSize: String { return self._s[1719]! } - public var Notification_PassportValuePhone: String { return self._s[1720]! } - public var Passport_Language_ne: String { return self._s[1721]! } - public var Notification_CallBack: String { return self._s[1722]! } - public var TwoStepAuth_EmailHelp: String { return self._s[1723]! } + public var Passport_Email_Help: String { return self._s[1710]! } + public var Watch_Conversation_Reply: String { return self._s[1711]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[1713]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1714]! } + public var Channel_BanUser_Unban: String { return self._s[1716]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1717]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[1718]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1720]! } + public var Passport_Identity_Name: String { return self._s[1721]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[1722]! } + public var Conversation_BlockUser: String { return self._s[1723]! } + public var Month_GenJanuary: String { return self._s[1724]! } + public var ChatSettings_TextSize: String { return self._s[1725]! } + public var Notification_PassportValuePhone: String { return self._s[1726]! } + public var Passport_Language_ne: String { return self._s[1727]! } + public var Notification_CallBack: String { return self._s[1728]! } + public var TwoStepAuth_EmailHelp: String { return self._s[1729]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1724]!, self._r[1724]!, [_0]) + return formatWithArgumentRanges(self._s[1730]!, self._r[1730]!, [_0]) } - public var Channel_Info_Management: String { return self._s[1725]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[1726]! } - public var Stickers_FrequentlyUsed: String { return self._s[1727]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[1728]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[1730]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[1731]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[1732]! } - public var CreatePoll_TextHeader: String { return self._s[1733]! } + public var Channel_Info_Management: String { return self._s[1731]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[1732]! } + public var Stickers_FrequentlyUsed: String { return self._s[1733]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[1734]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[1736]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[1737]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[1738]! } + public var CreatePoll_TextHeader: String { return self._s[1739]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1734]!, self._r[1734]!, [_0]) + return formatWithArgumentRanges(self._s[1740]!, self._r[1740]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[1735]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1736]! } + public var PhotoEditor_QualityMedium: String { return self._s[1741]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[1742]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1737]!, self._r[1737]!, [_0]) + return formatWithArgumentRanges(self._s[1743]!, self._r[1743]!, [_0]) } - public var Conversation_StatusKickedFromChannel: String { return self._s[1738]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[1739]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[1740]! } - public var Conversation_LinkDialogOpen: String { return self._s[1742]! } - public var Settings_Username: String { return self._s[1743]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[1744]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[1745]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[1746]! } + public var Conversation_LinkDialogOpen: String { return self._s[1748]! } + public var Settings_Username: String { return self._s[1749]! } public func PINNED_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1745]!, self._r[1745]!, [_1]) + return formatWithArgumentRanges(self._s[1751]!, self._r[1751]!, [_1]) } - public var Wallpaper_Wallpaper: String { return self._s[1746]! } + public var Wallpaper_Wallpaper: String { return self._s[1752]! } public func PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1748]!, self._r[1748]!, [_1]) + return formatWithArgumentRanges(self._s[1754]!, self._r[1754]!, [_1]) } - public var SocksProxySetup_UseProxy: String { return self._s[1749]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[1750]! } - public var MessageTimer_Forever: String { return self._s[1751]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[1752]! } - public var PhotoEditor_DiscardChanges: String { return self._s[1753]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[1754]! } - public var Passport_Language_da: String { return self._s[1755]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[1756]! } + public var SocksProxySetup_UseProxy: String { return self._s[1755]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[1756]! } + public var MessageTimer_Forever: String { return self._s[1757]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[1758]! } + public var PhotoEditor_DiscardChanges: String { return self._s[1759]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[1760]! } + public var Passport_Language_da: String { return self._s[1761]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[1762]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1757]!, self._r[1757]!, [_0]) + return formatWithArgumentRanges(self._s[1763]!, self._r[1763]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[1758]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[1764]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1760]!, self._r[1760]!, [_0]) + return formatWithArgumentRanges(self._s[1766]!, self._r[1766]!, [_0]) } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1762]! } - public var Conversation_SearchByName_Prefix: String { return self._s[1763]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[1768]! } + public var Conversation_SearchByName_Prefix: String { return self._s[1769]! } public func PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1764]!, self._r[1764]!, [_1]) + return formatWithArgumentRanges(self._s[1770]!, self._r[1770]!, [_1]) } - public var Conversation_PinnedPoll: String { return self._s[1765]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[1766]! } - public var Cache_ByPeerHeader: String { return self._s[1767]! } + public var Conversation_PinnedPoll: String { return self._s[1771]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[1772]! } + public var Cache_ByPeerHeader: String { return self._s[1773]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1768]!, self._r[1768]!, [_0]) + return formatWithArgumentRanges(self._s[1774]!, self._r[1774]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[1769]! } - public var Notification_PinnedMessage: String { return self._s[1772]! } - public var Contacts_SortBy: String { return self._s[1774]! } - public var Call_EncryptionKey_Title: String { return self._s[1776]! } - public var Watch_UserInfo_Service: String { return self._s[1777]! } - public var Conversation_Unpin: String { return self._s[1780]! } - public var CancelResetAccount_Title: String { return self._s[1781]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[1782]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[1775]! } + public var Notification_PinnedMessage: String { return self._s[1778]! } + public var Contacts_SortBy: String { return self._s[1780]! } + public var Call_EncryptionKey_Title: String { return self._s[1782]! } + public var Watch_UserInfo_Service: String { return self._s[1783]! } + public var Conversation_Unpin: String { return self._s[1786]! } + public var CancelResetAccount_Title: String { return self._s[1787]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[1788]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1784]!, self._r[1784]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[1785]! } - public var CallSettings_Title: String { return self._s[1786]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[1788]! } - public var AutoDownloadSettings_Contacts: String { return self._s[1789]! } - public var Passport_Identity_DocumentDetails: String { return self._s[1790]! } - public var LoginPassword_PasswordHelp: String { return self._s[1791]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[1792]! } - public var Checkout_TotalPaidAmount: String { return self._s[1793]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[1791]! } + public var CallSettings_Title: String { return self._s[1792]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[1794]! } + public var AutoDownloadSettings_Contacts: String { return self._s[1795]! } + public var Passport_Identity_DocumentDetails: String { return self._s[1796]! } + public var LoginPassword_PasswordHelp: String { return self._s[1797]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[1798]! } + public var Checkout_TotalPaidAmount: String { return self._s[1799]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1794]!, self._r[1794]!, [_0]) + return formatWithArgumentRanges(self._s[1800]!, self._r[1800]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[1795]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[1797]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[1798]! } - public var Contacts_InviteFriends: String { return self._s[1800]! } - public var Map_ChooseLocationTitle: String { return self._s[1801]! } - public var Conversation_StopPoll: String { return self._s[1803]! } - public var Calls_RatingFeedback: String { return self._s[1804]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1805]! } - public var NotificationsSound_Pulse: String { return self._s[1806]! } - public var Watch_LastSeen_Lately: String { return self._s[1807]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[1801]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[1803]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[1804]! } + public var Contacts_InviteFriends: String { return self._s[1806]! } + public var Map_ChooseLocationTitle: String { return self._s[1807]! } + public var Conversation_StopPoll: String { return self._s[1809]! } + public var Calls_RatingFeedback: String { return self._s[1810]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[1811]! } + public var NotificationsSound_Pulse: String { return self._s[1812]! } + public var Watch_LastSeen_Lately: String { return self._s[1813]! } public func CHAT_MESSAGE_VIDEO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1810]!, self._r[1810]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1816]!, self._r[1816]!, [_1, _2]) } - public var Widget_NoUsers: String { return self._s[1811]! } - public var Conversation_UnvotePoll: String { return self._s[1812]! } - public var NotificationsSound_Circles: String { return self._s[1814]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[1816]! } + public var Widget_NoUsers: String { return self._s[1817]! } + public var Conversation_UnvotePoll: String { return self._s[1818]! } + public var NotificationsSound_Circles: String { return self._s[1820]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[1822]! } public func CHANNEL_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1817]!, self._r[1817]!, [_1]) + return formatWithArgumentRanges(self._s[1823]!, self._r[1823]!, [_1]) } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[1818]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[1824]! } public func CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1819]!, self._r[1819]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1825]!, self._r[1825]!, [_1, _2]) } - public var Passport_Identity_CountryPlaceholder: String { return self._s[1821]! } - public var Conversation_FileDropbox: String { return self._s[1823]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[1824]! } - public var Tour_Text3: String { return self._s[1826]! } - public var Login_ResetAccountProtected_Title: String { return self._s[1828]! } - public var GroupPermission_NoSendMessages: String { return self._s[1829]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[1830]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[1827]! } + public var Conversation_FileDropbox: String { return self._s[1829]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[1830]! } + public var Tour_Text3: String { return self._s[1832]! } + public var Login_ResetAccountProtected_Title: String { return self._s[1834]! } + public var GroupPermission_NoSendMessages: String { return self._s[1835]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[1836]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1832]!, self._r[1832]!, [_0]) + return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[1833]! } - public var Checkout_ShippingOption_Title: String { return self._s[1834]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[1835]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[1839]! } + public var Checkout_ShippingOption_Title: String { return self._s[1840]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[1841]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1836]!, self._r[1836]!, [_0]) + return formatWithArgumentRanges(self._s[1842]!, self._r[1842]!, [_0]) } public func CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1837]!, self._r[1837]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1843]!, self._r[1843]!, [_1, _2]) } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[1838]! } - public var Appearance_PreviewIncomingText: String { return self._s[1840]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[1841]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[1842]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[1843]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1844]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[1845]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[1846]! } - public var Notification_SecretChatScreenshot: String { return self._s[1847]! } - public var Passport_Address_City: String { return self._s[1849]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[1850]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[1851]! } - public var AccessDenied_LocationDisabled: String { return self._s[1852]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[1854]! } - public var GroupInfo_Sound: String { return self._s[1855]! } - public var Stickers_RemoveFromFavorites: String { return self._s[1856]! } - public var Contacts_Title: String { return self._s[1857]! } - public var Passport_Language_fr: String { return self._s[1858]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[1844]! } + public var Appearance_PreviewIncomingText: String { return self._s[1846]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[1847]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[1848]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[1849]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[1850]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[1851]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[1852]! } + public var Notification_SecretChatScreenshot: String { return self._s[1853]! } + public var Passport_Address_City: String { return self._s[1855]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[1856]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[1857]! } + public var AccessDenied_LocationDisabled: String { return self._s[1858]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[1860]! } + public var GroupInfo_Sound: String { return self._s[1861]! } + public var Stickers_RemoveFromFavorites: String { return self._s[1862]! } + public var Contacts_Title: String { return self._s[1863]! } + public var Passport_Language_fr: String { return self._s[1864]! } public func CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1859]!, self._r[1859]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1865]!, self._r[1865]!, [_1, _2]) } - public var Notifications_ResetAllNotifications: String { return self._s[1860]! } - public var PrivacySettings_SecurityTitle: String { return self._s[1863]! } - public var Checkout_NewCard_Title: String { return self._s[1864]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[1865]! } - public var Conversation_ForwardChats: String { return self._s[1866]! } - public var Settings_FAQ: String { return self._s[1869]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[1870]! } - public var Conversation_ContextMenuForward: String { return self._s[1871]! } - public var PrivacyPolicy_Title: String { return self._s[1876]! } - public var Notifications_TextTone: String { return self._s[1877]! } - public var Profile_CreateNewContact: String { return self._s[1878]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[1880]! } - public var Channel_Username_InvalidCharacters: String { return self._s[1882]! } + public var Notifications_ResetAllNotifications: String { return self._s[1866]! } + public var PrivacySettings_SecurityTitle: String { return self._s[1869]! } + public var Checkout_NewCard_Title: String { return self._s[1870]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[1871]! } + public var Conversation_ForwardChats: String { return self._s[1872]! } + public var Settings_FAQ: String { return self._s[1875]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[1876]! } + public var Conversation_ContextMenuForward: String { return self._s[1877]! } + public var PrivacyPolicy_Title: String { return self._s[1882]! } + public var Notifications_TextTone: String { return self._s[1883]! } + public var Profile_CreateNewContact: String { return self._s[1884]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[1886]! } + public var Channel_Username_InvalidCharacters: String { return self._s[1888]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1883]!, self._r[1883]!, [_0]) + return formatWithArgumentRanges(self._s[1889]!, self._r[1889]!, [_0]) } - public var PrivacySettings_LastSeenTitle: String { return self._s[1884]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[1885]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[1886]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[1887]! } - public var Bot_Unblock: String { return self._s[1888]! } - public var TextFormat_Italic: String { return self._s[1889]! } - public var Settings_About_Help: String { return self._s[1890]! } - public var SearchImages_Title: String { return self._s[1891]! } - public var Weekday_Wednesday: String { return self._s[1892]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[1893]! } - public var ExplicitContent_AlertTitle: String { return self._s[1894]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[1890]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[1891]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[1892]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[1893]! } + public var Bot_Unblock: String { return self._s[1894]! } + public var TextFormat_Italic: String { return self._s[1895]! } + public var Settings_About_Help: String { return self._s[1896]! } + public var SearchImages_Title: String { return self._s[1897]! } + public var Weekday_Wednesday: String { return self._s[1898]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[1899]! } + public var ExplicitContent_AlertTitle: String { return self._s[1900]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1895]!, self._r[1895]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1901]!, self._r[1901]!, [_1, _2, _3]) } - public var Weekday_Thursday: String { return self._s[1896]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[1897]! } - public var Channel_Members_AddMembersHelp: String { return self._s[1898]! } + public var Weekday_Thursday: String { return self._s[1902]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[1903]! } + public var Channel_Members_AddMembersHelp: String { return self._s[1904]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1899]!, self._r[1899]!, [_0]) + return formatWithArgumentRanges(self._s[1905]!, self._r[1905]!, [_0]) } - public var Passport_RequestedInformation: String { return self._s[1900]! } - public var Login_PhoneAndCountryHelp: String { return self._s[1901]! } + public var Passport_RequestedInformation: String { return self._s[1906]! } + public var Login_PhoneAndCountryHelp: String { return self._s[1907]! } public func CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1902]!, self._r[1902]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1908]!, self._r[1908]!, [_1, _2]) } - public var Conversation_EncryptionProcessing: String { return self._s[1903]! } - public var PhotoEditor_EnhanceTool: String { return self._s[1906]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[1907]! } - public var Channel_Setup_Title: String { return self._s[1908]! } + public var Conversation_EncryptionProcessing: String { return self._s[1909]! } + public var PhotoEditor_EnhanceTool: String { return self._s[1912]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[1913]! } + public var Channel_Setup_Title: String { return self._s[1914]! } public func PINNED_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1909]!, self._r[1909]!, [_1]) + return formatWithArgumentRanges(self._s[1915]!, self._r[1915]!, [_1]) } - public var Conversation_SearchPlaceholder: String { return self._s[1910]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[1911]! } - public var Checkout_ErrorGeneric: String { return self._s[1912]! } - public var Passport_Language_hu: String { return self._s[1913]! } + public var Conversation_SearchPlaceholder: String { return self._s[1916]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[1917]! } + public var Checkout_ErrorGeneric: String { return self._s[1918]! } + public var Passport_Language_hu: String { return self._s[1919]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1915]!, self._r[1915]!, [_0]) + return formatWithArgumentRanges(self._s[1921]!, self._r[1921]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[1918]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[1919]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[1924]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[1925]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1920]!, self._r[1920]!, [_0]) + return formatWithArgumentRanges(self._s[1926]!, self._r[1926]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[1921]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[1922]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[1923]! } + public var Conversation_ClearPrivateHistory: String { return self._s[1927]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[1928]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[1929]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1924]!, self._r[1924]!, [_0]) + return formatWithArgumentRanges(self._s[1930]!, self._r[1930]!, [_0]) } - public var Passport_Language_cs: String { return self._s[1925]! } - public var Message_PinnedAnimationMessage: String { return self._s[1926]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[1928]! } - public var Embed_PlayingInPIP: String { return self._s[1930]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[1931]! } + public var Passport_Language_cs: String { return self._s[1931]! } + public var Message_PinnedAnimationMessage: String { return self._s[1932]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[1934]! } + public var Embed_PlayingInPIP: String { return self._s[1936]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[1937]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1932]!, self._r[1932]!, [_0]) + return formatWithArgumentRanges(self._s[1938]!, self._r[1938]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[1933]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[1939]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1934]!, self._r[1934]!, [_1]) + return formatWithArgumentRanges(self._s[1940]!, self._r[1940]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[1935]! } - public var PhotoEditor_CurvesGreen: String { return self._s[1936]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[1937]! } + public var Notification_PaymentSent: String { return self._s[1941]! } + public var PhotoEditor_CurvesGreen: String { return self._s[1942]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[1943]! } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1938]!, self._r[1938]!, [_1]) + return formatWithArgumentRanges(self._s[1944]!, self._r[1944]!, [_1]) } public func CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1939]!, self._r[1939]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1945]!, self._r[1945]!, [_1, _2]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[1940]! } - public var PasscodeSettings_HelpTop: String { return self._s[1941]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[1943]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[1944]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[1945]! } - public var Call_Accept: String { return self._s[1947]! } - public var GroupRemoved_RemoveInfo: String { return self._s[1948]! } - public var Month_GenMarch: String { return self._s[1949]! } - public var PhotoEditor_ShadowsTool: String { return self._s[1950]! } - public var LoginPassword_Title: String { return self._s[1951]! } - public var Watch_Conversation_GroupInfo: String { return self._s[1952]! } - public var CallSettings_Always: String { return self._s[1953]! } - public var TwoStepAuth_SetupHint: String { return self._s[1954]! } - public var ConversationProfile_UsersTooMuchError: String { return self._s[1955]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[1946]! } + public var PasscodeSettings_HelpTop: String { return self._s[1947]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[1949]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[1950]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[1951]! } + public var Call_Accept: String { return self._s[1953]! } + public var GroupRemoved_RemoveInfo: String { return self._s[1954]! } + public var Month_GenMarch: String { return self._s[1955]! } + public var PhotoEditor_ShadowsTool: String { return self._s[1956]! } + public var LoginPassword_Title: String { return self._s[1957]! } + public var Watch_Conversation_GroupInfo: String { return self._s[1958]! } + public var CallSettings_Always: String { return self._s[1959]! } + public var TwoStepAuth_SetupHint: String { return self._s[1960]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[1961]! } public func MESSAGE_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1956]!, self._r[1956]!, [_1]) + return formatWithArgumentRanges(self._s[1962]!, self._r[1962]!, [_1]) } - public var Login_PhoneTitle: String { return self._s[1957]! } - public var Passport_FieldPhoneHelp: String { return self._s[1958]! } - public var Weekday_ShortSunday: String { return self._s[1959]! } - public var Passport_InfoFAQ_URL: String { return self._s[1960]! } - public var ContactInfo_Job: String { return self._s[1962]! } - public var UserInfo_InviteBotToGroup: String { return self._s[1963]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1964]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[1966]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[1968]! } - public var MediaPicker_AddCaption: String { return self._s[1969]! } - public var CallSettings_TabIconDescription: String { return self._s[1970]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[1971]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[1972]! } - public var DialogList_SearchSectionRecent: String { return self._s[1973]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[1974]! } - public var LastSeen_WithinAWeek: String { return self._s[1977]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[1978]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[1980]! } - public var Passport_Address_TypeResidentialAddress: String { return self._s[1981]! } - public var Conversation_StatusLeftGroup: String { return self._s[1982]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[1983]! } + public var Login_PhoneTitle: String { return self._s[1963]! } + public var Passport_FieldPhoneHelp: String { return self._s[1964]! } + public var Weekday_ShortSunday: String { return self._s[1965]! } + public var Passport_InfoFAQ_URL: String { return self._s[1966]! } + public var ContactInfo_Job: String { return self._s[1968]! } + public var UserInfo_InviteBotToGroup: String { return self._s[1969]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[1970]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[1972]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[1974]! } + public var MediaPicker_AddCaption: String { return self._s[1975]! } + public var CallSettings_TabIconDescription: String { return self._s[1976]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[1977]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[1978]! } + public var DialogList_SearchSectionRecent: String { return self._s[1979]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[1980]! } + public var LastSeen_WithinAWeek: String { return self._s[1983]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[1984]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[1986]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[1987]! } + public var Conversation_StatusLeftGroup: String { return self._s[1988]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[1989]! } public func CHANNEL_MESSAGE_AUDIO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1985]!, self._r[1985]!, [_1]) + return formatWithArgumentRanges(self._s[1991]!, self._r[1991]!, [_1]) } - public var GroupPermission_AddSuccess: String { return self._s[1986]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[1988]! } - public var Conversation_ContextMenuCopy: String { return self._s[1989]! } - public var AccessDenied_CallMicrophone: String { return self._s[1990]! } + public var GroupPermission_AddSuccess: String { return self._s[1992]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[1994]! } + public var Conversation_ContextMenuCopy: String { return self._s[1995]! } + public var AccessDenied_CallMicrophone: String { return self._s[1996]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1991]!, self._r[1991]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1997]!, self._r[1997]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[1992]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[1993]! } - public var Checkout_PaymentMethod_New: String { return self._s[1994]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[1995]! } - public var PhotoEditor_QualityTool: String { return self._s[1996]! } - public var Login_SendCodeViaSms: String { return self._s[1997]! } + public var Login_InvalidFirstNameError: String { return self._s[1998]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[1999]! } + public var Checkout_PaymentMethod_New: String { return self._s[2000]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2001]! } + public var PhotoEditor_QualityTool: String { return self._s[2002]! } + public var Login_SendCodeViaSms: String { return self._s[2003]! } public func CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1998]!, self._r[1998]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_1, _2]) } - public var Login_EmailNotConfiguredError: String { return self._s[1999]! } - public var PrivacyPolicy_Accept: String { return self._s[2000]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2001]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2002]! } - public var AutoNightTheme_Automatic: String { return self._s[2003]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2004]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2005]! } - public var Cache_Help: String { return self._s[2006]! } - public var Passport_Language_fa: String { return self._s[2007]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2008]! } - public var PrivacySettings_LastSeen: String { return self._s[2009]! } + public var Login_EmailNotConfiguredError: String { return self._s[2005]! } + public var PrivacyPolicy_Accept: String { return self._s[2006]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2007]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2008]! } + public var AutoNightTheme_Automatic: String { return self._s[2009]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2010]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2011]! } + public var Cache_Help: String { return self._s[2012]! } + public var Passport_Language_fa: String { return self._s[2013]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2014]! } + public var PrivacySettings_LastSeen: String { return self._s[2015]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2010]!, self._r[2010]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2016]!, self._r[2016]!, [_0, _1]) } - public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[2012]! } - public var Preview_SaveGif: String { return self._s[2014]! } - public var Profile_About: String { return self._s[2015]! } - public var Channel_About_Placeholder: String { return self._s[2016]! } - public var Login_InfoTitle: String { return self._s[2017]! } + public var Channel_EditAdmin_PermissionInviteUsers: String { return self._s[2018]! } + public var Preview_SaveGif: String { return self._s[2020]! } + public var Profile_About: String { return self._s[2021]! } + public var Channel_About_Placeholder: String { return self._s[2022]! } + public var Login_InfoTitle: String { return self._s[2023]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2018]!, self._r[2018]!, [_0]) + return formatWithArgumentRanges(self._s[2024]!, self._r[2024]!, [_0]) } - public var Watch_Suggestion_CantTalk: String { return self._s[2020]! } - public var ContactInfo_Title: String { return self._s[2021]! } - public var Media_ShareThisVideo: String { return self._s[2022]! } - public var Weekday_ShortFriday: String { return self._s[2023]! } - public var AccessDenied_Contacts: String { return self._s[2024]! } - public var Notification_CallIncomingShort: String { return self._s[2025]! } - public var Group_Setup_TypePublic: String { return self._s[2026]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2027]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2028]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2031]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2032]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2033]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2034]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2035]! } - public var DialogList_Typing: String { return self._s[2036]! } - public var Checkout_Phone: String { return self._s[2039]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2042]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2026]! } + public var ContactInfo_Title: String { return self._s[2027]! } + public var Media_ShareThisVideo: String { return self._s[2028]! } + public var Weekday_ShortFriday: String { return self._s[2029]! } + public var AccessDenied_Contacts: String { return self._s[2030]! } + public var Notification_CallIncomingShort: String { return self._s[2031]! } + public var Group_Setup_TypePublic: String { return self._s[2032]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2033]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2034]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2037]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2038]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2039]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2040]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2041]! } + public var DialogList_Typing: String { return self._s[2042]! } + public var Checkout_Phone: String { return self._s[2045]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2048]! } public func PINNED_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2043]!, self._r[2043]!, [_1]) + return formatWithArgumentRanges(self._s[2049]!, self._r[2049]!, [_1]) } - public var Privacy_Calls_Integration: String { return self._s[2044]! } - public var Notifications_PermissionsAllow: String { return self._s[2046]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2049]! } - public var Settings_ChatSettings: String { return self._s[2050]! } + public var Privacy_Calls_Integration: String { return self._s[2050]! } + public var Notifications_PermissionsAllow: String { return self._s[2052]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2055]! } + public var Settings_ChatSettings: String { return self._s[2056]! } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2051]!, self._r[2051]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2057]!, self._r[2057]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2053]! } + public var GroupRemoved_DeleteUser: String { return self._s[2059]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2054]!, self._r[2054]!, [_0]) + return formatWithArgumentRanges(self._s[2060]!, self._r[2060]!, [_0]) } - public var Login_ContinueWithLocalization: String { return self._s[2055]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2056]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2058]! } - public var Conversation_Unblock: String { return self._s[2059]! } - public var PrivacySettings_DataSettings: String { return self._s[2060]! } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2061]! } + public var Login_ContinueWithLocalization: String { return self._s[2061]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2062]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2064]! } + public var Conversation_Unblock: String { return self._s[2065]! } + public var PrivacySettings_DataSettings: String { return self._s[2066]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2067]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2062]!, self._r[2062]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2068]!, self._r[2068]!, [_0, _1]) } - public var PrivacySettings_Passcode: String { return self._s[2065]! } + public var PrivacySettings_Passcode: String { return self._s[2071]! } public func ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2066]!, self._r[2066]!, [_1]) + return formatWithArgumentRanges(self._s[2072]!, self._r[2072]!, [_1]) } - public var Passport_Language_dz: String { return self._s[2067]! } - public var Passport_Language_tk: String { return self._s[2068]! } + public var Passport_Language_dz: String { return self._s[2073]! } + public var Passport_Language_tk: String { return self._s[2074]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2069]!, self._r[2069]!, [_0]) + return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_0]) } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2070]! } - public var Conversation_ContextMenuReply: String { return self._s[2071]! } - public var Tour_Title1: String { return self._s[2072]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2076]! } + public var Conversation_ContextMenuReply: String { return self._s[2077]! } + public var Tour_Title1: String { return self._s[2078]! } public func MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2073]!, self._r[2073]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2079]!, self._r[2079]!, [_1, _2]) } - public var Conversation_ClearGroupHistory: String { return self._s[2075]! } + public var Conversation_ClearGroupHistory: String { return self._s[2081]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2076]!, self._r[2076]!, [_0]) + return formatWithArgumentRanges(self._s[2082]!, self._r[2082]!, [_0]) } - public var Call_RateCall: String { return self._s[2077]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2078]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2079]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2081]! } + public var Call_RateCall: String { return self._s[2083]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2084]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2085]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2087]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2083]!, self._r[2083]!, [_0]) + return formatWithArgumentRanges(self._s[2089]!, self._r[2089]!, [_0]) } - public var Compose_Create: String { return self._s[2084]! } - public var Contacts_InviteToTelegram: String { return self._s[2085]! } - public var GroupInfo_Notifications: String { return self._s[2086]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2088]! } - public var Month_GenApril: String { return self._s[2089]! } - public var Appearance_AutoNightTheme: String { return self._s[2090]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2092]! } - public var Login_CodeSentSms: String { return self._s[2094]! } + public var Compose_Create: String { return self._s[2090]! } + public var Contacts_InviteToTelegram: String { return self._s[2091]! } + public var GroupInfo_Notifications: String { return self._s[2092]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2094]! } + public var Month_GenApril: String { return self._s[2095]! } + public var Appearance_AutoNightTheme: String { return self._s[2096]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2098]! } + public var Login_CodeSentSms: String { return self._s[2100]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2095]!, self._r[2095]!, [_0]) + return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2096]! } - public var Passport_Language_hr: String { return self._s[2097]! } + public var EmptyGroupInfo_Line3: String { return self._s[2102]! } + public var Passport_Language_hr: String { return self._s[2103]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2098]!, self._r[2098]!, [_0]) + return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2099]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2100]! } - public var Privacy_SecretChatsTitle: String { return self._s[2101]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2103]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2104]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2105]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2106]! } + public var Privacy_SecretChatsTitle: String { return self._s[2107]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2109]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2110]! } public func CHANNEL_MESSAGE_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2105]!, self._r[2105]!, [_1]) + return formatWithArgumentRanges(self._s[2111]!, self._r[2111]!, [_1]) } - public var Preview_DeleteGif: String { return self._s[2106]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2107]! } - public var Group_ErrorNotMutualContact: String { return self._s[2108]! } - public var Notification_MessageLifetime5s: String { return self._s[2109]! } + public var Preview_DeleteGif: String { return self._s[2112]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2113]! } + public var Group_ErrorNotMutualContact: String { return self._s[2114]! } + public var Notification_MessageLifetime5s: String { return self._s[2115]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2110]!, self._r[2110]!, [_0]) + return formatWithArgumentRanges(self._s[2116]!, self._r[2116]!, [_0]) } - public var Passport_Address_AddBankStatement: String { return self._s[2112]! } - public var Notification_CallIncoming: String { return self._s[2113]! } - public var Compose_NewGroupTitle: String { return self._s[2114]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2116]! } - public var Passport_Address_Postcode: String { return self._s[2118]! } + public var Passport_Address_AddBankStatement: String { return self._s[2118]! } + public var Notification_CallIncoming: String { return self._s[2119]! } + public var Compose_NewGroupTitle: String { return self._s[2120]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2122]! } + public var Passport_Address_Postcode: String { return self._s[2124]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2119]!, self._r[2119]!, [_0]) + return formatWithArgumentRanges(self._s[2125]!, self._r[2125]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2120]! } - public var GroupPermission_Duration: String { return self._s[2121]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2126]! } + public var GroupPermission_Duration: String { return self._s[2127]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2122]!, self._r[2122]!, [_0]) + return formatWithArgumentRanges(self._s[2128]!, self._r[2128]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2123]! } - public var Username_Placeholder: String { return self._s[2124]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2125]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2126]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2129]! } + public var Username_Placeholder: String { return self._s[2130]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2131]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2132]! } public func CHAT_ADD_MEMBER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2127]!, self._r[2127]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2133]!, self._r[2133]!, [_1, _2, _3]) } - public var Passport_PasswordDescription: String { return self._s[2129]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2130]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2131]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2132]! } - public var Conversation_ContextMenuMore: String { return self._s[2133]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2134]! } - public var CallSettings_TabIcon: String { return self._s[2135]! } - public var KeyCommand_Find: String { return self._s[2136]! } - public var Message_PinnedGame: String { return self._s[2137]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2138]! } - public var Login_CallRequestState2: String { return self._s[2140]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2142]! } + public var Passport_PasswordDescription: String { return self._s[2135]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2136]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2137]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2138]! } + public var Conversation_ContextMenuMore: String { return self._s[2139]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2140]! } + public var CallSettings_TabIcon: String { return self._s[2141]! } + public var KeyCommand_Find: String { return self._s[2142]! } + public var Message_PinnedGame: String { return self._s[2143]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2144]! } + public var Login_CallRequestState2: String { return self._s[2146]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2148]! } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2144]!, self._r[2144]!, [_0]) + return formatWithArgumentRanges(self._s[2150]!, self._r[2150]!, [_0]) } - public var Conversation_InstantPagePreview: String { return self._s[2145]! } + public var Conversation_InstantPagePreview: String { return self._s[2151]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2146]!, self._r[2146]!, [_0]) + return formatWithArgumentRanges(self._s[2152]!, self._r[2152]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2149]! } - public var GroupPermission_NoPinMessages: String { return self._s[2150]! } - public var Passport_Language_es: String { return self._s[2151]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2153]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2154]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2155]! } - public var Watch_UserInfo_Unmute: String { return self._s[2156]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2157]! } - public var AccessDenied_CameraRestricted: String { return self._s[2159]! } + public var SecretTimer_VideoDescription: String { return self._s[2155]! } + public var GroupPermission_NoPinMessages: String { return self._s[2156]! } + public var Passport_Language_es: String { return self._s[2157]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2159]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2160]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2161]! } + public var Watch_UserInfo_Unmute: String { return self._s[2162]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2163]! } + public var AccessDenied_CameraRestricted: String { return self._s[2165]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2160]!, self._r[2160]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2166]!, self._r[2166]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2162]! } - public var Settings_CopyUsername: String { return self._s[2163]! } - public var Contacts_SearchLabel: String { return self._s[2164]! } + public var ChatList_ReadAll: String { return self._s[2168]! } + public var Settings_CopyUsername: String { return self._s[2169]! } + public var Contacts_SearchLabel: String { return self._s[2170]! } public func MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2166]!, self._r[2166]!, [_1]) + return formatWithArgumentRanges(self._s[2172]!, self._r[2172]!, [_1]) } - public var Map_OpenInYandexNavigator: String { return self._s[2167]! } - public var PasscodeSettings_EncryptData: String { return self._s[2168]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2170]! } - public var DialogList_AdNoticeAlert: String { return self._s[2171]! } + public var Map_OpenInYandexNavigator: String { return self._s[2173]! } + public var PasscodeSettings_EncryptData: String { return self._s[2174]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2176]! } + public var DialogList_AdNoticeAlert: String { return self._s[2177]! } public func CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2173]!, self._r[2173]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2179]!, self._r[2179]!, [_1, _2, _3]) } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2174]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2175]! } - public var Localization_LanguageCustom: String { return self._s[2176]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2177]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2180]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2181]! } + public var Localization_LanguageCustom: String { return self._s[2182]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2183]! } public func CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2179]!, self._r[2179]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2185]!, self._r[2185]!, [_1, _2]) } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2181]! } - public var Conversation_InfoGroup: String { return self._s[2182]! } - public var Compose_NewMessage: String { return self._s[2183]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2185]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2186]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2187]! } + public var Conversation_InfoGroup: String { return self._s[2188]! } + public var Compose_NewMessage: String { return self._s[2189]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2191]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2192]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2187]!, self._r[2187]!, [_0]) + return formatWithArgumentRanges(self._s[2193]!, self._r[2193]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2188]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2189]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2190]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2191]! } - public var Channel_BlackList_Title: String { return self._s[2192]! } - public var UserInfo_PhoneCall: String { return self._s[2193]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2195]! } - public var State_connecting: String { return self._s[2196]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2194]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2195]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2196]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2197]! } + public var Channel_BlackList_Title: String { return self._s[2198]! } + public var UserInfo_PhoneCall: String { return self._s[2199]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2201]! } + public var State_connecting: String { return self._s[2202]! } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2197]!, self._r[2197]!, [_0]) + return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2198]! } - public var Passport_Identity_EditPassport: String { return self._s[2199]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2201]! } - public var Localization_EnglishLanguageName: String { return self._s[2202]! } - public var Share_AuthDescription: String { return self._s[2203]! } - public var Passport_Identity_Surname: String { return self._s[2204]! } - public var Compose_TokenListPlaceholder: String { return self._s[2205]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2206]! } - public var Settings_AboutEmpty: String { return self._s[2207]! } - public var Conversation_Unmute: String { return self._s[2208]! } - public var Login_CodeSentCall: String { return self._s[2211]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2212]! } - public var ChatSettings_Appearance: String { return self._s[2213]! } - public var Appearance_PickAccentColor: String { return self._s[2214]! } - public var Notification_CallMissed: String { return self._s[2215]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2216]! } - public var ChatAdmins_AdminLabel: String { return self._s[2218]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2219]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2221]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2222]! } - public var Month_GenJune: String { return self._s[2223]! } - public var Watch_Location_Current: String { return self._s[2224]! } - public var Conversation_TitleMute: String { return self._s[2225]! } + public var Notifications_GroupNotifications: String { return self._s[2204]! } + public var Passport_Identity_EditPassport: String { return self._s[2205]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2207]! } + public var Localization_EnglishLanguageName: String { return self._s[2208]! } + public var Share_AuthDescription: String { return self._s[2209]! } + public var Passport_Identity_Surname: String { return self._s[2210]! } + public var Compose_TokenListPlaceholder: String { return self._s[2211]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2212]! } + public var Settings_AboutEmpty: String { return self._s[2213]! } + public var Conversation_Unmute: String { return self._s[2214]! } + public var Login_CodeSentCall: String { return self._s[2217]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2218]! } + public var ChatSettings_Appearance: String { return self._s[2219]! } + public var Appearance_PickAccentColor: String { return self._s[2220]! } + public var Notification_CallMissed: String { return self._s[2221]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2222]! } + public var ChatAdmins_AdminLabel: String { return self._s[2224]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2225]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2227]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2228]! } + public var Month_GenJune: String { return self._s[2229]! } + public var Watch_Location_Current: String { return self._s[2230]! } + public var Conversation_TitleMute: String { return self._s[2231]! } public func PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2226]!, self._r[2226]!, [_1]) + return formatWithArgumentRanges(self._s[2232]!, self._r[2232]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2227]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2233]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2228]!, self._r[2228]!, [_0]) + return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[2229]! } - public var MaskStickerSettings_Info: String { return self._s[2230]! } + public var Call_ReportPlaceholder: String { return self._s[2235]! } + public var MaskStickerSettings_Info: String { return self._s[2236]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2231]!, self._r[2231]!, [_0]) + return formatWithArgumentRanges(self._s[2237]!, self._r[2237]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2232]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2234]! } - public var Contacts_ShareTelegram: String { return self._s[2235]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2238]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2240]! } + public var Contacts_ShareTelegram: String { return self._s[2241]! } public func CHAT_MESSAGE_GIF_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2236]!, self._r[2236]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2242]!, self._r[2242]!, [_1, _2]) } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2237]! } - public var Channel_ErrorAccessDenied: String { return self._s[2238]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2240]! } - public var Call_ConnectionErrorTitle: String { return self._s[2241]! } - public var UserInfo_NotificationsEnable: String { return self._s[2242]! } - public var Tour_Text4: String { return self._s[2245]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2243]! } + public var Channel_ErrorAccessDenied: String { return self._s[2244]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2246]! } + public var Call_ConnectionErrorTitle: String { return self._s[2247]! } + public var UserInfo_NotificationsEnable: String { return self._s[2248]! } + public var Tour_Text4: String { return self._s[2251]! } public func CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2247]!, self._r[2247]!, [_1]) + return formatWithArgumentRanges(self._s[2253]!, self._r[2253]!, [_1]) } - public var Profile_MessageLifetime2s: String { return self._s[2248]! } - public var Notification_MessageLifetime2s: String { return self._s[2249]! } + public var Profile_MessageLifetime2s: String { return self._s[2254]! } + public var Notification_MessageLifetime2s: String { return self._s[2255]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2250]!, self._r[2250]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2256]!, self._r[2256]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[2251]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[2252]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2253]! } + public var Cache_ClearCache: String { return self._s[2257]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[2258]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2259]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_0]) + return formatWithArgumentRanges(self._s[2261]!, self._r[2261]!, [_0]) } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2257]! } - public var SocksProxySetup_TypeSocks: String { return self._s[2258]! } - public var AutoNightTheme_Title: String { return self._s[2259]! } - public var InstantPage_FeedbackButton: String { return self._s[2260]! } - public var Passport_FieldAddress: String { return self._s[2261]! } - public var Month_ShortMarch: String { return self._s[2262]! } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2263]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2264]! } - public var Passport_FloodError: String { return self._s[2265]! } - public var SecretGif_Title: String { return self._s[2266]! } - public var Passport_Language_th: String { return self._s[2268]! } - public var Passport_Address_Address: String { return self._s[2269]! } - public var Login_InvalidLastNameError: String { return self._s[2270]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[2271]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[2272]! } - public var ShareMenu_Send: String { return self._s[2273]! } - public var Month_GenNovember: String { return self._s[2276]! } - public var Checkout_Email: String { return self._s[2278]! } - public var NotificationsSound_Tritone: String { return self._s[2279]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[2281]! } - public var ChangePhoneNumberNumber_Help: String { return self._s[2284]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2263]! } + public var SocksProxySetup_TypeSocks: String { return self._s[2264]! } + public var AutoNightTheme_Title: String { return self._s[2265]! } + public var InstantPage_FeedbackButton: String { return self._s[2266]! } + public var Passport_FieldAddress: String { return self._s[2267]! } + public var Month_ShortMarch: String { return self._s[2268]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2269]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2270]! } + public var Passport_FloodError: String { return self._s[2271]! } + public var SecretGif_Title: String { return self._s[2272]! } + public var Passport_Language_th: String { return self._s[2274]! } + public var Passport_Address_Address: String { return self._s[2275]! } + public var Login_InvalidLastNameError: String { return self._s[2276]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[2277]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[2278]! } + public var ShareMenu_Send: String { return self._s[2279]! } + public var Month_GenNovember: String { return self._s[2282]! } + public var Checkout_Email: String { return self._s[2284]! } + public var NotificationsSound_Tritone: String { return self._s[2285]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[2287]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[2290]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2285]!, self._r[2285]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[2291]!, self._r[2291]!, [_1, _1, _1, _2]) } - public var DialogList_You: String { return self._s[2286]! } - public var MediaPicker_Send: String { return self._s[2289]! } - public var Call_AudioRouteSpeaker: String { return self._s[2290]! } - public var Watch_UserInfo_Title: String { return self._s[2291]! } - public var Appearance_AccentColor: String { return self._s[2292]! } + public var DialogList_You: String { return self._s[2292]! } + public var MediaPicker_Send: String { return self._s[2295]! } + public var Call_AudioRouteSpeaker: String { return self._s[2296]! } + public var Watch_UserInfo_Title: String { return self._s[2297]! } + public var Appearance_AccentColor: String { return self._s[2298]! } public func PINNED_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2299]!, self._r[2299]!, [_1, _2]) } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2294]!, self._r[2294]!, [_0]) + return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2295]! } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[2296]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[2297]! } - public var Notification_CallOutgoing: String { return self._s[2298]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2299]! } - public var Call_RecordingDisabledMessage: String { return self._s[2300]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2301]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2302]! } - public var Date_DialogDateFormat: String { return self._s[2303]! } - public var Notifications_InAppNotifications: String { return self._s[2304]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2301]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[2302]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[2303]! } + public var Notification_CallOutgoing: String { return self._s[2304]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2305]! } + public var Call_RecordingDisabledMessage: String { return self._s[2306]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2307]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2308]! } + public var Date_DialogDateFormat: String { return self._s[2309]! } + public var Notifications_InAppNotifications: String { return self._s[2310]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2305]!, self._r[2305]!, [_0]) + return formatWithArgumentRanges(self._s[2311]!, self._r[2311]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2306]!, self._r[2306]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2312]!, self._r[2312]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[2307]! } - public var Conversation_ViewContactDetails: String { return self._s[2308]! } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2310]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[2311]! } - public var PrivacySettings_Title: String { return self._s[2312]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2315]! } + public var NewContact_Title: String { return self._s[2313]! } + public var Conversation_ViewContactDetails: String { return self._s[2314]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2316]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[2317]! } + public var PrivacySettings_Title: String { return self._s[2318]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2321]! } public func CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_1]) + return formatWithArgumentRanges(self._s[2322]!, self._r[2322]!, [_1]) } - public var GroupRemoved_UsersSectionTitle: String { return self._s[2317]! } - public var Contacts_PhoneNumber: String { return self._s[2318]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[2323]! } + public var Contacts_PhoneNumber: String { return self._s[2324]! } public func CHANNEL_MESSAGE_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2320]!, self._r[2320]!, [_1]) + return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_1]) } - public var Map_ShowPlaces: String { return self._s[2321]! } - public var ChatAdmins_Title: String { return self._s[2322]! } - public var InstantPage_Reference: String { return self._s[2324]! } - public var Camera_FlashOff: String { return self._s[2325]! } - public var Watch_UserInfo_Block: String { return self._s[2326]! } - public var ChatSettings_Stickers: String { return self._s[2327]! } - public var ChatSettings_DownloadInBackground: String { return self._s[2328]! } + public var Map_ShowPlaces: String { return self._s[2327]! } + public var ChatAdmins_Title: String { return self._s[2328]! } + public var InstantPage_Reference: String { return self._s[2330]! } + public var Camera_FlashOff: String { return self._s[2331]! } + public var Watch_UserInfo_Block: String { return self._s[2332]! } + public var ChatSettings_Stickers: String { return self._s[2333]! } + public var ChatSettings_DownloadInBackground: String { return self._s[2334]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2329]!, self._r[2329]!, [_0]) + return formatWithArgumentRanges(self._s[2335]!, self._r[2335]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[2330]! } - public var Login_CheckOtherSessionMessages: String { return self._s[2331]! } - public var AutoDownloadSettings_Cellular: String { return self._s[2332]! } + public var Settings_ViewPhoto: String { return self._s[2336]! } + public var Login_CheckOtherSessionMessages: String { return self._s[2337]! } + public var AutoDownloadSettings_Cellular: String { return self._s[2338]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2334]!, self._r[2334]!, [_0]) + return formatWithArgumentRanges(self._s[2340]!, self._r[2340]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[2335]! } + public var Privacy_DeleteDrafts: String { return self._s[2341]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[2342]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2336]!, self._r[2336]!, [_0]) - } - public var DialogList_SavedMessagesHelp: String { return self._s[2337]! } - public var DialogList_SavedMessages: String { return self._s[2338]! } - public var GroupInfo_UpgradeButton: String { return self._s[2339]! } - public func CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2340]!, self._r[2340]!, [_1, _2, _3]) - } - public var DialogList_Pin: String { return self._s[2341]! } - public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2342]!, self._r[2342]!, [_0, _1]) - } - public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2343]!, self._r[2343]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[2344]! } - public var UserInfo_NotificationsDisable: String { return self._s[2345]! } - public var Paint_Outlined: String { return self._s[2346]! } - public var Activity_PlayingGame: String { return self._s[2347]! } - public var SearchImages_NoImagesFound: String { return self._s[2348]! } - public var SocksProxySetup_ProxyType: String { return self._s[2349]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[2351]! } - public var Settings_AppLanguage: String { return self._s[2352]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[2353]! } - public var Common_ChoosePhoto: String { return self._s[2354]! } - public var Privacy_Calls_AlwaysAllow: String { return self._s[2355]! } - public var Activity_UploadingVideo: String { return self._s[2356]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2357]! } - public var NetworkUsageSettings_Wifi: String { return self._s[2358]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[2359]! } - public var Checkout_PayWithTouchId: String { return self._s[2360]! } - public var Notifications_ExceptionsNone: String { return self._s[2362]! } + public var DialogList_SavedMessagesHelp: String { return self._s[2344]! } + public var DialogList_SavedMessages: String { return self._s[2345]! } + public var GroupInfo_UpgradeButton: String { return self._s[2346]! } + public func CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2347]!, self._r[2347]!, [_1, _2, _3]) + } + public var DialogList_Pin: String { return self._s[2348]! } + public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0, _1]) + } + public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2350]!, self._r[2350]!, [_0]) + } + public var Notification_Exceptions_AlwaysOn: String { return self._s[2351]! } + public var UserInfo_NotificationsDisable: String { return self._s[2352]! } + public var Paint_Outlined: String { return self._s[2353]! } + public var Activity_PlayingGame: String { return self._s[2354]! } + public var SearchImages_NoImagesFound: String { return self._s[2355]! } + public var SocksProxySetup_ProxyType: String { return self._s[2356]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[2358]! } + public var Settings_AppLanguage: String { return self._s[2359]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[2360]! } + public var Common_ChoosePhoto: String { return self._s[2361]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[2362]! } + public var Activity_UploadingVideo: String { return self._s[2363]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2364]! } + public var NetworkUsageSettings_Wifi: String { return self._s[2365]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[2366]! } + public var Checkout_PayWithTouchId: String { return self._s[2367]! } + public var Notifications_ExceptionsNone: String { return self._s[2369]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2363]!, self._r[2363]!, [_0]) + return formatWithArgumentRanges(self._s[2370]!, self._r[2370]!, [_0]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[2365]! } - public var Passport_Address_Region: String { return self._s[2368]! } - public var PhotoEditor_TiltShift: String { return self._s[2369]! } - public var Settings_FAQ_URL: String { return self._s[2370]! } - public var SharedMedia_TitleLink: String { return self._s[2372]! } - public var Settings_PrivacySettings: String { return self._s[2373]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[2374]! } - public var Passport_Language_sl: String { return self._s[2375]! } - public var Settings_SetProfilePhoto: String { return self._s[2376]! } - public var Channel_About_Help: String { return self._s[2377]! } - public var Contacts_PermissionsEnable: String { return self._s[2378]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[2379]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[2381]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[2382]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[2384]! } - public var Map_OpenInYandexMaps: String { return self._s[2386]! } - public var PhotoEditor_SaturationTool: String { return self._s[2387]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2388]! } - public var Appearance_TextSize: String { return self._s[2390]! } - public var Channel_Username_InvalidTooShort: String { return self._s[2392]! } - public var Passport_PassportInformation: String { return self._s[2395]! } - public var WatchRemote_AlertTitle: String { return self._s[2396]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2397]! } - public var ConvertToSupergroup_HelpText: String { return self._s[2399]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[2372]! } + public var Passport_Address_Region: String { return self._s[2375]! } + public var PhotoEditor_TiltShift: String { return self._s[2376]! } + public var Settings_FAQ_URL: String { return self._s[2377]! } + public var SharedMedia_TitleLink: String { return self._s[2379]! } + public var Settings_PrivacySettings: String { return self._s[2380]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[2381]! } + public var Passport_Language_sl: String { return self._s[2382]! } + public var Settings_SetProfilePhoto: String { return self._s[2383]! } + public var Channel_About_Help: String { return self._s[2384]! } + public var Contacts_PermissionsEnable: String { return self._s[2385]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[2386]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[2388]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[2389]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[2391]! } + public var Map_OpenInYandexMaps: String { return self._s[2393]! } + public var PhotoEditor_SaturationTool: String { return self._s[2394]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2395]! } + public var Appearance_TextSize: String { return self._s[2397]! } + public var Channel_Username_InvalidTooShort: String { return self._s[2399]! } + public var Passport_PassportInformation: String { return self._s[2402]! } + public var WatchRemote_AlertTitle: String { return self._s[2403]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2404]! } + public var ConvertToSupergroup_HelpText: String { return self._s[2406]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2400]!, self._r[2400]!, [_0]) + return formatWithArgumentRanges(self._s[2407]!, self._r[2407]!, [_0]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2401]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2403]! } - public var AccessDenied_CameraDisabled: String { return self._s[2404]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2408]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2410]! } + public var AccessDenied_CameraDisabled: String { return self._s[2411]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2405]!, self._r[2405]!, [_0]) + return formatWithArgumentRanges(self._s[2412]!, self._r[2412]!, [_0]) } - public var PhotoEditor_ContrastTool: String { return self._s[2408]! } - public var DialogList_Draft: String { return self._s[2409]! } - public var Privacy_TopPeersDelete: String { return self._s[2411]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[2412]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2413]! } - public var WebSearch_RecentSectionClear: String { return self._s[2414]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[2416]! } - public var Common_Done: String { return self._s[2417]! } - public var AuthSessions_EmptyText: String { return self._s[2418]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[2419]! } - public var Tour_Title5: String { return self._s[2420]! } + public var PhotoEditor_ContrastTool: String { return self._s[2415]! } + public var DialogList_Draft: String { return self._s[2416]! } + public var Privacy_TopPeersDelete: String { return self._s[2418]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[2419]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2420]! } + public var WebSearch_RecentSectionClear: String { return self._s[2421]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[2423]! } + public var Common_Done: String { return self._s[2424]! } + public var AuthSessions_EmptyText: String { return self._s[2425]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[2426]! } + public var Tour_Title5: String { return self._s[2427]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2421]!, self._r[2421]!, [_0]) + return formatWithArgumentRanges(self._s[2428]!, self._r[2428]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2422]! } - public var Conversation_LinkDialogSave: String { return self._s[2423]! } - public var GroupInfo_ActionRestrict: String { return self._s[2424]! } - public var Checkout_Title: String { return self._s[2425]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[2428]! } - public var Notification_RenamedGroup: String { return self._s[2429]! } - public var Checkout_PayWithFaceId: String { return self._s[2430]! } - public var Channel_BanList_BlockedTitle: String { return self._s[2431]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2429]! } + public var Conversation_LinkDialogSave: String { return self._s[2430]! } + public var GroupInfo_ActionRestrict: String { return self._s[2431]! } + public var Checkout_Title: String { return self._s[2432]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[2435]! } + public var Notification_RenamedGroup: String { return self._s[2436]! } + public var Checkout_PayWithFaceId: String { return self._s[2437]! } + public var Channel_BanList_BlockedTitle: String { return self._s[2438]! } public func PINNED_TEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2433]!, self._r[2433]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2440]!, self._r[2440]!, [_1, _2]) } - public var Checkout_WebConfirmation_Title: String { return self._s[2434]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[2435]! } - public var Profile_AddToExisting: String { return self._s[2437]! } + public var Checkout_WebConfirmation_Title: String { return self._s[2441]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[2442]! } + public var Profile_AddToExisting: String { return self._s[2444]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2438]!, self._r[2438]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2445]!, self._r[2445]!, [_0, _1]) } - public var Cache_Files: String { return self._s[2441]! } - public var Permissions_PrivacyPolicy: String { return self._s[2442]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[2443]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2444]! } + public var Cache_Files: String { return self._s[2448]! } + public var Permissions_PrivacyPolicy: String { return self._s[2449]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[2450]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2451]! } public func MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2446]!, self._r[2446]!, [_1]) + return formatWithArgumentRanges(self._s[2453]!, self._r[2453]!, [_1]) } - public var Calls_NoCallsPlaceholder: String { return self._s[2448]! } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2449]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2451]! } - public var Passport_FieldAddressHelp: String { return self._s[2452]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2453]! } + public var Calls_NoCallsPlaceholder: String { return self._s[2455]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2456]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2458]! } + public var Passport_FieldAddressHelp: String { return self._s[2459]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2460]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2454]!, self._r[2454]!, [_0]) + return formatWithArgumentRanges(self._s[2461]!, self._r[2461]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[2455]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[2457]! } - public var Login_UnknownError: String { return self._s[2458]! } - public var Group_UpgradeNoticeText2: String { return self._s[2460]! } - public var Watch_Compose_AddContact: String { return self._s[2461]! } - public var Web_Error: String { return self._s[2462]! } - public var Profile_MessageLifetime1h: String { return self._s[2463]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2464]! } - public var Channel_Username_CheckingUsername: String { return self._s[2465]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[2462]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[2464]! } + public var Login_UnknownError: String { return self._s[2465]! } + public var Group_UpgradeNoticeText2: String { return self._s[2467]! } + public var Watch_Compose_AddContact: String { return self._s[2468]! } + public var Web_Error: String { return self._s[2469]! } + public var Profile_MessageLifetime1h: String { return self._s[2470]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2471]! } + public var Channel_Username_CheckingUsername: String { return self._s[2472]! } public func PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2466]!, self._r[2466]!, [_1]) + return formatWithArgumentRanges(self._s[2473]!, self._r[2473]!, [_1]) } - public var Channel_AboutItem: String { return self._s[2467]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2469]! } - public var GroupInfo_SharedMedia: String { return self._s[2470]! } + public var Channel_AboutItem: String { return self._s[2474]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2476]! } + public var GroupInfo_SharedMedia: String { return self._s[2477]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2471]!, self._r[2471]!, [_1]) + return formatWithArgumentRanges(self._s[2478]!, self._r[2478]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[2472]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2473]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[2474]! } - public var CreatePoll_AddOption: String { return self._s[2475]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2476]! } - public var Group_UpgradeNoticeHeader: String { return self._s[2477]! } - public var Channel_Management_AddModerator: String { return self._s[2478]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[2479]! } - public var NotificationsSound_Hello: String { return self._s[2480]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[2479]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2480]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[2481]! } + public var CreatePoll_AddOption: String { return self._s[2482]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2483]! } + public var Group_UpgradeNoticeHeader: String { return self._s[2484]! } + public var Channel_Management_AddModerator: String { return self._s[2485]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[2486]! } + public var NotificationsSound_Hello: String { return self._s[2487]! } public func CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2481]!, self._r[2481]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2488]!, self._r[2488]!, [_1, _2]) } - public var SocksProxySetup_SavedProxies: String { return self._s[2482]! } - public var Channel_Stickers_Placeholder: String { return self._s[2484]! } + public var SocksProxySetup_SavedProxies: String { return self._s[2489]! } + public var Channel_Stickers_Placeholder: String { return self._s[2491]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2485]!, self._r[2485]!, [_0]) + return formatWithArgumentRanges(self._s[2492]!, self._r[2492]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2486]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[2487]! } - public var ContactInfo_BirthdayLabel: String { return self._s[2488]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2489]! } - public var AutoDownloadSettings_Channels: String { return self._s[2490]! } - public var Passport_Language_mn: String { return self._s[2491]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[2494]! } - public var Passport_Language_ja: String { return self._s[2496]! } - public var Settings_About_Title: String { return self._s[2497]! } - public var Settings_NotificationsAndSounds: String { return self._s[2498]! } - public var ChannelInfo_DeleteGroup: String { return self._s[2499]! } - public var Settings_BlockedUsers: String { return self._s[2500]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2493]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[2494]! } + public var ContactInfo_BirthdayLabel: String { return self._s[2495]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2496]! } + public var AutoDownloadSettings_Channels: String { return self._s[2497]! } + public var Passport_Language_mn: String { return self._s[2498]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[2501]! } + public var Passport_Language_ja: String { return self._s[2503]! } + public var Settings_About_Title: String { return self._s[2504]! } + public var Settings_NotificationsAndSounds: String { return self._s[2505]! } + public var ChannelInfo_DeleteGroup: String { return self._s[2506]! } + public var Settings_BlockedUsers: String { return self._s[2507]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2501]!, self._r[2501]!, [_0]) + return formatWithArgumentRanges(self._s[2508]!, self._r[2508]!, [_0]) } - public var Passport_Address_AddResidentialAddress: String { return self._s[2502]! } - public var Channel_Username_Title: String { return self._s[2503]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[2509]! } + public var Channel_Username_Title: String { return self._s[2510]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2504]!, self._r[2504]!, [_0]) + return formatWithArgumentRanges(self._s[2511]!, self._r[2511]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[2506]! } - public var AppleWatch_Title: String { return self._s[2507]! } - public var Activity_RecordingVideoMessage: String { return self._s[2508]! } - public var Weekday_Saturday: String { return self._s[2509]! } - public var Profile_CreateEncryptedChatError: String { return self._s[2510]! } - public var Common_Next: String { return self._s[2512]! } - public var Channel_Stickers_YourStickers: String { return self._s[2514]! } - public var Call_AudioRouteHeadphones: String { return self._s[2515]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2517]! } - public var Watch_Contacts_NoResults: String { return self._s[2519]! } - public var PhotoEditor_TintTool: String { return self._s[2521]! } - public var LoginPassword_ResetAccount: String { return self._s[2523]! } - public var Settings_SavedMessages: String { return self._s[2524]! } + public var AttachmentMenu_File: String { return self._s[2513]! } + public var AppleWatch_Title: String { return self._s[2514]! } + public var Activity_RecordingVideoMessage: String { return self._s[2515]! } + public var Weekday_Saturday: String { return self._s[2516]! } + public var Profile_CreateEncryptedChatError: String { return self._s[2517]! } + public var Common_Next: String { return self._s[2519]! } + public var Channel_Stickers_YourStickers: String { return self._s[2521]! } + public var Call_AudioRouteHeadphones: String { return self._s[2522]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2524]! } + public var Watch_Contacts_NoResults: String { return self._s[2526]! } + public var PhotoEditor_TintTool: String { return self._s[2528]! } + public var LoginPassword_ResetAccount: String { return self._s[2530]! } + public var Settings_SavedMessages: String { return self._s[2531]! } public func MESSAGE_GIF_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2525]!, self._r[2525]!, [_1]) + return formatWithArgumentRanges(self._s[2532]!, self._r[2532]!, [_1]) } - public var StickerPack_Add: String { return self._s[2526]! } - public var Your_cards_number_is_invalid: String { return self._s[2527]! } - public var Checkout_TotalAmount: String { return self._s[2528]! } + public var StickerPack_Add: String { return self._s[2533]! } + public var Your_cards_number_is_invalid: String { return self._s[2534]! } + public var Checkout_TotalAmount: String { return self._s[2535]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2529]!, self._r[2529]!, [_0]) + return formatWithArgumentRanges(self._s[2536]!, self._r[2536]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2530]!, self._r[2530]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2537]!, self._r[2537]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2531]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2538]! } public func CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2533]!, self._r[2533]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2540]!, self._r[2540]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2534]!, self._r[2534]!, [_0]) + return formatWithArgumentRanges(self._s[2541]!, self._r[2541]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[2535]! } - public var StickerPack_Share: String { return self._s[2536]! } - public var Passport_DeleteAddress: String { return self._s[2537]! } - public var Settings_Passport: String { return self._s[2538]! } - public var SharedMedia_EmptyFilesText: String { return self._s[2539]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[2540]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2541]! } - public var Contacts_PermissionsText: String { return self._s[2542]! } - public var Group_Setup_HistoryVisible: String { return self._s[2543]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[2545]! } - public var SocksProxySetup_Title: String { return self._s[2546]! } - public var Notification_Mute1h: String { return self._s[2547]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[2542]! } + public var StickerPack_Share: String { return self._s[2543]! } + public var Passport_DeleteAddress: String { return self._s[2544]! } + public var Settings_Passport: String { return self._s[2545]! } + public var SharedMedia_EmptyFilesText: String { return self._s[2546]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[2547]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2548]! } + public var Contacts_PermissionsText: String { return self._s[2549]! } + public var Group_Setup_HistoryVisible: String { return self._s[2550]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[2552]! } + public var SocksProxySetup_Title: String { return self._s[2553]! } + public var Notification_Mute1h: String { return self._s[2554]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2548]!, self._r[2548]!, [_0]) + return formatWithArgumentRanges(self._s[2555]!, self._r[2555]!, [_0]) } public func PINNED_CONTACT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_1]) + return formatWithArgumentRanges(self._s[2556]!, self._r[2556]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[2550]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[2553]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2555]! } - public var DialogList_NoMessagesText: String { return self._s[2556]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[2557]! } - public var Privacy_Calls_P2PHelp: String { return self._s[2558]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[2560]! } - public var Common_TakePhotoOrVideo: String { return self._s[2561]! } - public var Call_StatusBusy: String { return self._s[2562]! } - public var Conversation_PinnedMessage: String { return self._s[2563]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2564]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2565]! } - public var AppleWatch_ReplyPresets: String { return self._s[2566]! } - public var Passport_DiscardMessageDescription: String { return self._s[2568]! } - public var Login_NetworkError: String { return self._s[2569]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[2557]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[2560]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[2562]! } + public var DialogList_NoMessagesText: String { return self._s[2563]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[2564]! } + public var Privacy_Calls_P2PHelp: String { return self._s[2565]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[2567]! } + public var Common_TakePhotoOrVideo: String { return self._s[2568]! } + public var Call_StatusBusy: String { return self._s[2569]! } + public var Conversation_PinnedMessage: String { return self._s[2570]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[2571]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[2572]! } + public var AppleWatch_ReplyPresets: String { return self._s[2573]! } + public var Passport_DiscardMessageDescription: String { return self._s[2575]! } + public var Login_NetworkError: String { return self._s[2576]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2570]!, self._r[2570]!, [_0]) - } - public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2571]!, self._r[2571]!, [_0]) - } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[2572]! } - public func CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2574]!, self._r[2574]!, [_1]) - } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2575]! } - public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2577]!, self._r[2577]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[2578]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[2580]! } - public var ConversationMedia_Title: String { return self._s[2581]! } - public var EncryptionKey_Title: String { return self._s[2583]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[2584]! } - public var Notification_Exceptions_AddException: String { return self._s[2585]! } - public var Profile_MessageLifetime1m: String { return self._s[2586]! } + public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2578]!, self._r[2578]!, [_0]) + } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[2579]! } + public func CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2581]!, self._r[2581]!, [_1]) + } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[2582]! } + public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2584]!, self._r[2584]!, [_0]) + } + public var Call_ConnectionErrorMessage: String { return self._s[2585]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[2587]! } + public var ConversationMedia_Title: String { return self._s[2588]! } + public var EncryptionKey_Title: String { return self._s[2590]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[2591]! } + public var Notification_Exceptions_AddException: String { return self._s[2592]! } + public var Profile_MessageLifetime1m: String { return self._s[2593]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2587]!, self._r[2587]!, [_1]) + return formatWithArgumentRanges(self._s[2594]!, self._r[2594]!, [_1]) } - public var Month_GenMay: String { return self._s[2588]! } + public var Month_GenMay: String { return self._s[2595]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2589]!, self._r[2589]!, [_0]) + return formatWithArgumentRanges(self._s[2596]!, self._r[2596]!, [_0]) } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2590]! } - public var Conversation_EmptyPlaceholder: String { return self._s[2592]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[2593]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[2594]! } - public var Camera_TapAndHoldForVideo: String { return self._s[2595]! } - public var Channel_JoinChannel: String { return self._s[2597]! } - public var Appearance_Animations: String { return self._s[2600]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2597]! } + public var Conversation_EmptyPlaceholder: String { return self._s[2599]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[2600]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[2601]! } + public var Camera_TapAndHoldForVideo: String { return self._s[2602]! } + public var Channel_JoinChannel: String { return self._s[2604]! } + public var Appearance_Animations: String { return self._s[2607]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2601]!, self._r[2601]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2608]!, self._r[2608]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[2603]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[2605]! } - public var Passport_Address_Street: String { return self._s[2606]! } - public var Conversation_AddContact: String { return self._s[2607]! } - public var Login_PhonePlaceholder: String { return self._s[2608]! } - public var Channel_Members_InviteLink: String { return self._s[2610]! } - public var Bot_Stop: String { return self._s[2611]! } - public var Notification_PassportValueAddress: String { return self._s[2613]! } - public var Month_ShortJuly: String { return self._s[2614]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[2615]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[2616]! } - public var Passport_Identity_ReverseSide: String { return self._s[2617]! } - public var Watch_Stickers_Recents: String { return self._s[2620]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2622]! } - public var Map_SendThisLocation: String { return self._s[2623]! } + public var Stickers_GroupStickers: String { return self._s[2610]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[2612]! } + public var Passport_Address_Street: String { return self._s[2613]! } + public var Conversation_AddContact: String { return self._s[2614]! } + public var Login_PhonePlaceholder: String { return self._s[2615]! } + public var Channel_Members_InviteLink: String { return self._s[2617]! } + public var Bot_Stop: String { return self._s[2618]! } + public var Notification_PassportValueAddress: String { return self._s[2620]! } + public var Month_ShortJuly: String { return self._s[2621]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[2622]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[2623]! } + public var Passport_Identity_ReverseSide: String { return self._s[2624]! } + public var Watch_Stickers_Recents: String { return self._s[2627]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[2629]! } + public var Map_SendThisLocation: String { return self._s[2630]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2624]!, self._r[2624]!, [_0]) + return formatWithArgumentRanges(self._s[2631]!, self._r[2631]!, [_0]) } public func CHANNEL_MESSAGE_STICKER_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2625]!, self._r[2625]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_1, _2]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2626]!, self._r[2626]!, [_0]) + return formatWithArgumentRanges(self._s[2633]!, self._r[2633]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[2627]! } + public var ConvertToSupergroup_Note: String { return self._s[2634]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2628]!, self._r[2628]!, [_0]) + return formatWithArgumentRanges(self._s[2635]!, self._r[2635]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[2629]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[2636]! } public func PINNED_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2630]!, self._r[2630]!, [_1]) + return formatWithArgumentRanges(self._s[2637]!, self._r[2637]!, [_1]) } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2631]!, self._r[2631]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2638]!, self._r[2638]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[2632]! } + public var Login_CallRequestState3: String { return self._s[2639]! } public func CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2635]!, self._r[2635]!, [_1]) + return formatWithArgumentRanges(self._s[2642]!, self._r[2642]!, [_1]) } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[2636]! } - public var Channel_AdminLogFilter_Title: String { return self._s[2637]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[2641]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[2643]! } + public var Channel_AdminLogFilter_Title: String { return self._s[2644]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[2648]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2642]!, self._r[2642]!, [_0]) + return formatWithArgumentRanges(self._s[2649]!, self._r[2649]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[2643]! } + public var Passport_CorrectErrors: String { return self._s[2650]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2644]!, self._r[2644]!, [_0]) - } - public var Map_SendMyCurrentLocation: String { return self._s[2645]! } - public var SharedMedia_SearchNoResults: String { return self._s[2646]! } - public var Permissions_NotificationsText_v0: String { return self._s[2647]! } - public var LoginPassword_FloodError: String { return self._s[2648]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[2650]! } - public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2651]!, self._r[2651]!, [_0]) } - public var Passport_Language_bn: String { return self._s[2652]! } + public var Map_SendMyCurrentLocation: String { return self._s[2652]! } + public var SharedMedia_SearchNoResults: String { return self._s[2653]! } + public var Permissions_NotificationsText_v0: String { return self._s[2654]! } + public var LoginPassword_FloodError: String { return self._s[2655]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[2657]! } + public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2658]!, self._r[2658]!, [_0]) + } + public var Passport_Language_bn: String { return self._s[2659]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2653]!, self._r[2653]!, [_0]) + return formatWithArgumentRanges(self._s[2660]!, self._r[2660]!, [_0]) } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2654]!, self._r[2654]!, [_0]) + return formatWithArgumentRanges(self._s[2661]!, self._r[2661]!, [_0]) } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2655]!, self._r[2655]!, [_0]) + return formatWithArgumentRanges(self._s[2662]!, self._r[2662]!, [_0]) } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2658]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2660]! } - public var Contacts_PermissionsAllow: String { return self._s[2661]! } - public var ReportPeer_ReasonCopyright: String { return self._s[2662]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[2663]! } - public var Paint_Duplicate: String { return self._s[2664]! } - public var Notification_ChannelMigratedFrom: String { return self._s[2665]! } - public var Passport_Address_Country: String { return self._s[2666]! } - public var Notification_RenamedChannel: String { return self._s[2668]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[2669]! } - public var Group_MessagePhotoUpdated: String { return self._s[2670]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[2671]! } - public var Conversation_ContextMenuBan: String { return self._s[2672]! } - public var TwoStepAuth_EmailSent: String { return self._s[2673]! } - public var MessagePoll_NoVotes: String { return self._s[2674]! } - public var Passport_Language_is: String { return self._s[2675]! } - public var Tour_Text5: String { return self._s[2677]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[2665]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[2667]! } + public var Contacts_PermissionsAllow: String { return self._s[2668]! } + public var ReportPeer_ReasonCopyright: String { return self._s[2669]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[2670]! } + public var Paint_Duplicate: String { return self._s[2671]! } + public var Notification_ChannelMigratedFrom: String { return self._s[2672]! } + public var Passport_Address_Country: String { return self._s[2673]! } + public var Notification_RenamedChannel: String { return self._s[2675]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[2676]! } + public var Group_MessagePhotoUpdated: String { return self._s[2677]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[2678]! } + public var Conversation_ContextMenuBan: String { return self._s[2679]! } + public var TwoStepAuth_EmailSent: String { return self._s[2680]! } + public var MessagePoll_NoVotes: String { return self._s[2681]! } + public var Passport_Language_is: String { return self._s[2682]! } + public var Tour_Text5: String { return self._s[2684]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2679]!, self._r[2679]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2686]!, self._r[2686]!, [_1, _2]) } - public var Paint_Edit: String { return self._s[2681]! } - public var LoginPassword_ForgotPassword: String { return self._s[2684]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[2685]! } + public var Paint_Edit: String { return self._s[2688]! } + public var LoginPassword_ForgotPassword: String { return self._s[2691]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[2692]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2686]!, self._r[2686]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2693]!, self._r[2693]!, [_0, _1]) } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[2687]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[2688]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[2689]! } - public var Passport_Language_uz: String { return self._s[2690]! } - public var Map_StopLiveLocation: String { return self._s[2692]! } - public var PasscodeSettings_Help: String { return self._s[2694]! } - public var NotificationsSound_Input: String { return self._s[2695]! } - public var Share_Title: String { return self._s[2697]! } - public var Login_TermsOfServiceAgree: String { return self._s[2698]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[2699]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2700]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[2701]! } - public var EnterPasscode_EnterTitle: String { return self._s[2702]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[2694]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[2695]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[2696]! } + public var Passport_Language_uz: String { return self._s[2697]! } + public var Map_StopLiveLocation: String { return self._s[2699]! } + public var PasscodeSettings_Help: String { return self._s[2701]! } + public var NotificationsSound_Input: String { return self._s[2702]! } + public var Share_Title: String { return self._s[2704]! } + public var Login_TermsOfServiceAgree: String { return self._s[2705]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[2706]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2707]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[2708]! } + public var EnterPasscode_EnterTitle: String { return self._s[2709]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2703]!, self._r[2703]!, [_0]) + return formatWithArgumentRanges(self._s[2710]!, self._r[2710]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[2704]! } - public var NotificationsSound_Keys: String { return self._s[2705]! } + public var Settings_CopyPhoneNumber: String { return self._s[2711]! } + public var NotificationsSound_Keys: String { return self._s[2712]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2706]!, self._r[2706]!, [_0]) - } - public var Notification_MessageLifetime1w: String { return self._s[2707]! } - public var Message_Video: String { return self._s[2708]! } - public func MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2711]!, self._r[2711]!, [_1]) - } - public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2712]!, self._r[2712]!, [_0]) - } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2713]!, self._r[2713]!, [_0]) } - public var Passport_Language_mk: String { return self._s[2714]! } - public var CreatePoll_CancelConfirmation: String { return self._s[2715]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[2717]! } - public var PrivacyPolicy_Decline: String { return self._s[2718]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[2719]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[2720]! } - public var Permissions_SiriAllow_v0: String { return self._s[2721]! } + public var Notification_MessageLifetime1w: String { return self._s[2714]! } + public var Message_Video: String { return self._s[2715]! } + public func MESSAGE_GEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2718]!, self._r[2718]!, [_1]) + } + public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2719]!, self._r[2719]!, [_0]) + } + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2720]!, self._r[2720]!, [_0]) + } + public var Passport_Language_mk: String { return self._s[2721]! } + public var CreatePoll_CancelConfirmation: String { return self._s[2722]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[2724]! } + public var PrivacyPolicy_Decline: String { return self._s[2725]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[2726]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[2727]! } + public var Permissions_SiriAllow_v0: String { return self._s[2728]! } public func CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2722]!, self._r[2722]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2729]!, self._r[2729]!, [_1, _2, _3]) } public func CHANNEL_MESSAGES(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2723]!, self._r[2723]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2730]!, self._r[2730]!, [_1, _2]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2724]!, self._r[2724]!, [_0]) + return formatWithArgumentRanges(self._s[2731]!, self._r[2731]!, [_0]) } - public var Paint_Regular: String { return self._s[2725]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[2726]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[2727]! } - public var GroupInfo_InviteByLink: String { return self._s[2729]! } - public var MessageTimer_Custom: String { return self._s[2730]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[2731]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[2733]! } - public var Channel_Username_InvalidTaken: String { return self._s[2734]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[2735]! } + public var Paint_Regular: String { return self._s[2732]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[2733]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[2734]! } + public var GroupInfo_InviteByLink: String { return self._s[2736]! } + public var MessageTimer_Custom: String { return self._s[2737]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[2738]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[2740]! } + public var Channel_Username_InvalidTaken: String { return self._s[2741]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[2742]! } public func CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2736]!, self._r[2736]!, [_1]) + return formatWithArgumentRanges(self._s[2743]!, self._r[2743]!, [_1]) } - public var Settings_ChatBackground: String { return self._s[2737]! } - public var Channel_Subscribers_Title: String { return self._s[2738]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[2739]! } - public var Watch_ConnectionDescription: String { return self._s[2740]! } + public var Settings_ChatBackground: String { return self._s[2744]! } + public var Channel_Subscribers_Title: String { return self._s[2745]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[2746]! } + public var Watch_ConnectionDescription: String { return self._s[2747]! } public func PINNED_VIDEO_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_1]) + return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_1]) } - public var EditProfile_Title: String { return self._s[2745]! } - public var NotificationsSound_Bamboo: String { return self._s[2747]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[2749]! } - public var Login_SmsRequestState2: String { return self._s[2750]! } - public var Passport_Language_ar: String { return self._s[2751]! } - public var Conversation_MessageDialogEdit: String { return self._s[2752]! } - public var Common_Close: String { return self._s[2753]! } + public var EditProfile_Title: String { return self._s[2752]! } + public var NotificationsSound_Bamboo: String { return self._s[2754]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[2756]! } + public var Login_SmsRequestState2: String { return self._s[2757]! } + public var Passport_Language_ar: String { return self._s[2758]! } + public var Conversation_MessageDialogEdit: String { return self._s[2759]! } + public var Common_Close: String { return self._s[2760]! } public func CHAT_MESSAGE_TEXT_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2757]!, self._r[2757]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2764]!, self._r[2764]!, [_1, _2, _3]) } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2758]!, self._r[2758]!, [_0]) + return formatWithArgumentRanges(self._s[2765]!, self._r[2765]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[2759]! } + public var UserInfo_About_Placeholder: String { return self._s[2766]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2760]!, self._r[2760]!, [_0]) + return formatWithArgumentRanges(self._s[2767]!, self._r[2767]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[2761]! } - public var Channel_Info_Banned: String { return self._s[2763]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[2768]! } + public var Channel_Info_Banned: String { return self._s[2770]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2764]!, self._r[2764]!, [_0]) + return formatWithArgumentRanges(self._s[2771]!, self._r[2771]!, [_0]) } - public var Passport_Language_my: String { return self._s[2765]! } + public var Passport_Language_my: String { return self._s[2772]! } public func CHAT_MESSAGE_GEO_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2766]!, self._r[2766]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2773]!, self._r[2773]!, [_1, _2]) } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2767]!, self._r[2767]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2774]!, self._r[2774]!, [_1, _2, _3]) } - public var Preview_CopyAddress: String { return self._s[2768]! } + public var Preview_CopyAddress: String { return self._s[2775]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2769]!, self._r[2769]!, [_0]) + return formatWithArgumentRanges(self._s[2776]!, self._r[2776]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[2770]! } - public var UserInfo_BotSettings: String { return self._s[2771]! } - public var LiveLocation_MenuStopAll: String { return self._s[2773]! } - public var Passport_PasswordCreate: String { return self._s[2774]! } - public var StickerSettings_MaskContextInfo: String { return self._s[2775]! } - public var Message_PinnedLocationMessage: String { return self._s[2776]! } - public var Map_Satellite: String { return self._s[2777]! } - public var Watch_Message_Unsupported: String { return self._s[2778]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[2779]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2780]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[2777]! } + public var UserInfo_BotSettings: String { return self._s[2778]! } + public var LiveLocation_MenuStopAll: String { return self._s[2780]! } + public var Passport_PasswordCreate: String { return self._s[2781]! } + public var StickerSettings_MaskContextInfo: String { return self._s[2782]! } + public var Message_PinnedLocationMessage: String { return self._s[2783]! } + public var Map_Satellite: String { return self._s[2784]! } + public var Watch_Message_Unsupported: String { return self._s[2785]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[2786]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[2787]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2781]!, self._r[2781]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2788]!, self._r[2788]!, [_0, _1]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[2782]! } - public var Privacy_Calls_P2PContacts: String { return self._s[2783]! } - public var NotificationsSound_None: String { return self._s[2784]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[2786]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[2789]! } + public var Privacy_Calls_P2PContacts: String { return self._s[2790]! } + public var NotificationsSound_None: String { return self._s[2791]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[2793]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2787]!, self._r[2787]!, [_1]) + return formatWithArgumentRanges(self._s[2794]!, self._r[2794]!, [_1]) } - public var Cache_Indexing: String { return self._s[2788]! } - public var DialogList_RecentTitlePeople: String { return self._s[2790]! } - public var DialogList_EncryptionRejected: String { return self._s[2791]! } - public var GroupInfo_Administrators: String { return self._s[2792]! } - public var Passport_ScanPassportHelp: String { return self._s[2793]! } - public var Application_Name: String { return self._s[2794]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2795]! } - public var Passport_Identity_TranslationHelp: String { return self._s[2797]! } + public var Cache_Indexing: String { return self._s[2795]! } + public var DialogList_RecentTitlePeople: String { return self._s[2797]! } + public var DialogList_EncryptionRejected: String { return self._s[2798]! } + public var GroupInfo_Administrators: String { return self._s[2799]! } + public var Passport_ScanPassportHelp: String { return self._s[2800]! } + public var Application_Name: String { return self._s[2801]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[2802]! } + public var Passport_Identity_TranslationHelp: String { return self._s[2804]! } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2798]!, self._r[2798]!, [_0]) + return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2799]!, self._r[2799]!, [_0]) + return formatWithArgumentRanges(self._s[2806]!, self._r[2806]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[2800]! } - public var Privacy_ChatsTitle: String { return self._s[2801]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[2802]! } - public var Watch_Suggestion_HoldOn: String { return self._s[2803]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[2804]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2805]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[2806]! } - public var Channel_Setup_TypePublic: String { return self._s[2809]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[2807]! } + public var Privacy_ChatsTitle: String { return self._s[2808]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[2809]! } + public var Watch_Suggestion_HoldOn: String { return self._s[2810]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[2811]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2812]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[2813]! } + public var Channel_Setup_TypePublic: String { return self._s[2816]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2810]!, self._r[2810]!, [_0]) + return formatWithArgumentRanges(self._s[2817]!, self._r[2817]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[2812]! } - public var Map_OpenInMaps: String { return self._s[2814]! } - public var NotificationsSound_Tremolo: String { return self._s[2816]! } + public var Channel_TypeSetup_Title: String { return self._s[2819]! } + public var Map_OpenInMaps: String { return self._s[2821]! } + public var NotificationsSound_Tremolo: String { return self._s[2823]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2818]!, self._r[2818]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2825]!, self._r[2825]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[2819]! } - public var Passport_PasswordHelp: String { return self._s[2820]! } - public var Login_CodeExpiredError: String { return self._s[2821]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2822]! } - public var Conversation_TitleUnmute: String { return self._s[2823]! } - public var Passport_Identity_ScansHelp: String { return self._s[2824]! } - public var Passport_Language_lo: String { return self._s[2825]! } - public var Camera_FlashAuto: String { return self._s[2826]! } - public var Common_Cancel: String { return self._s[2827]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[2828]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2829]! } - public var Conversation_ReportSpamConfirmation: String { return self._s[2830]! } - public var ChatSettings_Title: String { return self._s[2832]! } - public var Passport_PasswordReset: String { return self._s[2833]! } - public var SocksProxySetup_TypeNone: String { return self._s[2834]! } - public var PhoneNumberHelp_Help: String { return self._s[2836]! } - public var Checkout_EnterPassword: String { return self._s[2837]! } - public var Activity_UploadingDocument: String { return self._s[2839]! } - public var Share_AuthTitle: String { return self._s[2840]! } - public var State_Connecting: String { return self._s[2841]! } - public var Profile_MessageLifetime1w: String { return self._s[2842]! } - public var Conversation_ContextMenuReport: String { return self._s[2843]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[2844]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[2845]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[2826]! } + public var Passport_PasswordHelp: String { return self._s[2827]! } + public var Login_CodeExpiredError: String { return self._s[2828]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[2829]! } + public var Conversation_TitleUnmute: String { return self._s[2830]! } + public var Passport_Identity_ScansHelp: String { return self._s[2831]! } + public var Passport_Language_lo: String { return self._s[2832]! } + public var Camera_FlashAuto: String { return self._s[2833]! } + public var Common_Cancel: String { return self._s[2834]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[2835]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[2836]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[2837]! } + public var ChatSettings_Title: String { return self._s[2839]! } + public var Passport_PasswordReset: String { return self._s[2840]! } + public var SocksProxySetup_TypeNone: String { return self._s[2841]! } + public var PhoneNumberHelp_Help: String { return self._s[2843]! } + public var Checkout_EnterPassword: String { return self._s[2844]! } + public var Activity_UploadingDocument: String { return self._s[2846]! } + public var Share_AuthTitle: String { return self._s[2847]! } + public var State_Connecting: String { return self._s[2848]! } + public var Profile_MessageLifetime1w: String { return self._s[2849]! } + public var Conversation_ContextMenuReport: String { return self._s[2850]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[2851]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[2852]! } public func CHAT_DELETE_MEMBER_SEPARATED(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2846]!, self._r[2846]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2853]!, self._r[2853]!, [_1, _2, _3]) } - public var AuthSessions_Terminate: String { return self._s[2847]! } + public var AuthSessions_Terminate: String { return self._s[2854]! } public func MESSAGE_TEXT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2848]!, self._r[2848]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2855]!, self._r[2855]!, [_1, _2]) } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[2849]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[2850]! } - public var PhotoEditor_Set: String { return self._s[2851]! } - public var EmptyGroupInfo_Title: String { return self._s[2852]! } - public var Login_PadPhoneHelp: String { return self._s[2853]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[2856]! } - public var NotificationsSound_Complete: String { return self._s[2857]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[2856]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[2857]! } + public var PhotoEditor_Set: String { return self._s[2858]! } + public var EmptyGroupInfo_Title: String { return self._s[2859]! } + public var Login_PadPhoneHelp: String { return self._s[2860]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[2863]! } + public var NotificationsSound_Complete: String { return self._s[2864]! } public func CHAT_MESSAGE_CONTACT_SEPARATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2858]!, self._r[2858]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2865]!, self._r[2865]!, [_1, _2]) } - public var Group_Info_AdminLog: String { return self._s[2859]! } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[2860]! } - public var Conversation_Admin: String { return self._s[2862]! } - public var Conversation_GifTooltip: String { return self._s[2863]! } - public var Passport_NotLoggedInMessage: String { return self._s[2864]! } - public var Profile_MessageLifetimeForever: String { return self._s[2865]! } + public var Group_Info_AdminLog: String { return self._s[2866]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[2867]! } + public var Conversation_Admin: String { return self._s[2869]! } + public var Conversation_GifTooltip: String { return self._s[2870]! } + public var Passport_NotLoggedInMessage: String { return self._s[2871]! } + public var Profile_MessageLifetimeForever: String { return self._s[2872]! } public func MESSAGE_POLL_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2867]!, self._r[2867]!, [_1]) + return formatWithArgumentRanges(self._s[2874]!, self._r[2874]!, [_1]) } - public var SharedMedia_EmptyTitle: String { return self._s[2868]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[2869]! } - public var Username_Help: String { return self._s[2870]! } - public var DialogList_LanguageTooltip: String { return self._s[2872]! } - public var Map_LoadError: String { return self._s[2873]! } - public var Notification_Exceptions_NewException: String { return self._s[2874]! } - public var TwoStepAuth_EmailTitle: String { return self._s[2875]! } - public var WatchRemote_AlertText: String { return self._s[2876]! } - public var ChatSettings_ConnectionType_Title: String { return self._s[2878]! } + public var SharedMedia_EmptyTitle: String { return self._s[2875]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[2876]! } + public var Username_Help: String { return self._s[2877]! } + public var DialogList_LanguageTooltip: String { return self._s[2879]! } + public var Map_LoadError: String { return self._s[2880]! } + public var Notification_Exceptions_NewException: String { return self._s[2881]! } + public var TwoStepAuth_EmailTitle: String { return self._s[2882]! } + public var WatchRemote_AlertText: String { return self._s[2883]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[2885]! } public func CHANNEL_MESSAGE_GEOLIVE_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2879]!, self._r[2879]!, [_1]) + return formatWithArgumentRanges(self._s[2886]!, self._r[2886]!, [_1]) } public func LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2880]!, self._r[2880]!, [_1]) + return formatWithArgumentRanges(self._s[2887]!, self._r[2887]!, [_1]) } - public var Passport_Address_CountryPlaceholder: String { return self._s[2881]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[2888]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2882]!, self._r[2882]!, [_0]) + return formatWithArgumentRanges(self._s[2889]!, self._r[2889]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2883]!, self._r[2883]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2890]!, self._r[2890]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[2884]! } - public var AccessDenied_VideoMicrophone: String { return self._s[2886]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[2887]! } - public var Cache_ClearNone: String { return self._s[2888]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[2889]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[2890]! } + public var Group_AdminLog_EmptyText: String { return self._s[2891]! } + public var AccessDenied_VideoMicrophone: String { return self._s[2893]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[2894]! } + public var Cache_ClearNone: String { return self._s[2895]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[2896]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[2897]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, [_0]) + return formatWithArgumentRanges(self._s[2898]!, self._r[2898]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[2892]! } + public var Passport_Identity_Country: String { return self._s[2899]! } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2893]!, self._r[2893]!, [_0]) + return formatWithArgumentRanges(self._s[2900]!, self._r[2900]!, [_0]) } - public var AccessDenied_Settings: String { return self._s[2894]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2895]! } - public var Month_ShortMay: String { return self._s[2896]! } - public var Compose_NewGroup: String { return self._s[2897]! } - public var Group_Setup_TypePrivate: String { return self._s[2899]! } - public var Login_PadPhoneHelpTitle: String { return self._s[2900]! } - public var Appearance_ThemeDayClassic: String { return self._s[2901]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[2902]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[2903]! } - public var Conversation_typing: String { return self._s[2905]! } - public var Paint_Masks: String { return self._s[2906]! } + public var AccessDenied_Settings: String { return self._s[2901]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[2902]! } + public var Month_ShortMay: String { return self._s[2903]! } + public var Compose_NewGroup: String { return self._s[2904]! } + public var Group_Setup_TypePrivate: String { return self._s[2906]! } + public var Login_PadPhoneHelpTitle: String { return self._s[2907]! } + public var Appearance_ThemeDayClassic: String { return self._s[2908]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[2909]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[2910]! } + public var Conversation_typing: String { return self._s[2912]! } + public var Paint_Masks: String { return self._s[2913]! } public func PINNED_DOC_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2907]!, self._r[2907]!, [_1]) + return formatWithArgumentRanges(self._s[2914]!, self._r[2914]!, [_1]) } - public var Username_InvalidTaken: String { return self._s[2908]! } + public var Username_InvalidTaken: String { return self._s[2915]! } public func CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2909]!, self._r[2909]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2916]!, self._r[2916]!, [_1, _2]) } - public var Call_StatusNoAnswer: String { return self._s[2910]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[2911]! } - public var Passport_Identity_Selfie: String { return self._s[2912]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[2913]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2914]! } - public var Conversation_ClearSecretHistory: String { return self._s[2915]! } - public var NetworkUsageSettings_Title: String { return self._s[2917]! } - public var Your_cards_security_code_is_invalid: String { return self._s[2919]! } + public var Call_StatusNoAnswer: String { return self._s[2917]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[2918]! } + public var Passport_Identity_Selfie: String { return self._s[2919]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[2920]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2921]! } + public var Conversation_ClearSecretHistory: String { return self._s[2922]! } + public var NetworkUsageSettings_Title: String { return self._s[2924]! } + public var Your_cards_security_code_is_invalid: String { return self._s[2926]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2921]!, self._r[2921]!, [_0]) + return formatWithArgumentRanges(self._s[2928]!, self._r[2928]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2922]!, self._r[2922]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2929]!, self._r[2929]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[2924]! } - public var Map_LiveLocationTitle: String { return self._s[2925]! } - public var Login_InfoAvatarAdd: String { return self._s[2926]! } - public var Passport_Identity_FilesView: String { return self._s[2927]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[2928]! } - public var Privacy_Calls_NeverAllow: String { return self._s[2929]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[2931]! } + public var Map_LiveLocationTitle: String { return self._s[2932]! } + public var Login_InfoAvatarAdd: String { return self._s[2933]! } + public var Passport_Identity_FilesView: String { return self._s[2934]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[2935]! } + public var Privacy_Calls_NeverAllow: String { return self._s[2936]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2930]!, self._r[2930]!, [_0]) + return formatWithArgumentRanges(self._s[2937]!, self._r[2937]!, [_0]) } - public var TwoStepAuth_ConfirmationText: String { return self._s[2931]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[2932]! } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2933]! } - public var Tour_Title2: String { return self._s[2934]! } - public var Conversation_FileOpenIn: String { return self._s[2935]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2936]! } - public var Wallpaper_Set: String { return self._s[2937]! } - public var Passport_Identity_Translations: String { return self._s[2939]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[2938]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[2939]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2940]! } + public var Tour_Title2: String { return self._s[2941]! } + public var Conversation_FileOpenIn: String { return self._s[2942]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[2943]! } + public var Wallpaper_Set: String { return self._s[2944]! } + public var Passport_Identity_Translations: String { return self._s[2946]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2940]!, self._r[2940]!, [_0]) + return formatWithArgumentRanges(self._s[2947]!, self._r[2947]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[2941]! } + public var Channel_LeaveChannel: String { return self._s[2948]! } public func MESSAGE_NOTEXT_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2942]!, self._r[2942]!, [_1]) + return formatWithArgumentRanges(self._s[2949]!, self._r[2949]!, [_1]) } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2943]!, self._r[2943]!, [_1]) + return formatWithArgumentRanges(self._s[2950]!, self._r[2950]!, [_1]) } - public var PhotoEditor_HighlightsTint: String { return self._s[2944]! } - public var Passport_Email_Delete: String { return self._s[2945]! } - public var Conversation_Mute: String { return self._s[2947]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[2949]! } + public var PhotoEditor_HighlightsTint: String { return self._s[2951]! } + public var Passport_Email_Delete: String { return self._s[2952]! } + public var Conversation_Mute: String { return self._s[2954]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[2956]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2950]!, self._r[2950]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2957]!, self._r[2957]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[2951]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[2952]! } - public var Common_No: String { return self._s[2953]! } - public var Weekday_Sunday: String { return self._s[2954]! } - public var Notification_Reply: String { return self._s[2955]! } - public var Conversation_ViewMessage: String { return self._s[2956]! } + public var Calls_CallTabDescription: String { return self._s[2958]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[2959]! } + public var Common_No: String { return self._s[2960]! } + public var Weekday_Sunday: String { return self._s[2961]! } + public var Notification_Reply: String { return self._s[2962]! } + public var Conversation_ViewMessage: String { return self._s[2963]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2957]!, self._r[2957]!, [_0]) + return formatWithArgumentRanges(self._s[2964]!, self._r[2964]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2958]!, self._r[2958]!, [_0]) + return formatWithArgumentRanges(self._s[2965]!, self._r[2965]!, [_0]) } - public var Message_PinnedDocumentMessage: String { return self._s[2959]! } - public var DialogList_TabTitle: String { return self._s[2961]! } - public var Passport_FieldEmail: String { return self._s[2962]! } - public var Conversation_UnpinMessageAlert: String { return self._s[2963]! } - public var Passport_Address_TypeBankStatement: String { return self._s[2964]! } - public var Passport_Identity_ExpiryDate: String { return self._s[2965]! } - public var Privacy_Calls_P2P: String { return self._s[2966]! } + public var Message_PinnedDocumentMessage: String { return self._s[2966]! } + public var DialogList_TabTitle: String { return self._s[2968]! } + public var Passport_FieldEmail: String { return self._s[2969]! } + public var Conversation_UnpinMessageAlert: String { return self._s[2970]! } + public var Passport_Address_TypeBankStatement: String { return self._s[2971]! } + public var Passport_Identity_ExpiryDate: String { return self._s[2972]! } + public var Privacy_Calls_P2P: String { return self._s[2973]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2968]!, self._r[2968]!, [_0]) + return formatWithArgumentRanges(self._s[2975]!, self._r[2975]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[2969]! } - public var EnterPasscode_ChangeTitle: String { return self._s[2970]! } - public var Passport_InfoText: String { return self._s[2971]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[2972]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[2976]! } + public var EnterPasscode_ChangeTitle: String { return self._s[2977]! } + public var Passport_InfoText: String { return self._s[2978]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[2979]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2973]!, self._r[2973]!, [_0]) + return formatWithArgumentRanges(self._s[2980]!, self._r[2980]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2974]!, self._r[2974]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2981]!, self._r[2981]!, [_1, _2, _3]) } - public var Passport_Identity_EditDriversLicense: String { return self._s[2975]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[2977]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[2982]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[2984]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2978]!, self._r[2978]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_1, _2]) } public func MESSAGE_ROUND_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2979]!, self._r[2979]!, [_1]) + return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_1]) } public func PHONE_CALL_MISSED_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2981]!, self._r[2981]!, [_1]) + return formatWithArgumentRanges(self._s[2988]!, self._r[2988]!, [_1]) } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2983]!, self._r[2983]!, [_0]) + return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_0]) } - public var DialogList_Unread: String { return self._s[2984]! } - public var User_DeletedAccount: String { return self._s[2985]! } + public var DialogList_Unread: String { return self._s[2991]! } + public var User_DeletedAccount: String { return self._s[2992]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_0]) + return formatWithArgumentRanges(self._s[2993]!, self._r[2993]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[2987]! } - public var SharedMedia_CategoryMedia: String { return self._s[2988]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[2989]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[2990]! } - public var Watch_ChatList_Compose: String { return self._s[2991]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[2992]! } - public var Watch_Microphone_Access: String { return self._s[2993]! } - public var Group_Setup_HistoryHeader: String { return self._s[2994]! } - public var Activity_UploadingPhoto: String { return self._s[2995]! } + public var UserInfo_NotificationsDefault: String { return self._s[2994]! } + public var SharedMedia_CategoryMedia: String { return self._s[2995]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[2996]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[2997]! } + public var Watch_ChatList_Compose: String { return self._s[2998]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[2999]! } + public var Watch_Microphone_Access: String { return self._s[3000]! } + public var Group_Setup_HistoryHeader: String { return self._s[3001]! } + public var Activity_UploadingPhoto: String { return self._s[3002]! } public func MESSAGE_VIDEO_SECRET_SEPARATED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2997]!, self._r[2997]!, [_1]) + return formatWithArgumentRanges(self._s[3004]!, self._r[3004]!, [_1]) } - public var Conversation_Edit: String { return self._s[2998]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[2999]! } - public var Login_TermsOfServiceDecline: String { return self._s[3000]! } - public var Message_PinnedContactMessage: String { return self._s[3001]! } + public var Conversation_Edit: String { return self._s[3005]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[3006]! } + public var Login_TermsOfServiceDecline: String { return self._s[3007]! } + public var Message_PinnedContactMessage: String { return self._s[3008]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3002]!, self._r[3002]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3009]!, self._r[3009]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3003]!, self._r[3003]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[3010]!, self._r[3010]!, [_1, _2, _3, _4, _5]) } - public var TwoStepAuth_AdditionalPassword: String { return self._s[3005]! } - public var Passport_Phone_EnterOtherNumber: String { return self._s[3006]! } - public var Message_PinnedPhotoMessage: String { return self._s[3007]! } - public var Passport_FieldPhone: String { return self._s[3008]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3009]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[3011]! } - public var Conversation_Call: String { return self._s[3012]! } - public var Common_TakePhoto: String { return self._s[3014]! } - public var Channel_NotificationLoading: String { return self._s[3015]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[3012]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[3013]! } + public var Message_PinnedPhotoMessage: String { return self._s[3014]! } + public var Passport_FieldPhone: String { return self._s[3015]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3016]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[3018]! } + public var Conversation_Call: String { return self._s[3019]! } + public var Common_TakePhoto: String { return self._s[3021]! } + public var Channel_NotificationLoading: String { return self._s[3022]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3016]!, self._r[3016]!, [_0]) + return formatWithArgumentRanges(self._s[3023]!, self._r[3023]!, [_0]) } - public var Permissions_SiriTitle_v0: String { return self._s[3017]! } + public var Permissions_SiriTitle_v0: String { return self._s[3024]! } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3018]!, self._r[3018]!, [_0]) + return formatWithArgumentRanges(self._s[3025]!, self._r[3025]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[3019]! } - public var Common_edit: String { return self._s[3020]! } - public var PrivacySettings_AuthSessions: String { return self._s[3021]! } - public var Month_ShortJune: String { return self._s[3022]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3023]! } - public var Call_ReportSend: String { return self._s[3024]! } - public var Watch_LastSeen_JustNow: String { return self._s[3025]! } - public var Notifications_MessageNotifications: String { return self._s[3026]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[3028]! } - public var Group_Status: String { return self._s[3029]! } + public var Channel_MessagePhotoRemoved: String { return self._s[3026]! } + public var Common_edit: String { return self._s[3027]! } + public var PrivacySettings_AuthSessions: String { return self._s[3028]! } + public var Month_ShortJune: String { return self._s[3029]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3030]! } + public var Call_ReportSend: String { return self._s[3031]! } + public var Watch_LastSeen_JustNow: String { return self._s[3032]! } + public var Notifications_MessageNotifications: String { return self._s[3033]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[3035]! } + public var Group_Status: String { return self._s[3036]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3030]!, self._r[3030]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3037]!, self._r[3037]!, [_0, _1]) } - public var ShareMenu_ShareTo: String { return self._s[3031]! } - public var Conversation_Moderate_Ban: String { return self._s[3032]! } + public var ShareMenu_ShareTo: String { return self._s[3038]! } + public var Conversation_Moderate_Ban: String { return self._s[3039]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3033]!, self._r[3033]!, [_0]) + return formatWithArgumentRanges(self._s[3040]!, self._r[3040]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[3034]! } - public var Map_LiveLocationFor8Hours: String { return self._s[3035]! } + public var SharedMedia_ViewInChat: String { return self._s[3041]! } + public var Map_LiveLocationFor8Hours: String { return self._s[3042]! } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3037]!, self._r[3037]!, [_0]) + return formatWithArgumentRanges(self._s[3044]!, self._r[3044]!, [_0]) } - public var Appearance_ReduceMotion: String { return self._s[3038]! } - public var Map_OpenInHereMaps: String { return self._s[3039]! } - public var Channel_Setup_TypePublicHelp: String { return self._s[3040]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[3041]! } - public var PhotoEditor_Skip: String { return self._s[3042]! } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { + public var Appearance_ReduceMotion: String { return self._s[3045]! } + public var Map_OpenInHereMaps: String { return self._s[3046]! } + public var Channel_Setup_TypePublicHelp: String { return self._s[3047]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[3048]! } + public var PhotoEditor_Skip: String { return self._s[3049]! } + public func ForwardedPolls(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideos(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedGifs(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func UserCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHANNEL_MESSAGES_SEPARATED(_ value: Int32) -> String { + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + public func SharedMedia_Generic(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func QuickSend_Photos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHAT_MESSAGES_SEPARATED(_ value: Int32) -> String { + public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { + public func CHAT_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func MessagePoll_VotedCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_StickerCount(_ value: Int32) -> String { + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_SharePhoto(_ value: Int32) -> String { + public func MessageTimer_ShortHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LastSeen_HoursAgo(_ value: Int32) -> String { + public func MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, "\(value)") } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + public func ForwardedVideos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedMessages(_ value: Int32) -> String { + public func ForwardedStickers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func Call_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAuthorsOthers(_ value: Int32) -> String { + public func MuteFor_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, "\(value)") } @@ -3632,231 +3639,231 @@ public final class PresentationStrings { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Days(_ value: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + public func Notifications_Exceptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHAT_MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_Minutes(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + public func Media_SharePhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAMinutes(_ value: Int32) -> String { + public func SharedMedia_File(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, "\(value)") } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + public func Contacts_ImportersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + public func Map_ETAMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + public func Invitation_Members(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHANNEL_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_Exceptions(_ value: Int32) -> String { + public func ForwardedFiles(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Invitation_Members(_ value: Int32) -> String { + public func Map_ETAHours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortHours(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + public func CHANNEL_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public func MessageTimer_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func Call_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + public func ForwardedLocations(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, "\(value)") } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + public func CHANNEL_MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_File(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func MessageTimer_ShortDays(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MESSAGES_SEPARATED(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { + public func MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareVideo(_ value: Int32) -> String { + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Hours(_ value: Int32) -> String { + public func MuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Minutes(_ value: Int32) -> String { + public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteFor_Days(_ value: Int32) -> String { + public func ForwardedGifs(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func Media_ShareItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Passport_Scans(_ value: Int32) -> String { + public func ForwardedPhotos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func CHAT_MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, "\(value)") } - public func UserCount(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Months(_ value: Int32) -> String { + public func ForwardedVideoMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedAudios(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Hours(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Years(_ value: Int32) -> String { + public func Conversation_StatusMembers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, "\(value)") } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + public func ForwardedAuthorsOthers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedStickers(_ value: Int32) -> String { + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notification_GameScoreSimple(_ value: Int32) -> String { + public func MuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, "\(value)") } - public func QuickSend_Photos(_ value: Int32) -> String { + public func CHAT_MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CHAT_MESSAGE_PHOTOS_SEPARATED(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Link(_ value: Int32) -> String { + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, "\(value)") } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Map_ETAHours(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MESSAGE_FWDS_SEPARATED(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_ShortMinutes(_ value: Int32) -> String { + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { + public func Media_ShareVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, "\(value)") } @@ -3864,83 +3871,83 @@ public final class PresentationStrings { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessagePoll_VotedCount(_ 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 Conversation_StatusMembers(_ value: Int32) -> String { + public func StickerPack_StickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedContacts(_ value: Int32) -> String { + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedPolls(_ value: Int32) -> String { + public func InviteText_ContactsCountText(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, "\(value)") } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public func Passport_Scans(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Call_Seconds(_ value: Int32) -> String { + public func ForwardedMessages(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[84 * 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[85 * 6 + Int(form.rawValue)]!, "\(value)") } - public func Media_ShareItem(_ value: Int32) -> String { + public func StickerPack_AddStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_Video(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedPhotos(_ value: Int32) -> String { + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedLocations(_ value: Int32) -> String { + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, "\(value)") } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + public func MESSAGES_SEPARATED(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Days(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, "\(value)") } - public func MuteExpires_Hours(_ value: Int32) -> String { + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, "\(value)") } - public func ForwardedFiles(_ value: Int32) -> String { + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, "\(value)") } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, "\(value)") } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func ForwardedAudios(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, "\(value)") } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, "\(value)") } diff --git a/TelegramUI/RadialCheckContentNode.swift b/TelegramUI/RadialCheckContentNode.swift index 6911695334..07304d9364 100644 --- a/TelegramUI/RadialCheckContentNode.swift +++ b/TelegramUI/RadialCheckContentNode.swift @@ -131,7 +131,7 @@ final class RadialCheckContentNode: RadialStatusContentNode { var s = CGPoint(x: center.x - 10.0, y: center.y + 1.0) var p1 = CGPoint(x: 7.0, y: 7.0) - var p2 = CGPoint(x: 15.0, y: -16.0) + var p2 = CGPoint(x: 13.0, y: -15.0) if diameter < 36.0 { s = CGPoint(x: center.x - 7.0, y: center.y + 1.0) diff --git a/TelegramUI/Resources/PresentationStrings.mapping b/TelegramUI/Resources/PresentationStrings.mapping index dcc2adc265..bd4dd9cbfc 100644 Binary files a/TelegramUI/Resources/PresentationStrings.mapping and b/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/TelegramUI/SearchBarNode.swift b/TelegramUI/SearchBarNode.swift index 267e67224f..84498e22bf 100644 --- a/TelegramUI/SearchBarNode.swift +++ b/TelegramUI/SearchBarNode.swift @@ -147,9 +147,9 @@ final class SearchBarNodeTheme: Equatable { self.keyboard = keyboard } - init(theme: PresentationTheme, active: Bool = true) { - self.background = active ? theme.rootController.activeNavigationSearchBar.backgroundColor : theme.rootController.navigationBar.backgroundColor - self.separator = active ? theme.rootController.navigationBar.separatorColor : theme.rootController.navigationBar.backgroundColor + init(theme: PresentationTheme, hasSeparator: Bool = true) { + self.background = theme.rootController.navigationBar.backgroundColor + self.separator = hasSeparator ? theme.rootController.navigationBar.separatorColor : theme.rootController.navigationBar.backgroundColor self.inputFill = theme.rootController.activeNavigationSearchBar.inputFillColor self.placeholder = theme.rootController.activeNavigationSearchBar.inputPlaceholderTextColor self.primaryText = theme.rootController.activeNavigationSearchBar.inputTextColor @@ -385,7 +385,9 @@ class SearchBarNode: ASDisplayNode, UITextFieldDelegate { } if self.theme != theme { self.backgroundNode.backgroundColor = theme.background - self.separatorNode.backgroundColor = theme.separator + if fieldStyle != .modern { + self.separatorNode.backgroundColor = theme.separator + } self.textBackgroundNode.image = generateBackground(backgroundColor: theme.background, foregroundColor: theme.inputFill, diameter: self.fieldStyle.cornerDiameter) self.textField.textColor = theme.primaryText self.clearButton.setImage(generateClearIcon(color: theme.inputClear), for: []) @@ -410,7 +412,7 @@ class SearchBarNode: ASDisplayNode, UITextFieldDelegate { self.backgroundNode.frame = self.bounds transition.updateFrame(node: self.separatorNode, frame: CGRect(origin: CGPoint(x: 0.0, y: self.bounds.size.height), size: CGSize(width: self.bounds.size.width, height: UIScreenPixel))) - let verticalOffset: CGFloat = boundingSize.height - 64.0 + let verticalOffset: CGFloat = boundingSize.height - 82.0 let contentFrame = CGRect(origin: CGPoint(x: leftInset, y: 0.0), size: CGSize(width: boundingSize.width - leftInset - rightInset, height: boundingSize.height)) diff --git a/TelegramUI/SearchBarPlaceholderNode.swift b/TelegramUI/SearchBarPlaceholderNode.swift index 73915eda0f..b5a68243fc 100644 --- a/TelegramUI/SearchBarPlaceholderNode.swift +++ b/TelegramUI/SearchBarPlaceholderNode.swift @@ -111,6 +111,7 @@ class SearchBarPlaceholderNode: ASDisplayNode { strongSelf.backgroundNode.isUserInteractionEnabled = expansionProgress > 1.0 - CGFloat.ulpOfOne if let updatedColor = updatedColor { + strongSelf.labelNode.backgroundColor = updatedColor strongSelf.backgroundNode.backgroundColor = updatedColor } if let updatedIconImage = updatedIconImage { @@ -139,10 +140,10 @@ class SearchBarPlaceholderNode: ASDisplayNode { let innerAlpha = max(0.0, expansionProgress - 0.77) / 0.23 transition.updateAlpha(node: strongSelf.labelNode, alpha: innerAlpha) transition.updateAlpha(node: strongSelf.iconNode, alpha: innerAlpha) - let outerAlpha = min(0.3, expansionProgress) / 0.3 + let outerAlpha = min(0.3, expansionProgress) / 0.3 let cornerRadius = min(strongSelf.fieldStyle.cornerDiameter / 2.0, height / 2.0) - strongSelf.backgroundNode.cornerRadius = cornerRadius + transition.updateCornerRadius(node: strongSelf.backgroundNode, cornerRadius: cornerRadius) transition.updateAlpha(node: strongSelf.backgroundNode, alpha: outerAlpha) transition.updateFrame(node: strongSelf.backgroundNode, frame: CGRect(origin: CGPoint(), size: CGSize(width: constrainedSize.width, height: height))) } diff --git a/TelegramUI/SearchDisplayController.swift b/TelegramUI/SearchDisplayController.swift index 9dea04e88b..a59c738f5c 100644 --- a/TelegramUI/SearchDisplayController.swift +++ b/TelegramUI/SearchDisplayController.swift @@ -4,7 +4,7 @@ import SwiftSignalKit import Display enum SearchDisplayControllerMode { - case standalone + case list case navigation } @@ -19,18 +19,8 @@ final class SearchDisplayController { private var isSearchingDisposable: Disposable? - init(theme: PresentationTheme, strings: PresentationStrings, mode: SearchDisplayControllerMode = .standalone, contentNode: SearchDisplayControllerContentNode, cancel: @escaping () -> Void) { - let active: Bool - let searchBarStyle: SearchBarStyle - switch mode { - case .standalone: - active = true - searchBarStyle = .legacy - case .navigation: - active = false - searchBarStyle = .modern - } - self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme, active: active), strings: strings, fieldStyle: searchBarStyle) + init(theme: PresentationTheme, strings: PresentationStrings, mode: SearchDisplayControllerMode = .navigation, contentNode: SearchDisplayControllerContentNode, cancel: @escaping () -> Void) { + self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme, hasSeparator: false), strings: strings, fieldStyle: .modern) self.mode = mode self.contentNode = contentNode @@ -56,14 +46,7 @@ final class SearchDisplayController { } func updateThemeAndStrings(theme: PresentationTheme, strings: PresentationStrings) { - let active: Bool - switch mode { - case .standalone: - active = true - case .navigation: - active = false - } - self.searchBar.updateThemeAndStrings(theme: SearchBarNodeTheme(theme: theme, active: active), strings: strings) + self.searchBar.updateThemeAndStrings(theme: SearchBarNodeTheme(theme: theme, hasSeparator: false), strings: strings) } func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { @@ -79,13 +62,13 @@ final class SearchDisplayController { if layout.statusBarHeight == nil { navigationBarFrame.size.height = 64.0 } + navigationBarFrame.size.height += 10.0 let searchBarFrame: CGRect if case .navigation = self.mode { - searchBarFrame = CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: 36.0) - navigationBarFrame.size.height += 10.0 + searchBarFrame = CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: 54.0) } else { - searchBarFrame = navigationBarFrame + searchBarFrame = CGRect(x: 0.0, y: navigationBarFrame.height - 54.0, width: layout.size.width, height: 54.0) } transition.updateFrame(node: self.searchBar, frame: searchBarFrame) self.searchBar.updateLayout(boundingSize: searchBarFrame.size, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right, transition: transition) @@ -116,7 +99,7 @@ final class SearchDisplayController { let navigationBarFrame: CGRect switch self.mode { - case .standalone: + case .list: let statusBarHeight: CGFloat = layout.statusBarHeight ?? 0.0 let searchBarHeight: CGFloat = max(20.0, statusBarHeight) + 44.0 let navigationBarOffset: CGFloat @@ -131,7 +114,7 @@ final class SearchDisplayController { } navigationBarFrame = frame case .navigation: - navigationBarFrame = CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: 36.0) + navigationBarFrame = CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: 54.0) } self.searchBar.frame = navigationBarFrame diff --git a/TelegramUI/SettingsThemeWallpaperNode.swift b/TelegramUI/SettingsThemeWallpaperNode.swift index 84e317e3e6..7c7a91b149 100644 --- a/TelegramUI/SettingsThemeWallpaperNode.swift +++ b/TelegramUI/SettingsThemeWallpaperNode.swift @@ -11,25 +11,39 @@ final class SettingsThemeWallpaperNode: ASDisplayNode { let buttonNode = HighlightTrackingButtonNode() let backgroundNode = ASDisplayNode() let imageNode = TransformImageNode() + private let statusNode: RadialStatusNode var pressed: (() -> Void)? override init() { self.imageNode.contentAnimations = [.subsequentUpdates] + + self.statusNode = RadialStatusNode(backgroundNodeColor: UIColor(white: 0.0, alpha: 0.6)) + let progressDiameter: CGFloat = 50.0 + self.statusNode.frame = CGRect(x: 0.0, y: 0.0, width: progressDiameter, height: progressDiameter) + self.statusNode.isUserInteractionEnabled = false + super.init() self.addSubnode(self.backgroundNode) self.addSubnode(self.imageNode) self.addSubnode(self.buttonNode) + self.addSubnode(self.statusNode) self.buttonNode.addTarget(self, action: #selector(self.buttonPressed), forControlEvents: .touchUpInside) } - func setWallpaper(account: Account, wallpaper: TelegramWallpaper, size: CGSize) { + func setWallpaper(account: Account, wallpaper: TelegramWallpaper, selected: Bool, size: CGSize) { self.buttonNode.frame = CGRect(origin: CGPoint(), size: size) self.backgroundNode.frame = CGRect(origin: CGPoint(), size: size) self.imageNode.frame = CGRect(origin: CGPoint(), size: size) + let state: RadialStatusNodeState = selected ? .check(.white) : .none + self.statusNode.transitionToState(state, animated: false, completion: {}) + + let progressDiameter: CGFloat = 50.0 + self.statusNode.frame = CGRect(x: floorToScreenPixels((size.width - progressDiameter) / 2.0), y: floorToScreenPixels((size.height - progressDiameter) / 2.0), width: progressDiameter, height: progressDiameter) + if self.wallpaper != wallpaper { self.wallpaper = wallpaper switch wallpaper { diff --git a/TelegramUI/StickerPaneSearchBarNode.swift b/TelegramUI/StickerPaneSearchBarNode.swift index fea30a23ee..5a1032755d 100644 --- a/TelegramUI/StickerPaneSearchBarNode.swift +++ b/TelegramUI/StickerPaneSearchBarNode.swift @@ -215,7 +215,7 @@ class StickerPaneSearchBarNode: ASDisplayNode, UITextFieldDelegate { self.textField = StickerPaneSearchBarTextField() self.textField.autocorrectionType = .no self.textField.returnKeyType = .done - self.textField.font = Font.regular(14.0) + self.textField.font = Font.regular(17.0) self.clearButton = HighlightableButtonNode() self.clearButton.imageNode.displaysAsynchronously = false @@ -256,7 +256,7 @@ class StickerPaneSearchBarNode: ASDisplayNode, UITextFieldDelegate { activityIndicator.type = .custom(theme.chat.inputMediaPanel.stickersSearchControlColor, 13.0, 1.0, false) } self.separatorNode.backgroundColor = theme.chat.inputMediaPanel.panelSeparatorColor - self.textBackgroundNode.image = generateStretchableFilledCircleImage(diameter: 33.0, color: theme.chat.inputMediaPanel.stickersSearchBackgroundColor) + self.textBackgroundNode.image = generateStretchableFilledCircleImage(diameter: 36.0, color: theme.chat.inputMediaPanel.stickersSearchBackgroundColor) self.textField.textColor = theme.chat.inputMediaPanel.stickersSearchPrimaryColor self.iconNode.image = generateLoupeIcon(color: theme.chat.inputMediaPanel.stickersSearchControlColor) self.clearButton.setImage(generateClearIcon(color: theme.chat.inputMediaPanel.stickersSearchControlColor), for: []) @@ -287,7 +287,7 @@ class StickerPaneSearchBarNode: ASDisplayNode, UITextFieldDelegate { let cancelButtonSize = self.cancelButton.measure(CGSize(width: 100.0, height: CGFloat.infinity)) transition.updateFrame(node: self.cancelButton, frame: CGRect(origin: CGPoint(x: contentFrame.maxX - 8.0 - cancelButtonSize.width, y: verticalOffset + 34.0), size: cancelButtonSize)) - let textBackgroundFrame = CGRect(origin: CGPoint(x: contentFrame.minX + 8.0, y: verticalOffset + 28.0), size: CGSize(width: contentFrame.width - 16.0 - cancelButtonSize.width - 11.0, height: 33.0)) + let textBackgroundFrame = CGRect(origin: CGPoint(x: contentFrame.minX + 8.0, y: verticalOffset + 28.0), size: CGSize(width: contentFrame.width - 16.0 - cancelButtonSize.width - 11.0, height: 36.0)) transition.updateFrame(node: self.textBackgroundNode, frame: textBackgroundFrame) let textFrame = CGRect(origin: CGPoint(x: textBackgroundFrame.minX + 27.0, y: textBackgroundFrame.minY), size: CGSize(width: max(1.0, textBackgroundFrame.size.width - 27.0 - 20.0), height: textBackgroundFrame.size.height)) diff --git a/TelegramUI/StickerPaneSearchBarPlaceholderItem.swift b/TelegramUI/StickerPaneSearchBarPlaceholderItem.swift index af3d7985e8..1b2a767cfb 100644 --- a/TelegramUI/StickerPaneSearchBarPlaceholderItem.swift +++ b/TelegramUI/StickerPaneSearchBarPlaceholderItem.swift @@ -78,7 +78,7 @@ final class StickerPaneSearchBarPlaceholderNode: GridItemNode { func setup(theme: PresentationTheme, strings: PresentationStrings) { if self.currentState?.0 !== theme || self.currentState?.1 !== strings { - self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 33.0, color: theme.chat.inputMediaPanel.stickersSearchBackgroundColor) + self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 36.0, color: theme.chat.inputMediaPanel.stickersSearchBackgroundColor) self.iconNode.image = generateLoupeIcon(color: theme.chat.inputMediaPanel.stickersSearchControlColor) self.labelNode.attributedText = NSAttributedString(string: strings.Stickers_Search, font: Font.regular(14.0), textColor: theme.chat.inputMediaPanel.stickersSearchPlaceholderColor) } @@ -89,7 +89,7 @@ final class StickerPaneSearchBarPlaceholderNode: GridItemNode { let bounds = self.bounds - let backgroundFrame = CGRect(origin: CGPoint(x: 8.0, y: 12.0), size: CGSize(width: bounds.width - 8.0 * 2.0, height: 33.0)) + let backgroundFrame = CGRect(origin: CGPoint(x: 8.0, y: 12.0), size: CGSize(width: bounds.width - 8.0 * 2.0, height: 36.0)) self.backgroundNode.frame = backgroundFrame let textSize = self.labelNode.updateLayout(bounds.size) diff --git a/TelegramUI/StickerPaneSearchContainerNode.swift b/TelegramUI/StickerPaneSearchContainerNode.swift index 3f88ea0d53..7a3c5ec1e3 100644 --- a/TelegramUI/StickerPaneSearchContainerNode.swift +++ b/TelegramUI/StickerPaneSearchContainerNode.swift @@ -376,7 +376,7 @@ final class StickerPaneSearchContainerNode: ASDisplayNode { self.notFoundNode.image = generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Media/StickersNotFoundIcon"), color: theme.list.freeMonoIcon) self.notFoundLabel.attributedText = NSAttributedString(string: strings.Stickers_NoStickersFound, font: Font.medium(14.0), textColor: theme.list.freeTextColor) self.searchBar.updateThemeAndStrings(theme: theme, strings: strings) - self.searchBar.placeholderString = NSAttributedString(string: strings.Stickers_Search, font: Font.regular(14.0), textColor: theme.chat.inputMediaPanel.stickersSearchPlaceholderColor) + self.searchBar.placeholderString = NSAttributedString(string: strings.Stickers_Search, font: Font.regular(17.0), textColor: theme.chat.inputMediaPanel.stickersSearchPlaceholderColor) } func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, bottomInset: CGFloat, inputHeight: CGFloat, transition: ContainedViewLayoutTransition) { @@ -384,7 +384,7 @@ final class StickerPaneSearchContainerNode: ASDisplayNode { self.validLayout = size transition.updateFrame(node: self.backgroundNode, frame: CGRect(origin: CGPoint(), size: size)) - let searchBarHeight: CGFloat = 48.0 + let searchBarHeight: CGFloat = 52.0 transition.updateFrame(node: self.searchBar, frame: CGRect(origin: CGPoint(), size: CGSize(width: size.width, height: searchBarHeight))) self.searchBar.updateLayout(boundingSize: CGSize(width: size.width, height: searchBarHeight), leftInset: leftInset, rightInset: rightInset, transition: transition) diff --git a/TelegramUI/TelegramController.swift b/TelegramUI/TelegramController.swift index d8ffb90e7e..edc122aeb0 100644 --- a/TelegramUI/TelegramController.swift +++ b/TelegramUI/TelegramController.swift @@ -74,7 +74,16 @@ public class TelegramController: ViewController { private var playlistPreloadDisposable: Disposable? override public var navigationHeight: CGFloat { - var height = super.navigationHeight + return super.navigationHeight + self.additionalHeight + + } + + override public var navigationInsetHeight: CGFloat { + return super.navigationInsetHeight + self.additionalHeight + } + + private var additionalHeight: CGFloat { + var height: CGFloat = 0.0 if let _ = self.mediaAccessoryPanel { height += MediaNavigationAccessoryHeaderNode.minimizedHeight } diff --git a/TelegramUI/TelegramRootController.swift b/TelegramUI/TelegramRootController.swift index 2ed4ebb866..4e670d436e 100644 --- a/TelegramUI/TelegramRootController.swift +++ b/TelegramUI/TelegramRootController.swift @@ -82,38 +82,40 @@ public final class TelegramRootController: NavigationController { return } - DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 0.5) { - let wrapperNode = ASDisplayNode() - let bounds = controller.displayNode.bounds - wrapperNode.frame = bounds - wrapperNode.backgroundColor = .gray - //controller.displayNode.addSubnode(wrapperNode) + DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 0.3) { + (controller.navigationController as? NavigationController)?.pushViewController(ThemeGridController(account: self.account, mode: .wallpapers)) - let radialStatusSize: CGFloat = 50.0 - let statusNode = RadialStatusNode(backgroundNodeColor: UIColor(rgb: 0x000000, alpha: 0.6)) - statusNode.frame = CGRect(origin: CGPoint(x: floor(bounds.midX - radialStatusSize / 2.0), y: floor(bounds.midY - radialStatusSize / 2.0)), size: CGSize(width: radialStatusSize, height: radialStatusSize)) - wrapperNode.addSubnode(statusNode) - - let color = UIColor.white - var smth = false - let button = HighlightTrackingButtonNode() - button.frame = CGRect(origin: CGPoint(x: floor(bounds.midX - radialStatusSize / 2.0), y: floor(bounds.midY - radialStatusSize / 2.0)), size: CGSize(width: radialStatusSize, height: radialStatusSize)) - wrapperNode.addSubnode(button) - button.highligthedChanged = { value in - if value { - if smth { - smth = false - //statusNode.transitionToState(.play(color), animated: true, completion: {}) - statusNode.transitionToState(.download(.white), animated: true, completion: {}) - //statusNode.transitionToState(.none, animated: true, completion: {}) - } else { - smth = true - statusNode.transitionToState(.progress(color: color, lineWidth: nil, value: 0.3, cancelEnabled: true), animated: true, completion: {}) - } - } - } - button.addTarget(self, action: #selector(self.mock), forControlEvents: .touchUpInside) - statusNode.transitionToState(.download(.white), animated: false, completion: {}) +// let wrapperNode = ASDisplayNode() +// let bounds = controller.displayNode.bounds +// wrapperNode.frame = bounds +// wrapperNode.backgroundColor = .gray +// //controller.displayNode.addSubnode(wrapperNode) +// +// let radialStatusSize: CGFloat = 50.0 +// let statusNode = RadialStatusNode(backgroundNodeColor: UIColor(rgb: 0x000000, alpha: 0.6)) +// statusNode.frame = CGRect(origin: CGPoint(x: floor(bounds.midX - radialStatusSize / 2.0), y: floor(bounds.midY - radialStatusSize / 2.0)), size: CGSize(width: radialStatusSize, height: radialStatusSize)) +// wrapperNode.addSubnode(statusNode) +// +// let color = UIColor.white +// var smth = false +// let button = HighlightTrackingButtonNode() +// button.frame = CGRect(origin: CGPoint(x: floor(bounds.midX - radialStatusSize / 2.0), y: floor(bounds.midY - radialStatusSize / 2.0)), size: CGSize(width: radialStatusSize, height: radialStatusSize)) +// wrapperNode.addSubnode(button) +// button.highligthedChanged = { value in +// if value { +// if smth { +// smth = false +// //statusNode.transitionToState(.play(color), animated: true, completion: {}) +// statusNode.transitionToState(.download(.white), animated: true, completion: {}) +// //statusNode.transitionToState(.none, animated: true, completion: {}) +// } else { +// smth = true +// statusNode.transitionToState(.progress(color: color, lineWidth: nil, value: 0.3, cancelEnabled: true), animated: true, completion: {}) +// } +// } +// } +// button.addTarget(self, action: #selector(self.mock), forControlEvents: .touchUpInside) +// statusNode.transitionToState(.download(.white), animated: false, completion: {}) } } diff --git a/TelegramUI/ThemeGalleryController.swift b/TelegramUI/ThemeGalleryController.swift index 82ac037537..3a87609683 100644 --- a/TelegramUI/ThemeGalleryController.swift +++ b/TelegramUI/ThemeGalleryController.swift @@ -220,10 +220,6 @@ class ThemeGalleryController: ViewController { wallpaper = value } let _ = (updatePresentationThemeSettingsInteractively(postbox: strongSelf.account.postbox, { current in - if case .color(0x000000) = wallpaper { - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: .regular, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) - } - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) }) |> deliverOnMainQueue).start(completed: { self?.dismiss(forceAway: true) diff --git a/TelegramUI/ThemeGridActionNode.swift b/TelegramUI/ThemeGridActionNode.swift deleted file mode 100644 index 653b7c6f24..0000000000 --- a/TelegramUI/ThemeGridActionNode.swift +++ /dev/null @@ -1,14 +0,0 @@ -import Foundation -import AsyncDisplayKit -import Display - -final class ThemeGridActionNode: NSObject { -// private let button: HighlightableButtonNode -// private var background: ASDisplayNode -// private var topSeparator: ASDisplayNode -// private var bottomSeparator: ASDisplayNode - - override init() { - super.init() - } -} diff --git a/TelegramUI/ThemeGridController.swift b/TelegramUI/ThemeGridController.swift index f5a69605f4..bfbfd69a79 100644 --- a/TelegramUI/ThemeGridController.swift +++ b/TelegramUI/ThemeGridController.swift @@ -26,6 +26,8 @@ final class ThemeGridController: ViewController { private var presentationData: PresentationData private var presentationDataDisposable: Disposable? + private var searchContentNode: NavigationBarSearchContentNode? + init(account: Account, mode: ThemeGridControllerMode) { self.account = account self.mode = mode @@ -54,6 +56,11 @@ final class ThemeGridController: ViewController { } } }) + + self.searchContentNode = NavigationBarSearchContentNode(theme: self.presentationData.theme, placeholder: self.presentationData.strings.Wallpaper_Search, activate: { [weak self] in + self?.activateSearch() + }) + self.navigationBar?.setContentNode(self.searchContentNode, animated: false) } required public init(coder aDecoder: NSCoder) { @@ -69,6 +76,7 @@ final class ThemeGridController: ViewController { self.statusBar.statusBarStyle = self.presentationData.theme.rootController.statusBar.style.style self.navigationBar?.updatePresentationData(NavigationBarPresentationData(presentationData: self.presentationData)) + self.searchContentNode?.updateThemeAndPlaceholder(theme: self.presentationData.theme, placeholder: self.presentationData.strings.Wallpaper_Search) if self.isNodeLoaded { self.controllerNode.updatePresentationData(self.presentationData) @@ -106,7 +114,25 @@ final class ThemeGridController: ViewController { strongSelf.present(legacyPicker, in: .window(.root), blockInteraction: true) } }) + self.controllerNode.navigationBar = self.navigationBar + self.controllerNode.requestDeactivateSearch = { [weak self] in + self?.deactivateSearch(animated: true) + } self._ready.set(self.controllerNode.ready.get()) +// +// self.controllerNode.gridNode.scroll = { [weak self] offset in +// if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { +// searchContentNode.updateListVisibleContentOffset(offset) +// } +// } +// +// self.controllerNode.gridNode.scrollingCompleted = { [weak self] in +// if let strongSelf = self, let searchContentNode = strongSelf.searchContentNode { +// return fixNavigationSearchableListNodeScrolling(listView, searchNode: searchContentNode) +// } else { +// return false +// } +// } self.displayNodeDidLoad() } @@ -121,19 +147,45 @@ final class ThemeGridController: ViewController { let wallpaper: TelegramWallpaper = .image([TelegramMediaImageRepresentation(dimensions: image.size, resource: resource)]) let _ = (updatePresentationThemeSettingsInteractively(postbox: self.account.postbox, { current in - if case .color(0x000000) = wallpaper { - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) - } - return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) }) |> deliverOnMainQueue).start(completed: { [weak self] in let _ = (self?.navigationController as? NavigationController)?.popViewController(animated: true) }) + + let _ = uploadWallpaper(account: self.account, resource: resource) } override func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { super.containerLayoutUpdated(layout, transition: transition) - self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationInsetHeight, transition: transition) + } + + func activateSearch() { + if self.displayNavigationBar { + let _ = (self.controllerNode.ready.get() + |> take(1) + |> deliverOnMainQueue).start(completed: { [weak self] in + guard let strongSelf = self else { + return + } + if let scrollToTop = strongSelf.scrollToTop { + scrollToTop() + } + if let searchContentNode = strongSelf.searchContentNode { + strongSelf.controllerNode.activateSearch(placeholderNode: searchContentNode.placeholderNode) + } + strongSelf.setDisplayNavigationBar(false, transition: .animated(duration: 0.5, curve: .spring)) + }) + } + } + + func deactivateSearch(animated: Bool) { + if !self.displayNavigationBar { + self.setDisplayNavigationBar(true, transition: animated ? .animated(duration: 0.5, curve: .spring) : .immediate) + if let searchContentNode = self.searchContentNode { + self.controllerNode.deactivateSearch(placeholderNode: searchContentNode.placeholderNode, animated: animated) + } + } } } diff --git a/TelegramUI/ThemeGridControllerItem.swift b/TelegramUI/ThemeGridControllerItem.swift index f909ed94ad..3386741b98 100644 --- a/TelegramUI/ThemeGridControllerItem.swift +++ b/TelegramUI/ThemeGridControllerItem.swift @@ -8,19 +8,21 @@ import Postbox final class ThemeGridControllerItem: GridItem { let account: Account let wallpaper: TelegramWallpaper + let selected: Bool let interaction: ThemeGridControllerInteraction let section: GridSection? = nil - init(account: Account, wallpaper: TelegramWallpaper, interaction: ThemeGridControllerInteraction) { + init(account: Account, wallpaper: TelegramWallpaper, selected: Bool, interaction: ThemeGridControllerInteraction) { self.account = account self.wallpaper = wallpaper + self.selected = selected self.interaction = interaction } func node(layout: GridNodeLayout, synchronousLoad: Bool) -> GridItemNode { let node = ThemeGridControllerItemNode() - node.setup(account: self.account, wallpaper: self.wallpaper, interaction: self.interaction) + node.setup(account: self.account, wallpaper: self.wallpaper, selected: self.selected, interaction: self.interaction) return node } @@ -29,7 +31,7 @@ final class ThemeGridControllerItem: GridItem { assertionFailure() return } - node.setup(account: self.account, wallpaper: self.wallpaper, interaction: self.interaction) + node.setup(account: self.account, wallpaper: self.wallpaper, selected: self.selected, interaction: self.interaction) } } @@ -39,12 +41,11 @@ private let textFont = Font.regular(11.0) final class ThemeGridControllerItemNode: GridItemNode { private let wallpaperNode: SettingsThemeWallpaperNode - private var currentState: (Account, TelegramWallpaper)? + private var currentState: (Account, TelegramWallpaper, Bool)? private var interaction: ThemeGridControllerInteraction? override init() { self.wallpaperNode = SettingsThemeWallpaperNode() - super.init() self.addSubnode(self.wallpaperNode) @@ -56,18 +57,18 @@ final class ThemeGridControllerItemNode: GridItemNode { self.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.tapGesture(_:)))) } - func setup(account: Account, wallpaper: TelegramWallpaper, interaction: ThemeGridControllerInteraction) { + func setup(account: Account, wallpaper: TelegramWallpaper, selected: Bool, interaction: ThemeGridControllerInteraction) { self.interaction = interaction - if self.currentState == nil || self.currentState!.0 !== account || wallpaper != self.currentState!.1 { - self.currentState = (account, wallpaper) + if self.currentState == nil || self.currentState!.0 !== account || wallpaper != self.currentState!.1 || selected != self.currentState!.2 { + self.currentState = (account, wallpaper, selected) self.setNeedsLayout() } } @objc func tapGesture(_ recognizer: UITapGestureRecognizer) { if case .ended = recognizer.state { - if let (_, wallpaper) = self.currentState { + if let (_, wallpaper, _) = self.currentState { self.interaction?.openWallpaper(wallpaper) } } @@ -77,8 +78,8 @@ final class ThemeGridControllerItemNode: GridItemNode { super.layout() let bounds = self.bounds - if let (account, wallpaper) = self.currentState { - self.wallpaperNode.setWallpaper(account: account, wallpaper: wallpaper, size: bounds.size) + if let (account, wallpaper, selected) = self.currentState { + self.wallpaperNode.setWallpaper(account: account, wallpaper: wallpaper, selected: selected, size: bounds.size) } } } diff --git a/TelegramUI/ThemeGridControllerNode.swift b/TelegramUI/ThemeGridControllerNode.swift index 8a86aaa493..5db5fa8169 100644 --- a/TelegramUI/ThemeGridControllerNode.swift +++ b/TelegramUI/ThemeGridControllerNode.swift @@ -16,9 +16,10 @@ final class ThemeGridControllerInteraction { private struct ThemeGridControllerEntry: Comparable, Identifiable { let index: Int let wallpaper: TelegramWallpaper + let selected: Bool static func ==(lhs: ThemeGridControllerEntry, rhs: ThemeGridControllerEntry) -> Bool { - return lhs.index == rhs.index && lhs.wallpaper == rhs.wallpaper + return lhs.index == rhs.index && lhs.wallpaper == rhs.wallpaper && lhs.selected == rhs.selected } static func <(lhs: ThemeGridControllerEntry, rhs: ThemeGridControllerEntry) -> Bool { @@ -30,7 +31,7 @@ private struct ThemeGridControllerEntry: Comparable, Identifiable { } func item(account: Account, interaction: ThemeGridControllerInteraction) -> ThemeGridControllerItem { - return ThemeGridControllerItem(account: account, wallpaper: self.wallpaper, interaction: interaction) + return ThemeGridControllerItem(account: account, wallpaper: self.wallpaper, selected: self.selected, interaction: interaction) } } @@ -62,24 +63,27 @@ final class ThemeGridControllerNode: ASDisplayNode { private let present: (ViewController, Any?) -> Void private let selectCustomWallpaper: () -> Void + var requestDeactivateSearch: (() -> Void)? let ready = ValuePromise() private var customWallpaperBackground: ASDisplayNode private var customWallpaperSeparator: ASDisplayNode - - //private let photoLibraryButton: ThemeGridActionNode - //private let solidColorsButton: ThemeGridActionNode - + private let customWallpaperButton: HighlightableButtonNode private var customWallpaperButtonBackground: ASDisplayNode private var customWallpaperButtonTopSeparator: ASDisplayNode private var customWallpaperButtonBottomSeparator: ASDisplayNode + private var customWallpaperLabel: ASTextNode + + let gridNode: GridNode + var navigationBar: NavigationBar? - private let gridNode: GridNode private var queuedTransitions: [ThemeGridEntryTransition] = [] private var validLayout: (ContainerViewLayout, CGFloat)? + private(set) var searchDisplayController: SearchDisplayController? + private var disposable: Disposable? init(account: Account, presentationData: PresentationData, mode: ThemeGridControllerMode, present: @escaping (ViewController, Any?) -> Void, selectCustomWallpaper: @escaping () -> Void) { @@ -92,6 +96,7 @@ final class ThemeGridControllerNode: ASDisplayNode { self.gridNode.showVerticalScrollIndicator = true self.customWallpaperButton = HighlightableButtonNode() + self.customWallpaperButton.contentHorizontalAlignment = .left self.customWallpaperButtonBackground = ASDisplayNode() self.customWallpaperButtonBackground.backgroundColor = presentationData.theme.list.itemBlocksBackgroundColor @@ -108,6 +113,8 @@ final class ThemeGridControllerNode: ASDisplayNode { self.customWallpaperButtonBottomSeparator = ASDisplayNode() self.customWallpaperButtonBottomSeparator.backgroundColor = presentationData.theme.list.itemBlocksSeparatorColor + self.customWallpaperLabel = ASTextNode() + super.init() self.setViewBlock({ @@ -116,8 +123,8 @@ final class ThemeGridControllerNode: ASDisplayNode { self.backgroundColor = presentationData.theme.list.itemBlocksBackgroundColor - self.customWallpaperButton.setAttributedTitle(NSAttributedString(string: presentationData.strings.Wallpaper_PhotoLibrary, font: Font.regular(17.0), textColor: presentationData.theme.list.itemAccentColor), for: []) - self.customWallpaperButton.backgroundColor = presentationData.theme.list.itemBlocksBackgroundColor + self.customWallpaperButton.setAttributedTitle(NSAttributedString(string: self.presentationData.strings.Wallpaper_SetCustomBackground, font: Font.regular(17.0), textColor: presentationData.theme.list.itemAccentColor), for: []) + self.customWallpaperButton.backgroundColor = self.presentationData.theme.list.itemBlocksBackgroundColor self.customWallpaperButton.highligthedChanged = { [weak self] highlighted in if let strongSelf = self { if highlighted { @@ -130,12 +137,15 @@ final class ThemeGridControllerNode: ASDisplayNode { } } + self.customWallpaperLabel.attributedText = NSAttributedString(string: self.presentationData.strings.Wallpaper_SetCustomBackgroundInfo, font: Font.regular(14.0), textColor: self.presentationData.theme.list.freeTextColor) + self.gridNode.addSubnode(self.customWallpaperBackground) self.gridNode.addSubnode(self.customWallpaperSeparator) self.gridNode.addSubnode(self.customWallpaperButtonTopSeparator) self.gridNode.addSubnode(self.customWallpaperButtonBottomSeparator) self.gridNode.addSubnode(self.customWallpaperButtonBackground) self.gridNode.addSubnode(self.customWallpaperButton) + self.gridNode.addSubnode(self.customWallpaperLabel) self.addSubnode(self.gridNode) let previousEntries = Atomic<[ThemeGridControllerEntry]?>(value: nil) @@ -145,12 +155,12 @@ final class ThemeGridControllerNode: ASDisplayNode { let entries = previousEntries.with { $0 } if let entries = entries, !entries.isEmpty { let wallpapers = entries.map { $0.wallpaper } - /*let controller = WallpaperListPreviewController(account: account, source: .list(wallpapers: wallpapers, central: wallpaper)) - strongSelf.present(controller, nil)*/ - let controller = ThemeGalleryController(account: account, wallpapers: wallpapers, at: wallpaper) - strongSelf.present(controller, ThemePreviewControllerPresentationArguments(transitionArguments: { entry -> GalleryTransitionArguments? in - return nil - })) + let controller = WallpaperListPreviewController(account: account, source: .list(wallpapers: wallpapers, central: wallpaper)) + strongSelf.present(controller, nil) + //let controller = ThemeGalleryController(account: account, wallpapers: wallpapers, at: wallpaper) + //strongSelf.present(controller, ThemePreviewControllerPresentationArguments(transitionArguments: { entry -> GalleryTransitionArguments? in + // return nil + //})) } } }) @@ -166,21 +176,24 @@ final class ThemeGridControllerNode: ASDisplayNode { case .dayClassic: break case .day: - entries.append(ThemeGridControllerEntry(index: index, wallpaper: .color(0xffffff))) + let wallpaper = TelegramWallpaper.color(0xffffff) + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) index += 1 case .nightGrayscale: - entries.append(ThemeGridControllerEntry(index: index, wallpaper: .color(0x000000))) + let wallpaper = TelegramWallpaper.color(0xffffff) + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) index += 1 case .nightAccent: - entries.append(ThemeGridControllerEntry(index: index, wallpaper: .color(0x18222D))) + let wallpaper = TelegramWallpaper.color(0xffffff) + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) index += 1 } default: break } - for item in wallpapers { - entries.append(ThemeGridControllerEntry(index: index, wallpaper: item)) + for wallpaper in wallpapers { + entries.append(ThemeGridControllerEntry(index: index, wallpaper: wallpaper, selected: presentationData.chatWallpaper == wallpaper)) index += 1 } let previous = previousEntries.swap(entries) @@ -203,6 +216,7 @@ final class ThemeGridControllerNode: ASDisplayNode { self.presentationData = presentationData self.backgroundColor = presentationData.theme.list.itemBlocksBackgroundColor + self.searchDisplayController?.updateThemeAndStrings(theme: presentationData.theme, strings: presentationData.strings) } private func enqueueTransition(_ transition: ThemeGridEntryTransition) { @@ -228,9 +242,9 @@ final class ThemeGridControllerNode: ASDisplayNode { insets.top += navigationBarHeight let scrollIndicatorInsets = insets - let referenceImageSize = CGSize(width: 108.0, height: 163.0) + let referenceImageSize = CGSize(width: 108.0, height: 230.0) - let minSpacing: CGFloat = 10.0 + let minSpacing: CGFloat = 8.0 let imageCount = Int((layout.size.width - minSpacing * 2.0) / (referenceImageSize.width + minSpacing)) @@ -238,19 +252,29 @@ final class ThemeGridControllerNode: ASDisplayNode { let spacing = floor((layout.size.width - CGFloat(imageCount) * imageSize.width) / CGFloat(imageCount + 1)) - let buttonInset: CGFloat = 32.0 + 44.0 + 32.0 + let textInset: CGFloat = 15.0 + let textSize = self.customWallpaperLabel.measure(CGSize(width: layout.size.width - layout.safeInsets.left - layout.safeInsets.right - textInset * 2.0, height: CGFloat.greatestFiniteMagnitude)) + + let buttonTopInset: CGFloat = 32.0 + let buttonHeight: CGFloat = 44.0 + let buttonBottomInset: CGFloat = textSize.height + 6.0 + 25.0 + + let buttonInset: CGFloat = buttonTopInset + buttonHeight + buttonBottomInset let buttonOffset = buttonInset + 10.0 - transition.updateFrame(node: self.customWallpaperBackground, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset - 500.0), size: CGSize(width: layout.size.width, height: 32.0 + 44.0 + 32.0 + 500.0))) - transition.updateFrame(node: self.customWallpaperSeparator, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + 32.0 + 44.0 + 32.0 - UIScreenPixel), size: CGSize(width: layout.size.width, height: UIScreenPixel))) - transition.updateFrame(node: self.customWallpaperButtonTopSeparator, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + 32.0 - UIScreenPixel), size: CGSize(width: layout.size.width, height: UIScreenPixel))) - transition.updateFrame(node: self.customWallpaperButtonBottomSeparator, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + 32.0 + 44.0), size: CGSize(width: layout.size.width, height: UIScreenPixel))) - transition.updateFrame(node: self.customWallpaperButtonBackground, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + 32.0), size: CGSize(width: layout.size.width, height: 44.0))) - transition.updateFrame(node: self.customWallpaperButton, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + 32.0), size: CGSize(width: layout.size.width, height: 44.0))) + self.customWallpaperButton.contentEdgeInsets = UIEdgeInsets(top: 0.0, left: 17.0 + layout.safeInsets.left, bottom: 0.0, right: 0.0) + + transition.updateFrame(node: self.customWallpaperBackground, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset - 500.0), size: CGSize(width: layout.size.width, height: buttonTopInset + buttonHeight + buttonBottomInset + 500.0))) + transition.updateFrame(node: self.customWallpaperSeparator, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + buttonTopInset + buttonHeight + buttonBottomInset - UIScreenPixel), size: CGSize(width: layout.size.width, height: UIScreenPixel))) + transition.updateFrame(node: self.customWallpaperButtonTopSeparator, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + buttonTopInset - UIScreenPixel), size: CGSize(width: layout.size.width, height: UIScreenPixel))) + transition.updateFrame(node: self.customWallpaperButtonBottomSeparator, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + buttonTopInset + buttonHeight), size: CGSize(width: layout.size.width, height: UIScreenPixel))) + transition.updateFrame(node: self.customWallpaperButtonBackground, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + buttonTopInset), size: CGSize(width: layout.size.width, height: buttonHeight))) + transition.updateFrame(node: self.customWallpaperButton, frame: CGRect(origin: CGPoint(x: 0.0, y: -buttonOffset + buttonTopInset), size: CGSize(width: layout.size.width, height: buttonHeight))) + transition.updateFrame(node: self.customWallpaperLabel, frame: CGRect(origin: CGPoint(x: textInset + layout.safeInsets.left, y: -buttonOffset + buttonTopInset + buttonHeight + 6.0), size: textSize)) insets.top += spacing + buttonInset - self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: nil, updateLayout: GridNodeUpdateLayout(layout: GridNodeLayout(size: layout.size, insets: insets, scrollIndicatorInsets: scrollIndicatorInsets, preloadSize: 300.0, type: .fixed(itemSize: imageSize, fillWidth: nil, lineSpacing: spacing, itemSpacing: nil)), transition: .immediate), itemTransition: .immediate, stationaryItems: .none, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: nil, updateLayout: GridNodeUpdateLayout(layout: GridNodeLayout(size: layout.size, insets: insets, scrollIndicatorInsets: scrollIndicatorInsets, preloadSize: 300.0, type: .fixed(itemSize: imageSize, fillWidth: nil, lineSpacing: spacing, itemSpacing: nil)), transition: transition), itemTransition: .immediate, stationaryItems: .none, updateFirstIndexInSectionOffset: nil), completion: { _ in }) self.gridNode.frame = CGRect(x: 0.0, y: 0.0, width: layout.size.width, height: layout.size.height) @@ -259,13 +283,57 @@ final class ThemeGridControllerNode: ASDisplayNode { if dequeue { self.dequeueTransitions() } - } - - func scrollToTop() { - self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: GridNodeScrollToItem(index: 0, position: .top, transition: .animated(duration: 0.25, curve: .easeInOut), directionHint: .up, adjustForSection: true, adjustForTopInset: true), updateLayout: nil, itemTransition: .immediate, stationaryItems: .none, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + + if let searchDisplayController = self.searchDisplayController { + searchDisplayController.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: transition) + } } @objc func customWallpaperPressed() { self.selectCustomWallpaper() } + + func activateSearch(placeholderNode: SearchBarPlaceholderNode) { + guard let (containerLayout, navigationBarHeight) = self.validLayout, let navigationBar = self.navigationBar, self.searchDisplayController == nil else { + return + } + + self.searchDisplayController = SearchDisplayController(theme: self.presentationData.theme, strings: self.presentationData.strings, contentNode: ChatListSearchContainerNode(account: self.account, filter: [], groupId: nil, openPeer: { [weak self] peer, dismissSearch in + + }, openRecentPeerOptions: { [weak self] peer in + + }, openMessage: { [weak self] peer, messageId in + + }, addContact: { [weak self] phoneNumber in + + }), cancel: { [weak self] in + self?.requestDeactivateSearch?() + }) + + self.searchDisplayController?.containerLayoutUpdated(containerLayout, navigationBarHeight: navigationBarHeight, transition: .immediate) + self.searchDisplayController?.activate(insertSubnode: { [weak self, weak placeholderNode] subnode, isSearchBar in + if let strongSelf = self, let strongPlaceholderNode = placeholderNode { + if isSearchBar { + strongPlaceholderNode.supernode?.insertSubnode(subnode, aboveSubnode: strongPlaceholderNode) + } else { + strongSelf.insertSubnode(subnode, belowSubnode: navigationBar) + } + } + }, placeholder: placeholderNode) + } + + func deactivateSearch(placeholderNode: SearchBarPlaceholderNode, animated: Bool) { + if let searchDisplayController = self.searchDisplayController { + searchDisplayController.deactivate(placeholder: placeholderNode, animated: animated) + self.searchDisplayController = nil + } + } + + func scrollToTop() { + if let searchDisplayController = self.searchDisplayController { + searchDisplayController.contentNode.scrollToTop() + } else { + self.gridNode.transaction(GridNodeTransaction(deleteItems: [], insertItems: [], updateItems: [], scrollToItem: GridNodeScrollToItem(index: 0, position: .top, transition: .animated(duration: 0.25, curve: .easeInOut), directionHint: .up, adjustForSection: true, adjustForTopInset: true), updateLayout: nil, itemTransition: .immediate, stationaryItems: .none, updateFirstIndexInSectionOffset: nil), completion: { _ in }) + } + } } diff --git a/TelegramUI/WallpaperListPreviewController.swift b/TelegramUI/WallpaperListPreviewController.swift index 9244606db0..4354733094 100644 --- a/TelegramUI/WallpaperListPreviewController.swift +++ b/TelegramUI/WallpaperListPreviewController.swift @@ -53,6 +53,7 @@ final class WallpaperListPreviewController: ViewController { }) self.title = self.presentationData.strings.BackgroundPreview_Title + self.navigationItem.rightBarButtonItem = UIBarButtonItem(image: generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Accessory Panels/MessageSelectionAction"), color: self.presentationData.theme.rootController.navigationBar.accentTextColor), style: .plain, target: self, action: #selector(self.sharePressed)) } required init(coder aDecoder: NSCoder) { @@ -66,6 +67,7 @@ final class WallpaperListPreviewController: ViewController { private func updateThemeAndStrings() { self.title = self.presentationData.strings.BackgroundPreview_Title self.navigationItem.backBarButtonItem = UIBarButtonItem(title: self.presentationData.strings.Common_Back, style: .plain, target: nil, action: nil) + self.navigationItem.rightBarButtonItem = UIBarButtonItem(image: generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Accessory Panels/MessageSelectionAction"), color: self.presentationData.theme.rootController.navigationBar.accentTextColor), style: .plain, target: self, action: #selector(self.sharePressed)) self.statusBar.statusBarStyle = self.presentationData.theme.rootController.statusBar.style.style self.navigationBar?.updatePresentationData(NavigationBarPresentationData(presentationData: self.presentationData)) @@ -94,6 +96,17 @@ final class WallpaperListPreviewController: ViewController { override public func loadDisplayNode() { self.displayNode = WallpaperListPreviewControllerNode(account: self.account, presentationData: self.presentationData, source: self.source, dismiss: { [weak self] in self?.dismiss() + }, apply: { [weak self] wallpaper in + guard let strongSelf = self else { + return + } + + let _ = (updatePresentationThemeSettingsInteractively(postbox: strongSelf.account.postbox, { current in + return PresentationThemeSettings(chatWallpaper: wallpaper, theme: current.theme, themeAccentColor: current.themeAccentColor, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, disableAnimations: current.disableAnimations) + }) + |> deliverOnMainQueue).start(completed: { + self?.dismiss() + }) }) self._ready.set(self.controllerNode.ready.get()) self.displayNodeDidLoad() @@ -104,4 +117,9 @@ final class WallpaperListPreviewController: ViewController { self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) } + + @objc func sharePressed() { + let shareController = ShareController(account: account, subject: .url("link")) + self.present(shareController, in: .window(.root), blockInteraction: true) + } } diff --git a/TelegramUI/WallpaperListPreviewControllerNode.swift b/TelegramUI/WallpaperListPreviewControllerNode.swift index 99f3f2764d..b0f66eca61 100644 --- a/TelegramUI/WallpaperListPreviewControllerNode.swift +++ b/TelegramUI/WallpaperListPreviewControllerNode.swift @@ -8,30 +8,42 @@ import TelegramCore private final class WallpaperBackgroundNode: ASDisplayNode { let wallpaper: TelegramWallpaper private var fetchDisposable: Disposable? + private var statusDisposable: Disposable? private let imageNode: TransformImageNode + private let statusNode: RadialStatusNode init(account: Account, wallpaper: TelegramWallpaper) { self.wallpaper = wallpaper self.imageNode = TransformImageNode() self.imageNode.contentAnimations = .subsequentUpdates + self.statusNode = RadialStatusNode(backgroundNodeColor: UIColor(white: 0.0, alpha: 0.6)) + let progressDiameter: CGFloat = 50.0 + self.statusNode.frame = CGRect(x: 0.0, y: 0.0, width: progressDiameter, height: progressDiameter) + self.statusNode.isUserInteractionEnabled = false + super.init() - self.backgroundColor = UIColor(rgb: arc4random()) + self.clipsToBounds = true + self.backgroundColor = .black self.addSubnode(self.imageNode) + self.addSubnode(self.statusNode) let signal: Signal<(TransformImageArguments) -> DrawingContext?, NoError> let fetchSignal: Signal + let statusSignal: Signal let displaySize: CGSize switch wallpaper { case .builtin: displaySize = CGSize(width: 640.0, height: 1136.0) signal = settingsBuiltinWallpaperImage(account: account) fetchSignal = .complete() + statusSignal = .single(.Local) case let .color(color): displaySize = CGSize(width: 1.0, height: 1.0) signal = .never() fetchSignal = .complete() + statusSignal = .single(.Local) self.backgroundColor = UIColor(rgb: UInt32(bitPattern: color)) case let .file(file): let dimensions = file.file.dimensions ?? CGSize(width: 100.0, height: 100.0) @@ -45,6 +57,7 @@ private final class WallpaperBackgroundNode: ASDisplayNode { convertedRepresentations.append(ImageRepresentationWithReference(representation: .init(dimensions: dimensions, resource: file.file.resource), reference: .standalone(resource: file.file.resource))) signal = chatAvatarGalleryPhoto(account: account, representations: convertedRepresentations) fetchSignal = fetchedMediaResource(postbox: account.postbox, reference: convertedRepresentations[convertedRepresentations.count - 1].reference) + statusSignal = account.postbox.mediaBox.resourceStatus(file.file.resource) case let .image(representations): if let largestSize = largestImageRepresentation(representations) { displaySize = largestSize.dimensions.dividedByScreenScale().integralFloor @@ -58,24 +71,48 @@ private final class WallpaperBackgroundNode: ASDisplayNode { } else { fetchSignal = .complete() } + statusSignal = account.postbox.mediaBox.resourceStatus(largestSize.resource) } else { displaySize = CGSize(width: 100.0, height: 100.0) signal = .never() fetchSignal = .complete() + statusSignal = .single(.Local) } } self.imageNode.setSignal(signal, dispatchOnDisplayLink: false) self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets()))() self.fetchDisposable = fetchSignal.start() + + let statusForegroundColor = UIColor.white + self.statusDisposable = (statusSignal + |> deliverOnMainQueue).start(next: { [weak self] status in + if let strongSelf = self { + let state: RadialStatusNodeState + switch status { + case let .Fetching(_, progress): + let adjustedProgress = max(progress, 0.027) + state = .progress(color: statusForegroundColor, lineWidth: nil, value: CGFloat(adjustedProgress), cancelEnabled: false) + case .Local: + state = .none + case .Remote: + state = .progress(color: statusForegroundColor, lineWidth: nil, value: 0.027, cancelEnabled: false) + } + strongSelf.statusNode.transitionToState(state, completion: {}) + } + }) self.imageNode.contentMode = .scaleAspectFill } deinit { self.fetchDisposable?.dispose() + self.statusDisposable?.dispose() } func updateLayout(_ layout: ContainerViewLayout, navigationHeight: CGFloat, transition: ContainedViewLayoutTransition) { self.imageNode.frame = CGRect(origin: CGPoint(), size: layout.size) + + let progressDiameter: CGFloat = 50.0 + self.statusNode.frame = CGRect(x: layout.safeInsets.left + floorToScreenPixels((layout.size.width - layout.safeInsets.left - layout.safeInsets.right - progressDiameter) / 2.0), y: floorToScreenPixels((layout.size.height - progressDiameter) / 2.0), width: progressDiameter, height: progressDiameter) } } @@ -83,14 +120,19 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { private let account: Account private var presentationData: PresentationData private let dismiss: () -> Void + private let apply: (TelegramWallpaper) -> Void private var validLayout: (ContainerViewLayout, CGFloat)? private let toolbarBackground: ASDisplayNode private let toolbarSeparator: ASDisplayNode private let toolbarVerticalSeparator: ASDisplayNode - private let toolbarButtonCancel: HighlightableButtonNode - private let toolbarButtonApply: HighlightableButtonNode + private let toolbarButtonCancel: HighlightTrackingButtonNode + private let toolbarButtonCancelBackground: ASDisplayNode + private let toolbarButtonApply: HighlightTrackingButtonNode + private let toolbarButtonApplyBackground: ASDisplayNode + + private let segmentedControl: UISegmentedControl private var wallpapersDisposable: Disposable? private var wallpapers: [TelegramWallpaper]? @@ -102,10 +144,11 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { private var centralWallpaper: TelegramWallpaper? private var visibleBackgroundNodesOffset: CGFloat = 0.0 - init(account: Account, presentationData: PresentationData, source: WallpaperListPreviewSource, dismiss: @escaping () -> Void) { + init(account: Account, presentationData: PresentationData, source: WallpaperListPreviewSource, dismiss: @escaping () -> Void, apply: @escaping (TelegramWallpaper) -> Void) { self.account = account self.presentationData = presentationData self.dismiss = dismiss + self.apply = apply self.toolbarBackground = ASDisplayNode() self.toolbarBackground.backgroundColor = self.presentationData.theme.rootController.navigationBar.backgroundColor @@ -115,12 +158,26 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { self.toolbarVerticalSeparator = ASDisplayNode() self.toolbarVerticalSeparator.backgroundColor = self.presentationData.theme.rootController.navigationBar.separatorColor - self.toolbarButtonCancel = HighlightableButtonNode() + self.toolbarButtonCancelBackground = ASDisplayNode() + self.toolbarButtonCancelBackground.alpha = 0.0 + self.toolbarButtonCancelBackground.backgroundColor = self.presentationData.theme.list.itemHighlightedBackgroundColor + self.toolbarButtonCancelBackground.isUserInteractionEnabled = false + + self.toolbarButtonCancel = HighlightTrackingButtonNode() self.toolbarButtonCancel.setAttributedTitle(NSAttributedString(string: self.presentationData.strings.Common_Cancel, font: Font.regular(17.0), textColor: self.presentationData.theme.rootController.navigationBar.primaryTextColor), for: []) - self.toolbarButtonApply = HighlightableButtonNode() + self.toolbarButtonApplyBackground = ASDisplayNode() + self.toolbarButtonApplyBackground.alpha = 0.0 + self.toolbarButtonApplyBackground.backgroundColor = self.presentationData.theme.list.itemHighlightedBackgroundColor + self.toolbarButtonApplyBackground.isUserInteractionEnabled = false + + self.toolbarButtonApply = HighlightTrackingButtonNode() self.toolbarButtonApply.setAttributedTitle(NSAttributedString(string: self.presentationData.strings.Wallpaper_Set, font: Font.regular(17.0), textColor: self.presentationData.theme.rootController.navigationBar.primaryTextColor), for: []) + self.segmentedControl = UISegmentedControl(items: [self.presentationData.strings.BackgroundPreview_Still, self.presentationData.strings.BackgroundPreview_Perspective, self.presentationData.strings.BackgroundPreview_Blurred]) + self.segmentedControl.selectedSegmentIndex = 0 + self.segmentedControl.tintColor = .white + super.init() self.backgroundColor = .black @@ -131,21 +188,42 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { self.addSubnode(self.toolbarButtonCancel) self.addSubnode(self.toolbarButtonApply) + self.view.addSubview(self.segmentedControl) + self.toolbarButtonCancel.addTarget(self, action: #selector(self.cancelPressed), forControlEvents: .touchUpInside) - self.toolbarButtonCancel.addTarget(self, action: #selector(self.applyPressed), forControlEvents: .touchUpInside) + self.toolbarButtonApply.addTarget(self, action: #selector(self.applyPressed), forControlEvents: .touchUpInside) + + self.toolbarButtonCancel.highligthedChanged = { [weak self] value in + if let strongSelf = self { + if value { + if strongSelf.toolbarButtonCancelBackground.supernode == nil { + strongSelf.insertSubnode(strongSelf.toolbarButtonCancelBackground, aboveSubnode: strongSelf.toolbarVerticalSeparator) + } + strongSelf.toolbarButtonCancelBackground.layer.removeAnimation(forKey: "opacity") + strongSelf.toolbarButtonCancelBackground.alpha = 1.0 + } else if !strongSelf.toolbarButtonCancelBackground.alpha.isZero { + strongSelf.toolbarButtonCancelBackground.alpha = 0.0 + strongSelf.toolbarButtonCancelBackground.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.25) + } + } + } + + self.toolbarButtonApply.highligthedChanged = { [weak self] value in + if let strongSelf = self { + if value { + if strongSelf.toolbarButtonApplyBackground.supernode == nil { + strongSelf.insertSubnode(strongSelf.toolbarButtonApplyBackground, aboveSubnode: strongSelf.toolbarVerticalSeparator) + } + strongSelf.toolbarButtonApplyBackground.layer.removeAnimation(forKey: "opacity") + strongSelf.toolbarButtonApplyBackground.alpha = 1.0 + } else if !strongSelf.toolbarButtonApplyBackground.alpha.isZero { + strongSelf.toolbarButtonApplyBackground.alpha = 0.0 + strongSelf.toolbarButtonApplyBackground.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.25) + } + } + } switch source { - /*case .common: - self.wallpapersDisposable = (telegramWallpapers(postbox: account.postbox, network: account.network) - |> deliverOnMainQueue).start(next: { [weak self] result in - guard let strongSelf = self else { - return - } - if let (layout, navigationHeight) = strongSelf.validLayout { - strongSelf.updateVisibleBackgroundNodes(layout: layout, navigationBarHeight: navigationHeight, transition: .immediate) - } - strongSelf.ready.set(true) - })*/ case let .list(wallpapers, central): self.wallpapers = wallpapers self.centralWallpaper = central @@ -180,6 +258,8 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { self.toolbarVerticalSeparator.backgroundColor = self.presentationData.theme.rootController.navigationBar.separatorColor self.toolbarButtonCancel.setAttributedTitle(NSAttributedString(string: self.presentationData.strings.Common_Cancel, font: Font.regular(17.0), textColor: self.presentationData.theme.rootController.navigationBar.primaryTextColor), for: []) self.toolbarButtonApply.setAttributedTitle(NSAttributedString(string: self.presentationData.strings.Wallpaper_Set, font: Font.regular(17.0), textColor: self.presentationData.theme.rootController.navigationBar.primaryTextColor), for: []) + self.toolbarButtonCancelBackground.backgroundColor = self.presentationData.theme.list.itemHighlightedBackgroundColor + self.toolbarButtonApplyBackground.backgroundColor = self.presentationData.theme.list.itemHighlightedBackgroundColor self.backgroundColor = .black if let (layout, navigationHeight) = self.validLayout { @@ -211,9 +291,11 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { var items: [ChatMessageItem] = [] let peerId = PeerId(namespace: Namespaces.Peer.CloudUser, id: 1) + let otherPeerId = self.account.peerId var peers = SimpleDictionary() let messages = SimpleDictionary() peers[peerId] = TelegramUser(id: peerId, accessHash: nil, firstName: self.presentationData.strings.Appearance_PreviewReplyAuthor, lastName: "", username: nil, phone: nil, photo: [], botInfo: nil, restrictionInfo: nil, flags: []) + peers[otherPeerId] = TelegramUser(id: otherPeerId, accessHash: nil, firstName: self.presentationData.strings.Appearance_PreviewReplyAuthor, lastName: "", username: nil, phone: nil, photo: [], botInfo: nil, restrictionInfo: nil, flags: []) let controllerInteraction = ChatControllerInteraction(openMessage: { _, _ in return false }, openPeer: { _, _, _ in }, openPeerMention: { _ in }, openMessageContextMenu: { _, _, _, _ in }, navigateToMessage: { _, _ in }, clickThroughMessage: { }, toggleMessagesSelection: { _, _ in }, sendMessage: { _ in }, sendSticker: { _, _ in }, sendGif: { _ in }, requestMessageActionCallback: { _, _, _ in }, activateSwitchInline: { _, _ in }, openUrl: { _, _, _ in }, shareCurrentLocation: {}, shareAccountContact: {}, sendBotCommand: { _, _ in }, openInstantPage: { _ in }, openHashtag: { _, _ in }, updateInputState: { _ in }, updateInputMode: { _ in }, openMessageShareMenu: { _ in }, presentController: { _, _ in }, navigationController: { @@ -234,7 +316,9 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { let chatPresentationData = ChatPresentationData(theme: ChatPresentationThemeData(theme: presentationData.theme, wallpaper: presentationData.chatWallpaper), fontSize: presentationData.fontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: false) - items.append(ChatMessageItem(presentationData: chatPresentationData, account: self.account, chatLocation: .peer(peerId), associatedData: ChatMessageItemAssociatedData(automaticDownloadPeerType: .contact, automaticDownloadNetworkType: .cellular, isRecentActions: false), controllerInteraction: controllerInteraction, content: .message(message: Message(stableId: 1, stableVersion: 0, id: MessageId(peerId: peerId, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: 66000, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: nil, text: self.presentationData.strings.Appearance_PreviewIncomingText, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), read: true, selection: .none, isAdmin: false), disableDate: true)) + items.append(ChatMessageItem(presentationData: chatPresentationData, account: self.account, chatLocation: .peer(peerId), associatedData: ChatMessageItemAssociatedData(automaticDownloadPeerType: .contact, automaticDownloadNetworkType: .cellular, isRecentActions: false), controllerInteraction: controllerInteraction, content: .message(message: Message(stableId: 2, stableVersion: 0, id: MessageId(peerId: peerId, namespace: 0, id: 2), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: 66001, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peers[otherPeerId], text: "Lorem ipsum dolor sit amet", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), read: true, selection: .none, isAdmin: false), disableDate: true)) + + items.append(ChatMessageItem(presentationData: chatPresentationData, account: self.account, chatLocation: .peer(peerId), associatedData: ChatMessageItemAssociatedData(automaticDownloadPeerType: .contact, automaticDownloadNetworkType: .cellular, isRecentActions: false), controllerInteraction: controllerInteraction, content: .message(message: Message(stableId: 1, stableVersion: 0, id: MessageId(peerId: peerId, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: 66000, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peers[peerId], text: presentationData.strings.BackgroundPreview_SwipeInfo, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), read: true, selection: .none, isAdmin: false), disableDate: true)) let params = ListViewItemLayoutParams(width: layout.size.width, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right) if let messageNodes = self.messageNodes { @@ -267,16 +351,27 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { self.messageNodes = messageNodes } - let bottomInset = layout.intrinsicInsets.bottom + 44.0 + let bottomInset = layout.intrinsicInsets.bottom + 49.0 transition.updateFrame(node: self.toolbarBackground, frame: CGRect(origin: CGPoint(x: 0.0, y: layout.size.height - bottomInset), size: CGSize(width: layout.size.width, height: bottomInset))) transition.updateFrame(node: self.toolbarSeparator, frame: CGRect(origin: CGPoint(x: 0.0, y: layout.size.height - bottomInset), size: CGSize(width: layout.size.width, height: UIScreenPixel))) transition.updateFrame(node: self.toolbarVerticalSeparator, frame: CGRect(origin: CGPoint(x: floor(layout.size.width / 2.0), y: layout.size.height - bottomInset), size: CGSize(width: UIScreenPixel, height: bottomInset))) - transition.updateFrame(node: self.toolbarButtonCancel, frame: CGRect(origin: CGPoint(x: 0.0, y: layout.size.height - bottomInset), size: CGSize(width: floor(layout.size.width / 2.0), height: 44.0))) - transition.updateFrame(node: self.toolbarButtonApply, frame: CGRect(origin: CGPoint(x: floor(layout.size.width / 2.0), y: layout.size.height - bottomInset), size: CGSize(width: ceil(layout.size.width / 2.0), height: 44.0))) + let cancelFrame = CGRect(origin: CGPoint(x: 0.0, y: layout.size.height - bottomInset), size: CGSize(width: floor(layout.size.width / 2.0), height: 49.0)) + transition.updateFrame(node: self.toolbarButtonCancel, frame: cancelFrame) + transition.updateFrame(node: self.toolbarButtonCancelBackground, frame: cancelFrame) + + let applyFrame = CGRect(origin: CGPoint(x: floor(layout.size.width / 2.0), y: layout.size.height - bottomInset), size: CGSize(width: ceil(layout.size.width / 2.0), height: 49.0)) + transition.updateFrame(node: self.toolbarButtonApply, frame: applyFrame) + transition.updateFrame(node: self.toolbarButtonApplyBackground, frame: applyFrame) + + var segmentedControlSize = self.segmentedControl.sizeThatFits(layout.size) + segmentedControlSize.width = max(270.0, segmentedControlSize.width) + + transition.updateFrame(view: self.segmentedControl, frame: CGRect(origin: CGPoint(x: layout.safeInsets.left + floor((layout.size.width - layout.safeInsets.left - layout.safeInsets.right - segmentedControlSize.width) / 2.0), y: layout.size.height - bottomInset - segmentedControlSize.height - 24.0), size: segmentedControlSize)) + if let messageNodes = self.messageNodes { - var bottomOffset: CGFloat = layout.size.height - bottomInset - 3.0 + var bottomOffset: CGFloat = layout.size.height - bottomInset - segmentedControlSize.height - 24.0 - 22.0 for itemNode in messageNodes { transition.updateFrame(node: itemNode, frame: CGRect(origin: CGPoint(x: 0.0, y: bottomOffset - itemNode.frame.height), size: itemNode.frame.size)) bottomOffset -= itemNode.frame.height @@ -361,6 +456,8 @@ final class WallpaperListPreviewControllerNode: ViewControllerTracingNode { } @objc private func applyPressed() { - + if let wallpaper = self.centralWallpaper { + self.apply(wallpaper) + } } } diff --git a/TelegramUI/WebSearchControllerNode.swift b/TelegramUI/WebSearchControllerNode.swift index 729026050e..71d5790c6d 100644 --- a/TelegramUI/WebSearchControllerNode.swift +++ b/TelegramUI/WebSearchControllerNode.swift @@ -347,16 +347,16 @@ class WebSearchControllerNode: ASDisplayNode { var insets = layout.insets(options: [.input]) insets.top += navigationBarHeight - let segmentedHeight: CGFloat = self.segmentedControl.superview != nil ? 40.0 : 5.0 + let segmentedHeight: CGFloat = self.segmentedControl.superview != nil ? 44.0 : 5.0 let panelY: CGFloat = insets.top - UIScreenPixel - 4.0 transition.updateFrame(node: self.segmentedBackgroundNode, frame: CGRect(origin: CGPoint(x: 0.0, y: panelY), size: CGSize(width: layout.size.width, height: segmentedHeight))) transition.updateFrame(node: self.segmentedSeparatorNode, frame: CGRect(origin: CGPoint(x: 0.0, y: panelY + segmentedHeight), size: CGSize(width: layout.size.width, height: UIScreenPixel))) var controlSize = self.segmentedControl.sizeThatFits(layout.size) - controlSize.width = layout.size.width - layout.safeInsets.left - layout.safeInsets.right - 8.0 * 2.0 + controlSize.width = layout.size.width - layout.safeInsets.left - layout.safeInsets.right - 10.0 * 2.0 - transition.updateFrame(view: self.segmentedControl, frame: CGRect(origin: CGPoint(x: layout.safeInsets.left + floor((layout.size.width - layout.safeInsets.left - layout.safeInsets.right - controlSize.width) / 2.0), y: panelY + floor((segmentedHeight - controlSize.height) / 2.0)), size: controlSize)) + transition.updateFrame(view: self.segmentedControl, frame: CGRect(origin: CGPoint(x: layout.safeInsets.left + floor((layout.size.width - layout.safeInsets.left - layout.safeInsets.right - controlSize.width) / 2.0), y: panelY + 5.0), size: controlSize)) insets.top -= 4.0 diff --git a/TelegramUI/WebSearchNavigationContentNode.swift b/TelegramUI/WebSearchNavigationContentNode.swift index 80c91aa142..7d01a838ad 100644 --- a/TelegramUI/WebSearchNavigationContentNode.swift +++ b/TelegramUI/WebSearchNavigationContentNode.swift @@ -4,7 +4,7 @@ import Display import Postbox import TelegramCore -private let searchBarFont = Font.regular(14.0) +private let searchBarFont = Font.regular(17.0) final class WebSearchNavigationContentNode: NavigationBarContentNode { private let theme: PresentationTheme @@ -18,7 +18,7 @@ final class WebSearchNavigationContentNode: NavigationBarContentNode { self.theme = theme self.strings = strings - self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme, active: false), strings: strings) + self.searchBar = SearchBarNode(theme: SearchBarNodeTheme(theme: theme, hasSeparator: false), strings: strings, fieldStyle: .modern) self.searchBar.hasCancelButton = false self.searchBar.placeholderString = NSAttributedString(string: strings.Common_Search, font: searchBarFont, textColor: theme.rootController.activeNavigationSearchBar.inputPlaceholderTextColor) @@ -48,14 +48,14 @@ final class WebSearchNavigationContentNode: NavigationBarContentNode { self.searchBar.text = query } - override func layout() { - super.layout() - - let size = self.bounds.size - - let searchBarFrame = CGRect(origin: CGPoint(), size: size) + override var nominalHeight: CGFloat { + return 54.0 + } + + override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { + let searchBarFrame = CGRect(origin: CGPoint(x: 0.0, y: size.height - self.nominalHeight), size: CGSize(width: size.width, height: 54.0)) self.searchBar.frame = searchBarFrame - self.searchBar.updateLayout(boundingSize: size, leftInset: 0.0, rightInset: 0.0, transition: .immediate) + self.searchBar.updateLayout(boundingSize: searchBarFrame.size, leftInset: leftInset, rightInset: rightInset, transition: transition) } func activate(select: Bool = false) {