From 05ee5f08ccc51b8644f261a9d6141243df0d09c7 Mon Sep 17 00:00:00 2001 From: Ilya Laktyushin Date: Tue, 8 Jan 2019 13:44:26 +0400 Subject: [PATCH] Search bar improvements --- TelegramUI.xcodeproj/project.pbxproj | 6 +- ...onSequenceCountrySelectionController.swift | 18 +- TelegramUI/ChatListController.swift | 19 +- TelegramUI/ChatListControllerNode.swift | 2 +- TelegramUI/ChatListSearchItem.swift | 13 +- .../ChatMessageInteractiveFileNode.swift | 2 +- TelegramUI/ChatMessageStickerItemNode.swift | 4 +- ...ntActionsSearchNavigationContentNode.swift | 18 +- .../ChatSearchNavigationContentNode.swift | 20 +- TelegramUI/ComposeController.swift | 16 +- TelegramUI/ComposeControllerNode.swift | 4 +- TelegramUI/ContactListNode.swift | 84 +- .../ContactMultiselectionControllerNode.swift | 2 +- TelegramUI/ContactSelectionController.swift | 16 +- .../ContactSelectionControllerNode.swift | 4 +- TelegramUI/ContactsController.swift | 23 +- TelegramUI/ContactsControllerNode.swift | 4 +- TelegramUI/EditSettingsController.swift | 13 +- TelegramUI/GalleryController.swift | 2 +- ...GroupInfoSearchNavigationContentNode.swift | 18 +- .../HashtagChatInputContextPanelNode.swift | 2 +- TelegramUI/HorizontalStickerGridItem.swift | 1 - ...rizontalStickersChatContextPanelNode.swift | 139 +- TelegramUI/InviteContactsController.swift | 14 +- TelegramUI/InviteContactsControllerNode.swift | 9 +- TelegramUI/ListMessageFileItemNode.swift | 8 +- TelegramUI/LocalizationListController.swift | 21 +- .../LocalizationListControllerNode.swift | 4 +- .../NavigationBarSearchContentNode.swift | 35 +- .../NotificationExceptionControllerNode.swift | 2 +- TelegramUI/NotificationExceptions.swift | 2 +- TelegramUI/OpenResolvedUrl.swift | 11 +- .../PeerMediaCollectionControllerNode.swift | 2 +- TelegramUI/PeerSelectionController.swift | 16 +- TelegramUI/PeerSelectionControllerNode.swift | 27 +- TelegramUI/PresentationStrings.swift | 4287 +++++++++-------- TelegramUI/RadialCheckContentNode.swift | 2 +- .../Resources/PresentationStrings.mapping | Bin 98803 -> 99069 bytes TelegramUI/SearchBarNode.swift | 12 +- TelegramUI/SearchBarPlaceholderNode.swift | 5 +- TelegramUI/SearchDisplayController.swift | 35 +- TelegramUI/SettingsThemeWallpaperNode.swift | 16 +- TelegramUI/StickerPaneSearchBarNode.swift | 6 +- .../StickerPaneSearchBarPlaceholderItem.swift | 4 +- .../StickerPaneSearchContainerNode.swift | 4 +- TelegramUI/TelegramController.swift | 11 +- TelegramUI/TelegramRootController.swift | 64 +- TelegramUI/ThemeGalleryController.swift | 4 - TelegramUI/ThemeGridActionNode.swift | 14 - TelegramUI/ThemeGridController.swift | 62 +- TelegramUI/ThemeGridControllerItem.swift | 23 +- TelegramUI/ThemeGridControllerNode.swift | 136 +- .../WallpaperListPreviewController.swift | 18 + .../WallpaperListPreviewControllerNode.swift | 145 +- TelegramUI/WebSearchControllerNode.swift | 6 +- .../WebSearchNavigationContentNode.swift | 18 +- 56 files changed, 2874 insertions(+), 2579 deletions(-) delete mode 100644 TelegramUI/ThemeGridActionNode.swift 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 dcc2adc26592cb281a2413ec21d5de4dcb6fa8ba..bd4dd9cbfcbf20e92c082d3d53a2d353ee46440e 100644 GIT binary patch delta 25448 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 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) {