diff --git a/Telegram/Telegram-iOS/en.lproj/Localizable.strings b/Telegram/Telegram-iOS/en.lproj/Localizable.strings index 2f1cba8cc0..9639ce4569 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -5741,3 +5741,16 @@ Any member of this group will be able to see messages in the channel."; "AccessDenied.VideoCallCamera" = "Telegram needs access to your camera to make video calls.\n\nPlease go to Settings > Privacy > Camera and set Telegram to ON."; "Call.AccountIsLoggedOnCurrentDevice" = "Sorry, you can't call %@ because that account is logged in to Telegram on the device you're using for the call."; + +"ChatList.Search.SearchBeforeDate" = "Search before %@"; +"ChatList.Search.SearchAfterDate" = "Search after %@"; + +"ChatList.Search.FilterMedia" = "Media"; +"ChatList.Search.FilterPhotos" = "Photos"; +"ChatList.Search.FilterVideos" = "Video"; +"ChatList.Search.FilterLinks" = "Links"; +"ChatList.Search.FilterFiles" = "Files"; +"ChatList.Search.FilterMusic" = "Audio"; + +"ChatList.Search.NoResults" = "No Results"; +"ChatList.Search.NoResultsDescription" = "There were no results for \"%@\".\nTry a new search."; diff --git a/submodules/AccountContext/Sources/AccountContext.swift b/submodules/AccountContext/Sources/AccountContext.swift index e470deadee..07d3a40d74 100644 --- a/submodules/AccountContext/Sources/AccountContext.swift +++ b/submodules/AccountContext/Sources/AccountContext.swift @@ -530,7 +530,7 @@ public protocol SharedAccountContext: class { func navigateToChat(accountId: AccountRecordId, peerId: PeerId, messageId: MessageId?) func openChatMessage(_ params: OpenChatMessageParams) -> Bool func messageFromPreloadedChatHistoryViewForLocation(id: MessageId, location: ChatHistoryLocationInput, context: AccountContext, chatLocation: ChatLocation, chatLocationContextHolder: Atomic, tagMask: MessageTags?) -> Signal<(MessageIndex?, Bool), NoError> - func makeOverlayAudioPlayerController(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, parentNavigationController: NavigationController?) -> ViewController & OverlayAudioPlayerController + func makeOverlayAudioPlayerController(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, isGlobalSearch: Bool, parentNavigationController: NavigationController?) -> ViewController & OverlayAudioPlayerController func makePeerInfoController(context: AccountContext, peer: Peer, mode: PeerInfoControllerMode, avatarInitiallyExpanded: Bool, fromChat: Bool) -> ViewController? func makeChannelAdminController(context: AccountContext, peerId: PeerId, adminId: PeerId, initialParticipant: ChannelParticipant) -> ViewController? func makeDeviceContactInfoController(context: AccountContext, subject: DeviceContactInfoSubject, completed: (() -> Void)?, cancelled: (() -> Void)?) -> ViewController diff --git a/submodules/AccountContext/Sources/ChatController.swift b/submodules/AccountContext/Sources/ChatController.swift index e0fe69e795..b4991ae99b 100644 --- a/submodules/AccountContext/Sources/ChatController.swift +++ b/submodules/AccountContext/Sources/ChatController.swift @@ -10,6 +10,83 @@ import SwiftSignalKit import TelegramPresentationData import TelegramUIPreferences +public final class ChatMessageItemAssociatedData: Equatable { + public let automaticDownloadPeerType: MediaAutoDownloadPeerType + public let automaticDownloadNetworkType: MediaAutoDownloadNetworkType + public let isRecentActions: Bool + public let isScheduledMessages: Bool + public let contactsPeerIds: Set + public let animatedEmojiStickers: [String: [StickerPackItem]] + public let forcedResourceStatus: FileMediaResourceStatus? + + public init(automaticDownloadPeerType: MediaAutoDownloadPeerType, automaticDownloadNetworkType: MediaAutoDownloadNetworkType, isRecentActions: Bool = false, isScheduledMessages: Bool = false, contactsPeerIds: Set = Set(), animatedEmojiStickers: [String: [StickerPackItem]] = [:], forcedResourceStatus: FileMediaResourceStatus? = nil) { + self.automaticDownloadPeerType = automaticDownloadPeerType + self.automaticDownloadNetworkType = automaticDownloadNetworkType + self.isRecentActions = isRecentActions + self.isScheduledMessages = isScheduledMessages + self.contactsPeerIds = contactsPeerIds + self.animatedEmojiStickers = animatedEmojiStickers + self.forcedResourceStatus = forcedResourceStatus + } + + public static func == (lhs: ChatMessageItemAssociatedData, rhs: ChatMessageItemAssociatedData) -> Bool { + if lhs.automaticDownloadPeerType != rhs.automaticDownloadPeerType { + return false + } + if lhs.automaticDownloadNetworkType != rhs.automaticDownloadNetworkType { + return false + } + if lhs.isRecentActions != rhs.isRecentActions { + return false + } + if lhs.isScheduledMessages != rhs.isScheduledMessages { + return false + } + if lhs.contactsPeerIds != rhs.contactsPeerIds { + return false + } + if lhs.animatedEmojiStickers != rhs.animatedEmojiStickers { + return false + } + if lhs.forcedResourceStatus != rhs.forcedResourceStatus { + return false + } + return true + } +} + +public enum ChatControllerInteractionLongTapAction { + case url(String) + case mention(String) + case peerMention(PeerId, String) + case command(String) + case hashtag(String) + case timecode(Double, String) + case bankCard(String) +} + +public enum ChatHistoryMessageSelection: Equatable { + case none + case selectable(selected: Bool) + + public static func ==(lhs: ChatHistoryMessageSelection, rhs: ChatHistoryMessageSelection) -> Bool { + switch lhs { + case .none: + if case .none = rhs { + return true + } else { + return false + } + case let .selectable(selected): + if case .selectable(selected) = rhs { + return true + } else { + return false + } + } + } +} + public enum ChatControllerInitialBotStartBehavior { case interactive case automatic(returnToPeerId: PeerId, scheduled: Bool) diff --git a/submodules/AccountContext/Sources/GalleryController.swift b/submodules/AccountContext/Sources/GalleryController.swift index c88a5fdafb..974eca8158 100644 --- a/submodules/AccountContext/Sources/GalleryController.swift +++ b/submodules/AccountContext/Sources/GalleryController.swift @@ -1,5 +1,13 @@ import Foundation import Postbox +import SwiftSignalKit +import TelegramCore + +public enum GalleryControllerItemSource { + case peerMessagesAtId(messageId: MessageId, chatLocation: ChatLocation, chatLocationContextHolder: Atomic) + case standaloneMessage(Message) + case searchResult(SearchMessagesResult, SearchMessagesState, MessageId) +} public final class GalleryControllerActionInteraction { public let openUrl: (String, Bool) -> Void diff --git a/submodules/AccountContext/Sources/MediaManager.swift b/submodules/AccountContext/Sources/MediaManager.swift index ba033b358d..fb7c3c345e 100644 --- a/submodules/AccountContext/Sources/MediaManager.swift +++ b/submodules/AccountContext/Sources/MediaManager.swift @@ -8,6 +8,120 @@ import AsyncDisplayKit import TelegramAudio import UniversalMediaPlayer +public enum PeerMessagesMediaPlaylistId: Equatable, SharedMediaPlaylistId { + case peer(PeerId) + case recentActions(PeerId) + case searchResults + + public func isEqual(to: SharedMediaPlaylistId) -> Bool { + if let to = to as? PeerMessagesMediaPlaylistId { + return self == to + } + return false + } +} + +public enum PeerMessagesPlaylistLocation: Equatable, SharedMediaPlaylistLocation { + case messages(peerId: PeerId, tagMask: MessageTags, at: MessageId) + case singleMessage(MessageId) + case recentActions(Message) + case searchResults(query: String?, peerId: PeerId?, messages: [Message], at: MessageId) + + public var playlistId: PeerMessagesMediaPlaylistId { + switch self { + case let .messages(peerId, _, _): + return .peer(peerId) + case let .singleMessage(id): + return .peer(id.peerId) + case let .recentActions(message): + return .recentActions(message.id.peerId) + case let .searchResults(query, peerId, messages, _): + return .searchResults + } + } + + public var messageId: MessageId? { + switch self { + case let .messages(_, _, messageId), let .singleMessage(messageId): + return messageId + default: + return nil + } + } + + public func isEqual(to: SharedMediaPlaylistLocation) -> Bool { + if let to = to as? PeerMessagesPlaylistLocation { + return self == to + } else { + return false + } + } + + public static func ==(lhs: PeerMessagesPlaylistLocation, rhs: PeerMessagesPlaylistLocation) -> Bool { + switch lhs { + case let .messages(peerId, tagMask, at): + if case .messages(peerId, tagMask, at) = rhs { + return true + } else { + return false + } + case let .singleMessage(messageId): + if case .singleMessage(messageId) = rhs { + return true + } else { + return false + } + case let .recentActions(lhsMessage): + if case let .recentActions(rhsMessage) = rhs, lhsMessage.id == rhsMessage.id { + return true + } else { + return false + } + case let .searchResults(lhsQuery, lhsPeerId, lhsMessages, lhsAt): + if case let .searchResults(rhsQuery, rhsPeerId, rhsMessages, rhsAt) = rhs, lhsQuery == rhsQuery, lhsPeerId == rhsPeerId, lhsAt == rhsAt { + return true + } else { + return false + } + } + } +} + +public func peerMessageMediaPlayerType(_ message: Message) -> MediaManagerPlayerType? { + func extractFileMedia(_ message: Message) -> TelegramMediaFile? { + var file: TelegramMediaFile? + for media in message.media { + if let media = media as? TelegramMediaFile { + file = media + break + } else if let media = media as? TelegramMediaWebpage, case let .Loaded(content) = media.content, let f = content.file { + file = f + break + } + } + return file + } + + if let file = extractFileMedia(message) { + if file.isVoice || file.isInstantVideo { + return .voice + } else if file.isMusic { + return .music + } + } + return nil +} + +public func peerMessagesMediaPlaylistAndItemId(_ message: Message, isRecentActions: Bool, isGlobalSearch: Bool) -> (SharedMediaPlaylistId, SharedMediaPlaylistItemId)? { + if isGlobalSearch { + return (PeerMessagesMediaPlaylistId.searchResults, PeerMessagesMediaPlaylistItemId(messageId: message.id)) + } else if isRecentActions { + return (PeerMessagesMediaPlaylistId.recentActions(message.id.peerId), PeerMessagesMediaPlaylistItemId(messageId: message.id)) + } else { + return (PeerMessagesMediaPlaylistId.peer(message.id.peerId), PeerMessagesMediaPlaylistItemId(messageId: message.id)) + } +} + public enum MediaManagerPlayerType { case voice case music diff --git a/submodules/AccountContext/Sources/OpenChatMessage.swift b/submodules/AccountContext/Sources/OpenChatMessage.swift index 2dbdc86169..be3fcfd330 100644 --- a/submodules/AccountContext/Sources/OpenChatMessage.swift +++ b/submodules/AccountContext/Sources/OpenChatMessage.swift @@ -6,6 +6,7 @@ import SyncCore import SwiftSignalKit import Display import AsyncDisplayKit +import UniversalMediaPlayer public enum ChatControllerInteractionOpenMessageMode { case `default` @@ -38,6 +39,8 @@ public final class OpenChatMessageParams { public let setupTemporaryHiddenMedia: (Signal, Int, Media) -> Void public let chatAvatarHiddenMedia: (Signal, Media) -> Void public let actionInteraction: GalleryControllerActionInteraction? + public let playlistLocation: PeerMessagesPlaylistLocation? + public let gallerySource: GalleryControllerItemSource? public init( context: AccountContext, @@ -60,7 +63,9 @@ public final class OpenChatMessageParams { sendSticker: ((FileMediaReference, ASDisplayNode, CGRect) -> Bool)?, setupTemporaryHiddenMedia: @escaping (Signal, Int, Media) -> Void, chatAvatarHiddenMedia: @escaping (Signal, Media) -> Void, - actionInteraction: GalleryControllerActionInteraction? = nil + actionInteraction: GalleryControllerActionInteraction? = nil, + playlistLocation: PeerMessagesPlaylistLocation? = nil, + gallerySource: GalleryControllerItemSource? = nil ) { self.context = context self.chatLocation = chatLocation @@ -83,5 +88,7 @@ public final class OpenChatMessageParams { self.setupTemporaryHiddenMedia = setupTemporaryHiddenMedia self.chatAvatarHiddenMedia = chatAvatarHiddenMedia self.actionInteraction = actionInteraction + self.playlistLocation = playlistLocation + self.gallerySource = gallerySource } } diff --git a/submodules/ChatListUI/BUILD b/submodules/ChatListUI/BUILD index 0eb8212ebd..401baf1f7c 100644 --- a/submodules/ChatListUI/BUILD +++ b/submodules/ChatListUI/BUILD @@ -46,6 +46,9 @@ swift_library( "//submodules/ItemListPeerActionItem:ItemListPeerActionItem", "//submodules/AnimatedStickerNode:AnimatedStickerNode", "//submodules/TooltipUI:TooltipUI", + "//submodules/ListMessageItem:ListMessageItem", + "//submodules/ChatMessageInteractiveMediaBadge:ChatMessageInteractiveMediaBadge", + "//submodules/MediaPlayer:UniversalMediaPlayer", ], visibility = [ "//visibility:public", diff --git a/submodules/ChatListUI/Sources/ChatListController.swift b/submodules/ChatListUI/Sources/ChatListController.swift index 44e06dca1e..5c3fe60788 100644 --- a/submodules/ChatListUI/Sources/ChatListController.swift +++ b/submodules/ChatListUI/Sources/ChatListController.swift @@ -1548,7 +1548,7 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, let isEmpty = resolvedItems.count <= 1 || displayTabsAtBottom - if wasEmpty != isEmpty { + if wasEmpty != isEmpty, strongSelf.displayNavigationBar { strongSelf.navigationBar?.setSecondaryContentNode(isEmpty ? nil : strongSelf.tabContainerNode) if let parentController = strongSelf.parent as? TabBarController { parentController.navigationBar?.setSecondaryContentNode(isEmpty ? nil : strongSelf.tabContainerNode) @@ -1681,20 +1681,70 @@ public class ChatListControllerImpl: TelegramBaseController, ChatListController, if let scrollToTop = strongSelf.scrollToTop { scrollToTop() } + if let searchContentNode = strongSelf.searchContentNode { - strongSelf.chatListDisplayNode.activateSearch(placeholderNode: searchContentNode.placeholderNode) + var updatedSearchOptionsImpl: ((ChatListSearchOptions?) -> Void)? + + if let filterContainerNodeAndActivate = strongSelf.chatListDisplayNode.activateSearch(placeholderNode: searchContentNode.placeholderNode, navigationController: strongSelf.navigationController as? NavigationController, updatedSearchOptions: { options in + updatedSearchOptionsImpl?(options) + }) { + let (filterContainerNode, activate) = filterContainerNodeAndActivate + strongSelf.navigationBar?.setSecondaryContentNode(filterContainerNode, animated: true) + if let parentController = strongSelf.parent as? TabBarController { + parentController.navigationBar?.setSecondaryContentNode(filterContainerNode, animated: true) + } + activate() + + updatedSearchOptionsImpl = { [weak self, weak filterContainerNode] options in + guard let strongSelf = self, let strongFilterContainerNode = filterContainerNode else { + return + } + var node: ASDisplayNode? + if let options = options, options.messageTags != nil { + } else { + node = strongFilterContainerNode + } + + strongSelf.navigationBar?.setSecondaryContentNode(node, animated: true) + if let parentController = strongSelf.parent as? TabBarController { + parentController.navigationBar?.setSecondaryContentNode(node, animated: true) + } + + let transition: ContainedViewLayoutTransition = .animated(duration: 0.4, curve: .spring) + if let layout = strongSelf.validLayout { + strongSelf.containerLayoutUpdated(layout, transition: transition) + (strongSelf.parent as? TabBarController)?.updateLayout(transition: transition) + } + } + } } - strongSelf.setDisplayNavigationBar(false, transition: .animated(duration: 0.5, curve: .spring)) + + let transition: ContainedViewLayoutTransition = .animated(duration: 0.4, curve: .spring) + strongSelf.setDisplayNavigationBar(false, transition: transition) }) } } public 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.chatListDisplayNode.deactivateSearch(placeholderNode: searchContentNode.placeholderNode, animated: animated) } + + let filtersIsEmpty: Bool + if let (resolvedItems, displayTabsAtBottom) = tabContainerData { + filtersIsEmpty = resolvedItems.count <= 1 || displayTabsAtBottom + } else { + filtersIsEmpty = true + } + + self.navigationBar?.setSecondaryContentNode(filtersIsEmpty ? nil : self.tabContainerNode, animated: animated) + if let parentController = self.parent as? TabBarController { + parentController.navigationBar?.setSecondaryContentNode(filtersIsEmpty ? nil : self.tabContainerNode, animated: animated) + } + + let transition: ContainedViewLayoutTransition = animated ? .animated(duration: 0.5, curve: .spring) : .immediate + self.setDisplayNavigationBar(true, transition: transition) } } diff --git a/submodules/ChatListUI/Sources/ChatListControllerNode.swift b/submodules/ChatListUI/Sources/ChatListControllerNode.swift index 169d57ed6f..88f78da6cc 100644 --- a/submodules/ChatListUI/Sources/ChatListControllerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListControllerNode.swift @@ -1147,12 +1147,12 @@ final class ChatListControllerNode: ASDisplayNode { } } - func activateSearch(placeholderNode: SearchBarPlaceholderNode) { + func activateSearch(placeholderNode: SearchBarPlaceholderNode, navigationController: NavigationController?, updatedSearchOptions: ((ChatListSearchOptions?) -> Void)?) -> (ASDisplayNode, () -> Void)? { guard let (containerLayout, _, _, cleanNavigationBarHeight) = self.containerLayout, let navigationBar = self.navigationBar, self.searchDisplayController == nil else { - return + return nil } - self.searchDisplayController = SearchDisplayController(presentationData: self.presentationData, contentNode: ChatListSearchContainerNode(context: self.context, filter: [], groupId: self.groupId, openPeer: { [weak self] peer, dismissSearch in + let contentNode = ChatListSearchContainerNode(context: self.context, filter: [], groupId: self.groupId, openPeer: { [weak self] peer, dismissSearch in self?.requestOpenPeerFromSearch?(peer, dismissSearch) }, openDisabledPeer: { _ in }, openRecentPeerOptions: { [weak self] peer in @@ -1165,25 +1165,34 @@ final class ChatListControllerNode: ASDisplayNode { if let requestAddContact = self?.requestAddContact { requestAddContact(phoneNumber) } - }, peerContextAction: self.peerContextAction, present: { [weak self] c in - self?.controller?.present(c, in: .window(.root)) - }), cancel: { [weak self] in + }, peerContextAction: self.peerContextAction, present: { [weak self] c, a in + self?.controller?.present(c, in: .window(.root), with: a) + }, navigationController: navigationController, updatedSearchOptions: { options in + updatedSearchOptions?(options) + }) + + self.searchDisplayController = SearchDisplayController(presentationData: self.presentationData, contentNode: contentNode, cancel: { [weak self] in if let requestDeactivateSearch = self?.requestDeactivateSearch { requestDeactivateSearch() } }) self.containerNode.accessibilityElementsHidden = true - - self.searchDisplayController?.containerLayoutUpdated(containerLayout, navigationBarHeight: cleanNavigationBarHeight, 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) - } + + return (contentNode.filterContainerNode, { [weak self] in + guard let strongSelf = self else { + return } - }, placeholder: placeholderNode) + strongSelf.searchDisplayController?.containerLayoutUpdated(containerLayout, navigationBarHeight: cleanNavigationBarHeight, transition: .immediate) + strongSelf.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) { diff --git a/submodules/ChatListUI/Sources/ChatListDatePickerScreen.swift b/submodules/ChatListUI/Sources/ChatListDatePickerScreen.swift new file mode 100644 index 0000000000..51db0520ee --- /dev/null +++ b/submodules/ChatListUI/Sources/ChatListDatePickerScreen.swift @@ -0,0 +1,424 @@ +import Foundation +import UIKit +import Display +import AsyncDisplayKit +import Postbox +import TelegramCore +import SyncCore +import SwiftSignalKit +import AccountContext +import TelegramPresentationData +import TelegramStringFormatting +import SolidRoundedButtonNode +import PresentationDataUtils + +final class ChatListDatePickerScreen: ViewController { + private var controllerNode: ChatListDatePickerScreenNode { + return self.displayNode as! ChatListDatePickerScreenNode + } + + private var animatedIn = false + + private let context: AccountContext + private let dismissByTapOutside: Bool + private let completion: (Int32?, Bool) -> Void + + private var presentationDataDisposable: Disposable? + + init(context: AccountContext, dismissByTapOutside: Bool = true, completion: @escaping (Int32?, Bool) -> Void) { + self.context = context + self.dismissByTapOutside = dismissByTapOutside + self.completion = completion + + super.init(navigationBarPresentationData: nil) + + self.statusBar.statusBarStyle = .Ignore + + self.blocksBackgroundWhenInOverlay = true + + self.presentationDataDisposable = (context.sharedContext.presentationData + |> deliverOnMainQueue).start(next: { [weak self] presentationData in + if let strongSelf = self { + strongSelf.controllerNode.updatePresentationData(presentationData) + } + }) + + self.statusBar.statusBarStyle = .Ignore + } + + required init(coder aDecoder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } + + deinit { + self.presentationDataDisposable?.dispose() + } + + override public func loadDisplayNode() { + self.displayNode = ChatListDatePickerScreenNode(context: self.context, dismissByTapOutside: self.dismissByTapOutside) + self.controllerNode.completion = { [weak self] date, after in + guard let strongSelf = self else { + return + } + strongSelf.completion(date, after) + strongSelf.dismiss() + } + self.controllerNode.dismiss = { [weak self] in + self?.presentingViewController?.dismiss(animated: false, completion: nil) + } + self.controllerNode.cancel = { [weak self] in + self?.dismiss() + } + } + + override public func loadView() { + super.loadView() + } + + override public func viewDidAppear(_ animated: Bool) { + super.viewDidAppear(animated) + + if !self.animatedIn { + self.animatedIn = true + self.controllerNode.animateIn() + } + } + + override public func dismiss(completion: (() -> Void)? = nil) { + self.controllerNode.animateOut(completion: completion) + } + + override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { + super.containerLayoutUpdated(layout, transition: transition) + + self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + } +} + +class ChatListDatePickerScreenNode: ViewControllerTracingNode, UIScrollViewDelegate { + private let context: AccountContext + private var presentationData: PresentationData + private let dismissByTapOutside: Bool + + private let dimNode: ASDisplayNode + private let wrappingScrollNode: ASScrollNode + private let contentContainerNode: ASDisplayNode + private let effectNode: ASDisplayNode + private let backgroundNode: ASDisplayNode + private let contentBackgroundNode: ASDisplayNode + private let titleNode: ASTextNode + private let cancelButton: HighlightableButtonNode + private let beforeButton: SolidRoundedButtonNode + private let afterButton: SolidRoundedButtonNode + + private var pickerView: UIDatePicker? + private let dateFormatter: DateFormatter + + private var containerLayout: (ContainerViewLayout, CGFloat)? + + var completion: ((Int32?, Bool) -> Void)? + var dismiss: (() -> Void)? + var cancel: (() -> Void)? + + init(context: AccountContext, dismissByTapOutside: Bool) { + self.context = context + self.presentationData = context.sharedContext.currentPresentationData.with { $0 } + self.dismissByTapOutside = dismissByTapOutside + + self.wrappingScrollNode = ASScrollNode() + self.wrappingScrollNode.view.alwaysBounceVertical = true + self.wrappingScrollNode.view.delaysContentTouches = false + self.wrappingScrollNode.view.canCancelContentTouches = true + + self.dimNode = ASDisplayNode() + self.dimNode.backgroundColor = UIColor(white: 0.0, alpha: 0.5) + + self.contentContainerNode = ASDisplayNode() + self.contentContainerNode.isOpaque = false + + self.backgroundNode = ASDisplayNode() + self.backgroundNode.clipsToBounds = true + self.backgroundNode.cornerRadius = 16.0 + + let backgroundColor: UIColor + let textColor: UIColor + let accentColor: UIColor + let buttonColor: UIColor + let buttonTextColor: UIColor + let blurStyle: UIBlurEffect.Style + + backgroundColor = self.presentationData.theme.actionSheet.itemBackgroundColor + textColor = self.presentationData.theme.actionSheet.primaryTextColor + accentColor = self.presentationData.theme.actionSheet.controlAccentColor + buttonColor = self.presentationData.theme.actionSheet.opaqueItemBackgroundColor + buttonTextColor = accentColor + blurStyle = self.presentationData.theme.actionSheet.backgroundType == .light ? .light : .dark + + self.effectNode = ASDisplayNode(viewBlock: { + return UIVisualEffectView(effect: UIBlurEffect(style: blurStyle)) + }) + + self.contentBackgroundNode = ASDisplayNode() + self.contentBackgroundNode.backgroundColor = backgroundColor + + let title: String = "Set Date" + + self.titleNode = ASTextNode() + self.titleNode.attributedText = NSAttributedString(string: title, font: Font.bold(17.0), textColor: textColor) + + self.cancelButton = HighlightableButtonNode() + self.cancelButton.setTitle(self.presentationData.strings.Common_Cancel, with: Font.regular(17.0), with: accentColor, for: .normal) + + self.beforeButton = SolidRoundedButtonNode(theme: SolidRoundedButtonTheme(theme: self.presentationData.theme), height: 52.0, cornerRadius: 11.0, gloss: false) + + self.afterButton = SolidRoundedButtonNode(theme: SolidRoundedButtonTheme(backgroundColor: buttonColor, foregroundColor: buttonTextColor), font: .regular, height: 52.0, cornerRadius: 11.0, gloss: false) + self.afterButton.title = self.presentationData.strings.Conversation_ScheduleMessage_SendWhenOnline + + self.dateFormatter = DateFormatter() + self.dateFormatter.timeStyle = .none + self.dateFormatter.dateStyle = .short + self.dateFormatter.timeZone = TimeZone.current + + super.init() + + self.backgroundColor = nil + self.isOpaque = false + + self.dimNode.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.dimTapGesture(_:)))) + self.addSubnode(self.dimNode) + + self.wrappingScrollNode.view.delegate = self + self.addSubnode(self.wrappingScrollNode) + + self.wrappingScrollNode.addSubnode(self.backgroundNode) + self.wrappingScrollNode.addSubnode(self.contentContainerNode) + + self.backgroundNode.addSubnode(self.effectNode) + self.backgroundNode.addSubnode(self.contentBackgroundNode) + self.contentContainerNode.addSubnode(self.titleNode) + self.contentContainerNode.addSubnode(self.cancelButton) + self.contentContainerNode.addSubnode(self.beforeButton) + self.contentContainerNode.addSubnode(self.afterButton) + + self.cancelButton.addTarget(self, action: #selector(self.cancelButtonPressed), forControlEvents: .touchUpInside) + self.beforeButton.pressed = { [weak self] in + if let strongSelf = self, let pickerView = strongSelf.pickerView { + strongSelf.beforeButton.isUserInteractionEnabled = false + strongSelf.completion?(Int32(pickerView.date.timeIntervalSince1970), false) + } + } + self.afterButton.pressed = { [weak self] in + if let strongSelf = self, let pickerView = strongSelf.pickerView { + strongSelf.afterButton.isUserInteractionEnabled = false + strongSelf.completion?(Int32(pickerView.date.timeIntervalSince1970), true) + } + } + + self.setupPickerView(currentTime: nil) + self.updateButtonTitle() + } + + func setupPickerView(currentTime: Int32? = nil) { + var currentDate: Date? + if let pickerView = self.pickerView { + currentDate = pickerView.date + pickerView.removeFromSuperview() + } + + let textColor: UIColor = self.presentationData.theme.actionSheet.primaryTextColor + + let pickerView = UIDatePicker() + pickerView.timeZone = TimeZone(secondsFromGMT: 0) + pickerView.setValue(textColor, forKey: "textColor") + pickerView.datePickerMode = .countDownTimer + pickerView.datePickerMode = .date + pickerView.locale = Locale.current + pickerView.timeZone = TimeZone.current + pickerView.minuteInterval = 1 + self.contentContainerNode.view.addSubview(pickerView) + pickerView.addTarget(self, action: #selector(self.datePickerUpdated), for: .valueChanged) + self.pickerView = pickerView + + self.updateMinimumDate(currentTime: currentTime) + if let currentDate = currentDate { + pickerView.date = currentDate + } + } + + func updatePresentationData(_ presentationData: PresentationData) { + let previousTheme = self.presentationData.theme + self.presentationData = presentationData + + if let effectView = self.effectNode.view as? UIVisualEffectView { + effectView.effect = UIBlurEffect(style: presentationData.theme.actionSheet.backgroundType == .light ? .light : .dark) + } + + self.contentBackgroundNode.backgroundColor = self.presentationData.theme.actionSheet.itemBackgroundColor + self.titleNode.attributedText = NSAttributedString(string: self.titleNode.attributedText?.string ?? "", font: Font.bold(17.0), textColor: self.presentationData.theme.actionSheet.primaryTextColor) + + if previousTheme !== presentationData.theme, let (layout, navigationBarHeight) = self.containerLayout { + self.setupPickerView() + self.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: .immediate) + } + + self.cancelButton.setTitle(self.presentationData.strings.Common_Cancel, with: Font.regular(17.0), with: self.presentationData.theme.actionSheet.controlAccentColor, for: .normal) + self.beforeButton.updateTheme(SolidRoundedButtonTheme(theme: self.presentationData.theme)) + self.afterButton.updateTheme(SolidRoundedButtonTheme(backgroundColor: self.presentationData.theme.actionSheet.opaqueItemBackgroundColor, foregroundColor: self.presentationData.theme.actionSheet.controlAccentColor)) + } + + private func updateMinimumDate(currentTime: Int32? = nil) { +// let timeZone = TimeZone(secondsFromGMT: 0)! +// var calendar = Calendar(identifier: .gregorian) +// calendar.timeZone = timeZone +// let currentDate = Date() +// var components = calendar.dateComponents(Set([.era, .year, .month, .day, .hour, .minute, .second]), from: currentDate) +// components.second = 0 +// let minute = (components.minute ?? 0) % 5 + + self.pickerView?.minimumDate = Date(timeIntervalSince1970: 1376438400.0) + self.pickerView?.maximumDate = Date(timeIntervalSinceNow: 2.0) + self.pickerView?.date = Date() + } + + override func didLoad() { + super.didLoad() + + if #available(iOSApplicationExtension 11.0, iOS 11.0, *) { + self.wrappingScrollNode.view.contentInsetAdjustmentBehavior = .never + } + } + + private func updateButtonTitle() { + guard let date = self.pickerView?.date else { + return + } + + self.beforeButton.title = self.presentationData.strings.ChatList_Search_SearchBeforeDate(self.dateFormatter.string(from: date)).0 + self.afterButton.title = self.presentationData.strings.ChatList_Search_SearchAfterDate(self.dateFormatter.string(from: date)).0 + } + + @objc private func datePickerUpdated() { + self.updateButtonTitle() +// if let date = self.pickerView?.date, date < Date() { +// self.beforeButton.alpha = 0.4 +// self.beforeButton.isUserInteractionEnabled = false +// } else { +// self.beforeButton.alpha = 1.0 +// self.beforeButton.isUserInteractionEnabled = true +// } + } + + @objc func cancelButtonPressed() { + self.cancel?() + } + + @objc func dimTapGesture(_ recognizer: UITapGestureRecognizer) { + if self.dismissByTapOutside, case .ended = recognizer.state { + self.cancelButtonPressed() + } + } + + func animateIn() { + self.dimNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.4) + + let offset = self.bounds.size.height - self.contentBackgroundNode.frame.minY + + let dimPosition = self.dimNode.layer.position + self.dimNode.layer.animatePosition(from: CGPoint(x: dimPosition.x, y: dimPosition.y - offset), to: dimPosition, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) + self.layer.animateBoundsOriginYAdditive(from: -offset, to: 0.0, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) + } + + func animateOut(completion: (() -> Void)? = nil) { + var dimCompleted = false + var offsetCompleted = false + + let internalCompletion: () -> Void = { [weak self] in + if let strongSelf = self, dimCompleted && offsetCompleted { + strongSelf.dismiss?() + } + completion?() + } + + self.dimNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.3, removeOnCompletion: false, completion: { _ in + dimCompleted = true + internalCompletion() + }) + + let offset = self.bounds.size.height - self.contentBackgroundNode.frame.minY + let dimPosition = self.dimNode.layer.position + self.dimNode.layer.animatePosition(from: dimPosition, to: CGPoint(x: dimPosition.x, y: dimPosition.y - offset), duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false) + self.layer.animateBoundsOriginYAdditive(from: 0.0, to: -offset, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false, completion: { _ in + offsetCompleted = true + internalCompletion() + }) + } + + override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + if self.bounds.contains(point) { + if !self.contentBackgroundNode.bounds.contains(self.convert(point, to: self.contentBackgroundNode)) { + return self.dimNode.view + } + } + return super.hitTest(point, with: event) + } + + func scrollViewDidEndDragging(_ scrollView: UIScrollView, willDecelerate decelerate: Bool) { + let contentOffset = scrollView.contentOffset + let additionalTopHeight = max(0.0, -contentOffset.y) + + if additionalTopHeight >= 30.0 { + self.cancelButtonPressed() + } + } + + func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { + self.containerLayout = (layout, navigationBarHeight) + + var insets = layout.insets(options: [.statusBar, .input]) + let cleanInsets = layout.insets(options: [.statusBar]) + insets.top = max(10.0, insets.top) + + var buttonOffset: CGFloat = 64.0 + + let bottomInset: CGFloat = 10.0 + cleanInsets.bottom + let titleHeight: CGFloat = 54.0 + var contentHeight = titleHeight + bottomInset + 52.0 + 17.0 + let pickerHeight: CGFloat = min(216.0, layout.size.height - contentHeight) + contentHeight = titleHeight + bottomInset + 52.0 + 17.0 + pickerHeight + buttonOffset + + let width = horizontalContainerFillingSizeForLayout(layout: layout, sideInset: layout.safeInsets.left) + + let sideInset = floor((layout.size.width - width) / 2.0) + let contentContainerFrame = CGRect(origin: CGPoint(x: sideInset, y: layout.size.height - contentHeight), size: CGSize(width: width, height: contentHeight)) + let contentFrame = contentContainerFrame + + var backgroundFrame = CGRect(origin: CGPoint(x: contentFrame.minX, y: contentFrame.minY), size: CGSize(width: contentFrame.width, height: contentFrame.height + 2000.0)) + if backgroundFrame.minY < contentFrame.minY { + backgroundFrame.origin.y = contentFrame.minY + } + transition.updateFrame(node: self.backgroundNode, frame: backgroundFrame) + transition.updateFrame(node: self.effectNode, frame: CGRect(origin: CGPoint(), size: backgroundFrame.size)) + transition.updateFrame(node: self.contentBackgroundNode, frame: CGRect(origin: CGPoint(), size: backgroundFrame.size)) + transition.updateFrame(node: self.wrappingScrollNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + transition.updateFrame(node: self.dimNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + + let titleSize = self.titleNode.measure(CGSize(width: width, height: titleHeight)) + let titleFrame = CGRect(origin: CGPoint(x: floor((contentFrame.width - titleSize.width) / 2.0), y: 16.0), size: titleSize) + transition.updateFrame(node: self.titleNode, frame: titleFrame) + + let cancelSize = self.cancelButton.measure(CGSize(width: width, height: titleHeight)) + let cancelFrame = CGRect(origin: CGPoint(x: 16.0, y: 16.0), size: cancelSize) + transition.updateFrame(node: self.cancelButton, frame: cancelFrame) + + let buttonInset: CGFloat = 16.0 + let doneButtonHeight = self.beforeButton.updateLayout(width: contentFrame.width - buttonInset * 2.0, transition: transition) + transition.updateFrame(node: self.beforeButton, frame: CGRect(x: buttonInset, y: contentHeight - doneButtonHeight - insets.bottom - 16.0 - buttonOffset, width: contentFrame.width, height: doneButtonHeight)) + + let onlineButtonHeight = self.afterButton.updateLayout(width: contentFrame.width - buttonInset * 2.0, transition: transition) + transition.updateFrame(node: self.afterButton, frame: CGRect(x: buttonInset, y: contentHeight - onlineButtonHeight - insets.bottom - 16.0, width: contentFrame.width, height: onlineButtonHeight)) + + self.pickerView?.frame = CGRect(origin: CGPoint(x: 0.0, y: 54.0), size: CGSize(width: contentFrame.width, height: pickerHeight)) + + transition.updateFrame(node: self.contentContainerNode, frame: contentContainerFrame) + } +} diff --git a/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift b/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift index d7c12d1c90..5424516ee6 100644 --- a/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListFilterTabContainerNode.swift @@ -625,7 +625,7 @@ final class ChatListFilterTabContainerNode: ASDisplayNode { let previousContentWidth = self.scrollNode.view.contentSize.width if self.currentParams?.presentationData.theme !== presentationData.theme { - self.selectedLineNode.image = generateImage(CGSize(width: 7.0, height: 4.0), rotatedContext: { size, context in + self.selectedLineNode.image = generateImage(CGSize(width: 8.0, height: 4.0), rotatedContext: { size, context in context.clear(CGRect(origin: CGPoint(), size: size)) context.setFillColor(presentationData.theme.list.itemAccentColor.cgColor) context.fillEllipse(in: CGRect(origin: CGPoint(), size: CGSize(width: size.width, height: size.width))) diff --git a/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift b/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift index 7e9b5bf567..cd69f90954 100644 --- a/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift @@ -17,6 +17,27 @@ import ContactListUI import ContextUI import PhoneNumberFormat import ItemListUI +import SearchBarNode +import ListMessageItem +import TelegramBaseController +import OverlayStatusController +import UniversalMediaPlayer +import PresentationDataUtils +import AnimatedStickerNode +import AppBundle + +private final class PassthroughContainerNode: ASDisplayNode { + override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + if let subnodes = self.subnodes { + for subnode in subnodes { + if let result = subnode.view.hitTest(self.view.convert(point, to: subnode.view), with: event) { + return result + } + } + } + return nil + } +} private enum ChatListRecentEntryStableId: Hashable { case topPeers @@ -349,7 +370,7 @@ public enum ChatListSearchEntry: Comparable, Identifiable { } } - public func item(context: AccountContext, presentationData: PresentationData, enableHeaders: Bool, filter: ChatListNodePeersFilter, interaction: ChatListNodeInteraction, peerContextAction: ((Peer, ChatListSearchContextActionSource, ASDisplayNode, ContextGesture?) -> Void)?, toggleExpandLocalResults: @escaping () -> Void, toggleExpandGlobalResults: @escaping () -> Void) -> ListViewItem { + public func item(context: AccountContext, presentationData: PresentationData, enableHeaders: Bool, filter: ChatListNodePeersFilter, interaction: ChatListNodeInteraction, peerContextAction: ((Peer, ChatListSearchContextActionSource, ASDisplayNode, ContextGesture?) -> Void)?, toggleExpandLocalResults: @escaping () -> Void, toggleExpandGlobalResults: @escaping () -> Void, presentDatePicker: @escaping () -> Void, searchPeer: @escaping (Peer) -> Void, searchResults: [Message], searchOptions: ChatListSearchOptions?, messageContextAction: ((Message, ASDisplayNode?, CGRect?, UIGestureRecognizer?) -> Void)?) -> ListViewItem { switch self { case let .localPeer(peer, associatedPeer, unreadBadge, _, theme, strings, nameSortOrder, nameDisplayOrder, expandType): let primaryPeer: Peer @@ -424,6 +445,10 @@ public enum ChatListSearchEntry: Comparable, Identifiable { gesture?.cancel() } } + }, arrowAction: { + if let chatPeer = chatPeer { + searchPeer(chatPeer) + } }) case let .globalPeer(peer, unreadBadge, _, theme, strings, nameSortOrder, nameDisplayOrder, expandType): var enabled = true @@ -485,7 +510,54 @@ public enum ChatListSearchEntry: Comparable, Identifiable { } }) case let .message(message, peer, readState, presentationData): - return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(messages: [message], peer: peer, combinedReadState: readState, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: true, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) + let header: ChatListSearchItemHeader? = enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil + + if let tags = searchOptions?.messageTags, tags != .photoOrVideo { + let interaction = ListMessageItemInteraction(openMessage: { message, mode -> Bool in + if let peer = peer.peer { + return context.sharedContext.openChatMessage(OpenChatMessageParams(context: context, chatLocation: nil, chatLocationContextHolder: nil, message: message, standalone: false, reverseMessageGalleryOrder: false, navigationController: nil, dismissInput: { + + }, present: { c, a in + interaction.present(c) + // self?.controller?.present(c, in: .window(.root), with: a, blockInteraction: true) + }, transitionNode: { messageId, media in + + return nil + // return strongSelf.paneContainerNode.transitionNodeForGallery(messageId: messageId, media: media) + }, addToTransitionSurface: { view in + + // strongSelf.paneContainerNode.currentPane?.node.addToTransitionSurface(view: view) + }, openUrl: { url in + // self?.openUrl(url: url, concealed: false, external: false) + }, openPeer: { peer, navigation in + // self?.openPeer(peerId: peer.id, navigation: navigation) + }, callPeer: { peerId, isVideo in + //self?.controllerInteraction?.callPeer(peerId) + }, enqueueMessage: { _ in + }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in }, chatAvatarHiddenMedia: { _, _ in }, playlistLocation: .searchResults(query: "", peerId: nil, messages: searchResults, at: message.id))) + + // interaction.messageSelected(peer, message, nil) + } + return true + }, openMessageContextMenu: { message, bool, node, rect, gesture in + messageContextAction?(message, node, rect, gesture) + }, toggleMessagesSelection: { messageId, selected in + + }, openUrl: { url, _, _, message in + + }, openInstantPage: { message, data in + + }, longTap: { action, message in + + }, getHiddenMedia: { + return [:] + }) + + + return ListMessageItem(presentationData: ChatPresentationData(theme: ChatPresentationThemeData(theme: presentationData.theme, wallpaper: .builtin(WallpaperSettings())), fontSize: presentationData.fontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations, largeEmoji: false, chatBubbleCorners: PresentationChatBubbleCorners(mainRadius: 0.0, auxiliaryRadius: 0.0, mergeBubbleCorners: false)), context: context, chatLocation: .peer(peer.peerId), interaction: interaction, message: message, selection: .none, displayHeader: false, customHeader: header, isGlobalSearchResult: true) + } else { + return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(messages: [message], peer: peer, combinedReadState: readState, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: true, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: header, enableContextActions: false, hiddenOffset: false, interaction: interaction) + } case let .addContact(phoneNumber, theme, strings): return ContactsAddItem(theme: theme, strings: strings, phoneNumber: phoneNumber, header: ChatListSearchItemHeader(type: .phoneNumber, theme: theme, strings: strings, actionTitle: nil, action: nil), action: { interaction.addContact(phoneNumber) @@ -505,12 +577,16 @@ public struct ChatListSearchContainerTransition { public let insertions: [ListViewInsertItem] public let updates: [ListViewUpdateItem] public let displayingResults: Bool + public let isEmpty: Bool + public let query: String - public init(deletions: [ListViewDeleteItem], insertions: [ListViewInsertItem], updates: [ListViewUpdateItem], displayingResults: Bool) { + public init(deletions: [ListViewDeleteItem], insertions: [ListViewInsertItem], updates: [ListViewUpdateItem], displayingResults: Bool, isEmpty: Bool, query: String) { self.deletions = deletions self.insertions = insertions self.updates = updates self.displayingResults = displayingResults + self.isEmpty = isEmpty + self.query = query } } @@ -524,14 +600,14 @@ private func chatListSearchContainerPreparedRecentTransition(from fromEntries: [ return ChatListSearchContainerRecentTransition(deletions: deletions, insertions: insertions, updates: updates) } -public func chatListSearchContainerPreparedTransition(from fromEntries: [ChatListSearchEntry], to toEntries: [ChatListSearchEntry], displayingResults: Bool, context: AccountContext, presentationData: PresentationData, enableHeaders: Bool, filter: ChatListNodePeersFilter, interaction: ChatListNodeInteraction, peerContextAction: ((Peer, ChatListSearchContextActionSource, ASDisplayNode, ContextGesture?) -> Void)?, toggleExpandLocalResults: @escaping () -> Void, toggleExpandGlobalResults: @escaping () -> Void) -> ChatListSearchContainerTransition { +public func chatListSearchContainerPreparedTransition(from fromEntries: [ChatListSearchEntry], to toEntries: [ChatListSearchEntry], displayingResults: Bool, isEmpty: Bool, searchQuery: String, context: AccountContext, presentationData: PresentationData, enableHeaders: Bool, filter: ChatListNodePeersFilter, interaction: ChatListNodeInteraction, peerContextAction: ((Peer, ChatListSearchContextActionSource, ASDisplayNode, ContextGesture?) -> Void)?, toggleExpandLocalResults: @escaping () -> Void, toggleExpandGlobalResults: @escaping () -> Void, presentDatePicker: @escaping () -> Void, searchPeer: @escaping (Peer) -> Void, searchResults: [Message], searchOptions: ChatListSearchOptions?, messageContextAction: ((Message, ASDisplayNode?, CGRect?, UIGestureRecognizer?) -> Void)?) -> ChatListSearchContainerTransition { let (deleteIndices, indicesAndItems, updateIndices) = mergeListsStableWithUpdates(leftList: fromEntries, rightList: toEntries) let deletions = deleteIndices.map { ListViewDeleteItem(index: $0, directionHint: nil) } - let insertions = indicesAndItems.map { ListViewInsertItem(index: $0.0, previousIndex: $0.2, item: $0.1.item(context: context, presentationData: presentationData, enableHeaders: enableHeaders, filter: filter, interaction: interaction, peerContextAction: peerContextAction, toggleExpandLocalResults: toggleExpandLocalResults, toggleExpandGlobalResults: toggleExpandGlobalResults), directionHint: nil) } - let updates = updateIndices.map { ListViewUpdateItem(index: $0.0, previousIndex: $0.2, item: $0.1.item(context: context, presentationData: presentationData, enableHeaders: enableHeaders, filter: filter, interaction: interaction, peerContextAction: peerContextAction, toggleExpandLocalResults: toggleExpandLocalResults, toggleExpandGlobalResults: toggleExpandGlobalResults), directionHint: nil) } + let insertions = indicesAndItems.map { ListViewInsertItem(index: $0.0, previousIndex: $0.2, item: $0.1.item(context: context, presentationData: presentationData, enableHeaders: enableHeaders, filter: filter, interaction: interaction, peerContextAction: peerContextAction, toggleExpandLocalResults: toggleExpandLocalResults, toggleExpandGlobalResults: toggleExpandGlobalResults, presentDatePicker: presentDatePicker, searchPeer: searchPeer, searchResults: searchResults, searchOptions: searchOptions, messageContextAction: messageContextAction), directionHint: nil) } + let updates = updateIndices.map { ListViewUpdateItem(index: $0.0, previousIndex: $0.2, item: $0.1.item(context: context, presentationData: presentationData, enableHeaders: enableHeaders, filter: filter, interaction: interaction, peerContextAction: peerContextAction, toggleExpandLocalResults: toggleExpandLocalResults, toggleExpandGlobalResults: toggleExpandGlobalResults, presentDatePicker: presentDatePicker, searchPeer: searchPeer, searchResults: searchResults, searchOptions: searchOptions, messageContextAction: messageContextAction), directionHint: nil) } - return ChatListSearchContainerTransition(deletions: deletions, insertions: insertions, updates: updates, displayingResults: displayingResults) + return ChatListSearchContainerTransition(deletions: deletions, insertions: insertions, updates: updates, displayingResults: displayingResults, isEmpty: isEmpty, query: searchQuery) } private struct ChatListSearchContainerNodeState: Equatable { @@ -581,6 +657,7 @@ private struct ChatListSearchMessagesResult { let messages: [Message] let readStates: [PeerId: CombinedPeerReadState] let hasMore: Bool + let totalCount: Int32 let state: SearchMessagesState } @@ -595,21 +672,53 @@ public enum ChatListSearchContextActionSource { case search } +public struct ChatListSearchOptions { + let peerId: PeerId? + let peerName: String? + let minDate: Int32? + let maxDate: Int32? + let messageTags: MessageTags? + + func withUpdatedPeerId(_ peerId: PeerId?, peerName: String?) -> ChatListSearchOptions { + return ChatListSearchOptions(peerId: peerId, peerName: peerName, minDate: self.minDate, maxDate: self.maxDate, messageTags: self.messageTags) + } + + func withUpdatedMinDate(_ minDate: Int32?) -> ChatListSearchOptions { + return ChatListSearchOptions(peerId: self.peerId, peerName: self.peerName, minDate: minDate, maxDate: self.maxDate, messageTags: self.messageTags) + } + + func withUpdatedMaxDate(_ maxDate: Int32?) -> ChatListSearchOptions { + return ChatListSearchOptions(peerId: self.peerId, peerName: self.peerName, minDate: self.minDate, maxDate: maxDate, messageTags: self.messageTags) + } + + func withUpdatedMessageTags(_ messageTags: MessageTags?) -> ChatListSearchOptions { + return ChatListSearchOptions(peerId: self.peerId, peerName: self.peerName, minDate: self.minDate, maxDate: self.maxDate, messageTags: messageTags) + } +} + public final class ChatListSearchContainerNode: SearchDisplayControllerContentNode { private let context: AccountContext + private let filter: ChatListNodePeersFilter private var interaction: ChatListNodeInteraction? + private let openMessage: (Peer, MessageId) -> Void + private let navigationController: NavigationController? + let filterContainerNode: ChatListSearchFiltersContainerNode private let recentListNode: ListView private let listNode: ListView + private let mediaNode: ChatListSearchMediaNode private let dimNode: ASDisplayNode private var enqueuedRecentTransitions: [(ChatListSearchContainerRecentTransition, Bool)] = [] private var enqueuedTransitions: [(ChatListSearchContainerTransition, Bool)] = [] - private var validLayout: ContainerViewLayout? + private var validLayout: (ContainerViewLayout, CGFloat)? private let recentDisposable = MetaDisposable() private let updatedRecentPeersDisposable = MetaDisposable() - private let searchQuery = Promise() + private var searchQueryValue: String? + private let searchQuery = Promise(nil) + private var searchOptionsValue: ChatListSearchOptions? + private let searchOptions = Promise(nil) private let searchDisposable = MetaDisposable() private var presentationData: PresentationData @@ -620,48 +729,127 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo private let statePromise: ValuePromise private var searchStateValue = ChatListSearchContainerNodeSearchState() private let searchStatePromise: ValuePromise + private let searchContextValue = Atomic(value: nil) private let _isSearching = ValuePromise(false, ignoreRepeated: true) override public var isSearching: Signal { return self._isSearching.get() } - private let filter: ChatListNodePeersFilter + private var mediaStatusDisposable: Disposable? + private var playlistPreloadDisposable: Disposable? - public init(context: AccountContext, filter: ChatListNodePeersFilter, groupId: PeerGroupId, openPeer originalOpenPeer: @escaping (Peer, Bool) -> Void, openDisabledPeer: @escaping (Peer) -> Void, openRecentPeerOptions: @escaping (Peer) -> Void, openMessage originalOpenMessage: @escaping (Peer, MessageId) -> Void, addContact: ((String) -> Void)?, peerContextAction: ((Peer, ChatListSearchContextActionSource, ASDisplayNode, ContextGesture?) -> Void)?, present: @escaping (ViewController) -> Void) { + private var playlistStateAndType: (SharedMediaPlaylistItem, SharedMediaPlaylistItem?, SharedMediaPlaylistItem?, MusicPlaybackSettingsOrder, MediaManagerPlayerType, Account)? + private var mediaAccessoryPanelContainer: PassthroughContainerNode + private var mediaAccessoryPanel: (MediaNavigationAccessoryPanel, MediaManagerPlayerType)? + private var dismissingPanel: ASDisplayNode? + + private let updatedSearchOptions: ((ChatListSearchOptions?) -> Void)? + + private let emptyResultsTitleNode: ImmediateTextNode + private let emptyResultsTextNode: ImmediateTextNode + private let emptyResultsAnimationNode: AnimatedStickerNode + private var animationSize: CGSize = CGSize() + + public init(context: AccountContext, filter: ChatListNodePeersFilter, groupId: PeerGroupId, openPeer originalOpenPeer: @escaping (Peer, Bool) -> Void, openDisabledPeer: @escaping (Peer) -> Void, openRecentPeerOptions: @escaping (Peer) -> Void, openMessage originalOpenMessage: @escaping (Peer, MessageId) -> Void, addContact: ((String) -> Void)?, peerContextAction: ((Peer, ChatListSearchContextActionSource, ASDisplayNode, ContextGesture?) -> Void)?, present: @escaping (ViewController, Any?) -> Void, navigationController: NavigationController?, updatedSearchOptions: ((ChatListSearchOptions?) -> Void)? = nil) { self.context = context self.filter = filter self.dimNode = ASDisplayNode() + self.navigationController = navigationController + self.updatedSearchOptions = updatedSearchOptions - let openPeer: (Peer, Bool) -> Void = { peer, value in - originalOpenPeer(peer, value) - - if peer.id.namespace != Namespaces.Peer.SecretChat { - addAppLogEvent(postbox: context.account.postbox, time: Date().timeIntervalSince1970, type: "search_global_open_peer", peerId: peer.id, data: .dictionary([:])) - } - } - - let openMessage: (Peer, MessageId) -> Void = { peer, messageId in - originalOpenMessage(peer, messageId) - - if peer.id.namespace != Namespaces.Peer.SecretChat { - addAppLogEvent(postbox: context.account.postbox, time: Date().timeIntervalSince1970, type: "search_global_open_message", peerId: peer.id, data: .dictionary(["msg_id": .number(Double(messageId.id))])) - } - } - + self.openMessage = originalOpenMessage + self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.presentationDataPromise = Promise(ChatListPresentationData(theme: self.presentationData.theme, fontSize: self.presentationData.listsFontSize, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameSortOrder: self.presentationData.nameSortOrder, nameDisplayOrder: self.presentationData.nameDisplayOrder, disableAnimations: self.presentationData.disableAnimations)) + self.filterContainerNode = ChatListSearchFiltersContainerNode() + self.recentListNode = ListView() self.recentListNode.verticalScrollIndicatorColor = self.presentationData.theme.list.scrollIndicatorColor + + var openMediaMessageImpl: ((Message, ChatControllerInteractionOpenMessageMode) -> Void)? + var transitionNodeImpl: ((MessageId, Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))?)? + var addToTransitionSurfaceImpl: ((UIView) -> Void)? + + self.mediaNode = ChatListSearchMediaNode(context: self.context, contentType: .photoOrVideo, openMessage: { message, mode in + openMediaMessageImpl?(message, mode) + }) + self.listNode = ListView() self.listNode.verticalScrollIndicatorColor = self.presentationData.theme.list.scrollIndicatorColor self.statePromise = ValuePromise(self.stateValue, ignoreRepeated: true) self.searchStatePromise = ValuePromise(self.searchStateValue, ignoreRepeated: true) + self.mediaAccessoryPanelContainer = PassthroughContainerNode() + self.mediaAccessoryPanelContainer.clipsToBounds = true + + self.emptyResultsTitleNode = ImmediateTextNode() + self.emptyResultsTitleNode.attributedText = NSAttributedString(string: self.presentationData.strings.ChatList_Search_NoResults, font: Font.semibold(17.0), textColor: self.presentationData.theme.list.freeTextColor) + self.emptyResultsTitleNode.textAlignment = .center + self.emptyResultsTitleNode.isHidden = true + + self.emptyResultsTextNode = ImmediateTextNode() + self.emptyResultsTextNode.maximumNumberOfLines = 0 + self.emptyResultsTextNode.textAlignment = .center + self.emptyResultsTextNode.isHidden = true + + self.emptyResultsAnimationNode = AnimatedStickerNode() + self.emptyResultsAnimationNode.isHidden = true + super.init() + if let path = getAppBundle().path(forResource: "ChatListNoResults", ofType: "tgs") { + self.emptyResultsAnimationNode.setup(source: AnimatedStickerNodeLocalFileSource(path: path), width: 248, height: 248, playbackMode: .once, mode: .direct(cachePathPrefix: nil)) + self.animationSize = CGSize(width: 124.0, height: 124.0) + } + + openMediaMessageImpl = { [weak self] message, mode in + if let searchContext = self?.searchContextValue.with({ $0 }) { + let _ = context.sharedContext.openChatMessage(OpenChatMessageParams(context: context, chatLocation: nil, chatLocationContextHolder: nil, message: message, standalone: false, reverseMessageGalleryOrder: true, navigationController: nil, dismissInput: { + self?.view.window?.endEditing(true) + }, present: { c, a in + present(c, a) + }, transitionNode: { messageId, media in + return transitionNodeImpl?(messageId, media) + }, addToTransitionSurface: { view in + addToTransitionSurfaceImpl?(view) + }, openUrl: { [weak self] url in + openUserGeneratedUrl(context: context, url: url, concealed: false, present: { [weak self] c in + present(c, nil) + }, openResolved: { [weak self] resolved in + context.sharedContext.openResolvedUrl(resolved, context: context, urlContext: .generic, navigationController: navigationController, openPeer: { peerId, navigation in +// self?.openPeer(peerId: peerId, navigation: navigation) + }, sendFile: nil, + sendSticker: nil, + present: { c, a in + present(c, a) + }, dismissInput: { + self?.view.window?.endEditing(true) + }, contentContext: nil) + }) + }, openPeer: { peer, navigation in + //self?.openPeer(peerId: peer.id, navigation: navigation) + }, callPeer: { _, _ in + }, enqueueMessage: { _ in + }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in }, chatAvatarHiddenMedia: { _, _ in }, gallerySource: .searchResult(SearchMessagesResult(messages: searchContext.result.messages, readStates: searchContext.result.readStates, totalCount: searchContext.result.totalCount, completed: !searchContext.result.hasMore), searchContext.result.state, message.id))) + } + } + + transitionNodeImpl = { [weak self] messageId, media in + if let strongSelf = self { + return strongSelf.mediaNode.transitionNodeForGallery(messageId: messageId, media: media) + } else { + return nil + } + } + + addToTransitionSurfaceImpl = { [weak self] view in + if let strongSelf = self { + strongSelf.mediaNode.addToTransitionSurface(view: view) + } + } self.dimNode.backgroundColor = filter.contains(.excludeRecent) ? UIColor.black.withAlphaComponent(0.5) : self.presentationData.theme.chatList.backgroundColor self.backgroundColor = filter.contains(.excludeRecent) ? nil : self.presentationData.theme.chatList.backgroundColor @@ -669,9 +857,16 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo self.addSubnode(self.dimNode) self.addSubnode(self.recentListNode) self.addSubnode(self.listNode) + self.addSubnode(self.mediaNode) + + self.addSubnode(self.mediaAccessoryPanelContainer) + + self.addSubnode(self.emptyResultsAnimationNode) + self.addSubnode(self.emptyResultsTitleNode) + self.addSubnode(self.emptyResultsTextNode) let searchContext = Promise(nil) - let searchContextValue = Atomic(value: nil) + let searchContextValue = self.searchContextValue let updateSearchContext: ((ChatListSearchMessagesContext?) -> (ChatListSearchMessagesContext?, Bool)) -> Void = { f in var shouldUpdate = false let updated = searchContextValue.modify { current in @@ -689,6 +884,7 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo } self.listNode.isHidden = true + self.mediaNode.isHidden = true self.listNode.visibleBottomContentOffsetChanged = { offset in guard case let .known(value) = offset, value < 100.0 else { return @@ -712,9 +908,9 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo let presentationDataPromise = self.presentationDataPromise let searchStatePromise = self.searchStatePromise - let foundItems = self.searchQuery.get() - |> mapToSignal { query -> Signal<([ChatListSearchEntry], Bool)?, NoError> in - guard let query = query, !query.isEmpty else { + let foundItems = combineLatest(self.searchQuery.get(), self.searchOptions.get()) + |> mapToSignal { query, options -> Signal<([ChatListSearchEntry], Bool)?, NoError> in + if query == nil && options == nil { let _ = currentRemotePeers.swap(nil) return .single(nil) } @@ -722,71 +918,68 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo let accountPeer = context.account.postbox.loadedPeerWithId(context.account.peerId) |> take(1) - let foundLocalPeers = context.account.postbox.searchPeers(query: query.lowercased()) - |> mapToSignal { local -> Signal<([PeerView], [RenderedPeer]), NoError> in - return combineLatest(local.map { context.account.postbox.peerView(id: $0.peerId) }) |> map { views in - return (views, local) + let foundLocalPeers: Signal<(peers: [RenderedPeer], unread: [PeerId: (Int32, Bool)]), NoError> + + if let query = query { + foundLocalPeers = context.account.postbox.searchPeers(query: query.lowercased()) + |> mapToSignal { local -> Signal<([PeerView], [RenderedPeer]), NoError> in + return combineLatest(local.map { context.account.postbox.peerView(id: $0.peerId) }) |> map { views in + return (views, local) + } } - } - |> mapToSignal { viewsAndPeers -> Signal<(peers: [RenderedPeer], unread: [PeerId: (Int32, Bool)]), NoError> in - return context.account.postbox.unreadMessageCountsView(items: viewsAndPeers.0.map {.peer($0.peerId)}) |> map { values in - var unread: [PeerId: (Int32, Bool)] = [:] - for peerView in viewsAndPeers.0 { - var isMuted: Bool = false - if let nofiticationSettings = peerView.notificationSettings as? TelegramPeerNotificationSettings { - switch nofiticationSettings.muteState { - case .muted: - isMuted = true - default: - break + |> mapToSignal { viewsAndPeers -> Signal<(peers: [RenderedPeer], unread: [PeerId: (Int32, Bool)]), NoError> in + return context.account.postbox.unreadMessageCountsView(items: viewsAndPeers.0.map {.peer($0.peerId)}) |> map { values in + var unread: [PeerId: (Int32, Bool)] = [:] + for peerView in viewsAndPeers.0 { + var isMuted: Bool = false + if let nofiticationSettings = peerView.notificationSettings as? TelegramPeerNotificationSettings { + switch nofiticationSettings.muteState { + case .muted: + isMuted = true + default: + break + } + } + + let unreadCount = values.count(for: .peer(peerView.peerId)) + if let unreadCount = unreadCount, unreadCount > 0 { + unread[peerView.peerId] = (unreadCount, isMuted) } } - - let unreadCount = values.count(for: .peer(peerView.peerId)) - if let unreadCount = unreadCount, unreadCount > 0 { - unread[peerView.peerId] = (unreadCount, isMuted) - } + return (peers: viewsAndPeers.1, unread: unread) } - return (peers: viewsAndPeers.1, unread: unread) } + } else { + foundLocalPeers = .single((peers: [], unread: [:])) } let foundRemotePeers: Signal<([FoundPeer], [FoundPeer], Bool), NoError> let currentRemotePeersValue = currentRemotePeers.with { $0 } ?? ([], []) - foundRemotePeers = ( - .single((currentRemotePeersValue.0, currentRemotePeersValue.1, true)) - |> then( - searchPeers(account: context.account, query: query) - |> map { ($0.0, $0.1, false) } - |> delay(0.2, queue: Queue.concurrentDefaultQueue()) + if let query = query { + foundRemotePeers = ( + .single((currentRemotePeersValue.0, currentRemotePeersValue.1, true)) + |> then( + searchPeers(account: context.account, query: query) + |> map { ($0.0, $0.1, false) } + |> delay(0.2, queue: Queue.concurrentDefaultQueue()) + ) ) - ) - let location: SearchMessagesLocation - let messageTags: MessageTags? - if query.hasPrefix("%media ") { - messageTags = .photoOrVideo - } else if query.hasPrefix("%photo ") { - messageTags = .photo - } else if query.hasPrefix("%video ") { - messageTags = .video - } else if query.hasPrefix("%file ") { - messageTags = .file - } else if query.hasPrefix("%music ") { - messageTags = .music - } else if query.hasPrefix("%link ") { - messageTags = .webPage - } else if query.hasPrefix("%gif ") { - messageTags = .gif } else { - messageTags = nil + foundRemotePeers = .single(([], [], false)) } - location = .general(tags: messageTags) - - var finalQuery = query - if let _ = messageTags, let index = finalQuery.firstIndex(of: " ") { - finalQuery = String(finalQuery.suffix(from: finalQuery.index(after: index))) + let location: SearchMessagesLocation + if let options = options { + if let peerId = options.peerId { + location = .peer(peerId: peerId, fromId: nil, tags: options.messageTags, topMsgId: nil, minDate: options.minDate, maxDate: options.maxDate) + } else { + + location = .general(tags: options.messageTags, minDate: options.minDate, maxDate: options.maxDate) + } + } else { + location = .general(tags: nil, minDate: nil, maxDate: nil) } + let finalQuery = query ?? "" updateSearchContext { _ in return (nil, true) } @@ -795,12 +988,12 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo foundRemoteMessages = .single((([], [:], 0), false)) } else { if !finalQuery.isEmpty { - addAppLogEvent(postbox: context.account.postbox, time: Date().timeIntervalSince1970, type: "search_global_query", peerId: nil, data: .dictionary([:])) + addAppLogEvent(postbox: context.account.postbox, type: "search_global_query") } let searchSignal = searchMessages(account: context.account, location: location, query: finalQuery, state: nil, limit: 50) |> map { result, updatedState -> ChatListSearchMessagesResult in - return ChatListSearchMessagesResult(query: finalQuery, messages: result.messages.sorted(by: { $0.index > $1.index }), readStates: result.readStates, hasMore: !result.completed, state: updatedState) + return ChatListSearchMessagesResult(query: finalQuery, messages: result.messages.sorted(by: { $0.index > $1.index }), readStates: result.readStates, hasMore: !result.completed, totalCount: result.totalCount, state: updatedState) } let loadMore = searchContext.get() @@ -809,7 +1002,7 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo if let _ = searchContext.loadMoreIndex { return searchMessages(account: context.account, location: location, query: finalQuery, state: searchContext.result.state, limit: 80) |> map { result, updatedState -> ChatListSearchMessagesResult in - return ChatListSearchMessagesResult(query: finalQuery, messages: result.messages.sorted(by: { $0.index > $1.index }), readStates: result.readStates, hasMore: !result.completed, state: updatedState) + return ChatListSearchMessagesResult(query: finalQuery, messages: result.messages.sorted(by: { $0.index > $1.index }), readStates: result.readStates, hasMore: !result.completed, totalCount: result.totalCount, state: updatedState) } |> mapToSignal { foundMessages -> Signal<(([Message], [PeerId: CombinedPeerReadState], Int32), Bool), NoError> in updateSearchContext { previous in @@ -852,8 +1045,8 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo return combineLatest(accountPeer, foundLocalPeers, foundRemotePeers, foundRemoteMessages, presentationDataPromise.get(), searchStatePromise.get(), resolvedMessage) |> map { accountPeer, foundLocalPeers, foundRemotePeers, foundRemoteMessages, presentationData, searchState, resolvedMessage -> ([ChatListSearchEntry], Bool)? in - var entries: [ChatListSearchEntry] = [] let isSearching = foundRemotePeers.2 || foundRemoteMessages.1 + var entries: [ChatListSearchEntry] = [] var index = 0 let _ = currentRemotePeers.swap((foundRemotePeers.0, foundRemotePeers.1)) @@ -919,7 +1112,16 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo existingPeerIds.removeAll() - let localExpandType: ChatListSearchSectionExpandType = .none + let localExpandType: ChatListSearchSectionExpandType + if let _ = options?.messageTags { + if totalNumberOfLocalPeers > 3 { + localExpandType = searchState.expandLocalSearch ? .collapse : .expand + } else { + localExpandType = .none + } + } else { + localExpandType = .none + } let globalExpandType: ChatListSearchSectionExpandType if totalNumberOfGlobalPeers > 3 { globalExpandType = searchState.expandGlobalSearch ? .collapse : .expand @@ -927,10 +1129,11 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo globalExpandType = .none } - if let _ = messageTags { + if let _ = options?.messageTags, finalQuery.isEmpty { + } else if let _ = options?.peerId { } else { let lowercasedQuery = finalQuery.lowercased() - if presentationData.strings.DialogList_SavedMessages.lowercased().hasPrefix(lowercasedQuery) || "saved messages".hasPrefix(lowercasedQuery) { + if lowercasedQuery.count > 1 && presentationData.strings.DialogList_SavedMessages.lowercased().hasPrefix(lowercasedQuery) || "saved messages".hasPrefix(lowercasedQuery) { if !existingPeerIds.contains(accountPeer.id), filteredPeer(accountPeer, accountPeer) { existingPeerIds.insert(accountPeer.id) entries.append(.localPeer(accountPeer, nil, nil, index, presentationData.theme, presentationData.strings, presentationData.nameSortOrder, presentationData.nameDisplayOrder, localExpandType)) @@ -940,7 +1143,7 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo var numberOfLocalPeers = 0 for renderedPeer in foundLocalPeers.peers { - if case .expand = localExpandType, numberOfLocalPeers >= 5 { + if case .expand = localExpandType, numberOfLocalPeers >= 3 { break } @@ -959,7 +1162,7 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo } for peer in foundRemotePeers.0 { - if case .expand = localExpandType, numberOfLocalPeers >= 5 { + if case .expand = localExpandType, numberOfLocalPeers >= 3 { break } @@ -973,16 +1176,19 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo var numberOfGlobalPeers = 0 index = 0 - for peer in foundRemotePeers.1 { - if case .expand = globalExpandType, numberOfGlobalPeers >= 3 { - break - } - - if !existingPeerIds.contains(peer.peer.id), filteredPeer(peer.peer, accountPeer) { - existingPeerIds.insert(peer.peer.id) - entries.append(.globalPeer(peer, nil, index, presentationData.theme, presentationData.strings, presentationData.nameSortOrder, presentationData.nameDisplayOrder, globalExpandType)) - index += 1 - numberOfGlobalPeers += 1 + if let _ = options?.messageTags { + } else { + for peer in foundRemotePeers.1 { + if case .expand = globalExpandType, numberOfGlobalPeers >= 3 { + break + } + + if !existingPeerIds.contains(peer.peer.id), filteredPeer(peer.peer, accountPeer) { + existingPeerIds.insert(peer.peer.id) + entries.append(.globalPeer(peer, nil, index, presentationData.theme, presentationData.strings, presentationData.nameSortOrder, presentationData.nameDisplayOrder, globalExpandType)) + index += 1 + numberOfGlobalPeers += 1 + } } } } @@ -1022,6 +1228,25 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo let previousSearchItems = Atomic<[ChatListSearchEntry]?>(value: nil) + let openPeer: (Peer, Bool) -> Void = { [weak self] peer, value in + guard let strongSelf = self else { + return + } + originalOpenPeer(peer, value) + + if peer.id.namespace != Namespaces.Peer.SecretChat { + addAppLogEvent(postbox: context.account.postbox, type: "search_global_open_peer", peerId: peer.id) + } + } + + let openMessage: (Peer, MessageId) -> Void = { peer, messageId in + originalOpenMessage(peer, messageId) + + if peer.id.namespace != Namespaces.Peer.SecretChat { + addAppLogEvent(postbox: context.account.postbox, type: "search_global_open_message", peerId: peer.id, data: .dictionary(["msg_id": .number(Double(messageId.id))])) + } + } + let interaction = ChatListNodeInteraction(activateSearch: { }, peerSelected: { [weak self] peer, _ in self?.view.endEditing(true) @@ -1073,7 +1298,7 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo gesture?.cancel() } }, present: { c in - present(c) + present(c, nil) }) self.interaction = interaction @@ -1181,12 +1406,16 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo self.searchDisposable.set((foundItems |> deliverOnMainQueue).start(next: { [weak self] entriesAndFlags in if let strongSelf = self { - strongSelf._isSearching.set(entriesAndFlags?.1 ?? false) + let isSearching = entriesAndFlags?.1 ?? false + strongSelf._isSearching.set(isSearching) + + strongSelf.mediaNode.updateHistory(entries: entriesAndFlags?.0 ?? [], updateType: .Initial) let previousEntries = previousSearchItems.swap(entriesAndFlags?.0) + let newEntries = entriesAndFlags?.0 ?? [] let firstTime = previousEntries == nil - let transition = chatListSearchContainerPreparedTransition(from: previousEntries ?? [], to: entriesAndFlags?.0 ?? [], displayingResults: entriesAndFlags?.0 != nil, context: context, presentationData: strongSelf.presentationData, enableHeaders: true, filter: filter, interaction: interaction, peerContextAction: peerContextAction, + let transition = chatListSearchContainerPreparedTransition(from: previousEntries ?? [], to: newEntries, displayingResults: entriesAndFlags?.0 != nil, isEmpty: !isSearching && (entriesAndFlags?.0.isEmpty ?? false), searchQuery: strongSelf.searchQueryValue ?? "", context: context, presentationData: strongSelf.presentationData, enableHeaders: true, filter: filter, interaction: interaction, peerContextAction: peerContextAction, toggleExpandLocalResults: { guard let strongSelf = self else { return @@ -1205,6 +1434,39 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo state.expandGlobalSearch = !state.expandGlobalSearch return state } + }, presentDatePicker: { + guard let strongSelf = self else { + return + } + let controller = ChatListDatePickerScreen(context: strongSelf.context, dismissByTapOutside: true, completion: { [weak self] date, after in + guard let strongSelf = self else { + return + } + if let date = date { + strongSelf.updateSearchOptions(strongSelf.currentSearchOptions.withUpdatedMinDate(after ? date : nil).withUpdatedMaxDate(after ? nil : date)) + } else { + strongSelf.updateSearchOptions(strongSelf.currentSearchOptions.withUpdatedMinDate(nil).withUpdatedMaxDate(nil)) + } + }) + strongSelf.dismissInput?() + strongSelf.interaction?.present(controller) + }, searchPeer: { peer in + guard let strongSelf = self else { + return + } + strongSelf.updateSearchOptions(strongSelf.currentSearchOptions.withUpdatedPeerId(peer.id, peerName: peer.compactDisplayTitle), clearQuery: true) + strongSelf.dismissInput?() + }, searchResults: newEntries.compactMap { entry -> Message? in + if case let .message(message, _, _, _) = entry { + return message + } else { + return nil + } + }, searchOptions: strongSelf.searchOptionsValue, messageContextAction: { message, node, rect, gesture in + guard let strongSelf = self else { + return + } + strongSelf.messageContextAction(message, node: node, rect: rect, gesture: gesture) }) strongSelf.enqueueTransition(transition, firstTime: firstTime) } @@ -1230,6 +1492,66 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo self.listNode.beganInteractiveDragging = { [weak self] in self?.dismissInput?() } + + self.filterContainerNode.filterPressed = { [weak self] filter in + guard let strongSelf = self else { + return + } + let messageTags: MessageTags + switch filter { + case .media: + messageTags = .photoOrVideo + case .links: + messageTags = .webPage + case .files: + messageTags = .file + case .music: + messageTags = .music + } + strongSelf.updateSearchOptions(strongSelf.currentSearchOptions.withUpdatedMessageTags(messageTags)) + } + + self.mediaStatusDisposable = (combineLatest(context.sharedContext.mediaManager.globalMediaPlayerState, self.searchOptions.get()) + |> mapToSignal { playlistStateAndType, searchOptions -> Signal<(Account, SharedMediaPlayerItemPlaybackState, MediaManagerPlayerType)?, NoError> in + if let (account, state, type) = playlistStateAndType { + switch state { + case let .state(state): + if let playlistId = state.playlistId as? PeerMessagesMediaPlaylistId, case .searchResults = playlistId { + if case .music = type, searchOptions?.messageTags == .music { + return .single((account, state, type)) + } else { + return .single(nil) |> delay(0.1, queue: .mainQueue()) + } + } else { + return .single(nil) |> delay(0.1, queue: .mainQueue()) + } + case .loading: + return .single(nil) |> delay(0.1, queue: .mainQueue()) + } + } else { + return .single(nil) + } + } + |> deliverOnMainQueue).start(next: { [weak self] playlistStateAndType in + guard let strongSelf = self else { + return + } + if !arePlaylistItemsEqual(strongSelf.playlistStateAndType?.0, playlistStateAndType?.1.item) || + !arePlaylistItemsEqual(strongSelf.playlistStateAndType?.1, playlistStateAndType?.1.previousItem) || + !arePlaylistItemsEqual(strongSelf.playlistStateAndType?.2, playlistStateAndType?.1.nextItem) || + strongSelf.playlistStateAndType?.3 != playlistStateAndType?.1.order || strongSelf.playlistStateAndType?.4 != playlistStateAndType?.2 { + + if let playlistStateAndType = playlistStateAndType { + strongSelf.playlistStateAndType = (playlistStateAndType.1.item, playlistStateAndType.1.previousItem, playlistStateAndType.1.nextItem, playlistStateAndType.1.order, playlistStateAndType.2, playlistStateAndType.0) + } else { + strongSelf.playlistStateAndType = nil + } + + if let (layout, navigationBarHeight) = strongSelf.validLayout { + strongSelf.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: .animated(duration: 0.4, curve: .spring)) + } + } + }) } deinit { @@ -1237,6 +1559,8 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo self.recentDisposable.dispose() self.searchDisposable.dispose() self.presentationDataDisposable?.dispose() + self.mediaStatusDisposable?.dispose() + self.playlistPreloadDisposable?.dispose() } override public func didLoad() { @@ -1250,6 +1574,65 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo } } + private var currentSearchOptions: ChatListSearchOptions { + return self.searchOptionsValue ?? ChatListSearchOptions(peerId: nil, peerName: nil, minDate: nil, maxDate: nil, messageTags: nil) + } + + public override func searchTokensUpdated(tokens: [SearchBarToken]) { + var updatedOptions = self.searchOptionsValue + if updatedOptions?.peerId != nil { + updatedOptions = updatedOptions?.withUpdatedPeerId(nil, peerName: nil) + } + self.updateSearchOptions(updatedOptions) + } + + private func updateSearchOptions(_ options: ChatListSearchOptions?, clearQuery: Bool = false) { + self.searchOptionsValue = options + self.searchOptions.set(.single(options)) + + var tokens: [SearchBarToken] = [] + if let messageTags = options?.messageTags { + var title: String? + var icon: UIImage? + if messageTags == .photoOrVideo { + title = self.presentationData.strings.ChatList_Search_FilterMedia + icon = UIImage(bundleImageName: "Chat List/Search/Media") + } else if messageTags == .webPage { + title = self.presentationData.strings.ChatList_Search_FilterLinks + icon = UIImage(bundleImageName: "Chat List/Search/Links") + } else if messageTags == .file { + title = self.presentationData.strings.ChatList_Search_FilterFiles + icon = UIImage(bundleImageName: "Chat List/Search/Files") + } else if messageTags == .music { + title = self.presentationData.strings.ChatList_Search_FilterMusic + icon = UIImage(bundleImageName: "Chat List/Search/Music") + } + + if let title = title { + tokens.append(SearchBarToken(id: messageTags.rawValue, icon: icon, title: title)) + } + } + + if let peerId = options?.peerId, let peerName = options?.peerName { + tokens.append(SearchBarToken(id: peerId, icon: UIImage(bundleImageName: "Chat List/Search/User"), title: peerName)) + } + + if clearQuery { + self.setQuery?(nil, tokens, "") + } else { + self.setQuery?(nil, tokens, self.searchQueryValue ?? "") + } + + if options?.peerId == nil { + self.updateSearchState { state in + var state = state + state.expandLocalSearch = false + return state + } + } + + self.updatedSearchOptions?(options) + } private func updateTheme(theme: PresentationTheme) { self.backgroundColor = self.filter.contains(.excludeRecent) ? nil : theme.chatList.backgroundColor @@ -1289,6 +1672,15 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo let searchQuery: String? = !text.isEmpty ? text : nil self.interaction?.searchTextHighightState = searchQuery self.searchQuery.set(.single(searchQuery)) + self.searchQueryValue = searchQuery + + if text.isEmpty { + self.updateSearchState { state in + var state = state + state.expandLocalSearch = false + return state + } + } } private func enqueueRecentTransition(_ transition: ChatListSearchContainerRecentTransition, firstTime: Bool) { @@ -1338,11 +1730,28 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo let displayingResults = transition.displayingResults self.listNode.transaction(deleteIndices: transition.deletions, insertIndicesAndItems: transition.insertions, updateIndicesAndItems: transition.updates, options: options, updateSizeAndInsets: nil, updateOpaqueState: nil, completion: { [weak self] _ in if let strongSelf = self { - strongSelf.listNode.isHidden = !displayingResults + strongSelf.listNode.isHidden = strongSelf.searchOptionsValue?.messageTags == .photoOrVideo && (strongSelf.searchQueryValue ?? "").isEmpty + strongSelf.mediaNode.isHidden = !strongSelf.listNode.isHidden + if !displayingResults { + strongSelf.listNode.isHidden = true + strongSelf.mediaNode.isHidden = true + } + + strongSelf.emptyResultsTextNode.attributedText = NSAttributedString(string: strongSelf.presentationData.strings.ChatList_Search_NoResultsDescription(transition.query).0, font: Font.regular(15.0), textColor: strongSelf.presentationData.theme.list.freeTextColor) + + let emptyResults = displayingResults && transition.isEmpty + strongSelf.emptyResultsAnimationNode.isHidden = !emptyResults + strongSelf.emptyResultsTitleNode.isHidden = !emptyResults + strongSelf.emptyResultsTextNode.isHidden = !emptyResults + strongSelf.emptyResultsAnimationNode.visibility = emptyResults + strongSelf.recentListNode.isHidden = displayingResults || strongSelf.filter.contains(.excludeRecent) strongSelf.dimNode.isHidden = displayingResults strongSelf.backgroundColor = !displayingResults && strongSelf.filter.contains(.excludeRecent) ? nil : strongSelf.presentationData.theme.chatList.backgroundColor - + + if let (layout, navigationBarHeight) = strongSelf.validLayout { + strongSelf.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: .immediate) + } } }) } @@ -1352,18 +1761,240 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo super.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: transition) let hadValidLayout = self.validLayout != nil - self.validLayout = layout + self.validLayout = (layout, navigationBarHeight) + + var topInset = navigationBarHeight + + var topPanelHeight: CGFloat = 0.0 + if let (item, previousItem, nextItem, order, type, _) = self.playlistStateAndType { + let panelHeight = MediaNavigationAccessoryHeaderNode.minimizedHeight + topPanelHeight = panelHeight + let panelFrame = CGRect(origin: CGPoint(x: 0.0, y: topPanelHeight - panelHeight), size: CGSize(width: layout.size.width, height: panelHeight)) + if let (mediaAccessoryPanel, mediaType) = self.mediaAccessoryPanel, mediaType == type { + transition.updateFrame(layer: mediaAccessoryPanel.layer, frame: panelFrame) + mediaAccessoryPanel.updateLayout(size: panelFrame.size, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right, transition: transition) + switch order { + case .regular: + mediaAccessoryPanel.containerNode.headerNode.playbackItems = (item, previousItem, nextItem) + case .reversed: + mediaAccessoryPanel.containerNode.headerNode.playbackItems = (item, nextItem, previousItem) + case .random: + mediaAccessoryPanel.containerNode.headerNode.playbackItems = (item, nil, nil) + } + let delayedStatus = self.context.sharedContext.mediaManager.globalMediaPlayerState + |> mapToSignal { value -> Signal<(Account, SharedMediaPlayerItemPlaybackStateOrLoading, MediaManagerPlayerType)?, NoError> in + guard let value = value else { + return .single(nil) + } + switch value.1 { + case .state: + return .single(value) + case .loading: + return .single(value) |> delay(0.1, queue: .mainQueue()) + } + } + + mediaAccessoryPanel.containerNode.headerNode.playbackStatus = delayedStatus + |> map { state -> MediaPlayerStatus in + if let stateOrLoading = state?.1, case let .state(state) = stateOrLoading { + return state.status + } else { + return MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .paused, soundEnabled: true) + } + } + } else { + if let (mediaAccessoryPanel, _) = self.mediaAccessoryPanel { + self.mediaAccessoryPanel = nil + self.dismissingPanel = mediaAccessoryPanel + mediaAccessoryPanel.animateOut(transition: transition, completion: { [weak self, weak mediaAccessoryPanel] in + mediaAccessoryPanel?.removeFromSupernode() + if let strongSelf = self, strongSelf.dismissingPanel === mediaAccessoryPanel { + strongSelf.dismissingPanel = nil + } + }) + } + + let mediaAccessoryPanel = MediaNavigationAccessoryPanel(context: self.context) + mediaAccessoryPanel.containerNode.headerNode.displayScrubber = item.playbackData?.type != .instantVideo + mediaAccessoryPanel.close = { [weak self] in + if let strongSelf = self, let (_, _, _, _, type, _) = strongSelf.playlistStateAndType { + strongSelf.context.sharedContext.mediaManager.setPlaylist(nil, type: type, control: SharedMediaPlayerControlAction.playback(.pause)) + } + } + mediaAccessoryPanel.toggleRate = { + [weak self] in + guard let strongSelf = self else { + return + } + let _ = (strongSelf.context.sharedContext.accountManager.transaction { transaction -> AudioPlaybackRate in + let settings = transaction.getSharedData(ApplicationSpecificSharedDataKeys.musicPlaybackSettings) as? MusicPlaybackSettings ?? MusicPlaybackSettings.defaultSettings + + let nextRate: AudioPlaybackRate + switch settings.voicePlaybackRate { + case .x1: + nextRate = .x2 + case .x2: + nextRate = .x1 + } + transaction.updateSharedData(ApplicationSpecificSharedDataKeys.musicPlaybackSettings, { _ in + return settings.withUpdatedVoicePlaybackRate(nextRate) + }) + return nextRate + } + |> deliverOnMainQueue).start(next: { baseRate in + guard let strongSelf = self, let (_, _, _, _, type, _) = strongSelf.playlistStateAndType else { + return + } + strongSelf.context.sharedContext.mediaManager.playlistControl(.setBaseRate(baseRate), type: type) + }) + } + mediaAccessoryPanel.togglePlayPause = { [weak self] in + if let strongSelf = self, let (_, _, _, _, type, _) = strongSelf.playlistStateAndType { + strongSelf.context.sharedContext.mediaManager.playlistControl(.playback(.togglePlayPause), type: type) + } + } + mediaAccessoryPanel.playPrevious = { [weak self] in + if let strongSelf = self, let (_, _, _, _, type, _) = strongSelf.playlistStateAndType { + strongSelf.context.sharedContext.mediaManager.playlistControl(.next, type: type) + } + } + mediaAccessoryPanel.playNext = { [weak self] in + if let strongSelf = self, let (_, _, _, _, type, _) = strongSelf.playlistStateAndType { + strongSelf.context.sharedContext.mediaManager.playlistControl(.previous, type: type) + } + } + mediaAccessoryPanel.tapAction = { [weak self] in + guard let strongSelf = self, let (state, _, _, order, type, account) = strongSelf.playlistStateAndType else { + return + } + if let id = state.id as? PeerMessagesMediaPlaylistItemId { + if type == .music { + let signal = strongSelf.context.sharedContext.messageFromPreloadedChatHistoryViewForLocation(id: id.messageId, location: ChatHistoryLocationInput(content: .InitialSearch(location: .id(id.messageId), count: 60), id: 0), context: strongSelf.context, chatLocation: .peer(id.messageId.peerId), chatLocationContextHolder: Atomic(value: nil), tagMask: MessageTags.music) + + var cancelImpl: (() -> Void)? + let presentationData = strongSelf.context.sharedContext.currentPresentationData.with { $0 } + let progressSignal = Signal { subscriber in + let controller = OverlayStatusController(theme: presentationData.theme, type: .loading(cancelled: { + cancelImpl?() + })) + self?.interaction?.present(controller) + return ActionDisposable { [weak controller] in + Queue.mainQueue().async() { + controller?.dismiss() + } + } + } + |> runOn(Queue.mainQueue()) + |> delay(0.15, queue: Queue.mainQueue()) + let progressDisposable = MetaDisposable() + var progressStarted = false + strongSelf.playlistPreloadDisposable?.dispose() + strongSelf.playlistPreloadDisposable = (signal + |> afterDisposed { + Queue.mainQueue().async { + progressDisposable.dispose() + } + } + |> deliverOnMainQueue).start(next: { index in + guard let strongSelf = self else { + return + } + if let _ = index.0 { + let controllerContext: AccountContext + if account.id == strongSelf.context.account.id { + controllerContext = strongSelf.context + } else { + controllerContext = strongSelf.context.sharedContext.makeTempAccountContext(account: account) + } + let controller = strongSelf.context.sharedContext.makeOverlayAudioPlayerController(context: controllerContext, peerId: id.messageId.peerId, type: type, initialMessageId: id.messageId, initialOrder: order, isGlobalSearch: true, parentNavigationController: strongSelf.navigationController) + strongSelf.view.window?.endEditing(true) + strongSelf.interaction?.present(controller) + } else if index.1 { + if !progressStarted { + progressStarted = true + progressDisposable.set(progressSignal.start()) + } + } + }, completed: { + }) + cancelImpl = { + self?.playlistPreloadDisposable?.dispose() + } + } else { + strongSelf.context.sharedContext.navigateToChat(accountId: strongSelf.context.account.id, peerId: id.messageId.peerId, messageId: id.messageId) + } + } + } + mediaAccessoryPanel.frame = panelFrame + if let dismissingPanel = self.dismissingPanel { + self.mediaAccessoryPanelContainer.insertSubnode(mediaAccessoryPanel, aboveSubnode: dismissingPanel) + } else { + self.mediaAccessoryPanelContainer.addSubnode(mediaAccessoryPanel) + } + self.mediaAccessoryPanel = (mediaAccessoryPanel, type) + mediaAccessoryPanel.updateLayout(size: panelFrame.size, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right, transition: .immediate) + switch order { + case .regular: + mediaAccessoryPanel.containerNode.headerNode.playbackItems = (item, previousItem, nextItem) + case .reversed: + mediaAccessoryPanel.containerNode.headerNode.playbackItems = (item, nextItem, previousItem) + case .random: + mediaAccessoryPanel.containerNode.headerNode.playbackItems = (item, nil, nil) + } + mediaAccessoryPanel.containerNode.headerNode.playbackStatus = self.context.sharedContext.mediaManager.globalMediaPlayerState + |> map { state -> MediaPlayerStatus in + if let stateOrLoading = state?.1, case let .state(state) = stateOrLoading { + return state.status + } else { + return MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .paused, soundEnabled: true) + } + } + mediaAccessoryPanel.animateIn(transition: transition) + } + } else if let (mediaAccessoryPanel, _) = self.mediaAccessoryPanel { + self.mediaAccessoryPanel = nil + self.dismissingPanel = mediaAccessoryPanel + mediaAccessoryPanel.animateOut(transition: transition, completion: { [weak self, weak mediaAccessoryPanel] in + mediaAccessoryPanel?.removeFromSupernode() + if let strongSelf = self, strongSelf.dismissingPanel === mediaAccessoryPanel { + strongSelf.dismissingPanel = nil + } + }) + } + + transition.updateFrame(node: self.mediaAccessoryPanelContainer, frame: CGRect(origin: CGPoint(x: 0.0, y: topInset), size: CGSize(width: layout.size.width, height: MediaNavigationAccessoryHeaderNode.minimizedHeight))) + topInset += topPanelHeight - let topInset = navigationBarHeight transition.updateFrame(node: self.dimNode, frame: CGRect(origin: CGPoint(x: 0.0, y: topInset), size: CGSize(width: layout.size.width, height: layout.size.height - topInset))) + transition.updateFrame(node: self.filterContainerNode, frame: CGRect(origin: CGPoint(x: 0.0, y: navigationBarHeight + 6.0), size: CGSize(width: layout.size.width, height: 37.0))) + self.filterContainerNode.update(size: CGSize(width: layout.size.width, height: 37.0), sideInset: layout.safeInsets.left, filters: ChatListSearchFilter.allCases.map { .filter($0) }, presentationData: self.presentationData, transition: .animated(duration: 0.4, curve: .spring)) + let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) self.recentListNode.frame = CGRect(origin: CGPoint(), size: layout.size) - self.recentListNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous], scrollToItem: nil, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: layout.size, insets: UIEdgeInsets(top: navigationBarHeight, left: layout.safeInsets.left, bottom: layout.insets(options: [.input]).bottom, right: layout.safeInsets.right), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + self.recentListNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous], scrollToItem: nil, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: layout.size, insets: UIEdgeInsets(top: topInset, left: layout.safeInsets.left, bottom: layout.insets(options: [.input]).bottom, right: layout.safeInsets.right), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) self.listNode.frame = CGRect(origin: CGPoint(), size: layout.size) - self.listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous], scrollToItem: nil, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: layout.size, insets: UIEdgeInsets(top: navigationBarHeight, left: layout.safeInsets.left, bottom: layout.insets(options: [.input]).bottom, right: layout.safeInsets.right), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + self.listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous], scrollToItem: nil, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: layout.size, insets: UIEdgeInsets(top: topInset, left: layout.safeInsets.left, bottom: layout.insets(options: [.input]).bottom, right: layout.safeInsets.right), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + + self.mediaNode.frame = CGRect(origin: CGPoint(x: 0.0, y: topInset), size: CGSize(width: layout.size.width, height: layout.size.height - topInset)) + self.mediaNode.update(size: layout.size, sideInset: 0, bottomInset: 0, visibleHeight: layout.size.height - navigationBarHeight, isScrollingLockedAtTop: false, expandProgress: 1.0, presentationData: self.presentationData, synchronous: true, transition: transition) + + let padding: CGFloat = 16.0 + let emptyTitleSize = self.emptyResultsTitleNode.updateLayout(CGSize(width: layout.size.width - layout.safeInsets.left - layout.safeInsets.right - padding * 2.0, height: CGFloat.greatestFiniteMagnitude)) + let emptyTextSize = self.emptyResultsTextNode.updateLayout(CGSize(width: layout.size.width - layout.safeInsets.left - layout.safeInsets.right - padding * 2.0, height: CGFloat.greatestFiniteMagnitude)) + + let insets = layout.insets(options: [.input]) + let emptyAnimationSpacing: CGFloat = 8.0 + let emptyTextSpacing: CGFloat = 8.0 + let emptyTotalHeight = self.animationSize.height + emptyAnimationSpacing + emptyTitleSize.height + emptyTextSize.height + emptyTextSpacing + let emptyAnimationY = navigationBarHeight + floorToScreenPixels((layout.size.height - navigationBarHeight - max(insets.bottom, layout.intrinsicInsets.bottom) - emptyTotalHeight) / 2.0) + + transition.updateFrame(node: self.emptyResultsAnimationNode, frame: CGRect(origin: CGPoint(x: layout.safeInsets.left + padding + (layout.size.width - layout.safeInsets.left - layout.safeInsets.right - padding * 2.0 - self.animationSize.width) / 2.0, y: emptyAnimationY), size: self.animationSize)) + transition.updateFrame(node: self.emptyResultsTitleNode, frame: CGRect(origin: CGPoint(x: layout.safeInsets.left + padding + (layout.size.width - layout.safeInsets.left - layout.safeInsets.right - padding * 2.0 - emptyTitleSize.width) / 2.0, y: emptyAnimationY + self.animationSize.height + emptyAnimationSpacing), size: emptyTitleSize)) + transition.updateFrame(node: self.emptyResultsTextNode, frame: CGRect(origin: CGPoint(x: layout.safeInsets.left + padding + (layout.size.width - layout.safeInsets.left - layout.safeInsets.right - padding * 2.0 - emptyTextSize.width) / 2.0, y: emptyAnimationY + self.animationSize.height + emptyAnimationSpacing + emptyTitleSize.height + emptyTextSpacing), size: emptyTextSize)) + self.emptyResultsAnimationNode.updateLayout(size: self.animationSize) if !hadValidLayout { while !self.enqueuedRecentTransitions.isEmpty { @@ -1449,4 +2080,76 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo self.recentListNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous, .LowLatency], scrollToItem: ListViewScrollToItem(index: 0, position: .top(0.0), animated: true, curve: .Default(duration: nil), directionHint: .Up), updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) } } + + func messageContextAction(_ message: Message, node: ASDisplayNode?, rect: CGRect?, gesture anyRecognizer: UIGestureRecognizer?) { + guard let node = node as? ContextExtractedContentContainingNode else { + return + } + let _ = storedMessageFromSearch(account: self.context.account, message: message).start() + + var linkForCopying: String? + var currentSupernode: ASDisplayNode? = node + while true { + if currentSupernode == nil { + break + } else if let currentSupernode = currentSupernode as? ListMessageSnippetItemNode { + linkForCopying = currentSupernode.currentPrimaryUrl + break + } else { + currentSupernode = currentSupernode?.supernode + } + } + + let gesture: ContextGesture? = anyRecognizer as? ContextGesture + var items: [ContextMenuItem] = [] + + if let linkForCopying = linkForCopying { + items.append(.action(ContextMenuActionItem(text: self.presentationData.strings.Conversation_ContextMenuCopyLink, icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Copy"), color: theme.contextMenu.primaryColor) }, action: { c, _ in + c.dismiss(completion: {}) + UIPasteboard.general.string = linkForCopying + }))) + } + + items.append(.action(ContextMenuActionItem(text: self.presentationData.strings.Conversation_ContextMenuForward, icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Forward"), color: theme.contextMenu.primaryColor) }, action: { [weak self] c, _ in + c.dismiss(completion: { [weak self] in + if let strongSelf = self { +// strongSelf.forwardMessages(messageIds: Set([message.id])) + } + }) + }))) + items.append(.action(ContextMenuActionItem(text: self.presentationData.strings.SharedMedia_ViewInChat, icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/GoToMessage"), color: theme.contextMenu.primaryColor) }, action: { [weak self] c, _ in + c.dismiss(completion: { [weak self] in + self?.openMessage(message.peers[message.id.peerId]!, message.id) + }) + }))) + + let controller = ContextController(account: self.context.account, presentationData: self.presentationData, source: .extracted(MessageContextExtractedContentSource(sourceNode: node)), items: .single(items), reactionItems: [], recognizer: nil, gesture: gesture) + self.interaction?.present(controller) +// self.controller?.window?.presentInGlobalOverlay(controller) + + } + + public override func searchTextClearTokens() { + self.updateSearchOptions(nil) + self.setQuery?(nil, [], self.searchQueryValue ?? "") + } +} + +private final class MessageContextExtractedContentSource: ContextExtractedContentSource { + let keepInPlace: Bool = false + let ignoreContentTouches: Bool = true + + private let sourceNode: ContextExtractedContentContainingNode + + init(sourceNode: ContextExtractedContentContainingNode) { + self.sourceNode = sourceNode + } + + func takeView() -> ContextControllerTakeViewInfo? { + return ContextControllerTakeViewInfo(contentContainingNode: self.sourceNode, contentAreaInScreenSpace: UIScreen.main.bounds) + } + + func putBack() -> ContextControllerPutBackViewInfo? { + return ContextControllerPutBackViewInfo(contentAreaInScreenSpace: UIScreen.main.bounds) + } } diff --git a/submodules/ChatListUI/Sources/ChatListSearchFiltersContainerNode.swift b/submodules/ChatListUI/Sources/ChatListSearchFiltersContainerNode.swift new file mode 100644 index 0000000000..1197494181 --- /dev/null +++ b/submodules/ChatListUI/Sources/ChatListSearchFiltersContainerNode.swift @@ -0,0 +1,281 @@ +import Foundation +import UIKit +import AsyncDisplayKit +import Display +import SyncCore +import Postbox +import TelegramCore +import TelegramPresentationData + +enum ChatListSearchFilter: Int32, Hashable, CaseIterable { + case media + case links + case files + case music +} + +private final class ItemNode: ASDisplayNode { + private let pressed: () -> Void + + private let iconNode: ASImageNode + private let titleNode: ImmediateTextNode + private let buttonNode: HighlightTrackingButtonNode + + private var selectionFraction: CGFloat = 0.0 + private(set) var unreadCount: Int = 0 + + private var isReordering: Bool = false + + private var theme: PresentationTheme? + + init(pressed: @escaping () -> Void) { + self.pressed = pressed + + let titleInset: CGFloat = 4.0 + + self.iconNode = ASImageNode() + self.iconNode.displaysAsynchronously = false + self.iconNode.displayWithoutProcessing = true + + self.titleNode = ImmediateTextNode() + self.titleNode.displaysAsynchronously = false + self.titleNode.insets = UIEdgeInsets(top: titleInset, left: 0.0, bottom: titleInset, right: 0.0) + + self.buttonNode = HighlightTrackingButtonNode() + + super.init() + + self.addSubnode(self.titleNode) + self.addSubnode(self.iconNode) + self.addSubnode(self.buttonNode) + + self.buttonNode.addTarget(self, action: #selector(self.buttonPressed), forControlEvents: .touchUpInside) + self.buttonNode.highligthedChanged = { [weak self] highlighted in + if let strongSelf = self { + if highlighted { + strongSelf.iconNode.layer.removeAnimation(forKey: "opacity") + strongSelf.iconNode.alpha = 0.4 + + strongSelf.titleNode.layer.removeAnimation(forKey: "opacity") + strongSelf.titleNode.alpha = 0.4 + } else { + strongSelf.iconNode.alpha = 1.0 + strongSelf.iconNode.layer.animateAlpha(from: 0.4, to: 1.0, duration: 0.2) + + strongSelf.titleNode.alpha = 1.0 + strongSelf.titleNode.layer.animateAlpha(from: 0.4, to: 1.0, duration: 0.2) + } + } + } + } + + @objc private func buttonPressed() { + self.pressed() + } + + func update(type: ChatListSearchFilter, presentationData: PresentationData, transition: ContainedViewLayoutTransition) { + let title: String + let icon: UIImage? + + let color = presentationData.theme.list.itemSecondaryTextColor + switch type { + case .media: + title = presentationData.strings.ChatList_Search_FilterMedia + icon = generateTintedImage(image: UIImage(bundleImageName: "Chat List/Search/Media"), color: color) + case .links: + title = presentationData.strings.ChatList_Search_FilterLinks + icon = generateTintedImage(image: UIImage(bundleImageName: "Chat List/Search/Links"), color: color) + case .files: + title = presentationData.strings.ChatList_Search_FilterFiles + icon = generateTintedImage(image: UIImage(bundleImageName: "Chat List/Search/Files"), color: color) + case .music: + title = presentationData.strings.ChatList_Search_FilterMusic + icon = generateTintedImage(image: UIImage(bundleImageName: "Chat List/Search/Music"), color: color) + } + + self.titleNode.attributedText = NSAttributedString(string: title, font: Font.medium(14.0), textColor: color) + + if self.theme !== presentationData.theme { + self.theme = presentationData.theme + self.iconNode.image = icon + } + } + + func updateLayout(height: CGFloat, transition: ContainedViewLayoutTransition) -> CGFloat { + let iconInset: CGFloat = 22.0 + if let image = self.iconNode.image { + self.iconNode.frame = CGRect(x: 0.0, y: floorToScreenPixels((height - image.size.height) / 2.0), width: image.size.width, height: image.size.height) + } + + let titleSize = self.titleNode.updateLayout(CGSize(width: 160.0, height: .greatestFiniteMagnitude)) + let titleFrame = CGRect(origin: CGPoint(x: -self.titleNode.insets.left + iconInset, y: floor((height - titleSize.height) / 2.0)), size: titleSize) + self.titleNode.frame = titleFrame + + return titleSize.width - self.titleNode.insets.left - self.titleNode.insets.right + iconInset + } + + func updateArea(size: CGSize, sideInset: CGFloat, transition: ContainedViewLayoutTransition) { + self.buttonNode.frame = CGRect(origin: CGPoint(x: -sideInset, y: 0.0), size: CGSize(width: size.width + sideInset * 2.0, height: size.height)) + + self.hitTestSlop = UIEdgeInsets(top: 0.0, left: -sideInset, bottom: 0.0, right: -sideInset) + } +} + +enum ChatListSearchFilterEntryId: Hashable { + case filter(Int32) +} + +enum ChatListSearchFilterEntry: Equatable { + case filter(ChatListSearchFilter) + + var id: ChatListSearchFilterEntryId { + switch self { + case let .filter(filter): + return .filter(filter.rawValue) + } + } +} + +final class ChatListSearchFiltersContainerNode: ASDisplayNode { + private let scrollNode: ASScrollNode + private var itemNodes: [ChatListSearchFilterEntryId: ItemNode] = [:] + + var filterPressed: ((ChatListSearchFilter) -> Void)? + + private var currentParams: (size: CGSize, sideInset: CGFloat, filters: [ChatListSearchFilterEntry], presentationData: PresentationData)? + + override init() { + self.scrollNode = ASScrollNode() + + super.init() + + self.scrollNode.view.showsHorizontalScrollIndicator = false + self.scrollNode.view.scrollsToTop = false + self.scrollNode.view.delaysContentTouches = false + self.scrollNode.view.canCancelContentTouches = true + if #available(iOS 11.0, *) { + self.scrollNode.view.contentInsetAdjustmentBehavior = .never + } + + self.addSubnode(self.scrollNode) + } + + func cancelAnimations() { + self.scrollNode.layer.removeAllAnimations() + } + + func update(size: CGSize, sideInset: CGFloat, filters: [ChatListSearchFilterEntry], presentationData: PresentationData, transition proposedTransition: ContainedViewLayoutTransition) { + let isFirstTime = self.currentParams == nil + let transition: ContainedViewLayoutTransition = isFirstTime ? .immediate : proposedTransition + + if self.currentParams?.presentationData.theme !== presentationData.theme { + self.backgroundColor = presentationData.theme.rootController.navigationBar.backgroundColor + } + + self.currentParams = (size: size, sideInset: sideInset, filters: filters, presentationData: presentationData) + + transition.updateFrame(node: self.scrollNode, frame: CGRect(origin: CGPoint(), size: size)) + + for i in 0 ..< filters.count { + let filter = filters[i] + if case let .filter(type) = filter { + let itemNode: ItemNode + var itemNodeTransition = transition + if let current = self.itemNodes[filter.id] { + itemNode = current + } else { + itemNodeTransition = .immediate + itemNode = ItemNode(pressed: { [weak self] in + self?.filterPressed?(type) + }) + self.itemNodes[filter.id] = itemNode + } + itemNode.update(type: type, presentationData: presentationData, transition: itemNodeTransition) + } + } + var removeKeys: [ChatListSearchFilterEntryId] = [] + for (id, _) in self.itemNodes { + if !filters.contains(where: { $0.id == id }) { + removeKeys.append(id) + } + } + for id in removeKeys { + if let itemNode = self.itemNodes.removeValue(forKey: id) { + transition.updateAlpha(node: itemNode, alpha: 0.0, completion: { [weak itemNode] _ in + itemNode?.removeFromSupernode() + }) + transition.updateTransformScale(node: itemNode, scale: 0.1) + } + } + + var tabSizes: [(ChatListSearchFilterEntryId, CGSize, ItemNode, Bool)] = [] + var totalRawTabSize: CGFloat = 0.0 + + for filter in filters { + guard let itemNode = self.itemNodes[filter.id] else { + continue + } + let wasAdded = itemNode.supernode == nil + var itemNodeTransition = transition + if wasAdded { + itemNodeTransition = .immediate + self.scrollNode.addSubnode(itemNode) + } + let paneNodeWidth = itemNode.updateLayout(height: size.height, transition: itemNodeTransition) + let paneNodeSize = CGSize(width: paneNodeWidth, height: size.height) + tabSizes.append((filter.id, paneNodeSize, itemNode, wasAdded)) + totalRawTabSize += paneNodeSize.width + } + + let minSpacing: CGFloat = 26.0 + var spacing = minSpacing + + let resolvedSideInset: CGFloat = 16.0 + sideInset + var leftOffset: CGFloat = resolvedSideInset + + var longTitlesWidth: CGFloat = resolvedSideInset + var titlesWidth: CGFloat = 0.0 + for i in 0 ..< tabSizes.count { + let (_, paneNodeSize, _, _) = tabSizes[i] + longTitlesWidth += paneNodeSize.width + titlesWidth += paneNodeSize.width + if i != tabSizes.count - 1 { + longTitlesWidth += minSpacing + } + } + longTitlesWidth += resolvedSideInset + + if longTitlesWidth < size.width { + spacing = (size.width - titlesWidth - resolvedSideInset * 2.0) / CGFloat(tabSizes.count - 1) + } + + let verticalOffset: CGFloat = -3.0 + for i in 0 ..< tabSizes.count { + let (_, paneNodeSize, paneNode, wasAdded) = tabSizes[i] + var itemNodeTransition = transition + if wasAdded { + itemNodeTransition = .immediate + } + + let paneFrame = CGRect(origin: CGPoint(x: leftOffset, y: floor((size.height - paneNodeSize.height) / 2.0) + verticalOffset), size: paneNodeSize) + itemNodeTransition.updateSublayerTransformScale(node: paneNode, scale: 1.0) + itemNodeTransition.updateAlpha(node: paneNode, alpha: 1.0) + if wasAdded { + paneNode.frame = paneFrame + paneNode.alpha = 0.0 + itemNodeTransition.updateAlpha(node: paneNode, alpha: 1.0) + } else { + itemNodeTransition.updateFrameAdditive(node: paneNode, frame: paneFrame) + } + + paneNode.updateArea(size: paneFrame.size, sideInset: spacing / 2.0, transition: itemNodeTransition) + paneNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -spacing / 2.0, bottom: 0.0, right: -spacing / 2.0) + + leftOffset += paneNodeSize.width + spacing + } + leftOffset -= spacing + leftOffset += resolvedSideInset + + self.scrollNode.view.contentSize = CGSize(width: leftOffset, height: size.height) + } +} diff --git a/submodules/ChatListUI/Sources/ChatListSearchGridNode.swift b/submodules/ChatListUI/Sources/ChatListSearchGridNode.swift new file mode 100644 index 0000000000..24a36dc80b --- /dev/null +++ b/submodules/ChatListUI/Sources/ChatListSearchGridNode.swift @@ -0,0 +1,1133 @@ +import AsyncDisplayKit +import Display +import TelegramCore +import SyncCore +import SwiftSignalKit +import Postbox +import TelegramPresentationData +import AccountContext +import ContextUI +import PhotoResources +import RadialStatusNode +import TelegramStringFormatting +import UniversalMediaPlayer +import ListMessageItem +import ChatMessageInteractiveMediaBadge + +private let mediaBadgeBackgroundColor = UIColor(white: 0.0, alpha: 0.6) +private let mediaBadgeTextColor = UIColor.white + +private final class VisualMediaItemInteraction { + let openMessage: (Message) -> Void + let openMessageContextActions: (Message, ASDisplayNode, CGRect, ContextGesture?) -> Void + let toggleSelection: (MessageId, Bool) -> Void + + var hiddenMedia: [MessageId: [Media]] = [:] + var selectedMessageIds: Set? + + init( + openMessage: @escaping (Message) -> Void, + openMessageContextActions: @escaping (Message, ASDisplayNode, CGRect, ContextGesture?) -> Void, + toggleSelection: @escaping (MessageId, Bool) -> Void + ) { + self.openMessage = openMessage + self.openMessageContextActions = openMessageContextActions + self.toggleSelection = toggleSelection + } +} + +private final class VisualMediaItemNode: ASDisplayNode { + private let context: AccountContext + private let interaction: VisualMediaItemInteraction + +// private var videoLayerFrameManager: SoftwareVideoLayerFrameManager? +// private var sampleBufferLayer: SampleBufferLayer? + private var displayLink: ConstantDisplayLinkAnimator? + private var displayLinkTimestamp: Double = 0.0 + + private let containerNode: ContextControllerSourceNode + private let imageNode: TransformImageNode + private var statusNode: RadialStatusNode + private let mediaBadgeNode: ChatMessageInteractiveMediaBadge + + private let fetchStatusDisposable = MetaDisposable() + private let fetchDisposable = MetaDisposable() + private var resourceStatus: MediaResourceStatus? + + private var item: (VisualMediaItem, Media?, CGSize, CGSize?)? + private var theme: PresentationTheme? + + private var hasVisibility: Bool = false + + init(context: AccountContext, interaction: VisualMediaItemInteraction) { + self.context = context + self.interaction = interaction + + self.containerNode = ContextControllerSourceNode() + self.imageNode = TransformImageNode() + self.statusNode = RadialStatusNode(backgroundNodeColor: UIColor(white: 0.0, alpha: 0.6)) + let progressDiameter: CGFloat = 40.0 + self.statusNode.frame = CGRect(x: 0.0, y: 0.0, width: progressDiameter, height: progressDiameter) + self.statusNode.isUserInteractionEnabled = false + + self.mediaBadgeNode = ChatMessageInteractiveMediaBadge() + self.mediaBadgeNode.frame = CGRect(origin: CGPoint(x: 6.0, y: 6.0), size: CGSize(width: 50.0, height: 50.0)) + + super.init() + + self.addSubnode(self.containerNode) + self.containerNode.addSubnode(self.imageNode) + self.containerNode.addSubnode(self.mediaBadgeNode) + + self.containerNode.activated = { [weak self] gesture, _ in + guard let strongSelf = self, let item = strongSelf.item else { + return + } + strongSelf.interaction.openMessageContextActions(item.0.message, strongSelf.containerNode, strongSelf.containerNode.bounds, gesture) + } + } + + deinit { + self.fetchStatusDisposable.dispose() + self.fetchDisposable.dispose() + } + + override func didLoad() { + super.didLoad() + + let recognizer = TapLongTapOrDoubleTapGestureRecognizer(target: self, action: #selector(self.tapGesture(_:))) + recognizer.tapActionAtPoint = { _ in + return .waitForSingleTap + } + self.imageNode.view.addGestureRecognizer(recognizer) + + self.mediaBadgeNode.pressed = { [weak self] in + self?.progressPressed() + } + } + + @objc func tapGesture(_ recognizer: TapLongTapOrDoubleTapGestureRecognizer) { + if case .ended = recognizer.state { + if let (gesture, _) = recognizer.lastRecognizedGestureAndLocation { + if case .tap = gesture { + if let (item, _, _, _) = self.item { + var media: Media? + for value in item.message.media { + if let image = value as? TelegramMediaImage { + media = image + break + } else if let file = value as? TelegramMediaFile { + media = file + break + } + } + + if let media = media { + if let file = media as? TelegramMediaFile { + if isMediaStreamable(message: item.message, media: file) { + self.interaction.openMessage(item.message) + } else { + self.progressPressed() + } + } else { + self.interaction.openMessage(item.message) + } + } + } + } + } + } + } + + private func progressPressed() { + guard let message = self.item?.0.message else { + return + } + + var media: Media? + for value in message.media { + if let image = value as? TelegramMediaImage { + media = image + break + } else if let file = value as? TelegramMediaFile { + media = file + break + } + } + + if let resourceStatus = self.resourceStatus, let file = media as? TelegramMediaFile { + switch resourceStatus { + case .Fetching: + messageMediaFileCancelInteractiveFetch(context: self.context, messageId: message.id, file: file) + case .Local: + self.interaction.openMessage(message) + case .Remote: + self.fetchDisposable.set(messageMediaFileInteractiveFetched(context: self.context, message: message, file: file, userInitiated: true).start()) + } + } + } + + func cancelPreviewGesture() { + self.containerNode.cancelGesture() + } + + func update(size: CGSize, item: VisualMediaItem, theme: PresentationTheme, synchronousLoad: Bool) { + if item === self.item?.0 && size == self.item?.2 { + return + } + self.theme = theme + var media: Media? + for value in item.message.media { + if let image = value as? TelegramMediaImage { + media = image + break + } else if let file = value as? TelegramMediaFile { + media = file + break + } + } + +// if let file = media as? TelegramMediaFile, file.isAnimated { +// if self.videoLayerFrameManager == nil { +// let sampleBufferLayer: SampleBufferLayer +// if let current = self.sampleBufferLayer { +// sampleBufferLayer = current +// } else { +// sampleBufferLayer = takeSampleBufferLayer() +// self.sampleBufferLayer = sampleBufferLayer +// self.imageNode.layer.addSublayer(sampleBufferLayer.layer) +// } +// +// self.videoLayerFrameManager = SoftwareVideoLayerFrameManager(account: self.context.account, fileReference: FileMediaReference.message(message: MessageReference(item.message), media: file), layerHolder: sampleBufferLayer) +// self.videoLayerFrameManager?.start() +// } +// } else { +// if let sampleBufferLayer = self.sampleBufferLayer { +// sampleBufferLayer.layer.removeFromSuperlayer() +// self.sampleBufferLayer = nil +// } +// self.videoLayerFrameManager = nil +// } + + if let media = media, (self.item?.1 == nil || !media.isEqual(to: self.item!.1!)) { + var mediaDimensions: CGSize? + if let image = media as? TelegramMediaImage, let largestSize = largestImageRepresentation(image.representations)?.dimensions { + mediaDimensions = largestSize.cgSize + + self.imageNode.setSignal(mediaGridMessagePhoto(account: context.account, photoReference: .message(message: MessageReference(item.message), media: image), fullRepresentationSize: CGSize(width: 300.0, height: 300.0), synchronousLoad: synchronousLoad), attemptSynchronously: synchronousLoad, dispatchOnDisplayLink: true) + + self.fetchStatusDisposable.set(nil) + self.statusNode.transitionToState(.none, completion: { [weak self] in + self?.statusNode.isHidden = true + }) + self.mediaBadgeNode.isHidden = true + self.resourceStatus = nil + } else if let file = media as? TelegramMediaFile, file.isVideo { + mediaDimensions = file.dimensions?.cgSize + self.imageNode.setSignal(mediaGridMessageVideo(postbox: context.account.postbox, videoReference: .message(message: MessageReference(item.message), media: file), synchronousLoad: synchronousLoad, autoFetchFullSizeThumbnail: true), attemptSynchronously: synchronousLoad) + + self.mediaBadgeNode.isHidden = file.isAnimated + + self.resourceStatus = nil + + self.item = (item, media, size, mediaDimensions) + + self.fetchStatusDisposable.set((messageMediaFileStatus(context: context, messageId: item.message.id, file: file) + |> deliverOnMainQueue).start(next: { [weak self] status in + if let strongSelf = self, let (item, _, _, _) = strongSelf.item { + strongSelf.resourceStatus = status + + let isStreamable = isMediaStreamable(message: item.message, media: file) + + var statusState: RadialStatusNodeState = .none + if isStreamable || file.isAnimated { + statusState = .none + } else { + switch status { + case let .Fetching(_, progress): + let adjustedProgress = max(progress, 0.027) + statusState = .progress(color: .white, lineWidth: nil, value: CGFloat(adjustedProgress), cancelEnabled: true) + case .Local: + statusState = .none + case .Remote: + statusState = .download(.white) + } + } + + switch statusState { + case .none: + break + default: + strongSelf.statusNode.isHidden = false + } + + strongSelf.statusNode.transitionToState(statusState, animated: true, completion: { + if let strongSelf = self { + if case .none = statusState { + strongSelf.statusNode.isHidden = true + } + } + }) + + if let duration = file.duration { + let durationString = stringForDuration(duration) + + var badgeContent: ChatMessageInteractiveMediaBadgeContent? + var mediaDownloadState: ChatMessageInteractiveMediaDownloadState? + + if isStreamable { + switch status { + case let .Fetching(_, progress): + let progressString = String(format: "%d%%", Int(progress * 100.0)) + badgeContent = .text(inset: 12.0, backgroundColor: mediaBadgeBackgroundColor, foregroundColor: mediaBadgeTextColor, text: NSAttributedString(string: progressString)) + mediaDownloadState = .compactFetching(progress: 0.0) + case .Local: + badgeContent = .text(inset: 0.0, backgroundColor: mediaBadgeBackgroundColor, foregroundColor: mediaBadgeTextColor, text: NSAttributedString(string: durationString)) + case .Remote: + badgeContent = .text(inset: 12.0, backgroundColor: mediaBadgeBackgroundColor, foregroundColor: mediaBadgeTextColor, text: NSAttributedString(string: durationString)) + mediaDownloadState = .compactRemote + } + } else { + badgeContent = .text(inset: 0.0, backgroundColor: mediaBadgeBackgroundColor, foregroundColor: mediaBadgeTextColor, text: NSAttributedString(string: durationString)) + } + + strongSelf.mediaBadgeNode.update(theme: nil, content: badgeContent, mediaDownloadState: mediaDownloadState, alignment: .right, animated: false, badgeAnimated: false) + } + } + })) + if self.statusNode.supernode == nil { + self.imageNode.addSubnode(self.statusNode) + } + } else { + self.mediaBadgeNode.isHidden = true + } + self.item = (item, media, size, mediaDimensions) + + let progressDiameter: CGFloat = 40.0 + self.statusNode.frame = CGRect(origin: CGPoint(x: floor((size.width - progressDiameter) / 2.0), y: floor((size.height - progressDiameter) / 2.0)), size: CGSize(width: progressDiameter, height: progressDiameter)) + + self.mediaBadgeNode.frame = CGRect(origin: CGPoint(x: size.width - 3.0, y: size.height - 18.0 - 3.0), size: CGSize(width: 50.0, height: 50.0)) + + self.updateHiddenMedia() + } + + if let (item, media, _, mediaDimensions) = self.item { + self.item = (item, media, size, mediaDimensions) + + let imageFrame = CGRect(origin: CGPoint(), size: size) + + self.containerNode.frame = imageFrame + self.imageNode.frame = imageFrame +// if let sampleBufferLayer = self.sampleBufferLayer { +// sampleBufferLayer.layer.frame = imageFrame +// } + + if let mediaDimensions = mediaDimensions { + let imageSize = mediaDimensions.aspectFilled(imageFrame.size) + self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: imageSize, boundingSize: imageFrame.size, intrinsicInsets: UIEdgeInsets(), emptyColor: theme.list.mediaPlaceholderColor))() + } + + self.updateSelectionState(animated: false) + } + } + + func updateIsVisible(_ isVisible: Bool) { + self.hasVisibility = isVisible +// if let _ = self.videoLayerFrameManager { +// let displayLink: ConstantDisplayLinkAnimator +// if let current = self.displayLink { +// displayLink = current +// } else { +// displayLink = ConstantDisplayLinkAnimator { [weak self] in +// guard let strongSelf = self else { +// return +// } +// strongSelf.displayLinkTimestamp += 1.0 / 30.0 +// } +// displayLink.frameInterval = 2 +// self.displayLink = displayLink +// } +// } + self.displayLink?.isPaused = !self.hasVisibility || self.isHidden + } + + func updateSelectionState(animated: Bool) { + if let (item, _, _, _) = self.item, let theme = self.theme { + self.containerNode.isGestureEnabled = self.interaction.selectedMessageIds == nil + } + } + + func transitionNode() -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { + let imageNode = self.imageNode + return (self.imageNode, self.imageNode.bounds, { [weak self, weak imageNode] in + var statusNodeHidden = false + var accessoryHidden = false + if let strongSelf = self { + statusNodeHidden = strongSelf.statusNode.isHidden + accessoryHidden = strongSelf.mediaBadgeNode.isHidden + strongSelf.statusNode.isHidden = true + strongSelf.mediaBadgeNode.isHidden = true + } + let view = imageNode?.view.snapshotView(afterScreenUpdates: false) + if let strongSelf = self { + strongSelf.statusNode.isHidden = statusNodeHidden + strongSelf.mediaBadgeNode.isHidden = accessoryHidden + } + return (view, nil) + }) + } + + func updateHiddenMedia() { + if let (item, _, _, _) = self.item { + if let _ = self.interaction.hiddenMedia[item.message.id] { + self.isHidden = true + } else { + self.isHidden = false + } + } else { + self.isHidden = false + } + self.displayLink?.isPaused = !self.hasVisibility || self.isHidden + } +} + +private final class VisualMediaItem { + let message: Message + let dimensions: CGSize + let aspectRatio: CGFloat + + init(message: Message) { + self.message = message + + var aspectRatio: CGFloat = 1.0 + var dimensions = CGSize(width: 100.0, height: 100.0) + for media in message.media { + if let file = media as? TelegramMediaFile { + if let dimensionsValue = file.dimensions, dimensions.height > 1 { + dimensions = dimensionsValue.cgSize + aspectRatio = CGFloat(dimensionsValue.width) / CGFloat(dimensionsValue.height) + } + } + } + self.aspectRatio = aspectRatio + self.dimensions = dimensions + } +} + +private final class FloatingHeaderNode: ASDisplayNode { + private let backgroundNode: ASImageNode + private let labelNode: ImmediateTextNode + + private var currentParams: (constrainedWidth: CGFloat, year: Int32, month: Int32, theme: PresentationTheme)? + private var currentSize: CGSize? + + override init() { + self.backgroundNode = ASImageNode() + self.backgroundNode.displaysAsynchronously = false + self.backgroundNode.displayWithoutProcessing = true + + self.labelNode = ImmediateTextNode() + self.labelNode.displaysAsynchronously = false + + super.init() + + self.addSubnode(self.backgroundNode) + self.addSubnode(self.labelNode) + } + + func update(constrainedWidth: CGFloat, year: Int32, month: Int32, theme: PresentationTheme, strings: PresentationStrings) -> CGSize { + if let currentParams = self.currentParams, let currentSize = self.currentSize { + if currentParams.constrainedWidth == constrainedWidth && + currentParams.year == year && + currentParams.month == month && + currentParams.theme === theme { + return currentSize + } + } + + if self.currentParams?.theme !== theme { + self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 27.0, color: mediaBadgeBackgroundColor) + } + + self.currentParams = (constrainedWidth, year, month, theme) + + self.labelNode.attributedText = NSAttributedString(string: stringForMonth(strings: strings, month: month, ofYear: year), font: Font.regular(14.0), textColor: .white) + let labelSize = self.labelNode.updateLayout(CGSize(width: constrainedWidth, height: .greatestFiniteMagnitude)) + + let sideInset: CGFloat = 10.0 + self.labelNode.frame = CGRect(origin: CGPoint(x: sideInset, y: floor((27.0 - labelSize.height) / 2.0)), size: labelSize) + self.backgroundNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: labelSize.width + sideInset * 2.0, height: 27.0)) + + let size = CGSize(width: labelSize.width + sideInset * 2.0, height: 27.0) + return size + } +} + +private enum ItemsLayout { + final class Grid { + let containerWidth: CGFloat + let itemCount: Int + let itemSpacing: CGFloat + let itemsInRow: Int + let itemSize: CGFloat + let rowCount: Int + let contentHeight: CGFloat + + init(containerWidth: CGFloat, itemCount: Int, bottomInset: CGFloat) { + self.containerWidth = containerWidth + self.itemCount = itemCount + self.itemSpacing = 1.0 + self.itemsInRow = max(3, min(6, Int(containerWidth / 140.0))) + self.itemSize = floor(containerWidth / CGFloat(itemsInRow)) + + self.rowCount = itemCount / self.itemsInRow + (itemCount % self.itemsInRow == 0 ? 0 : 1) + + self.contentHeight = CGFloat(self.rowCount + 1) * self.itemSpacing + CGFloat(rowCount) * itemSize + bottomInset + } + + func visibleRange(rect: CGRect) -> (Int, Int) { + var minVisibleRow = Int(floor((rect.minY - self.itemSpacing) / (self.itemSize + self.itemSpacing))) + minVisibleRow = max(0, minVisibleRow) + var maxVisibleRow = Int(ceil((rect.maxY - self.itemSpacing) / (self.itemSize + itemSpacing))) + maxVisibleRow = min(self.rowCount - 1, maxVisibleRow) + + let minVisibleIndex = minVisibleRow * itemsInRow + let maxVisibleIndex = min(self.itemCount - 1, (maxVisibleRow + 1) * itemsInRow - 1) + + return (minVisibleIndex, maxVisibleIndex) + } + + func frame(forItemAt index: Int, sideInset: CGFloat) -> CGRect { + let rowIndex = index / Int(self.itemsInRow) + let columnIndex = index % Int(self.itemsInRow) + let itemOrigin = CGPoint(x: sideInset + CGFloat(columnIndex) * (self.itemSize + self.itemSpacing), y: self.itemSpacing + CGFloat(rowIndex) * (self.itemSize + self.itemSpacing)) + return CGRect(origin: itemOrigin, size: CGSize(width: columnIndex == self.itemsInRow ? (self.containerWidth - itemOrigin.x) : self.itemSize, height: self.itemSize)) + } + } + + final class Balanced { + let frames: [CGRect] + let contentHeight: CGFloat + + init(containerWidth: CGFloat, items: [VisualMediaItem], bottomInset: CGFloat) { + self.frames = calculateItemFrames(items: items, containerWidth: containerWidth) + if let last = self.frames.last { + self.contentHeight = last.maxY + bottomInset + } else { + self.contentHeight = bottomInset + } + } + + func visibleRange(rect: CGRect) -> (Int, Int) { + for i in 0 ..< self.frames.count { + if self.frames[i].maxY >= rect.minY { + for j in i ..< self.frames.count { + if self.frames[j].minY >= rect.maxY { + return (i, j - 1) + } + } + return (i, self.frames.count - 1) + } + } + return (0, -1) + } + + func frame(forItemAt index: Int, sideInset: CGFloat) -> CGRect { + if index >= 0 && index < self.frames.count { + return self.frames[index] + } else { + assertionFailure() + return CGRect(origin: CGPoint(), size: CGSize(width: 100.0, height: 100.0)) + } + } + } + + case grid(Grid) + case balanced(Balanced) + + var contentHeight: CGFloat { + switch self { + case let .grid(grid): + return grid.contentHeight + case let .balanced(balanced): + return balanced.contentHeight + } + } + + func visibleRange(rect: CGRect) -> (Int, Int) { + switch self { + case let .grid(grid): + return grid.visibleRange(rect: rect) + case let .balanced(balanced): + return balanced.visibleRange(rect: rect) + } + } + + func frame(forItemAt index: Int, sideInset: CGFloat) -> CGRect { + switch self { + case let .grid(grid): + return grid.frame(forItemAt: index, sideInset: sideInset) + case let .balanced(balanced): + return balanced.frame(forItemAt: index, sideInset: sideInset) + } + } +} + +private func getStableId(message: Message) -> Int32 { + var hash = message.id.id + hash = hash &* 31 &+ message.id.peerId.id + return hash +} + +final class ChatListSearchMediaNode: ASDisplayNode, UIScrollViewDelegate { + enum ContentType { + case photoOrVideo + case gifs + } + + private let context: AccountContext + private let contentType: ContentType + + private let scrollNode: ASScrollNode + private let floatingHeaderNode: FloatingHeaderNode + private var flashHeaderDelayTimer: Foundation.Timer? + private var isDeceleratingAfterTracking = false + + private var _itemInteraction: VisualMediaItemInteraction? + private var itemInteraction: VisualMediaItemInteraction { + return self._itemInteraction! + } + + private var currentParams: (size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, isScrollingLockedAtTop: Bool, expandProgress: CGFloat, presentationData: PresentationData)? + + private let ready = Promise() + private var didSetReady: Bool = false + var isReady: Signal { + return self.ready.get() + } + + let shouldReceiveExpandProgressUpdates: Bool = false + + private let listDisposable = MetaDisposable() + private var hiddenMediaDisposable: Disposable? + private var mediaItems: [VisualMediaItem] = [] + private var itemsLayout: ItemsLayout? + private var visibleMediaItems: [Int32: VisualMediaItemNode] = [:] + + private var numberOfItemsToRequest: Int = 50 + private var currentView: MessageHistoryView? + private var isRequestingView: Bool = false + private var isFirstHistoryView: Bool = true + + private var decelerationAnimator: ConstantDisplayLinkAnimator? + + private var animationTimer: SwiftSignalKit.Timer? + + init(context: AccountContext, contentType: ContentType, openMessage: @escaping (Message, ChatControllerInteractionOpenMessageMode) -> Void) { + self.context = context + self.contentType = contentType + + self.scrollNode = ASScrollNode() + self.floatingHeaderNode = FloatingHeaderNode() + self.floatingHeaderNode.alpha = 0.0 + + super.init() + + self._itemInteraction = VisualMediaItemInteraction( + openMessage: { [weak self] message in + let _ = openMessage(message, .default) + }, + openMessageContextActions: { [weak self] message, sourceNode, sourceRect, gesture in +// self?.chatControllerInteraction.openMessageContextActions(message, sourceNode, sourceRect, gesture) + }, + toggleSelection: { [weak self] id, value in +// self?.chatControllerInteraction.toggleMessagesSelection([id], value) + } + ) +// self.itemInteraction.selectedMessageIds = chatControllerInteraction.selectionState.flatMap { $0.selectedIds } + + self.scrollNode.view.delaysContentTouches = false + self.scrollNode.view.canCancelContentTouches = true + self.scrollNode.view.showsVerticalScrollIndicator = true + if #available(iOS 11.0, *) { + self.scrollNode.view.contentInsetAdjustmentBehavior = .never + } + self.scrollNode.view.scrollsToTop = false + self.scrollNode.view.delegate = self + + self.addSubnode(self.scrollNode) + self.addSubnode(self.floatingHeaderNode) + + self.requestHistoryAroundVisiblePosition() + + self.hiddenMediaDisposable = context.sharedContext.mediaManager.galleryHiddenMediaManager.hiddenIds().start(next: { [weak self] ids in + guard let strongSelf = self else { + return + } + var hiddenMedia: [MessageId: [Media]] = [:] + for id in ids { + if case let .chat(accountId, messageId, media) = id, accountId == strongSelf.context.account.id { + hiddenMedia[messageId] = [media] + } + } + strongSelf.itemInteraction.hiddenMedia = hiddenMedia + for (_, itemNode) in strongSelf.visibleMediaItems { + itemNode.updateHiddenMedia() + } + }) + } + + deinit { + self.listDisposable.dispose() + self.hiddenMediaDisposable?.dispose() + self.animationTimer?.invalidate() + } + + private func requestHistoryAroundVisiblePosition() { +// if self.isRequestingView { +// return +// } +// self.isRequestingView = true +// self.listDisposable.set((self.context.account.viewTracker.aroundMessageHistoryViewForLocation(.peer(self.peerId), index: .upperBound, anchorIndex: .upperBound, count: self.numberOfItemsToRequest, fixedCombinedReadStates: nil, tagMask: tagMaskForType(self.contentType)) +// |> deliverOnMainQueue).start(next: { [weak self] (view, updateType, _) in +// guard let strongSelf = self else { +// return +// } +// strongSelf.updateHistory(view: view, updateType: updateType) +// strongSelf.isRequestingView = false +// })) + } + + func updateHistory(entries: [ChatListSearchEntry], updateType: ViewUpdateType) { +// self.currentView = view + + switch updateType { + case .FillHole: + self.requestHistoryAroundVisiblePosition() + default: + self.mediaItems.removeAll() + for entry in entries.reversed() { + if case let .message(message, _, _, _) = entry { + self.mediaItems.append(VisualMediaItem(message: message)) + } + } + self.itemsLayout = nil + + let wasFirstHistoryView = self.isFirstHistoryView + self.isFirstHistoryView = false + + if let (size, sideInset, bottomInset, visibleHeight, isScrollingLockedAtTop, expandProgress, presentationData) = self.currentParams { + self.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, isScrollingLockedAtTop: isScrollingLockedAtTop, expandProgress: expandProgress, presentationData: presentationData, synchronous: wasFirstHistoryView, transition: .immediate) + if !self.didSetReady { + self.didSetReady = true + self.ready.set(.single(true)) + } + } + } + } + + func scrollToTop() -> Bool { + if self.scrollNode.view.contentOffset.y > 0.0 { + self.scrollNode.view.setContentOffset(CGPoint(), animated: true) + return true + } else { + return false + } + } + + func findLoadedMessage(id: MessageId) -> Message? { + for item in self.mediaItems { + if item.message.id == id { + return item.message + } + } + return nil + } + + func updateHiddenMedia() { + for (_, itemNode) in self.visibleMediaItems { + itemNode.updateHiddenMedia() + } + } + + func transferVelocity(_ velocity: CGFloat) { + if velocity > 0.0 { + //print("transferVelocity \(velocity)") + self.decelerationAnimator?.isPaused = true + let startTime = CACurrentMediaTime() + var currentOffset = self.scrollNode.view.contentOffset + let decelerationRate: CGFloat = 0.998 + self.scrollViewDidEndDragging(self.scrollNode.view, willDecelerate: true) + self.decelerationAnimator = ConstantDisplayLinkAnimator(update: { [weak self] in + guard let strongSelf = self else { + return + } + let t = CACurrentMediaTime() - startTime + var currentVelocity = velocity * 15.0 * CGFloat(pow(Double(decelerationRate), 1000.0 * t)) + //print("value at \(t) = \(currentVelocity)") + currentOffset.y += currentVelocity + let maxOffset = strongSelf.scrollNode.view.contentSize.height - strongSelf.scrollNode.bounds.height + if currentOffset.y >= maxOffset { + currentOffset.y = maxOffset + currentVelocity = 0.0 + } + if currentOffset.y < 0.0 { + currentOffset.y = 0.0 + currentVelocity = 0.0 + } + + var didEnd = false + if abs(currentVelocity) < 0.1 { + strongSelf.decelerationAnimator?.isPaused = true + strongSelf.decelerationAnimator = nil + didEnd = true + } + var contentOffset = strongSelf.scrollNode.view.contentOffset + contentOffset.y = floorToScreenPixels(currentOffset.y) + strongSelf.scrollNode.view.setContentOffset(contentOffset, animated: false) + strongSelf.scrollViewDidScroll(strongSelf.scrollNode.view) + if didEnd { + strongSelf.scrollViewDidEndDecelerating(strongSelf.scrollNode.view) + } + }) + self.decelerationAnimator?.isPaused = false + } + } + + func cancelPreviewGestures() { + for (_, itemNode) in self.visibleMediaItems { + itemNode.cancelPreviewGesture() + } + } + + func transitionNodeForGallery(messageId: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { + for item in self.mediaItems { + if item.message.id == messageId { + if let itemNode = self.visibleMediaItems[getStableId(message: item.message)] { + return itemNode.transitionNode() + } + break + } + } + return nil + } + + func addToTransitionSurface(view: UIView) { + self.scrollNode.view.addSubview(view) + } + + func updateSelectedMessages(animated: Bool) { +// self.itemInteraction.selectedMessageIds = self.chatControllerInteraction.selectionState.flatMap { $0.selectedIds } + for (_, itemNode) in self.visibleMediaItems { + itemNode.updateSelectionState(animated: animated) + } + } + + func update(size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, isScrollingLockedAtTop: Bool, expandProgress: CGFloat, presentationData: PresentationData, synchronous: Bool, transition: ContainedViewLayoutTransition) { + self.currentParams = (size, sideInset, bottomInset, visibleHeight, isScrollingLockedAtTop, expandProgress, presentationData) + + transition.updateFrame(node: self.scrollNode, frame: CGRect(origin: CGPoint(), size: size)) + + let availableWidth = size.width - sideInset * 2.0 + + let itemsLayout: ItemsLayout + if let current = self.itemsLayout { + itemsLayout = current + } else { + switch self.contentType { + case .photoOrVideo, .gifs: + itemsLayout = .grid(ItemsLayout.Grid(containerWidth: availableWidth, itemCount: self.mediaItems.count, bottomInset: bottomInset)) + /*case .gifs: + itemsLayout = .balanced(ItemsLayout.Balanced(containerWidth: availableWidth, items: self.mediaItems, bottomInset: bottomInset))*/ + } + self.itemsLayout = itemsLayout + } + + self.scrollNode.view.contentSize = CGSize(width: size.width, height: itemsLayout.contentHeight) + self.updateVisibleItems(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, theme: presentationData.theme, strings: presentationData.strings, synchronousLoad: synchronous) + + if isScrollingLockedAtTop { + if self.scrollNode.view.contentOffset.y > .ulpOfOne { + transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(), size: self.scrollNode.bounds.size)) + } + } + self.scrollNode.view.isScrollEnabled = !isScrollingLockedAtTop + } + + func scrollViewWillBeginDragging(_ scrollView: UIScrollView) { + self.decelerationAnimator?.isPaused = true + self.decelerationAnimator = nil + + for (_, itemNode) in self.visibleMediaItems { + itemNode.cancelPreviewGesture() + } + + self.updateHeaderFlashing(animated: true) + } + + func scrollViewDidScroll(_ scrollView: UIScrollView) { + if let (size, sideInset, bottomInset, visibleHeight, _, _, presentationData) = self.currentParams { + self.updateVisibleItems(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, theme: presentationData.theme, strings: presentationData.strings, synchronousLoad: false) + + if scrollView.contentOffset.y >= scrollView.contentSize.height - scrollView.bounds.height * 2.0, let currentView = self.currentView, currentView.earlierId != nil { + if !self.isRequestingView { + self.numberOfItemsToRequest += 50 + self.requestHistoryAroundVisiblePosition() + } + } + } + } + + func scrollViewDidEndDragging(_ scrollView: UIScrollView, willDecelerate decelerate: Bool) { + if decelerate { + self.isDeceleratingAfterTracking = true + self.updateHeaderFlashing(animated: true) + } else { + self.isDeceleratingAfterTracking = false + self.resetHeaderFlashTimer(start: true) + self.updateHeaderFlashing(animated: true) + } + } + + func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) { + self.isDeceleratingAfterTracking = false + self.resetHeaderFlashTimer(start: true) + self.updateHeaderFlashing(animated: true) + } + + private func updateVisibleItems(size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, theme: PresentationTheme, strings: PresentationStrings, synchronousLoad: Bool) { + guard let itemsLayout = self.itemsLayout else { + return + } + + let headerItemMinY = self.scrollNode.view.bounds.minY + 20.0 + let activeRect = self.scrollNode.view.bounds + let visibleRect = activeRect.insetBy(dx: 0.0, dy: -400.0) + + let (minVisibleIndex, maxVisibleIndex) = itemsLayout.visibleRange(rect: visibleRect) + + var headerItem: Message? + + var validIds = Set() + if minVisibleIndex <= maxVisibleIndex { + for i in minVisibleIndex ... maxVisibleIndex { + var stableId = Int32(self.mediaItems[i].message.stableId) + if stableId == 0 { + stableId = getStableId(message: self.mediaItems[i].message) + } + validIds.insert(stableId) + + let itemFrame = itemsLayout.frame(forItemAt: i, sideInset: sideInset) + + let itemNode: VisualMediaItemNode + if let current = self.visibleMediaItems[stableId] { + itemNode = current + } else { + itemNode = VisualMediaItemNode(context: self.context, interaction: self.itemInteraction) + self.visibleMediaItems[stableId] = itemNode + self.scrollNode.addSubnode(itemNode) + } + itemNode.frame = itemFrame + if headerItem == nil && itemFrame.maxY > headerItemMinY { + headerItem = self.mediaItems[i].message + } + var itemSynchronousLoad = false + if itemFrame.maxY <= visibleHeight { + itemSynchronousLoad = synchronousLoad + } + itemNode.update(size: itemFrame.size, item: self.mediaItems[i], theme: theme, synchronousLoad: itemSynchronousLoad) + itemNode.updateIsVisible(itemFrame.intersects(activeRect)) + } + } + var removeKeys: [Int32] = [] + for (id, _) in self.visibleMediaItems { + if !validIds.contains(id) { + removeKeys.append(id) + } + } + for id in removeKeys { + if let itemNode = self.visibleMediaItems.removeValue(forKey: id) { + itemNode.removeFromSupernode() + } + } + + if let headerItem = headerItem { + let (year, month) = listMessageDateHeaderInfo(timestamp: headerItem.timestamp) + let headerSize = self.floatingHeaderNode.update(constrainedWidth: size.width, year: year, month: month, theme: theme, strings: strings) + self.floatingHeaderNode.frame = CGRect(origin: CGPoint(x: floor((size.width - headerSize.width) / 2.0), y: 7.0), size: headerSize) + self.floatingHeaderNode.isHidden = false + } else { + self.floatingHeaderNode.isHidden = true + } + } + + private func resetHeaderFlashTimer(start: Bool, duration: Double = 0.3) { + if let flashHeaderDelayTimer = self.flashHeaderDelayTimer { + flashHeaderDelayTimer.invalidate() + self.flashHeaderDelayTimer = nil + } + + if start { + final class TimerProxy: NSObject { + private let action: () -> () + + init(_ action: @escaping () -> ()) { + self.action = action + super.init() + } + + @objc func timerEvent() { + self.action() + } + } + + let timer = Timer(timeInterval: duration, target: TimerProxy { [weak self] in + if let strongSelf = self { + if let flashHeaderDelayTimer = strongSelf.flashHeaderDelayTimer { + flashHeaderDelayTimer.invalidate() + strongSelf.flashHeaderDelayTimer = nil + strongSelf.updateHeaderFlashing(animated: true) + } + } + }, selector: #selector(TimerProxy.timerEvent), userInfo: nil, repeats: false) + self.flashHeaderDelayTimer = timer + RunLoop.main.add(timer, forMode: RunLoop.Mode.common) + self.updateHeaderFlashing(animated: true) + } + } + + private func headerIsFlashing() -> Bool { + return self.scrollNode.view.isDragging || self.isDeceleratingAfterTracking || self.flashHeaderDelayTimer != nil + } + + private func updateHeaderFlashing(animated: Bool) { + let flashing = self.headerIsFlashing() + let alpha: CGFloat = flashing ? 1.0 : 0.0 + let previousAlpha = self.floatingHeaderNode.alpha + + if !previousAlpha.isEqual(to: alpha) { + self.floatingHeaderNode.alpha = alpha + if animated { + let duration: Double = flashing ? 0.3 : 0.4 + self.floatingHeaderNode.layer.animateAlpha(from: previousAlpha, to: alpha, duration: duration) + } + } + } + + override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + guard let result = super.hitTest(point, with: event) else { + return nil + } + if self.decelerationAnimator != nil { + self.decelerationAnimator?.isPaused = true + self.decelerationAnimator = nil + + return self.scrollNode.view + } + return result + } +} + +private func calculateItemFrames(items: [VisualMediaItem], containerWidth: CGFloat) -> [CGRect] { + var frames: [CGRect] = [] + + var rowsCount = 0 + var firstRowMax = 0; + + let viewPortAvailableSize = containerWidth + + let preferredRowSize: CGFloat = 100.0 + let itemsCount = items.count + let spanCount: CGFloat = 100.0 + var spanLeft = spanCount + var currentItemsInRow = 0 + var currentItemsSpanAmount: CGFloat = 0.0 + + var itemSpans: [Int: CGFloat] = [:] + var itemsToRow: [Int: Int] = [:] + + for a in 0 ..< itemsCount { + var size: CGSize = items[a].dimensions + if size.width <= 0.0 { + size.width = 100.0 + } + if size.height <= 0.0 { + size.height = 100.0 + } + let aspect: CGFloat = size.width / size.height + if aspect > 4.0 || aspect < 0.2 { + size.width = max(size.width, size.height) + size.height = size.width + } + + var requiredSpan = min(spanCount, floor(spanCount * (size.width / size.height * preferredRowSize / viewPortAvailableSize))) + let moveToNewRow = spanLeft < requiredSpan || requiredSpan > 33.0 && spanLeft < requiredSpan - 15.0 + if moveToNewRow { + if spanLeft > 0 { + let spanPerItem = floor(spanLeft / CGFloat(currentItemsInRow)) + + let start = a - currentItemsInRow + var b = start + while b < start + currentItemsInRow { + if (b == start + currentItemsInRow - 1) { + itemSpans[b] = itemSpans[b]! + spanLeft + } else { + itemSpans[b] = itemSpans[b]! + spanPerItem + } + spanLeft -= spanPerItem; + + b += 1 + } + + itemsToRow[a - 1] = rowsCount + } + rowsCount += 1 + currentItemsSpanAmount = 0 + currentItemsInRow = 0 + spanLeft = spanCount + } else { + if spanLeft < requiredSpan { + requiredSpan = spanLeft + } + } + if rowsCount == 0 { + firstRowMax = max(firstRowMax, a) + } + if a == itemsCount - 1 { + itemsToRow[a] = rowsCount + } + currentItemsSpanAmount += requiredSpan + currentItemsInRow += 1 + spanLeft -= requiredSpan + spanLeft = max(0, spanLeft) + + itemSpans[a] = requiredSpan + } + if itemsCount != 0 { + rowsCount += 1 + } + + var verticalOffset: CGFloat = 1.0 + + var currentRowHorizontalOffset: CGFloat = 0.0 + for index in 0 ..< items.count { + guard let width = itemSpans[index] else { + continue + } + let itemWidth = floor(width * containerWidth / 100.0) - 1 + + var itemSize = CGSize(width: itemWidth, height: preferredRowSize) + if itemsToRow[index] != nil && currentRowHorizontalOffset + itemSize.width >= containerWidth - 10.0 { + itemSize.width = max(itemSize.width, containerWidth - currentRowHorizontalOffset) + } + frames.append(CGRect(origin: CGPoint(x: currentRowHorizontalOffset, y: verticalOffset), size: itemSize)) + currentRowHorizontalOffset += itemSize.width + 1.0 + + if itemsToRow[index] != nil { + verticalOffset += preferredRowSize + 1.0 + currentRowHorizontalOffset = 0.0 + } + } + + return frames +} diff --git a/submodules/ChatMessageInteractiveMediaBadge/BUCK b/submodules/ChatMessageInteractiveMediaBadge/BUCK new file mode 100644 index 0000000000..55ad79a53c --- /dev/null +++ b/submodules/ChatMessageInteractiveMediaBadge/BUCK @@ -0,0 +1,17 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "TextSelectionNode", + srcs = glob([ + "Sources/**/*.swift", + ]), + deps = [ + "//submodules/AsyncDisplayKit:AsyncDisplayKit#shared", + "//submodules/Display:Display#shared", + "//submodules/TelegramPresentationData:TelegramPresentationData", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + ], +) diff --git a/submodules/ChatMessageInteractiveMediaBadge/BUILD b/submodules/ChatMessageInteractiveMediaBadge/BUILD new file mode 100644 index 0000000000..bb8f11a6d3 --- /dev/null +++ b/submodules/ChatMessageInteractiveMediaBadge/BUILD @@ -0,0 +1,20 @@ +load("@build_bazel_rules_swift//swift:swift.bzl", "swift_library") + +swift_library( + name = "ChatMessageInteractiveMediaBadge", + module_name = "ChatMessageInteractiveMediaBadge", + srcs = glob([ + "Sources/**/*.swift", + ]), + deps = [ + "//submodules/AsyncDisplayKit:AsyncDisplayKit", + "//submodules/Display:Display", + "//submodules/TelegramPresentationData:TelegramPresentationData", + "//submodules/TextFormat:TextFormat", + "//submodules/RadialStatusNode:RadialStatusNode", + "//submodules/AppBundle:AppBundle", + ], + visibility = [ + "//visibility:public", + ], +) diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaBadge.swift b/submodules/ChatMessageInteractiveMediaBadge/Sources/ChatMessageInteractiveMediaBadge.swift similarity index 95% rename from submodules/TelegramUI/Sources/ChatMessageInteractiveMediaBadge.swift rename to submodules/ChatMessageInteractiveMediaBadge/Sources/ChatMessageInteractiveMediaBadge.swift index 09ff15c32c..1c8fd02e91 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaBadge.swift +++ b/submodules/ChatMessageInteractiveMediaBadge/Sources/ChatMessageInteractiveMediaBadge.swift @@ -7,18 +7,21 @@ import TextFormat import RadialStatusNode import AppBundle -enum ChatMessageInteractiveMediaDownloadState: Equatable { +private let font = Font.regular(11.0) +private let boldFont = Font.semibold(11.0) + +public enum ChatMessageInteractiveMediaDownloadState: Equatable { case remote case fetching(progress: Float?) case compactRemote case compactFetching(progress: Float) } -enum ChatMessageInteractiveMediaBadgeContent: Equatable { +public enum ChatMessageInteractiveMediaBadgeContent: Equatable { case text(inset: CGFloat, backgroundColor: UIColor, foregroundColor: UIColor, text: NSAttributedString) case mediaDownload(backgroundColor: UIColor, foregroundColor: UIColor, duration: String, size: String?, muted: Bool, active: Bool) - static func ==(lhs: ChatMessageInteractiveMediaBadgeContent, rhs: ChatMessageInteractiveMediaBadgeContent) -> Bool { + public static func ==(lhs: ChatMessageInteractiveMediaBadgeContent, rhs: ChatMessageInteractiveMediaBadgeContent) -> Bool { switch lhs { case let .text(lhsInset, lhsBackgroundColor, lhsForegroundColor, lhsText): if case let .text(rhsInset, rhsBackgroundColor, rhsForegroundColor, rhsText) = rhs, lhsInset.isEqual(to: rhsInset), lhsBackgroundColor.isEqual(rhsBackgroundColor), lhsForegroundColor.isEqual(rhsForegroundColor), lhsText.isEqual(to: rhsText) { @@ -36,12 +39,9 @@ enum ChatMessageInteractiveMediaBadgeContent: Equatable { } } -private let font = Font.regular(11.0) -private let boldFont = Font.semibold(11.0) - -final class ChatMessageInteractiveMediaBadge: ASDisplayNode { +public final class ChatMessageInteractiveMediaBadge: ASDisplayNode { private var content: ChatMessageInteractiveMediaBadgeContent? - var pressed: (() -> Void)? + public var pressed: (() -> Void)? private var mediaDownloadState: ChatMessageInteractiveMediaDownloadState? @@ -56,7 +56,7 @@ final class ChatMessageInteractiveMediaBadge: ASDisplayNode { private var iconNode: ASImageNode? private var mediaDownloadStatusNode: RadialStatusNode? - override init() { + override public init() { self.backgroundNode = ASImageNode() self.backgroundNode.clipsToBounds = true self.durationNode = ASTextNode() @@ -68,7 +68,7 @@ final class ChatMessageInteractiveMediaBadge: ASDisplayNode { self.backgroundNode.addSubnode(self.durationNode) } - override func didLoad() { + override public func didLoad() { super.didLoad() self.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.tapGesture(_:)))) @@ -87,7 +87,7 @@ final class ChatMessageInteractiveMediaBadge: ASDisplayNode { return self.measureNode.measure(CGSize(width: 240.0, height: 160.0)).width } - func update(theme: PresentationTheme?, content: ChatMessageInteractiveMediaBadgeContent?, mediaDownloadState: ChatMessageInteractiveMediaDownloadState?, alignment: NSTextAlignment = .left, animated: Bool, badgeAnimated: Bool = true) { + public func update(theme: PresentationTheme?, content: ChatMessageInteractiveMediaBadgeContent?, mediaDownloadState: ChatMessageInteractiveMediaDownloadState?, alignment: NSTextAlignment = .left, animated: Bool, badgeAnimated: Bool = true) { var transition: ContainedViewLayoutTransition = animated ? .animated(duration: 0.2, curve: .easeInOut) : .immediate let previousContentSize = self.previousContentSize @@ -297,7 +297,7 @@ final class ChatMessageInteractiveMediaBadge: ASDisplayNode { } } - override func point(inside point: CGPoint, with event: UIEvent?) -> Bool { + override public func point(inside point: CGPoint, with event: UIEvent?) -> Bool { return self.backgroundNode.frame.contains(point) } } diff --git a/submodules/ContactsPeerItem/Sources/ContactsPeerItem.swift b/submodules/ContactsPeerItem/Sources/ContactsPeerItem.swift index 8623c54638..5bfcfebd57 100644 --- a/submodules/ContactsPeerItem/Sources/ContactsPeerItem.swift +++ b/submodules/ContactsPeerItem/Sources/ContactsPeerItem.swift @@ -140,6 +140,7 @@ public class ContactsPeerItem: ItemListItem, ListViewItemWithHeader { let deletePeer: ((PeerId) -> Void)? let itemHighlighting: ContactItemHighlighting? let contextAction: ((ASDisplayNode, ContextGesture?) -> Void)? + let arrowAction: (() -> Void)? public let selectable: Bool @@ -147,7 +148,7 @@ public class ContactsPeerItem: ItemListItem, ListViewItemWithHeader { public let header: ListViewItemHeader? - public init(presentationData: ItemListPresentationData, style: ItemListStyle = .plain, sectionId: ItemListSectionId = 0, sortOrder: PresentationPersonNameOrder, displayOrder: PresentationPersonNameOrder, context: AccountContext, peerMode: ContactsPeerItemPeerMode, peer: ContactsPeerItemPeer, status: ContactsPeerItemStatus, badge: ContactsPeerItemBadge? = nil, enabled: Bool, selection: ContactsPeerItemSelection, editing: ContactsPeerItemEditing, options: [ItemListPeerItemRevealOption] = [], additionalActions: [ContactsPeerItemAction] = [], actionIcon: ContactsPeerItemActionIcon = .none, index: PeerNameIndex?, header: ListViewItemHeader?, action: @escaping (ContactsPeerItemPeer) -> Void, disabledAction: ((ContactsPeerItemPeer) -> Void)? = nil, setPeerIdWithRevealedOptions: ((PeerId?, PeerId?) -> Void)? = nil, deletePeer: ((PeerId) -> Void)? = nil, itemHighlighting: ContactItemHighlighting? = nil, contextAction: ((ASDisplayNode, ContextGesture?) -> Void)? = nil) { + public init(presentationData: ItemListPresentationData, style: ItemListStyle = .plain, sectionId: ItemListSectionId = 0, sortOrder: PresentationPersonNameOrder, displayOrder: PresentationPersonNameOrder, context: AccountContext, peerMode: ContactsPeerItemPeerMode, peer: ContactsPeerItemPeer, status: ContactsPeerItemStatus, badge: ContactsPeerItemBadge? = nil, enabled: Bool, selection: ContactsPeerItemSelection, editing: ContactsPeerItemEditing, options: [ItemListPeerItemRevealOption] = [], additionalActions: [ContactsPeerItemAction] = [], actionIcon: ContactsPeerItemActionIcon = .none, index: PeerNameIndex?, header: ListViewItemHeader?, action: @escaping (ContactsPeerItemPeer) -> Void, disabledAction: ((ContactsPeerItemPeer) -> Void)? = nil, setPeerIdWithRevealedOptions: ((PeerId?, PeerId?) -> Void)? = nil, deletePeer: ((PeerId) -> Void)? = nil, itemHighlighting: ContactItemHighlighting? = nil, contextAction: ((ASDisplayNode, ContextGesture?) -> Void)? = nil, arrowAction: (() -> Void)? = nil) { self.presentationData = presentationData self.style = style self.sectionId = sectionId @@ -172,6 +173,7 @@ public class ContactsPeerItem: ItemListItem, ListViewItemWithHeader { self.itemHighlighting = itemHighlighting self.selectable = enabled || disabledAction != nil self.contextAction = contextAction + self.arrowAction = arrowAction if let index = index { var letter: String = "#" @@ -318,6 +320,7 @@ public class ContactsPeerItemNode: ItemListRevealOptionsItemNode { private var badgeTextNode: TextNode? private var selectionNode: CheckNode? private var actionButtonNodes: [HighlightableButtonNode]? + private var arrowButtonNode: HighlightableButtonNode? private var isHighlighted: Bool = false @@ -503,6 +506,11 @@ public class ContactsPeerItemNode: ItemListRevealOptionsItemNode { break } + var arrowButtonImage: UIImage? + if let _ = item.arrowAction { + arrowButtonImage = generateTintedImage(image: UIImage(bundleImageName: "Chat List/Search/Arrow"), color: item.presentationData.theme.list.disclosureArrowColor) + } + var actionButtons: [ActionButton]? struct ActionButton { let image: UIImage? @@ -856,6 +864,23 @@ public class ContactsPeerItemNode: ItemListRevealOptionsItemNode { actionButtonNodes.forEach { $0.removeFromSupernode() } } + if let arrowButtonImage = arrowButtonImage { + if strongSelf.arrowButtonNode == nil { + let arrowButtonNode = HighlightableButtonNode() + arrowButtonNode.addTarget(self, action: #selector(strongSelf.arrowButtonPressed), forControlEvents: .touchUpInside) + strongSelf.arrowButtonNode = arrowButtonNode + strongSelf.containerNode.addSubnode(arrowButtonNode) + } + if let arrowButtonNode = strongSelf.arrowButtonNode { + arrowButtonNode.setImage(arrowButtonImage, for: .normal) + + transition.updateFrame(node: arrowButtonNode, frame: CGRect(origin: CGPoint(x: params.width - params.rightInset - 12.0 - arrowButtonImage.size.width, y: floor((nodeLayout.contentSize.height - arrowButtonImage.size.height) / 2.0)), size: arrowButtonImage.size)) + } + } else if let arrowButtonNode = strongSelf.arrowButtonNode { + strongSelf.arrowButtonNode = nil + arrowButtonNode.removeFromSupernode() + } + let badgeBackgroundWidth: CGFloat if let currentBadgeBackgroundImage = currentBadgeBackgroundImage, let (badgeTextLayout, badgeTextApply) = badgeTextLayoutAndApply { let badgeBackgroundNode: ASImageNode @@ -1064,4 +1089,10 @@ public class ContactsPeerItemNode: ItemListRevealOptionsItemNode { return nil } } + + @objc func arrowButtonPressed() { + if let (item, _, _, _, _, _) = self.layoutParams { + item.arrowAction?() + } + } } diff --git a/submodules/Display/Source/NavigationBar.swift b/submodules/Display/Source/NavigationBar.swift index 0398a1f050..e8e33a2776 100644 --- a/submodules/Display/Source/NavigationBar.swift +++ b/submodules/Display/Source/NavigationBar.swift @@ -3,6 +3,17 @@ import AsyncDisplayKit private var backArrowImageCache: [Int32: UIImage] = [:] +class SparseNode: ASDisplayNode { + override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + let result = super.hitTest(point, with: event) + if result != self.view { + return result + } else { + return nil + } + } +} + public final class NavigationBarTheme { public static func generateBackArrowImage(color: UIColor) -> UIImage? { return generateImage(CGSize(width: 13.0, height: 22.0), rotatedContext: { size, context in @@ -126,7 +137,8 @@ open class NavigationBar: ASDisplayNode { } private let stripeNode: ASDisplayNode - private let clippingNode: ASDisplayNode + private let clippingNode: SparseNode + private let buttonsContainerNode: ASDisplayNode public private(set) var contentNode: NavigationBarContentNode? public private(set) var secondaryContentNode: ASDisplayNode? @@ -260,7 +272,7 @@ open class NavigationBar: ASDisplayNode { self.titleNode.attributedText = NSAttributedString(string: title, font: Font.bold(17.0), textColor: self.presentationData.theme.primaryTextColor) self.titleNode.accessibilityLabel = title if self.titleNode.supernode == nil { - self.clippingNode.addSubnode(self.titleNode) + self.buttonsContainerNode.addSubnode(self.titleNode) } } else { self.titleNode.removeFromSupernode() @@ -279,7 +291,7 @@ open class NavigationBar: ASDisplayNode { } if let titleView = self.titleView { - self.clippingNode.view.addSubview(titleView) + self.buttonsContainerNode.view.addSubview(titleView) } self.invalidateCalculatedLayout() @@ -499,7 +511,7 @@ open class NavigationBar: ASDisplayNode { } if self.leftButtonNode.supernode == nil { - self.clippingNode.addSubnode(self.leftButtonNode) + self.buttonsContainerNode.addSubnode(self.leftButtonNode) } if animated { @@ -540,9 +552,9 @@ open class NavigationBar: ASDisplayNode { if let backTitle = backTitle { self.backButtonNode.updateManualText(backTitle) if self.backButtonNode.supernode == nil { - self.clippingNode.addSubnode(self.backButtonNode) - self.clippingNode.addSubnode(self.backButtonArrow) - self.clippingNode.addSubnode(self.badgeNode) + self.buttonsContainerNode.addSubnode(self.backButtonNode) + self.buttonsContainerNode.addSubnode(self.backButtonArrow) + self.buttonsContainerNode.addSubnode(self.badgeNode) } if animated { @@ -588,7 +600,7 @@ open class NavigationBar: ASDisplayNode { } self.rightButtonNode.updateItems(items) if self.rightButtonNode.supernode == nil { - self.clippingNode.addSubnode(self.rightButtonNode) + self.buttonsContainerNode.addSubnode(self.rightButtonNode) } if animated { self.rightButtonNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.15) @@ -648,25 +660,25 @@ open class NavigationBar: ASDisplayNode { if let transitionTitleNode = value.navigationBar?.makeTransitionTitleNode(foregroundColor: self.presentationData.theme.primaryTextColor) { self.transitionTitleNode = transitionTitleNode if self.leftButtonNode.supernode != nil { - self.clippingNode.insertSubnode(transitionTitleNode, belowSubnode: self.leftButtonNode) + self.buttonsContainerNode.insertSubnode(transitionTitleNode, belowSubnode: self.leftButtonNode) } else if self.backButtonNode.supernode != nil { - self.clippingNode.insertSubnode(transitionTitleNode, belowSubnode: self.backButtonNode) + self.buttonsContainerNode.insertSubnode(transitionTitleNode, belowSubnode: self.backButtonNode) } else { - self.clippingNode.addSubnode(transitionTitleNode) + self.buttonsContainerNode.addSubnode(transitionTitleNode) } } case .bottom: if let transitionBackButtonNode = value.navigationBar?.makeTransitionBackButtonNode(accentColor: self.presentationData.theme.buttonColor) { self.transitionBackButtonNode = transitionBackButtonNode - self.clippingNode.addSubnode(transitionBackButtonNode) + self.buttonsContainerNode.addSubnode(transitionBackButtonNode) } if let transitionBackArrowNode = value.navigationBar?.makeTransitionBackArrowNode(accentColor: self.presentationData.theme.buttonColor) { self.transitionBackArrowNode = transitionBackArrowNode - self.clippingNode.addSubnode(transitionBackArrowNode) + self.buttonsContainerNode.addSubnode(transitionBackArrowNode) } if let transitionBadgeNode = value.navigationBar?.makeTransitionBadgeNode() { self.transitionBadgeNode = transitionBadgeNode - self.clippingNode.addSubnode(transitionBadgeNode) + self.buttonsContainerNode.addSubnode(transitionBadgeNode) } } } @@ -701,9 +713,12 @@ open class NavigationBar: ASDisplayNode { self.rightButtonNode = NavigationButtonNode() self.rightButtonNode.hitTestSlop = UIEdgeInsets(top: -4.0, left: -4.0, bottom: -4.0, right: -10.0) - self.clippingNode = ASDisplayNode() + self.clippingNode = SparseNode() self.clippingNode.clipsToBounds = true + self.buttonsContainerNode = ASDisplayNode() + self.buttonsContainerNode.clipsToBounds = true + self.backButtonNode.color = self.presentationData.theme.buttonColor self.backButtonNode.disabledColor = self.presentationData.theme.disabledButtonColor self.leftButtonNode.color = self.presentationData.theme.buttonColor @@ -720,6 +735,7 @@ open class NavigationBar: ASDisplayNode { super.init() + self.addSubnode(self.buttonsContainerNode) self.addSubnode(self.clippingNode) self.backgroundColor = self.presentationData.theme.backgroundColor @@ -821,7 +837,7 @@ open class NavigationBar: ASDisplayNode { self.validLayout = (size, defaultHeight, additionalHeight, leftInset, rightInset, appearsHidden) if let secondaryContentNode = self.secondaryContentNode { - transition.updateAlpha(node: secondaryContentNode, alpha: appearsHidden ? 0.0 : 1.0) +// transition.updateAlpha(node: secondaryContentNode, alpha: appearsHidden ? 0.0 : 1.0) } let apparentAdditionalHeight: CGFloat = self.secondaryContentNode != nil ? NavigationBar.defaultSecondaryContentHeight : 0.0 @@ -830,6 +846,7 @@ open class NavigationBar: ASDisplayNode { let backButtonInset: CGFloat = leftInset + 27.0 transition.updateFrame(node: self.clippingNode, frame: CGRect(origin: CGPoint(), size: size)) + transition.updateFrame(node: self.buttonsContainerNode, frame: CGRect(origin: CGPoint(), size: size)) var expansionHeight: CGFloat = 0.0 if let contentNode = self.contentNode { var contentNodeFrame: CGRect @@ -839,7 +856,9 @@ open class NavigationBar: ASDisplayNode { contentNodeFrame = CGRect(origin: CGPoint(x: 0.0, y: 0.0), size: CGSize(width: size.width, height: size.height)) case .expansion: expansionHeight = contentNode.height - contentNodeFrame = CGRect(origin: CGPoint(x: 0.0, y: size.height - expansionHeight - apparentAdditionalHeight), size: CGSize(width: size.width, height: expansionHeight)) + + let additionalExpansionHeight: CGFloat = self.secondaryContentNode != nil && appearsHidden ? NavigationBar.defaultSecondaryContentHeight : 0.0 + contentNodeFrame = CGRect(origin: CGPoint(x: 0.0, y: size.height - expansionHeight - apparentAdditionalHeight - additionalExpansionHeight), size: CGSize(width: size.width, height: expansionHeight)) if appearsHidden { if self.secondaryContentNode != nil { contentNodeFrame.origin.y += NavigationBar.defaultSecondaryContentHeight @@ -1174,10 +1193,10 @@ open class NavigationBar: ASDisplayNode { contentNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) } - if case .replacement = contentNode.mode, !self.clippingNode.alpha.isZero { - self.clippingNode.alpha = 0.0 + if case .replacement = contentNode.mode, !self.buttonsContainerNode.alpha.isZero { + self.buttonsContainerNode.alpha = 0.0 if animated { - self.clippingNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.2) + self.buttonsContainerNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.2) } } @@ -1187,23 +1206,35 @@ open class NavigationBar: ASDisplayNode { } else { self.requestLayout() } - } else if self.clippingNode.alpha.isZero { - self.clippingNode.alpha = 1.0 + } else if self.buttonsContainerNode.alpha.isZero { + self.buttonsContainerNode.alpha = 1.0 if animated { - self.clippingNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) + self.buttonsContainerNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) } } } } - public func setSecondaryContentNode(_ secondatryContentNode: ASDisplayNode?) { - if self.secondaryContentNode !== secondatryContentNode { + public func setSecondaryContentNode(_ secondaryContentNode: ASDisplayNode?, animated: Bool = false) { + if self.secondaryContentNode !== secondaryContentNode { if let previous = self.secondaryContentNode { - previous.removeFromSupernode() + if animated { + previous.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.3, completion: { [weak previous] finished in + if finished { + previous?.removeFromSupernode() + } + }) + } else { + previous.removeFromSupernode() + } } - self.secondaryContentNode = secondatryContentNode - if let secondaryContentNode = secondatryContentNode { + self.secondaryContentNode = secondaryContentNode + if let secondaryContentNode = secondaryContentNode { self.clippingNode.addSubnode(secondaryContentNode) + + if animated { + secondaryContentNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3) + } } } } @@ -1223,11 +1254,11 @@ open class NavigationBar: ASDisplayNode { if let contentNode = self.contentNode, case .replacement = contentNode.mode { } else { let targetAlpha: CGFloat = hidden ? 0.0 : 1.0 - let previousAlpha = self.clippingNode.alpha + let previousAlpha = self.buttonsContainerNode.alpha if previousAlpha != targetAlpha { - self.clippingNode.alpha = targetAlpha + self.buttonsContainerNode.alpha = targetAlpha if animated { - self.clippingNode.layer.animateAlpha(from: previousAlpha, to: targetAlpha, duration: 0.2) + self.buttonsContainerNode.layer.animateAlpha(from: previousAlpha, to: targetAlpha, duration: 0.2) } } } @@ -1247,7 +1278,7 @@ open class NavigationBar: ASDisplayNode { return nil } - if result == self.view || result == self.clippingNode.view { + if result == self.view || result == self.buttonsContainerNode.view { return nil } diff --git a/submodules/Display/Source/TabBarController.swift b/submodules/Display/Source/TabBarController.swift index 313b2382e1..6adad68208 100644 --- a/submodules/Display/Source/TabBarController.swift +++ b/submodules/Display/Source/TabBarController.swift @@ -340,9 +340,9 @@ open class TabBarController: ViewController { } } - public func updateLayout() { + public func updateLayout(transition: ContainedViewLayoutTransition = .immediate) { if let layout = self.validLayout { - self.containerLayoutUpdated(layout, transition: .immediate) + self.containerLayoutUpdated(layout, transition: transition) } } diff --git a/submodules/Display/Source/ViewController.swift b/submodules/Display/Source/ViewController.swift index c3d7b1d01d..37c1a7a2a1 100644 --- a/submodules/Display/Source/ViewController.swift +++ b/submodules/Display/Source/ViewController.swift @@ -400,6 +400,9 @@ public enum TabBarItemContextActionType { if let contentNode = navigationBar.contentNode, case .expansion = contentNode.mode, !self.displayNavigationBar { navigationBarFrame.origin.y += contentNode.height + statusBarHeight } + if let _ = navigationBar.contentNode, let _ = navigationBar.secondaryContentNode, !self.displayNavigationBar { + navigationBarFrame.origin.y += NavigationBar.defaultSecondaryContentHeight + } navigationBar.updateLayout(size: navigationBarFrame.size, defaultHeight: defaultNavigationBarHeight, additionalHeight: 0.0, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right, appearsHidden: !self.displayNavigationBar, transition: transition) if !transition.isAnimated { navigationBar.layer.cancelAnimationsRecursive(key: "bounds") diff --git a/submodules/FileMediaResourceStatus/BUCK b/submodules/FileMediaResourceStatus/BUCK new file mode 100644 index 0000000000..9e5d1ea350 --- /dev/null +++ b/submodules/FileMediaResourceStatus/BUCK @@ -0,0 +1,23 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "GameUI", + srcs = glob([ + "Sources/**/*.swift", + ]), + deps = [ + "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", + "//submodules/AsyncDisplayKit:AsyncDisplayKit#shared", + "//submodules/Display:Display#shared", + "//submodules/Postbox:Postbox#shared", + "//submodules/TelegramCore:TelegramCore#shared", + "//submodules/SyncCore:SyncCore#shared", + "//submodules/AccountContext:AccountContext", + "//submodules/MediaPlayer:UniversalMediaPlayer", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + "$SDKROOT/System/Library/Frameworks/WebKit.framework", + ], +) diff --git a/submodules/FileMediaResourceStatus/BUILD b/submodules/FileMediaResourceStatus/BUILD new file mode 100644 index 0000000000..b58e90917c --- /dev/null +++ b/submodules/FileMediaResourceStatus/BUILD @@ -0,0 +1,22 @@ +load("@build_bazel_rules_swift//swift:swift.bzl", "swift_library") + +swift_library( + name = "FileMediaResourceStatus", + module_name = "FileMediaResourceStatus", + srcs = glob([ + "Sources/**/*.swift", + ]), + deps = [ + "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit", + "//submodules/AsyncDisplayKit:AsyncDisplayKit", + "//submodules/Display:Display", + "//submodules/Postbox:Postbox", + "//submodules/TelegramCore:TelegramCore", + "//submodules/SyncCore:SyncCore", + "//submodules/AccountContext:AccountContext", + "//submodules/MediaPlayer:UniversalMediaPlayer", + ], + visibility = [ + "//visibility:public", + ], +) diff --git a/submodules/TelegramUI/Sources/FileMediaResourceStatus.swift b/submodules/FileMediaResourceStatus/Sources/FileMediaResourceStatus.swift similarity index 80% rename from submodules/TelegramUI/Sources/FileMediaResourceStatus.swift rename to submodules/FileMediaResourceStatus/Sources/FileMediaResourceStatus.swift index 66f8e5198d..30b7e823eb 100644 --- a/submodules/TelegramUI/Sources/FileMediaResourceStatus.swift +++ b/submodules/FileMediaResourceStatus/Sources/FileMediaResourceStatus.swift @@ -7,12 +7,12 @@ import SwiftSignalKit import UniversalMediaPlayer import AccountContext -private func internalMessageFileMediaPlaybackStatus(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool) -> Signal { +private func internalMessageFileMediaPlaybackStatus(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool, isGlobalSearch: Bool) -> Signal { guard let playerType = peerMessageMediaPlayerType(message) else { return .single(nil) } - if let (playlistId, itemId) = peerMessagesMediaPlaylistAndItemId(message, isRecentActions: isRecentActions) { + if let (playlistId, itemId) = peerMessagesMediaPlaylistAndItemId(message, isRecentActions: isRecentActions, isGlobalSearch: isGlobalSearch) { return context.sharedContext.mediaManager.filteredPlaylistState(accountId: context.account.id, playlistId: playlistId, itemId: itemId, type: playerType) |> mapToSignal { state -> Signal in return .single(state?.status) @@ -22,31 +22,31 @@ private func internalMessageFileMediaPlaybackStatus(context: AccountContext, fil } } -func messageFileMediaPlaybackStatus(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool) -> Signal { +public func messageFileMediaPlaybackStatus(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool, isGlobalSearch: Bool) -> Signal { var duration = 0.0 if let value = file.duration { duration = Double(value) } let defaultStatus = MediaPlayerStatus(generationTimestamp: 0.0, duration: duration, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .paused, soundEnabled: true) - return internalMessageFileMediaPlaybackStatus(context: context, file: file, message: message, isRecentActions: isRecentActions) |> map { status in + return internalMessageFileMediaPlaybackStatus(context: context, file: file, message: message, isRecentActions: isRecentActions, isGlobalSearch: isGlobalSearch) |> map { status in return status ?? defaultStatus } } -func messageFileMediaPlaybackAudioLevelEvents(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool) -> Signal { +public func messageFileMediaPlaybackAudioLevelEvents(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool, isGlobalSearch: Bool) -> Signal { guard let playerType = peerMessageMediaPlayerType(message) else { return .never() } - if let (playlistId, itemId) = peerMessagesMediaPlaylistAndItemId(message, isRecentActions: isRecentActions) { + if let (playlistId, itemId) = peerMessagesMediaPlaylistAndItemId(message, isRecentActions: isRecentActions, isGlobalSearch: isGlobalSearch) { return context.sharedContext.mediaManager.filteredPlayerAudioLevelEvents(accountId: context.account.id, playlistId: playlistId, itemId: itemId, type: playerType) } else { return .never() } } -func messageFileMediaResourceStatus(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool, isSharedMedia: Bool = false) -> Signal { - let playbackStatus = internalMessageFileMediaPlaybackStatus(context: context, file: file, message: message, isRecentActions: isRecentActions) |> map { status -> MediaPlayerPlaybackStatus? in +public func messageFileMediaResourceStatus(context: AccountContext, file: TelegramMediaFile, message: Message, isRecentActions: Bool, isSharedMedia: Bool = false, isGlobalSearch: Bool = false) -> Signal { + let playbackStatus = internalMessageFileMediaPlaybackStatus(context: context, file: file, message: message, isRecentActions: isRecentActions, isGlobalSearch: isGlobalSearch) |> map { status -> MediaPlayerPlaybackStatus? in return status?.status } diff --git a/submodules/GalleryUI/Sources/GalleryController.swift b/submodules/GalleryUI/Sources/GalleryController.swift index ec63e10e54..f529c52a13 100644 --- a/submodules/GalleryUI/Sources/GalleryController.swift +++ b/submodules/GalleryUI/Sources/GalleryController.swift @@ -247,6 +247,7 @@ public final class GalleryControllerPresentationArguments { private enum GalleryMessageHistoryView { case view(MessageHistoryView) case single(MessageHistoryEntry) + case searchResults(SearchMessagesResult, SearchMessagesState) var entries: [MessageHistoryEntry] { switch self { @@ -254,12 +255,14 @@ private enum GalleryMessageHistoryView { return view.entries case let .single(entry): return [entry] + case let .searchResults(result, _): + return result.messages.map { MessageHistoryEntry(message: $0, isRead: false, location: nil, monthLocation: nil, attributes: MutableMessageHistoryEntryAttributes(authorIsContact: false)) } } } var tagMask: MessageTags? { switch self { - case .single: + case .single, .searchResults: return nil case let .view(view): return view.tagMask @@ -272,6 +275,8 @@ private enum GalleryMessageHistoryView { return false case let .view(view): return view.earlierId != nil + case let .searchResults(result, _): + return false } } @@ -281,15 +286,12 @@ private enum GalleryMessageHistoryView { return false case let .view(view): return view.laterId != nil + case let .searchResults(result, _): + return false } } } -public enum GalleryControllerItemSource { - case peerMessagesAtId(messageId: MessageId, chatLocation: ChatLocation, chatLocationContextHolder: Atomic) - case standaloneMessage(Message) -} - public enum GalleryControllerInteractionTapAction { case url(url: String, concealed: Bool) case textMention(String) @@ -421,6 +423,8 @@ public class GalleryController: ViewController, StandalonePresentableController message = context.account.postbox.messageAtId(messageId) case let .standaloneMessage(m): message = .single(m) + case let .searchResult(result, _, messageId): + message = .single(result.messages.first(where: { $0.id == messageId })) } let messageView = message @@ -445,6 +449,8 @@ public class GalleryController: ViewController, StandalonePresentableController } case .standaloneMessage: return .single(GalleryMessageHistoryView.single(MessageHistoryEntry(message: message!, isRead: false, location: nil, monthLocation: nil, attributes: MutableMessageHistoryEntryAttributes(authorIsContact: false)))) + case let .searchResult(result, state, _): + return .single(GalleryMessageHistoryView.searchResults(result, state)) } } |> take(1) @@ -480,6 +486,11 @@ public class GalleryController: ViewController, StandalonePresentableController centralEntryStableId = message.stableId break loop } + case let .searchResult(result, state, messageId): + if message.id == messageId { + centralEntryStableId = message.stableId + break loop + } } } diff --git a/submodules/HashtagSearchUI/Sources/HashtagSearchController.swift b/submodules/HashtagSearchUI/Sources/HashtagSearchController.swift index 538fa413c0..c5d3b8f3fb 100644 --- a/submodules/HashtagSearchUI/Sources/HashtagSearchController.swift +++ b/submodules/HashtagSearchUI/Sources/HashtagSearchController.swift @@ -41,7 +41,7 @@ public final class HashtagSearchController: TelegramBaseController { let chatListPresentationData = ChatListPresentationData(theme: self.presentationData.theme, fontSize: self.presentationData.listsFontSize, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameSortOrder: self.presentationData.nameSortOrder, nameDisplayOrder: self.presentationData.nameDisplayOrder, disableAnimations: self.presentationData.disableAnimations) - let location: SearchMessagesLocation = .general(tags: nil) + let location: SearchMessagesLocation = .general(tags: nil, minDate: nil, maxDate: nil) let search = searchMessages(account: context.account, location: location, query: query, state: nil) let foundMessages: Signal<[ChatListSearchEntry], NoError> = search |> map { result, _ in @@ -83,9 +83,12 @@ public final class HashtagSearchController: TelegramBaseController { let previousEntries = previousSearchItems.swap(entries) let firstTime = previousEntries == nil - let transition = chatListSearchContainerPreparedTransition(from: previousEntries ?? [], to: entries, displayingResults: true, context: strongSelf.context, presentationData: strongSelf.presentationData, enableHeaders: false, filter: [], interaction: interaction, peerContextAction: nil, toggleExpandLocalResults: { + let transition = chatListSearchContainerPreparedTransition(from: previousEntries ?? [], to: entries, displayingResults: true, isEmpty: entries.isEmpty, searchQuery: "", context: strongSelf.context, presentationData: strongSelf.presentationData, enableHeaders: false, filter: [], interaction: interaction, peerContextAction: nil, toggleExpandLocalResults: { }, toggleExpandGlobalResults: { - }) + }, presentDatePicker: { + }, searchPeer: { _ in + + }, searchResults: [], searchOptions: nil, messageContextAction: nil) strongSelf.controllerNode.enqueueTransition(transition, firstTime: firstTime) } }) diff --git a/submodules/InstantPageUI/Sources/InstantPageLayout.swift b/submodules/InstantPageUI/Sources/InstantPageLayout.swift index 65fe599451..4de40ca9b9 100644 --- a/submodules/InstantPageUI/Sources/InstantPageLayout.swift +++ b/submodules/InstantPageUI/Sources/InstantPageLayout.swift @@ -855,6 +855,9 @@ func instantPageLayoutForWebPage(_ webPage: TelegramMediaWebpage, boundingWidth: if let image = loadedContent.image, let id = image.id { media[id] = image } + if let video = loadedContent.file, let id = video.id { + media[id] = video + } var mediaIndexCounter: Int = 0 var embedIndexCounter: Int = 0 diff --git a/submodules/ListMessageItem/BUCK b/submodules/ListMessageItem/BUCK new file mode 100644 index 0000000000..1058aa53d9 --- /dev/null +++ b/submodules/ListMessageItem/BUCK @@ -0,0 +1,36 @@ +load("//Config:buck_rule_macros.bzl", "static_library") + +static_library( + name = "ItemListAddressItem", + srcs = glob([ + "Sources/**/*.swift", + ]), + deps = [ + "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit#shared", + "//submodules/AsyncDisplayKit:AsyncDisplayKit#shared", + "//submodules/Display:Display#shared", + "//submodules/TelegramPresentationData:TelegramPresentationData", + "//submodules/ItemListUI:ItemListUI", + "//submodules/AccountContext:AccountContext", + "//submodules/TextFormat:TextFormat", + "//submodules/AppBundle:AppBundle", + "//submodules/PresentationDataUtils:PresentationDataUtils", + "//submodules/TelegramUIPreferences:TelegramUIPreferences", + "//submodules/ListSectionHeaderNode:ListSectionHeaderNode", + "//submodules/TelegramStringFormatting:TelegramStringFormatting", + "//submodules/UrlHandling:UrlHandling", + "//submodules/UrlWhitelist:UrlWhitelist", + "//submodules/WebsiteType:WebsiteType", + "//submodules/PhotoResources:PhotoResources", + "//submodules/RadialStatusNode:RadialStatusNode", + "//submodules/SemanticStatusNode:SemanticStatusNode", + "//submodules/MusicAlbumArtResources:MusicAlbumArtResources", + "//submodules/MediaPlayer:UniversalMediaPlayer", + "//submodules/ContextUI:ContextUI", + "//submodules/FileMediaResourceStatus:FileMediaResourceStatus", + ], + frameworks = [ + "$SDKROOT/System/Library/Frameworks/Foundation.framework", + "$SDKROOT/System/Library/Frameworks/UIKit.framework", + ], +) diff --git a/submodules/ListMessageItem/BUILD b/submodules/ListMessageItem/BUILD new file mode 100644 index 0000000000..55edc54d95 --- /dev/null +++ b/submodules/ListMessageItem/BUILD @@ -0,0 +1,38 @@ +load("@build_bazel_rules_swift//swift:swift.bzl", "swift_library") + +swift_library( + name = "ListMessageItem", + module_name = "ListMessageItem", + srcs = glob([ + "Sources/**/*.swift", + ]), + deps = [ + "//submodules/SSignalKit/SwiftSignalKit:SwiftSignalKit", + "//submodules/AsyncDisplayKit:AsyncDisplayKit", + "//submodules/Display:Display", + "//submodules/TelegramCore:TelegramCore", + "//submodules/SyncCore:SyncCore", + "//submodules/TelegramPresentationData:TelegramPresentationData", + "//submodules/ItemListUI:ItemListUI", + "//submodules/AccountContext:AccountContext", + "//submodules/TextFormat:TextFormat", + "//submodules/AppBundle:AppBundle", + "//submodules/PresentationDataUtils:PresentationDataUtils", + "//submodules/TelegramUIPreferences:TelegramUIPreferences", + "//submodules/ListSectionHeaderNode:ListSectionHeaderNode", + "//submodules/TelegramStringFormatting:TelegramStringFormatting", + "//submodules/UrlHandling:UrlHandling", + "//submodules/UrlWhitelist:UrlWhitelist", + "//submodules/WebsiteType:WebsiteType", + "//submodules/PhotoResources:PhotoResources", + "//submodules/RadialStatusNode:RadialStatusNode", + "//submodules/SemanticStatusNode:SemanticStatusNode", + "//submodules/MusicAlbumArtResources:MusicAlbumArtResources", + "//submodules/MediaPlayer:UniversalMediaPlayer", + "//submodules/ContextUI:ContextUI", + "//submodules/FileMediaResourceStatus:FileMediaResourceStatus", + ], + visibility = [ + "//visibility:public", + ], +) diff --git a/submodules/TelegramUI/Sources/ListMessageDateHeader.swift b/submodules/ListMessageItem/Sources/ListMessageDateHeader.swift similarity index 89% rename from submodules/TelegramUI/Sources/ListMessageDateHeader.swift rename to submodules/ListMessageItem/Sources/ListMessageDateHeader.swift index 67f3523968..8205218905 100644 --- a/submodules/TelegramUI/Sources/ListMessageDateHeader.swift +++ b/submodules/ListMessageItem/Sources/ListMessageDateHeader.swift @@ -16,7 +16,7 @@ private let timezoneOffset: Int32 = { return Int32(timeinfoNow.tm_gmtoff) }() -func listMessageDateHeaderId(timestamp: Int32) -> Int64 { +public func listMessageDateHeaderId(timestamp: Int32) -> Int64 { let unclippedValue: Int64 = min(Int64(Int32.max), Int64(timestamp) + Int64(timezoneOffset)) var time: time_t = time_t(Int32(clamping: unclippedValue)) @@ -28,7 +28,7 @@ func listMessageDateHeaderId(timestamp: Int32) -> Int64 { return Int64(roundedTimestamp) } -func listMessageDateHeaderInfo(timestamp: Int32) -> (year: Int32, month: Int32) { +public func listMessageDateHeaderInfo(timestamp: Int32) -> (year: Int32, month: Int32) { var time: time_t = time_t(timestamp + timezoneOffset) var timeinfo: tm = tm() localtime_r(&time, &timeinfo) @@ -76,7 +76,7 @@ final class ListMessageDateHeader: ListViewItemHeader { } } -final class ListMessageDateHeaderNode: ListViewItemHeaderNode { +public final class ListMessageDateHeaderNode: ListViewItemHeaderNode { var theme: PresentationTheme var strings: PresentationStrings let headerNode: ListSectionHeaderNode @@ -99,7 +99,7 @@ final class ListMessageDateHeaderNode: ListViewItemHeaderNode { self.headerNode.title = stringForMonth(strings: strings, month: month, ofYear: year).uppercased() } - func updateThemeAndStrings(theme: PresentationTheme, strings: PresentationStrings) { + public func updateThemeAndStrings(theme: PresentationTheme, strings: PresentationStrings) { self.theme = theme self.headerNode.updateTheme(theme: theme) @@ -109,7 +109,7 @@ final class ListMessageDateHeaderNode: ListViewItemHeaderNode { self.setNeedsLayout() } - override func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat) { + override public func updateLayout(size: CGSize, leftInset: CGFloat, rightInset: CGFloat) { let headerFrame = CGRect(origin: CGPoint(x: 0.0, y: -UIScreenPixel), size: CGSize(width: size.width, height: size.height + UIScreenPixel)) self.headerNode.frame = headerFrame self.headerNode.updateLayout(size: headerFrame.size, leftInset: leftInset, rightInset: rightInset) diff --git a/submodules/TelegramUI/Sources/ListMessageFileItemNode.swift b/submodules/ListMessageItem/Sources/ListMessageFileItemNode.swift similarity index 82% rename from submodules/TelegramUI/Sources/ListMessageFileItemNode.swift rename to submodules/ListMessageItem/Sources/ListMessageFileItemNode.swift index fd4ea3088e..c680379c18 100644 --- a/submodules/TelegramUI/Sources/ListMessageFileItemNode.swift +++ b/submodules/ListMessageItem/Sources/ListMessageFileItemNode.swift @@ -18,6 +18,7 @@ import PhotoResources import MusicAlbumArtResources import UniversalMediaPlayer import ContextUI +import FileMediaResourceStatus private let extensionImageCache = Atomic<[UInt32: UIImage]>(value: [:]) @@ -88,6 +89,36 @@ private func extensionImage(fileExtension: String?) -> UIImage? { } private let extensionFont = Font.with(size: 15.0, design: .round, traits: [.bold]) +func fullAuthorString(for item: ListMessageItem) -> String { + var authorString = "" + if let author = item.message.author, [Namespaces.Peer.CloudGroup, Namespaces.Peer.CloudChannel].contains(item.message.id.peerId.namespace) { + var authorName = "" + if author.id == item.context.account.peerId { + authorName = item.presentationData.strings.DialogList_You + } else { + authorName = author.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder) + } + if let peer = item.message.peers[item.message.id.peerId], author.id != peer.id { + authorString = "\(authorName) → \(peer.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder))" + } else { + authorString = authorName + } + } else if let peer = item.message.peers[item.message.id.peerId] { + if item.message.id.peerId.namespace == Namespaces.Peer.CloudChannel { + authorString = peer.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder) + } else { + if item.message.id.peerId == item.context.account.peerId { + authorString = item.presentationData.strings.DialogList_SavedMessages + } else if item.message.flags.contains(.Incoming) { + authorString = peer.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder) + } else { + authorString = "\(item.presentationData.strings.DialogList_You) → \(peer.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder))" + } + } + } + return authorString +} + private struct FetchControls { let fetch: () -> Void let cancel: () -> Void @@ -122,7 +153,7 @@ private enum FileIconImage: Equatable { } } -final class ListMessageFileItemNode: ListMessageNode { +public final class ListMessageFileItemNode: ListMessageNode { private let contextSourceNode: ContextExtractedContentContainingNode private let containerNode: ContextControllerSourceNode private let extractedBackgroundImageNode: ASImageNode @@ -140,6 +171,7 @@ final class ListMessageFileItemNode: ListMessageNode { private let titleNode: TextNode private let descriptionNode: TextNode private let descriptionProgressNode: ImmediateTextNode + private let dateNode: TextNode private let extensionIconNode: ASImageNode private let extensionIconText: TextNode @@ -195,6 +227,9 @@ final class ListMessageFileItemNode: ListMessageNode { self.descriptionProgressNode.isUserInteractionEnabled = false self.descriptionProgressNode.maximumNumberOfLines = 1 + self.dateNode = TextNode() + self.dateNode.isUserInteractionEnabled = false + self.extensionIconNode = ASImageNode() self.extensionIconNode.isLayerBacked = true self.extensionIconNode.displaysAsynchronously = false @@ -228,6 +263,7 @@ final class ListMessageFileItemNode: ListMessageNode { self.offsetContainerNode.addSubnode(self.titleNode) self.offsetContainerNode.addSubnode(self.descriptionNode) self.offsetContainerNode.addSubnode(self.descriptionProgressNode) + self.offsetContainerNode.addSubnode(self.dateNode) self.offsetContainerNode.addSubnode(self.extensionIconNode) self.offsetContainerNode.addSubnode(self.extensionIconText) self.offsetContainerNode.addSubnode(self.iconStatusNode) @@ -237,7 +273,7 @@ final class ListMessageFileItemNode: ListMessageNode { return } - item.controllerInteraction.openMessageContextMenu(item.message, false, strongSelf.contextSourceNode, strongSelf.contextSourceNode.bounds, gesture) + item.interaction.openMessageContextMenu(item.message, false, strongSelf.contextSourceNode, strongSelf.contextSourceNode.bounds, gesture) } self.contextSourceNode.willUpdateIsExtractedToContextPreview = { [weak self] isExtracted, transition in @@ -246,7 +282,7 @@ final class ListMessageFileItemNode: ListMessageNode { } if isExtracted { - strongSelf.extractedBackgroundImageNode.image = generateStretchableFilledCircleImage(diameter: 28.0, color: item.theme.list.plainBackgroundColor) + strongSelf.extractedBackgroundImageNode.image = generateStretchableFilledCircleImage(diameter: 28.0, color: item.presentationData.theme.theme.list.plainBackgroundColor) } if let extractedRect = strongSelf.extractedRect, let nonExtractedRect = strongSelf.nonExtractedRect { @@ -260,6 +296,7 @@ final class ListMessageFileItemNode: ListMessageNode { self?.extractedBackgroundImageNode.image = nil } }) + transition.updateAlpha(node: strongSelf.dateNode, alpha: isExtracted ? 0.0 : 1.0) } } @@ -294,14 +331,15 @@ final class ListMessageFileItemNode: ListMessageNode { self.addTransitionOffsetAnimation(0.0, duration: duration, beginAt: currentTimestamp) } - override func animateRemoved(_ currentTimestamp: Double, duration: Double) { + override public func animateRemoved(_ currentTimestamp: Double, duration: Double) { self.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15, removeOnCompletion: false) } - override func asyncLayout() -> (_ item: ListMessageItem, _ params: ListViewItemLayoutParams, _ mergedTop: Bool, _ mergedBottom: Bool, _ dateHeaderAtBottom: Bool) -> (ListViewItemNodeLayout, (ListViewItemUpdateAnimation) -> Void) { + override public func asyncLayout() -> (_ item: ListMessageItem, _ params: ListViewItemLayoutParams, _ mergedTop: Bool, _ mergedBottom: Bool, _ dateHeaderAtBottom: Bool) -> (ListViewItemNodeLayout, (ListViewItemUpdateAnimation) -> Void) { let titleNodeMakeLayout = TextNode.asyncLayout(self.titleNode) let descriptionNodeMakeLayout = TextNode.asyncLayout(self.descriptionNode) let extensionIconTextMakeLayout = TextNode.asyncLayout(self.extensionIconText) + let dateNodeMakeLayout = TextNode.asyncLayout(self.dateNode) let iconImageLayout = self.iconImageNode.asyncLayout() let currentMedia = self.currentMedia @@ -315,13 +353,14 @@ final class ListMessageFileItemNode: ListMessageNode { return { [weak self] item, params, _, _, dateHeaderAtBottom in var updatedTheme: PresentationTheme? - if currentItem?.theme !== item.theme { - updatedTheme = item.theme + if currentItem?.presentationData.theme.theme !== item.presentationData.theme.theme { + updatedTheme = item.presentationData.theme.theme } - let titleFont = Font.semibold(floor(item.fontSize.baseDisplaySize * 16.0 / 17.0)) - let audioTitleFont = Font.semibold(floor(item.fontSize.baseDisplaySize * 16.0 / 17.0)) - let descriptionFont = Font.regular(floor(item.fontSize.baseDisplaySize * 14.0 / 17.0)) + let titleFont = Font.semibold(floor(item.presentationData.fontSize.baseDisplaySize * 16.0 / 17.0)) + let audioTitleFont = Font.semibold(floor(item.presentationData.fontSize.baseDisplaySize * 16.0 / 17.0)) + let descriptionFont = Font.regular(floor(item.presentationData.fontSize.baseDisplaySize * 14.0 / 17.0)) + let dateFont = Font.regular(floor(item.presentationData.fontSize.itemListBaseFontSize * 14.0 / 17.0)) var leftInset: CGFloat = 65.0 + params.leftInset let rightInset: CGFloat = 8.0 + params.rightInset @@ -329,7 +368,7 @@ final class ListMessageFileItemNode: ListMessageNode { var leftOffset: CGFloat = 0.0 var selectionNodeWidthAndApply: (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode)? if case let .selectable(selected) = item.selection { - let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected, false) + let (selectionWidth, selectionApply) = selectionNodeLayout(item.presentationData.theme.theme.list.itemCheckColors.strokeColor, item.presentationData.theme.theme.list.itemCheckColors.fillColor, item.presentationData.theme.theme.list.itemCheckColors.foregroundColor, selected, false) selectionNodeWidthAndApply = (selectionWidth, selectionApply) leftOffset += selectionWidth } @@ -363,24 +402,37 @@ final class ListMessageFileItemNode: ListMessageNode { isAudio = true isVoice = voice - titleText = NSAttributedString(string: title ?? (file.fileName ?? "Unknown Track"), font: audioTitleFont, textColor: item.theme.list.itemPrimaryTextColor) + titleText = NSAttributedString(string: title ?? (file.fileName ?? "Unknown Track"), font: audioTitleFont, textColor: item.presentationData.theme.theme.list.itemPrimaryTextColor) - let descriptionString: String + var descriptionString: String if let performer = performer { - descriptionString = "\(stringForDuration(Int32(duration))) • \(performer)" + if item.isGlobalSearchResult { + descriptionString = performer + } else { + descriptionString = "\(stringForDuration(Int32(duration))) • \(performer)" + } } else if let size = file.size { - descriptionString = dataSizeString(size, decimalSeparator: item.dateTimeFormat.decimalSeparator) + descriptionString = dataSizeString(size, decimalSeparator: item.presentationData.dateTimeFormat.decimalSeparator) } else { descriptionString = "" } - descriptionText = NSAttributedString(string: descriptionString, font: descriptionFont, textColor: item.theme.list.itemSecondaryTextColor) + if item.isGlobalSearchResult { + let authorString = fullAuthorString(for: item) + if descriptionString.isEmpty { + descriptionString = authorString + } else { + descriptionString = "\(descriptionString) • \(authorString)" + } + } + + descriptionText = NSAttributedString(string: descriptionString, font: descriptionFont, textColor: item.presentationData.theme.theme.list.itemSecondaryTextColor) if !voice { iconImage = .albumArt(file, SharedMediaPlaybackAlbumArt(thumbnailResource: ExternalMusicAlbumArtResource(title: title ?? "", performer: performer ?? "", isThumbnail: true), fullSizeResource: ExternalMusicAlbumArtResource(title: title ?? "", performer: performer ?? "", isThumbnail: false))) } else { - titleText = NSAttributedString(string: " ", font: audioTitleFont, textColor: item.theme.list.itemPrimaryTextColor) - descriptionText = NSAttributedString(string: item.message.author?.displayTitle(strings: item.strings, displayOrder: .firstLast) ?? " ", font: descriptionFont, textColor: item.theme.list.itemSecondaryTextColor) + titleText = NSAttributedString(string: " ", font: audioTitleFont, textColor: item.presentationData.theme.theme.list.itemPrimaryTextColor) + descriptionText = NSAttributedString(string: item.message.author?.displayTitle(strings: item.presentationData.strings, displayOrder: .firstLast) ?? " ", font: descriptionFont, textColor: item.presentationData.theme.theme.list.itemSecondaryTextColor) } } } @@ -389,23 +441,23 @@ final class ListMessageFileItemNode: ListMessageNode { let authorName: String if let author = message.forwardInfo?.author { if author.id == item.context.account.peerId { - authorName = item.strings.DialogList_You + authorName = item.presentationData.strings.DialogList_You } else { - authorName = author.displayTitle(strings: item.strings, displayOrder: .firstLast) + authorName = author.displayTitle(strings: item.presentationData.strings, displayOrder: .firstLast) } } else if let signature = message.forwardInfo?.authorSignature { authorName = signature } else if let author = message.author { if author.id == item.context.account.peerId { - authorName = item.strings.DialogList_You + authorName = item.presentationData.strings.DialogList_You } else { - authorName = author.displayTitle(strings: item.strings, displayOrder: .firstLast) + authorName = author.displayTitle(strings: item.presentationData.strings, displayOrder: .firstLast) } } else { authorName = " " } - titleText = NSAttributedString(string: authorName, font: audioTitleFont, textColor: item.theme.list.itemPrimaryTextColor) - let dateString = stringForFullDate(timestamp: item.message.timestamp, strings: item.strings, dateTimeFormat: item.dateTimeFormat) + titleText = NSAttributedString(string: authorName, font: audioTitleFont, textColor: item.presentationData.theme.theme.list.itemPrimaryTextColor) + let dateString = stringForFullDate(timestamp: item.message.timestamp, strings: item.presentationData.strings, dateTimeFormat: item.presentationData.dateTimeFormat) let descriptionString: String if let duration = file.duration { descriptionString = "\(stringForDuration(Int32(duration))) • \(dateString)" @@ -413,11 +465,11 @@ final class ListMessageFileItemNode: ListMessageNode { descriptionString = dateString } - descriptionText = NSAttributedString(string: descriptionString, font: descriptionFont, textColor: item.theme.list.itemSecondaryTextColor) + descriptionText = NSAttributedString(string: descriptionString, font: descriptionFont, textColor: item.presentationData.theme.theme.list.itemSecondaryTextColor) iconImage = .roundVideo(file) } else if !isAudio { let fileName: String = file.fileName ?? "" - titleText = NSAttributedString(string: fileName, font: titleFont, textColor: item.theme.list.itemPrimaryTextColor) + titleText = NSAttributedString(string: fileName, font: titleFont, textColor: item.presentationData.theme.theme.list.itemPrimaryTextColor) var fileExtension: String? if let range = fileName.range(of: ".", options: [.backwards]) { @@ -432,16 +484,31 @@ final class ListMessageFileItemNode: ListMessageNode { iconImage = .imageRepresentation(file, representation) } - let dateString = stringForFullDate(timestamp: item.message.timestamp, strings: item.strings, dateTimeFormat: item.dateTimeFormat) + let dateString = stringForFullDate(timestamp: item.message.timestamp, strings: item.presentationData.strings, dateTimeFormat: item.presentationData.dateTimeFormat) - let descriptionString: String + var descriptionString: String = "" if let size = file.size { - descriptionString = "\(dataSizeString(size, decimalSeparator: item.dateTimeFormat.decimalSeparator)) • \(dateString)" + if item.isGlobalSearchResult { + descriptionString = (dataSizeString(size, decimalSeparator: item.presentationData.dateTimeFormat.decimalSeparator)) + } else { + descriptionString = "\(dataSizeString(size, decimalSeparator: item.presentationData.dateTimeFormat.decimalSeparator)) • \(dateString)" + } } else { - descriptionString = "\(dateString)" + if !item.isGlobalSearchResult { + descriptionString = "\(dateString)" + } + } + + if item.isGlobalSearchResult { + let authorString = fullAuthorString(for: item) + if descriptionString.isEmpty { + descriptionString = authorString + } else { + descriptionString = "\(descriptionString) • \(authorString)" + } } - descriptionText = NSAttributedString(string: descriptionString, font: descriptionFont, textColor: item.theme.list.itemSecondaryTextColor) + descriptionText = NSAttributedString(string: descriptionString, font: descriptionFont, textColor: item.presentationData.theme.theme.list.itemSecondaryTextColor) } break @@ -478,7 +545,7 @@ final class ListMessageFileItemNode: ListMessageNode { } if statusUpdated { - updatedStatusSignal = messageFileMediaResourceStatus(context: item.context, file: selectedMedia, message: message, isRecentActions: false, isSharedMedia: true) + updatedStatusSignal = messageFileMediaResourceStatus(context: item.context, file: selectedMedia, message: message, isRecentActions: false, isSharedMedia: true, isGlobalSearch: item.isGlobalSearchResult) if isAudio || isInstantVideo { if let currentUpdatedStatusSignal = updatedStatusSignal { @@ -494,14 +561,20 @@ final class ListMessageFileItemNode: ListMessageNode { } } if isVoice { - updatedPlaybackStatusSignal = messageFileMediaPlaybackStatus(context: item.context, file: selectedMedia, message: message, isRecentActions: false) + updatedPlaybackStatusSignal = messageFileMediaPlaybackStatus(context: item.context, file: selectedMedia, message: message, isRecentActions: false, isGlobalSearch: item.isGlobalSearchResult) } } } - let (titleNodeLayout, titleNodeApply) = titleNodeMakeLayout(TextNodeLayoutArguments(attributedString: titleText, backgroundColor: nil, maximumNumberOfLines: 2, truncationType: .middle, constrainedSize: CGSize(width: params.width - leftInset - rightInset - 40.0, height: CGFloat.infinity), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let timestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970) + let dateText = stringForRelativeTimestamp(strings: item.presentationData.strings, relativeTimestamp: item.message.timestamp, relativeTo: timestamp, dateTimeFormat: item.presentationData.dateTimeFormat) + let dateAttributedString = NSAttributedString(string: dateText, font: dateFont, textColor: item.presentationData.theme.theme.list.itemSecondaryTextColor) - let (descriptionNodeLayout, descriptionNodeApply) = descriptionNodeMakeLayout(TextNodeLayoutArguments(attributedString: descriptionText, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - rightInset - 12.0 - 40.0, height: CGFloat.infinity), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let (dateNodeLayout, dateNodeApply) = dateNodeMakeLayout(TextNodeLayoutArguments(attributedString: dateAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - rightInset - 12.0, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + + let (titleNodeLayout, titleNodeApply) = titleNodeMakeLayout(TextNodeLayoutArguments(attributedString: titleText, backgroundColor: nil, maximumNumberOfLines: 2, truncationType: .middle, constrainedSize: CGSize(width: params.width - leftInset - rightInset - dateNodeLayout.size.width, height: CGFloat.infinity), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + + let (descriptionNodeLayout, descriptionNodeApply) = descriptionNodeMakeLayout(TextNodeLayoutArguments(attributedString: descriptionText, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - rightInset - 12.0, height: CGFloat.infinity), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) let (extensionTextLayout, extensionTextApply) = extensionIconTextMakeLayout(TextNodeLayoutArguments(attributedString: extensionText, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: 38.0, height: CGFloat.infinity), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) @@ -511,17 +584,17 @@ final class ListMessageFileItemNode: ListMessageNode { case let .imageRepresentation(_, representation): let iconSize = CGSize(width: 40.0, height: 40.0) let imageCorners = ImageCorners(radius: 6.0) - let arguments = TransformImageArguments(corners: imageCorners, imageSize: representation.dimensions.cgSize.aspectFilled(iconSize), boundingSize: iconSize, intrinsicInsets: UIEdgeInsets(), emptyColor: item.theme.list.mediaPlaceholderColor) + let arguments = TransformImageArguments(corners: imageCorners, imageSize: representation.dimensions.cgSize.aspectFilled(iconSize), boundingSize: iconSize, intrinsicInsets: UIEdgeInsets(), emptyColor: item.presentationData.theme.theme.list.mediaPlaceholderColor) iconImageApply = iconImageLayout(arguments) case .albumArt: let iconSize = CGSize(width: 40.0, height: 40.0) let imageCorners = ImageCorners(radius: iconSize.width / 2.0) - let arguments = TransformImageArguments(corners: imageCorners, imageSize: iconSize, boundingSize: iconSize, intrinsicInsets: UIEdgeInsets(), emptyColor: item.theme.list.mediaPlaceholderColor) + let arguments = TransformImageArguments(corners: imageCorners, imageSize: iconSize, boundingSize: iconSize, intrinsicInsets: UIEdgeInsets(), emptyColor: item.presentationData.theme.theme.list.mediaPlaceholderColor) iconImageApply = iconImageLayout(arguments) case let .roundVideo(file): let iconSize = CGSize(width: 40.0, height: 40.0) let imageCorners = ImageCorners(radius: iconSize.width / 2.0) - let arguments = TransformImageArguments(corners: imageCorners, imageSize: (file.dimensions ?? PixelDimensions(width: 320, height: 320)).cgSize.aspectFilled(iconSize), boundingSize: iconSize, intrinsicInsets: UIEdgeInsets(), emptyColor: item.theme.list.mediaPlaceholderColor) + let arguments = TransformImageArguments(corners: imageCorners, imageSize: (file.dimensions ?? PixelDimensions(width: 320, height: 320)).cgSize.aspectFilled(iconSize), boundingSize: iconSize, intrinsicInsets: UIEdgeInsets(), emptyColor: item.presentationData.theme.theme.list.mediaPlaceholderColor) iconImageApply = iconImageLayout(arguments) } } @@ -532,7 +605,7 @@ final class ListMessageFileItemNode: ListMessageNode { case let .imageRepresentation(file, representation): updateIconImageSignal = chatWebpageSnippetFile(account: item.context.account, fileReference: .message(message: MessageReference(message), media: file), representation: representation) case let .albumArt(file, albumArt): - updateIconImageSignal = playerAlbumArt(postbox: item.context.account.postbox, fileReference: .message(message: MessageReference(message), media: file), albumArt: albumArt, thumbnail: true, overlayColor: UIColor(white: 0.0, alpha: 0.3), emptyColor: item.theme.list.itemAccentColor) + updateIconImageSignal = playerAlbumArt(postbox: item.context.account.postbox, fileReference: .message(message: MessageReference(message), media: file), albumArt: albumArt, thumbnail: true, overlayColor: UIColor(white: 0.0, alpha: 0.3), emptyColor: item.presentationData.theme.theme.list.itemAccentColor) case let .roundVideo(file): updateIconImageSignal = mediaGridMessageVideo(postbox: item.context.account.postbox, videoReference: FileMediaReference.message(message: MessageReference(message), media: file), autoFetchFullSizeThumbnail: true, overlayColor: UIColor(white: 0.0, alpha: 0.3)) } @@ -583,9 +656,9 @@ final class ListMessageFileItemNode: ListMessageNode { strongSelf.currentLeftOffset = leftOffset if let _ = updatedTheme { - strongSelf.separatorNode.backgroundColor = item.theme.list.itemPlainSeparatorColor - strongSelf.highlightedBackgroundNode.backgroundColor = item.theme.list.itemHighlightedBackgroundColor - strongSelf.linearProgressNode?.updateTheme(theme: item.theme) + strongSelf.separatorNode.backgroundColor = item.presentationData.theme.theme.list.itemPlainSeparatorColor + strongSelf.highlightedBackgroundNode.backgroundColor = item.presentationData.theme.theme.list.itemHighlightedBackgroundColor + strongSelf.linearProgressNode?.updateTheme(theme: item.presentationData.theme.theme) } if let (selectionWidth, selectionApply) = selectionNodeWidthAndApply { @@ -632,6 +705,10 @@ final class ListMessageFileItemNode: ListMessageNode { transition.updateFrame(node: strongSelf.descriptionNode, frame: CGRect(origin: CGPoint(x: leftOffset + leftInset + descriptionOffset, y: strongSelf.titleNode.frame.maxY + 1.0), size: descriptionNodeLayout.size)) let _ = descriptionNodeApply() + let _ = dateNodeApply() + transition.updateFrame(node: strongSelf.dateNode, frame: CGRect(origin: CGPoint(x: params.width - rightInset - dateNodeLayout.size.width, y: 11.0), size: dateNodeLayout.size)) + strongSelf.dateNode.isHidden = !item.isGlobalSearchResult + let iconFrame: CGRect if isAudio { let iconSize = CGSize(width: 40.0, height: 40.0) @@ -732,8 +809,8 @@ final class ListMessageFileItemNode: ListMessageNode { var iconStatusForegroundColor: UIColor = .white if isVoice { - iconStatusBackgroundColor = item.theme.list.itemAccentColor - iconStatusForegroundColor = item.theme.list.itemCheckColors.foregroundColor + iconStatusBackgroundColor = item.presentationData.theme.theme.list.itemAccentColor + iconStatusForegroundColor = item.presentationData.theme.theme.list.itemCheckColors.foregroundColor } if !isAudio && !isInstantVideo { @@ -767,7 +844,7 @@ final class ListMessageFileItemNode: ListMessageNode { self.iconStatusNode.transitionToState(iconStatusState) } - override func setHighlighted(_ highlighted: Bool, at point: CGPoint, animated: Bool) { + override public func setHighlighted(_ highlighted: Bool, at point: CGPoint, animated: Bool) { super.setHighlighted(highlighted, at: point, animated: animated) if highlighted, let item = self.item, case .none = item.selection { @@ -793,7 +870,7 @@ final class ListMessageFileItemNode: ListMessageNode { } } - override func transitionNode(id: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { + override public func transitionNode(id: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { if let item = self.item, item.message.id == id, self.iconImageNode.supernode != nil { let iconImageNode = self.iconImageNode return (self.iconImageNode, self.iconImageNode.bounds, { [weak iconImageNode] in @@ -803,15 +880,15 @@ final class ListMessageFileItemNode: ListMessageNode { return nil } - override func updateHiddenMedia() { - if let controllerInteraction = self.controllerInteraction, let item = self.item, controllerInteraction.hiddenMedia[item.message.id] != nil { + override public func updateHiddenMedia() { + if let interaction = self.interaction, let item = self.item, interaction.getHiddenMedia()[item.message.id] != nil { self.iconImageNode.isHidden = true } else { self.iconImageNode.isHidden = false } } - override func updateSelectionState(animated: Bool) { + override public func updateSelectionState(animated: Bool) { } private func updateProgressFrame(size: CGSize, leftInset: CGFloat, rightInset: CGFloat, transition: ContainedViewLayoutTransition) { @@ -831,7 +908,7 @@ final class ListMessageFileItemNode: ListMessageNode { switch fetchStatus { case let .Fetching(_, progress): if let file = self.currentMedia as? TelegramMediaFile, let size = file.size { - downloadingString = "\(dataSizeString(Int(Float(size) * progress), forceDecimal: true, decimalSeparator: item.dateTimeFormat.decimalSeparator)) / \(dataSizeString(size, forceDecimal: true, decimalSeparator: item.dateTimeFormat.decimalSeparator))" + downloadingString = "\(dataSizeString(Int(Float(size) * progress), forceDecimal: true, decimalSeparator: item.presentationData.dateTimeFormat.decimalSeparator)) / \(dataSizeString(size, forceDecimal: true, decimalSeparator: item.presentationData.dateTimeFormat.decimalSeparator))" } descriptionOffset = 14.0 case .Remote: @@ -849,7 +926,7 @@ final class ListMessageFileItemNode: ListMessageNode { linearProgressNode = current } else { linearProgressNode = LinearProgressNode() - linearProgressNode.updateTheme(theme: item.theme) + linearProgressNode.updateTheme(theme: item.presentationData.theme.theme) self.linearProgressNode = linearProgressNode self.addSubnode(linearProgressNode) } @@ -859,7 +936,7 @@ final class ListMessageFileItemNode: ListMessageNode { if self.downloadStatusIconNode.supernode == nil { self.offsetContainerNode.addSubnode(self.downloadStatusIconNode) } - self.downloadStatusIconNode.image = PresentationResourcesChat.sharedMediaFileDownloadPauseIcon(item.theme) + self.downloadStatusIconNode.image = PresentationResourcesChat.sharedMediaFileDownloadPauseIcon(item.presentationData.theme.theme) case .Local: if let linearProgressNode = self.linearProgressNode { self.linearProgressNode = nil @@ -883,7 +960,7 @@ final class ListMessageFileItemNode: ListMessageNode { if self.downloadStatusIconNode.supernode == nil { self.offsetContainerNode.addSubnode(self.downloadStatusIconNode) } - self.downloadStatusIconNode.image = PresentationResourcesChat.sharedMediaFileDownloadStartIcon(item.theme) + self.downloadStatusIconNode.image = PresentationResourcesChat.sharedMediaFileDownloadStartIcon(item.presentationData.theme.theme) } } else { if let linearProgressNode = self.linearProgressNode { @@ -911,8 +988,8 @@ final class ListMessageFileItemNode: ListMessageNode { self.descriptionProgressNode.isHidden = true self.descriptionNode.isHidden = false } - let descriptionFont = Font.regular(floor(item.fontSize.baseDisplaySize * 13.0 / 17.0)) - self.descriptionProgressNode.attributedText = NSAttributedString(string: downloadingString ?? "", font: descriptionFont, textColor: item.theme.list.itemSecondaryTextColor) + let descriptionFont = Font.regular(floor(item.presentationData.fontSize.baseDisplaySize * 13.0 / 17.0)) + self.descriptionProgressNode.attributedText = NSAttributedString(string: downloadingString ?? "", font: descriptionFont, textColor: item.presentationData.theme.theme.list.itemSecondaryTextColor) let descriptionSize = self.descriptionProgressNode.updateLayout(CGSize(width: size.width - 14.0, height: size.height)) transition.updateFrame(node: self.descriptionProgressNode, frame: CGRect(origin: self.descriptionNode.frame.origin, size: descriptionSize)) @@ -936,8 +1013,8 @@ final class ListMessageFileItemNode: ListMessageNode { fetch() } case .Local: - if let item = self.item, let controllerInteraction = self.controllerInteraction { - let _ = controllerInteraction.openMessage(item.message, .default) + if let item = self.item, let interaction = self.interaction { + let _ = interaction.openMessage(item.message, .default) } } case .playbackStatus: @@ -948,11 +1025,11 @@ final class ListMessageFileItemNode: ListMessageNode { } } - override func header() -> ListViewItemHeader? { + override public func header() -> ListViewItemHeader? { return self.item?.header } - override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + override public func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { if let item = self.item, case .selectable = item.selection { if self.bounds.contains(point) { return self.view diff --git a/submodules/TelegramUI/Sources/ListMessageHoleItem.swift b/submodules/ListMessageItem/Sources/ListMessageHoleItem.swift similarity index 100% rename from submodules/TelegramUI/Sources/ListMessageHoleItem.swift rename to submodules/ListMessageItem/Sources/ListMessageHoleItem.swift diff --git a/submodules/TelegramUI/Sources/ListMessageItem.swift b/submodules/ListMessageItem/Sources/ListMessageItem.swift similarity index 64% rename from submodules/TelegramUI/Sources/ListMessageItem.swift rename to submodules/ListMessageItem/Sources/ListMessageItem.swift index b3264a7cad..930c9b4bf7 100644 --- a/submodules/TelegramUI/Sources/ListMessageItem.swift +++ b/submodules/ListMessageItem/Sources/ListMessageItem.swift @@ -10,42 +10,60 @@ import TelegramPresentationData import AccountContext import TelegramUIPreferences -final class ListMessageItem: ListViewItem { - let theme: PresentationTheme - let strings: PresentationStrings - let fontSize: PresentationFontSize - let dateTimeFormat: PresentationDateTimeFormat +public final class ListMessageItemInteraction { + let openMessage: (Message, ChatControllerInteractionOpenMessageMode) -> Bool + let openMessageContextMenu: (Message, Bool, ASDisplayNode, CGRect, UIGestureRecognizer?) -> Void + let toggleMessagesSelection: ([MessageId], Bool) -> Void + let openUrl: (String, Bool, Bool?, Message?) -> Void + let openInstantPage: (Message, ChatMessageItemAssociatedData?) -> Void + let longTap: (ChatControllerInteractionLongTapAction, Message?) -> Void + let getHiddenMedia: () -> [MessageId: [Media]] + + public init(openMessage: @escaping (Message, ChatControllerInteractionOpenMessageMode) -> Bool, openMessageContextMenu: @escaping (Message, Bool, ASDisplayNode, CGRect, UIGestureRecognizer?) -> Void, toggleMessagesSelection: @escaping ([MessageId], Bool) -> Void, openUrl: @escaping (String, Bool, Bool?, Message?) -> Void, openInstantPage: @escaping (Message, ChatMessageItemAssociatedData?) -> Void, longTap: @escaping (ChatControllerInteractionLongTapAction, Message?) -> Void, getHiddenMedia: @escaping () -> [MessageId: [Media]]) { + self.openMessage = openMessage + self.openMessageContextMenu = openMessageContextMenu + self.toggleMessagesSelection = toggleMessagesSelection + self.openUrl = openUrl + self.openInstantPage = openInstantPage + self.longTap = longTap + self.getHiddenMedia = getHiddenMedia + } +} + +public final class ListMessageItem: ListViewItem { + let presentationData: ChatPresentationData let context: AccountContext let chatLocation: ChatLocation - let controllerInteraction: ChatControllerInteraction + let interaction: ListMessageItemInteraction let message: Message let selection: ChatHistoryMessageSelection + let isGlobalSearchResult: Bool - let header: ListMessageDateHeader? + let header: ListViewItemHeader? - let selectable: Bool = true + public let selectable: Bool = true - public init(theme: PresentationTheme, strings: PresentationStrings, fontSize: PresentationFontSize, dateTimeFormat: PresentationDateTimeFormat, context: AccountContext, chatLocation: ChatLocation, controllerInteraction: ChatControllerInteraction, message: Message, selection: ChatHistoryMessageSelection, displayHeader: Bool) { - self.theme = theme - self.strings = strings - self.fontSize = fontSize - self.dateTimeFormat = dateTimeFormat + public init(presentationData: ChatPresentationData, context: AccountContext, chatLocation: ChatLocation, interaction: ListMessageItemInteraction, message: Message, selection: ChatHistoryMessageSelection, displayHeader: Bool, customHeader: ListViewItemHeader? = nil, isGlobalSearchResult: Bool = false) { + self.presentationData = presentationData self.context = context self.chatLocation = chatLocation - self.controllerInteraction = controllerInteraction + self.interaction = interaction self.message = message - if displayHeader { - self.header = ListMessageDateHeader(timestamp: message.timestamp, theme: theme, strings: strings, fontSize: fontSize) + if let header = customHeader { + self.header = header + } else if displayHeader { + self.header = ListMessageDateHeader(timestamp: message.timestamp, theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize) } else { self.header = nil } self.selection = selection + self.isGlobalSearchResult = isGlobalSearchResult } public func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { var viewClassName: AnyClass = ListMessageSnippetItemNode.self - for media in message.media { + for media in self.message.media { if let _ = media as? TelegramMediaFile { viewClassName = ListMessageFileItemNode.self break @@ -54,7 +72,7 @@ final class ListMessageItem: ListViewItem { let configure = { () -> Void in let node = (viewClassName as! ListMessageNode.Type).init() - node.controllerInteraction = self.controllerInteraction + node.interaction = self.interaction node.setupItem(self) let nodeLayout = node.asyncLayout() @@ -106,11 +124,11 @@ final class ListMessageItem: ListViewItem { } } - func selected(listView: ListView) { + public func selected(listView: ListView) { listView.clearHighlightAnimated(true) if case let .selectable(selected) = self.selection { - self.controllerInteraction.toggleMessagesSelection([self.message.id], !selected) + self.interaction.toggleMessagesSelection([self.message.id], !selected) } else { listView.forEachItemNode { itemNode in if let itemNode = itemNode as? ListMessageFileItemNode { diff --git a/submodules/TelegramUI/Sources/ListMessageNode.swift b/submodules/ListMessageItem/Sources/ListMessageNode.swift similarity index 56% rename from submodules/TelegramUI/Sources/ListMessageNode.swift rename to submodules/ListMessageItem/Sources/ListMessageNode.swift index f110ca203e..7c3cea93b0 100644 --- a/submodules/TelegramUI/Sources/ListMessageNode.swift +++ b/submodules/ListMessageItem/Sources/ListMessageNode.swift @@ -3,10 +3,11 @@ import UIKit import Display import AsyncDisplayKit import Postbox +import AccountContext -class ListMessageNode: ListViewItemNode { +public class ListMessageNode: ListViewItemNode { var item: ListMessageItem? - var controllerInteraction: ChatControllerInteraction? + var interaction: ListMessageItemInteraction? required init() { super.init(layerBacked: false, dynamicBounce: false) @@ -19,7 +20,7 @@ class ListMessageNode: ListViewItemNode { override public func layoutForParams(_ params: ListViewItemLayoutParams, item: ListViewItem, previousItem: ListViewItem?, nextItem: ListViewItem?) { } - func asyncLayout() -> (_ item: ListMessageItem, _ params: ListViewItemLayoutParams, _ mergedTop: Bool, _ mergedBottom: Bool, _ dateAtBottom: Bool) -> (ListViewItemNodeLayout, (ListViewItemUpdateAnimation) -> Void) { + public func asyncLayout() -> (_ item: ListMessageItem, _ params: ListViewItemLayoutParams, _ mergedTop: Bool, _ mergedBottom: Bool, _ dateAtBottom: Bool) -> (ListViewItemNodeLayout, (ListViewItemUpdateAnimation) -> Void) { return { _, params, _, _, _ in return (ListViewItemNodeLayout(contentSize: CGSize(width: params.width, height: 1.0), insets: UIEdgeInsets()), { _ in @@ -27,13 +28,13 @@ class ListMessageNode: ListViewItemNode { } } - func transitionNode(id: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { + public func transitionNode(id: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { return nil } - func updateHiddenMedia() { + public func updateHiddenMedia() { } - func updateSelectionState(animated: Bool) { + public func updateSelectionState(animated: Bool) { } } diff --git a/submodules/TelegramUI/Sources/ListMessageSnippetItemNode.swift b/submodules/ListMessageItem/Sources/ListMessageSnippetItemNode.swift similarity index 81% rename from submodules/TelegramUI/Sources/ListMessageSnippetItemNode.swift rename to submodules/ListMessageItem/Sources/ListMessageSnippetItemNode.swift index 773aadf8af..888d949384 100644 --- a/submodules/TelegramUI/Sources/ListMessageSnippetItemNode.swift +++ b/submodules/ListMessageItem/Sources/ListMessageSnippetItemNode.swift @@ -13,12 +13,15 @@ import TextFormat import PhotoResources import WebsiteType import UrlHandling +import UrlWhitelist +import AccountContext +import TelegramStringFormatting private let iconFont = Font.with(size: 30.0, design: .round, traits: [.bold]) private let iconTextBackgroundImage = generateStretchableFilledCircleImage(radius: 6.0, color: UIColor(rgb: 0xFF9500)) -final class ListMessageSnippetItemNode: ListMessageNode { +public final class ListMessageSnippetItemNode: ListMessageNode { private let contextSourceNode: ContextExtractedContentContainingNode private let containerNode: ContextControllerSourceNode private let extractedBackgroundImageNode: ASImageNode @@ -34,9 +37,11 @@ final class ListMessageSnippetItemNode: ListMessageNode { private let titleNode: TextNode private let descriptionNode: TextNode + private let dateNode: TextNode private let instantViewIconNode: ASImageNode private let linkNode: TextNode private var linkHighlightingNode: LinkHighlightingNode? + private let authorNode: TextNode private let iconTextBackgroundNode: ASImageNode private let iconTextNode: TextNode @@ -44,7 +49,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { private var currentIconImageRepresentation: TelegramMediaImageRepresentation? private var currentMedia: Media? - var currentPrimaryUrl: String? + public var currentPrimaryUrl: String? private var currentIsInstantView: Bool? private var appliedItem: ListMessageItem? @@ -72,6 +77,9 @@ final class ListMessageSnippetItemNode: ListMessageNode { self.descriptionNode = TextNode() self.descriptionNode.isUserInteractionEnabled = false + self.dateNode = TextNode() + self.dateNode.isUserInteractionEnabled = false + self.instantViewIconNode = ASImageNode() self.instantViewIconNode.isLayerBacked = true self.instantViewIconNode.displaysAsynchronously = false @@ -90,6 +98,9 @@ final class ListMessageSnippetItemNode: ListMessageNode { self.iconImageNode = TransformImageNode() self.iconImageNode.displaysAsynchronously = false + self.authorNode = TextNode() + self.authorNode.isUserInteractionEnabled = false + super.init() self.addSubnode(self.separatorNode) @@ -102,16 +113,18 @@ final class ListMessageSnippetItemNode: ListMessageNode { self.contextSourceNode.contentNode.addSubnode(self.offsetContainerNode) self.offsetContainerNode.addSubnode(self.titleNode) self.offsetContainerNode.addSubnode(self.descriptionNode) + self.offsetContainerNode.addSubnode(self.dateNode) self.offsetContainerNode.addSubnode(self.linkNode) self.offsetContainerNode.addSubnode(self.instantViewIconNode) self.offsetContainerNode.addSubnode(self.iconImageNode) + self.offsetContainerNode.addSubnode(self.authorNode) self.containerNode.activated = { [weak self] gesture, _ in guard let strongSelf = self, let item = strongSelf.item else { return } - item.controllerInteraction.openMessageContextMenu(item.message, false, strongSelf.contextSourceNode, strongSelf.contextSourceNode.bounds, gesture) + item.interaction.openMessageContextMenu(item.message, false, strongSelf.contextSourceNode, strongSelf.contextSourceNode.bounds, gesture) } self.contextSourceNode.willUpdateIsExtractedToContextPreview = { [weak self] isExtracted, transition in @@ -120,7 +133,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { } if isExtracted { - strongSelf.extractedBackgroundImageNode.image = generateStretchableFilledCircleImage(diameter: 28.0, color: item.theme.list.plainBackgroundColor) + strongSelf.extractedBackgroundImageNode.image = generateStretchableFilledCircleImage(diameter: 28.0, color: item.presentationData.theme.theme.list.plainBackgroundColor) } if let extractedRect = strongSelf.extractedRect, let nonExtractedRect = strongSelf.nonExtractedRect { @@ -135,6 +148,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { self?.extractedBackgroundImageNode.image = nil } }) + transition.updateAlpha(node: strongSelf.dateNode, alpha: isExtracted ? 0.0 : 1.0) } } @@ -142,7 +156,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { fatalError("init(coder:) has not been implemented") } - override func didLoad() { + override public func didLoad() { super.didLoad() let recognizer = TapLongTapOrDoubleTapGestureRecognizer(target: self, action: #selector(self.tapLongTapOrDoubleTapGesture(_:))) @@ -182,17 +196,19 @@ final class ListMessageSnippetItemNode: ListMessageNode { self.addTransitionOffsetAnimation(0.0, duration: duration, beginAt: currentTimestamp) } - override func animateRemoved(_ currentTimestamp: Double, duration: Double) { + override public func animateRemoved(_ currentTimestamp: Double, duration: Double) { self.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15, removeOnCompletion: false) } - override func asyncLayout() -> (_ item: ListMessageItem, _ params: ListViewItemLayoutParams, _ mergedTop: Bool, _ mergedBottom: Bool, _ dateHeaderAtBottom: Bool) -> (ListViewItemNodeLayout, (ListViewItemUpdateAnimation) -> Void) { + override public func asyncLayout() -> (_ item: ListMessageItem, _ params: ListViewItemLayoutParams, _ mergedTop: Bool, _ mergedBottom: Bool, _ dateHeaderAtBottom: Bool) -> (ListViewItemNodeLayout, (ListViewItemUpdateAnimation) -> Void) { let titleNodeMakeLayout = TextNode.asyncLayout(self.titleNode) let descriptionNodeMakeLayout = TextNode.asyncLayout(self.descriptionNode) let linkNodeMakeLayout = TextNode.asyncLayout(self.linkNode) + let dateNodeMakeLayout = TextNode.asyncLayout(self.dateNode) let iconTextMakeLayout = TextNode.asyncLayout(self.iconTextNode) let iconImageLayout = self.iconImageNode.asyncLayout() - + let authorNodeMakeLayout = TextNode.asyncLayout(self.authorNode) + let currentIconImageRepresentation = self.currentIconImageRepresentation let currentItem = self.appliedItem @@ -202,19 +218,21 @@ final class ListMessageSnippetItemNode: ListMessageNode { return { [weak self] item, params, _, _, dateHeaderAtBottom in var updatedTheme: PresentationTheme? - if currentItem?.theme !== item.theme { - updatedTheme = item.theme + if currentItem?.presentationData.theme.theme !== item.presentationData.theme.theme { + updatedTheme = item.presentationData.theme.theme } - let titleFont = Font.semibold(floor(item.fontSize.baseDisplaySize * 16.0 / 17.0)) - let descriptionFont = Font.regular(floor(item.fontSize.baseDisplaySize * 14.0 / 17.0)) + let titleFont = Font.semibold(floor(item.presentationData.fontSize.baseDisplaySize * 16.0 / 17.0)) + let descriptionFont = Font.regular(floor(item.presentationData.fontSize.baseDisplaySize * 14.0 / 17.0)) + let dateFont = Font.regular(floor(item.presentationData.fontSize.itemListBaseFontSize * 14.0 / 17.0)) + let authorFont = Font.regular(floor(item.presentationData.fontSize.baseDisplaySize * 14.0 / 17.0)) let leftInset: CGFloat = 65.0 + params.leftInset var leftOffset: CGFloat = 0.0 var selectionNodeWidthAndApply: (CGFloat, (CGSize, Bool) -> ItemListSelectableControlNode)? if case let .selectable(selected) = item.selection { - let (selectionWidth, selectionApply) = selectionNodeLayout(item.theme.list.itemCheckColors.strokeColor, item.theme.list.itemCheckColors.fillColor, item.theme.list.itemCheckColors.foregroundColor, selected, false) + let (selectionWidth, selectionApply) = selectionNodeLayout(item.presentationData.theme.theme.list.itemCheckColors.strokeColor, item.presentationData.theme.theme.list.itemCheckColors.fillColor, item.presentationData.theme.theme.list.itemCheckColors.foregroundColor, selected, false) selectionNodeWidthAndApply = (selectionWidth, selectionApply) leftOffset += selectionWidth } @@ -255,7 +273,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { iconText = NSAttributedString(string: host[.. (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { + override public func transitionNode(id: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { if let item = self.item, item.message.id == id, self.iconImageNode.supernode != nil { let iconImageNode = self.iconImageNode return (self.iconImageNode, self.iconImageNode.bounds, { [weak iconImageNode] in @@ -564,15 +608,15 @@ final class ListMessageSnippetItemNode: ListMessageNode { return nil } - override func updateHiddenMedia() { - if let controllerInteraction = self.controllerInteraction, let item = self.item, controllerInteraction.hiddenMedia[item.message.id] != nil { + override public func updateHiddenMedia() { + if let interaction = self.interaction, let item = self.item, interaction.getHiddenMedia()[item.message.id] != nil { self.iconImageNode.isHidden = true } else { self.iconImageNode.isHidden = false } } - override func updateSelectionState(animated: Bool) { + override public func updateSelectionState(animated: Bool) { } func activateMedia() { @@ -580,30 +624,30 @@ final class ListMessageSnippetItemNode: ListMessageNode { if let webpage = self.currentMedia as? TelegramMediaWebpage, case let .Loaded(content) = webpage.content { if content.instantPage != nil { if websiteType(of: content.websiteName) == .instagram { - if !item.controllerInteraction.openMessage(item.message, .default) { - item.controllerInteraction.openInstantPage(item.message, nil) + if !item.interaction.openMessage(item.message, .default) { + item.interaction.openInstantPage(item.message, nil) } } else { - item.controllerInteraction.openInstantPage(item.message, nil) + item.interaction.openInstantPage(item.message, nil) } } else { - if isTelegramMeLink(content.url) || !item.controllerInteraction.openMessage(item.message, .link) { - item.controllerInteraction.openUrl(currentPrimaryUrl, false, false, nil) + if isTelegramMeLink(content.url) || !item.interaction.openMessage(item.message, .link) { + item.interaction.openUrl(currentPrimaryUrl, false, false, nil) } } } else { - if !item.controllerInteraction.openMessage(item.message, .default) { - item.controllerInteraction.openUrl(currentPrimaryUrl, false, false, nil) + if !item.interaction.openMessage(item.message, .default) { + item.interaction.openUrl(currentPrimaryUrl, false, false, nil) } } } } - override func header() -> ListViewItemHeader? { + override public func header() -> ListViewItemHeader? { return self.item?.header } - override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + override public func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { if let item = self.item, case .selectable = item.selection { if self.bounds.contains(point) { return self.view @@ -640,13 +684,13 @@ final class ListMessageSnippetItemNode: ListMessageNode { case .tap, .longTap: if let item = self.item, let url = self.urlAtPoint(location) { if case .longTap = gesture { - item.controllerInteraction.longTap(ChatControllerInteractionLongTapAction.url(url), item.message) + item.interaction.longTap(ChatControllerInteractionLongTapAction.url(url), item.message) } else if url == self.currentPrimaryUrl { - if !item.controllerInteraction.openMessage(item.message, .default) { - item.controllerInteraction.openUrl(url, false, false, nil) + if !item.interaction.openMessage(item.message, .default) { + item.interaction.openUrl(url, false, false, nil) } } else { - item.controllerInteraction.openUrl(url, false, true, nil) + item.interaction.openUrl(url, false, true, nil) } } case .hold, .doubleTap: @@ -683,7 +727,7 @@ final class ListMessageSnippetItemNode: ListMessageNode { if let current = self.linkHighlightingNode { linkHighlightingNode = current } else { - linkHighlightingNode = LinkHighlightingNode(color: item.message.effectivelyIncoming(item.context.account.peerId) ? item.theme.chat.message.incoming.linkHighlightColor : item.theme.chat.message.outgoing.linkHighlightColor) + linkHighlightingNode = LinkHighlightingNode(color: item.message.effectivelyIncoming(item.context.account.peerId) ? item.presentationData.theme.theme.chat.message.incoming.linkHighlightColor : item.presentationData.theme.theme.chat.message.outgoing.linkHighlightColor) self.linkHighlightingNode = linkHighlightingNode self.offsetContainerNode.insertSubnode(linkHighlightingNode, belowSubnode: self.linkNode) } diff --git a/submodules/PresentationDataUtils/BUCK b/submodules/PresentationDataUtils/BUCK index 533f10d829..84fa4c2fdc 100644 --- a/submodules/PresentationDataUtils/BUCK +++ b/submodules/PresentationDataUtils/BUCK @@ -14,6 +14,7 @@ static_library( "//submodules/ItemListUI:ItemListUI", "//submodules/SolidRoundedButtonNode:SolidRoundedButtonNode", "//submodules/OverlayStatusController:OverlayStatusController", + "//submodules/UrlWhitelist:UrlWhitelist", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/PresentationDataUtils/BUILD b/submodules/PresentationDataUtils/BUILD index 022f9f42c3..18415391b2 100644 --- a/submodules/PresentationDataUtils/BUILD +++ b/submodules/PresentationDataUtils/BUILD @@ -15,6 +15,7 @@ swift_library( "//submodules/ItemListUI:ItemListUI", "//submodules/SolidRoundedButtonNode:SolidRoundedButtonNode", "//submodules/OverlayStatusController:OverlayStatusController", + "//submodules/UrlWhitelist:UrlWhitelist", ], visibility = [ "//visibility:public", diff --git a/submodules/PresentationDataUtils/Sources/OpenUrl.swift b/submodules/PresentationDataUtils/Sources/OpenUrl.swift new file mode 100644 index 0000000000..9a7f4ea544 --- /dev/null +++ b/submodules/PresentationDataUtils/Sources/OpenUrl.swift @@ -0,0 +1,62 @@ +import Foundation +import Display +import SwiftSignalKit +import AccountContext +import OverlayStatusController +import UrlWhitelist + +public func openUserGeneratedUrl(context: AccountContext, url: String, concealed: Bool, present: @escaping (ViewController) -> Void, openResolved: @escaping (ResolvedUrl) -> Void) { + var concealed = concealed + + let presentationData = context.sharedContext.currentPresentationData.with { $0 } + + let openImpl: () -> Void = { + let disposable = MetaDisposable() + var cancelImpl: (() -> Void)? + let progressSignal = Signal { subscriber in + let controller = OverlayStatusController(theme: presentationData.theme, type: .loading(cancelled: { + cancelImpl?() + })) + present(controller) + return ActionDisposable { [weak controller] in + Queue.mainQueue().async() { + controller?.dismiss() + } + } + } + |> runOn(Queue.mainQueue()) + |> delay(0.15, queue: Queue.mainQueue()) + let progressDisposable = progressSignal.start() + + cancelImpl = { + disposable.dispose() + } + disposable.set((context.sharedContext.resolveUrl(account: context.account, url: url) + |> afterDisposed { + Queue.mainQueue().async { + progressDisposable.dispose() + } + } + |> deliverOnMainQueue).start(next: { result in + openResolved(result) + })) + } + + let (parsedString, parsedConcealed) = parseUrl(url: url, wasConcealed: concealed) + concealed = parsedConcealed + + if concealed { + var rawDisplayUrl: String = parsedString + let maxLength = 180 + if rawDisplayUrl.count > maxLength { + rawDisplayUrl = String(rawDisplayUrl[.. }, opaque: false)?.stretchableImage(withLeftCapWidth: Int(diameter / 2.0), topCapHeight: Int(diameter / 2.0)) } + +public struct SearchBarToken { + public let id: AnyHashable + public let icon: UIImage? + public let title: String + + public init(id: AnyHashable, icon: UIImage?, title: String) { + self.id = id + self.icon = icon + self.title = title + } +} + +private final class TokenNode: ASDisplayNode { + var theme: SearchBarNodeTheme + let token: SearchBarToken + let iconNode: ASImageNode + let titleNode: ASTextNode + let backgroundNode: ASImageNode + + var isSelected: Bool = false + var isCollapsed: Bool = false + + init(theme: SearchBarNodeTheme, token: SearchBarToken) { + self.theme = theme + self.token = token + self.iconNode = ASImageNode() + self.iconNode.displaysAsynchronously = false + self.iconNode.displayWithoutProcessing = true + self.titleNode = ASTextNode() + self.titleNode.isUserInteractionEnabled = false + self.titleNode.displaysAsynchronously = false + self.titleNode.maximumNumberOfLines = 1 + self.backgroundNode = ASImageNode() + self.backgroundNode.displaysAsynchronously = false + self.backgroundNode.displayWithoutProcessing = true + self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 8.0, color: theme.inputIcon) + + super.init() + + self.clipsToBounds = true + + self.addSubnode(self.backgroundNode) + + self.iconNode.image = generateTintedImage(image: token.icon, color: .white) + self.addSubnode(self.iconNode) + self.titleNode.attributedText = NSAttributedString(string: token.title, font: Font.regular(17.0), textColor: .white) + self.addSubnode(self.titleNode) + } + + func update(theme: SearchBarNodeTheme, token: SearchBarToken, isSelected: Bool, isCollapsed: Bool) { + self.isSelected = isSelected + self.isCollapsed = isCollapsed + + if theme !== self.theme { + self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 8.0, color: isSelected ? self.theme.accent : self.theme.inputIcon) + } + } + + func updateLayout(constrainedSize: CGSize, transition: ContainedViewLayoutTransition) -> CGSize { + let height: CGFloat = 24.0 + + var leftInset: CGFloat = 3.0 + if let icon = self.iconNode.image { + leftInset += 1.0 + transition.updateFrame(node: self.iconNode, frame: CGRect(origin: CGPoint(x: leftInset, y: floor((height - icon.size.height) / 2.0)), size: icon.size)) + leftInset += icon.size.width + 3.0 + } + + let iconSize = self.token.icon?.size ?? CGSize() + let titleSize = self.titleNode.measure(CGSize(width: constrainedSize.width - 6.0, height: constrainedSize.height)) + var width = titleSize.width + 6.0 + if !iconSize.width.isZero { + width += iconSize.width + 7.0 + } + + let size = CGSize(width: self.isCollapsed ? height : width, height: height) + transition.updateFrame(node: self.backgroundNode, frame: CGRect(origin: CGPoint(), size: size)) + transition.updateFrame(node: self.titleNode, frame: CGRect(origin: CGPoint(x: leftInset, y: floor((height - titleSize.height) / 2.0)), size: titleSize)) + + return size + } +} + private class SearchBarTextField: UITextField { public var didDeleteBackwardWhileEmpty: (() -> Void)? @@ -37,6 +121,124 @@ private class SearchBarTextField: UITextField { } } + var tokenNodes: [AnyHashable: TokenNode] = [:] + var tokens: [SearchBarToken] = [] { + didSet { + self.layoutTokens(transition: .animated(duration: 0.2, curve: .easeInOut)) + self.setNeedsLayout() + } + } + + var theme: SearchBarNodeTheme + + private func layoutTokens(transition: ContainedViewLayoutTransition = .immediate) { + for i in 0 ..< self.tokens.count { + let token = self.tokens[i] + + let tokenNode: TokenNode + var tokenNodeTransition = transition + if let current = self.tokenNodes[token.id] { + tokenNode = current + } else { + tokenNodeTransition = .immediate + tokenNode = TokenNode(theme: self.theme, token: token) + self.tokenNodes[token.id] = tokenNode + } + tokenNode.update(theme: self.theme, token: token, isSelected: false, isCollapsed: i < self.tokens.count - 1) + } + var removeKeys: [AnyHashable] = [] + for (id, _) in self.tokenNodes { + if !self.tokens.contains(where: { $0.id == id }) { + removeKeys.append(id) + } + } + for id in removeKeys { + if let itemNode = self.tokenNodes.removeValue(forKey: id) { + transition.updateAlpha(node: itemNode, alpha: 0.0, completion: { [weak itemNode] _ in + itemNode?.removeFromSupernode() + }) + transition.updateTransformScale(node: itemNode, scale: 0.1) + } + } + + var tokenSizes: [(AnyHashable, CGSize, TokenNode, Bool)] = [] + var totalRawTabSize: CGFloat = 0.0 + + for token in self.tokens { + guard let tokenNode = self.tokenNodes[token.id] else { + continue + } + let wasAdded = tokenNode.view.superview == nil + var tokenNodeTransition = transition + if wasAdded { + tokenNodeTransition = .immediate + self.addSubnode(tokenNode) + } + + let nodeSize = tokenNode.updateLayout(constrainedSize: self.bounds.size, transition: tokenNodeTransition) + tokenSizes.append((token.id, nodeSize, tokenNode, wasAdded)) + totalRawTabSize += nodeSize.width + } + + let minSpacing: CGFloat = 6.0 + + let resolvedSideInset: CGFloat = 10.0 + var leftOffset: CGFloat = 0.0 + if !tokenSizes.isEmpty { + leftOffset += resolvedSideInset + } + + var longTitlesWidth: CGFloat = resolvedSideInset + for i in 0 ..< tokenSizes.count { + let (_, paneNodeSize, _, _) = tokenSizes[i] + longTitlesWidth += paneNodeSize.width + if i != tokenSizes.count - 1 { + longTitlesWidth += minSpacing + } + } + longTitlesWidth += resolvedSideInset + + let verticalOffset: CGFloat = 0.0 + var horizontalOffset: CGFloat = 0.0 + for i in 0 ..< tokenSizes.count { + let (_, nodeSize, tokenNode, wasAdded) = tokenSizes[i] + let tokenNodeTransition = transition + + let nodeFrame = CGRect(origin: CGPoint(x: leftOffset, y: floor((self.frame.height - nodeSize.height) / 2.0) + verticalOffset), size: nodeSize) + + if wasAdded { + if horizontalOffset > 0.0 { + tokenNode.frame = nodeFrame.offsetBy(dx: horizontalOffset, dy: 0.0) + tokenNodeTransition.updatePosition(node: tokenNode, position: nodeFrame.center) + } else { + tokenNode.frame = nodeFrame + } + tokenNode.alpha = 0.0 + tokenNodeTransition.updateAlpha(node: tokenNode, alpha: 1.0) + + tokenNode.subnodeTransform = CATransform3DMakeScale(0.1, 0.1, 1.0) + tokenNodeTransition.updateSublayerTransformScale(node: tokenNode, scale: 1.0) + } else { + if nodeFrame.width < tokenNode.frame.width { + horizontalOffset += tokenNode.frame.width - nodeFrame.width + } + tokenNodeTransition.updateFrame(node: tokenNode, frame: nodeFrame) + } + + tokenNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -minSpacing / 2.0, bottom: 0.0, right: -minSpacing / 2.0) + + leftOffset += nodeSize.width + minSpacing + } + + if !tokenSizes.isEmpty { + leftOffset -= 4.0 + } + + self.tokensWidth = leftOffset + } + + private var tokensWidth: CGFloat = 0.0 + private let measurePrefixLabel: ImmediateTextNode let prefixLabel: ImmediateTextNode var prefixString: NSAttributedString? { @@ -47,7 +249,9 @@ private class SearchBarTextField: UITextField { } } - override init(frame: CGRect) { + init(theme: SearchBarNodeTheme) { + self.theme = theme + self.placeholderLabel = ImmediateTextNode() self.placeholderLabel.isUserInteractionEnabled = false self.placeholderLabel.displaysAsynchronously = false @@ -66,7 +270,7 @@ private class SearchBarTextField: UITextField { self.prefixLabel.maximumNumberOfLines = 1 self.prefixLabel.truncationMode = .byTruncatingTail - super.init(frame: frame) + super.init(frame: CGRect()) self.addSubnode(self.placeholderLabel) self.addSubnode(self.prefixLabel) @@ -97,6 +301,7 @@ private class SearchBarTextField: UITextField { return CGRect(origin: CGPoint(), size: CGSize()) } var rect = bounds.insetBy(dx: 4.0, dy: 4.0) + rect.origin.y += 1.0 let prefixSize = self.measurePrefixLabel.updateLayout(CGSize(width: floor(bounds.size.width * 0.7), height: bounds.size.height)) if !prefixSize.width.isZero { @@ -104,6 +309,10 @@ private class SearchBarTextField: UITextField { rect.origin.x += prefixOffset rect.size.width -= prefixOffset } + if !self.tokensWidth.isZero { + rect.origin.x += self.tokensWidth + rect.size.width -= self.tokensWidth + } rect.size.width = max(rect.size.width, 10.0) return rect } @@ -255,6 +464,9 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { public var textUpdated: ((String, String?) -> Void)? public var textReturned: ((String) -> Void)? public var clearPrefix: (() -> Void)? + public var clearTokens: (() -> Void)? + + public var tokensUpdated: (([SearchBarToken]) -> Void)? private let backgroundNode: ASDisplayNode private let separatorNode: ASDisplayNode @@ -273,6 +485,16 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { } } + public var tokens: [SearchBarToken] { + get { + return self.textField.tokens + } set { + let oldValue = self.textField.tokens + self.textField.tokens = newValue + self.updateIsEmpty(animated: newValue.isEmpty && !oldValue.isEmpty) + } + } + public var prefixString: NSAttributedString? { get { return self.textField.prefixString @@ -362,7 +584,7 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { self.iconNode.displaysAsynchronously = false self.iconNode.displayWithoutProcessing = true - self.textField = SearchBarTextField() + self.textField = SearchBarTextField(theme: theme) self.textField.accessibilityTraits = .searchField self.textField.autocorrectionType = .no self.textField.returnKeyType = .search @@ -393,7 +615,15 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { self.textField.addTarget(self, action: #selector(self.textFieldDidChange(_:)), for: .editingChanged) self.textField.didDeleteBackwardWhileEmpty = { [weak self] in - self?.clearPressed() + guard let strongSelf = self else { + return + } + if strongSelf.tokens.count > 1 { + strongSelf.tokens.removeLast() + strongSelf.tokensUpdated?(strongSelf.tokens) + } else { + strongSelf.clearPressed() + } } self.cancelButton.addTarget(self, action: #selector(self.cancelPressed), forControlEvents: .touchUpInside) @@ -499,7 +729,7 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { self.textBackgroundNode.layer.animateFrame(from: initialTextBackgroundFrame, to: self.textBackgroundNode.frame, duration: duration, timingFunction: timingFunction) let textFieldFrame = self.textField.frame - let initialLabelNodeFrame = CGRect(origin: node.labelNode.frame.offsetBy(dx: initialTextBackgroundFrame.origin.x - 4.0, dy: initialTextBackgroundFrame.origin.y - 7.0).origin, size: textFieldFrame.size) + let initialLabelNodeFrame = CGRect(origin: node.labelNode.frame.offsetBy(dx: initialTextBackgroundFrame.origin.x - 4.0, dy: initialTextBackgroundFrame.origin.y - 8.0).origin, size: textFieldFrame.size) self.textField.layer.animateFrame(from: initialLabelNodeFrame, to: self.textField.frame, duration: duration, timingFunction: timingFunction) let iconFrame = self.iconNode.frame @@ -515,7 +745,9 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { self.textField.resignFirstResponder() if clear { self.textField.text = nil - self.textField.placeholderLabel.isHidden = false + self.textField.tokens = [] + self.textField.prefixString = nil + self.textField.placeholderLabel.alpha = 1.0 } } @@ -576,7 +808,7 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { transitionBackgroundNode.layer.animateFrame(from: self.textBackgroundNode.frame, to: targetTextBackgroundFrame, duration: duration, timingFunction: timingFunction, removeOnCompletion: false) let textFieldFrame = self.textField.frame - let targetLabelNodeFrame = CGRect(origin: CGPoint(x: node.labelNode.frame.minX + targetTextBackgroundFrame.origin.x - 4.0, y: targetTextBackgroundFrame.minY + floorToScreenPixels((targetTextBackgroundFrame.size.height - textFieldFrame.size.height) / 2.0)), size: textFieldFrame.size) + let targetLabelNodeFrame = CGRect(origin: CGPoint(x: node.labelNode.frame.minX + targetTextBackgroundFrame.origin.x - 4.0, y: targetTextBackgroundFrame.minY + floorToScreenPixels((targetTextBackgroundFrame.size.height - textFieldFrame.size.height) / 2.0) - UIScreenPixel), size: textFieldFrame.size) self.textField.layer.animateFrame(from: self.textField.frame, to: targetLabelNodeFrame, duration: duration, timingFunction: timingFunction, removeOnCompletion: false) if #available(iOSApplicationExtension 10.0, iOS 10.0, *) { if let snapshot = node.labelNode.layer.snapshotContentTree() { @@ -636,12 +868,13 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { self.textField.selectAll(nil) } - private func updateIsEmpty() { - let isEmpty = !(self.textField.text?.isEmpty ?? true) - if isEmpty != self.textField.placeholderLabel.isHidden { - self.textField.placeholderLabel.isHidden = isEmpty - } - self.clearButton.isHidden = !isEmpty && self.prefixString == nil + private func updateIsEmpty(animated: Bool = false) { + let isEmpty = (self.textField.text?.isEmpty ?? true) && self.tokens.isEmpty + + let transition: ContainedViewLayoutTransition = animated ? .animated(duration: 0.2, curve: .linear) : .immediate + transition.updateAlpha(node: self.textField.placeholderLabel, alpha: isEmpty ? 1.0 : 0.0) + + self.clearButton.isHidden = isEmpty && self.prefixString == nil } @objc private func cancelPressed() { @@ -655,6 +888,9 @@ public class SearchBarNode: ASDisplayNode, UITextFieldDelegate { if self.prefixString != nil { self.clearPrefix?() } + if !self.tokens.isEmpty { + self.clearTokens?() + } } else { self.textField.text = "" self.textFieldDidChange(self.textField) diff --git a/submodules/SearchBarNode/Sources/SearchBarPlaceholderNode.swift b/submodules/SearchBarNode/Sources/SearchBarPlaceholderNode.swift index 78ad5c0b3f..f51b8dbc1c 100644 --- a/submodules/SearchBarNode/Sources/SearchBarPlaceholderNode.swift +++ b/submodules/SearchBarNode/Sources/SearchBarPlaceholderNode.swift @@ -152,7 +152,7 @@ public class SearchBarPlaceholderNode: ASDisplayNode { } var textOffset: CGFloat = 0.0 if constrainedSize.height >= 36.0 { - textOffset += UIScreenPixel + textOffset += 1.0 } let labelFrame = CGRect(origin: CGPoint(x: floor((constrainedSize.width - totalWidth) / 2.0) + iconSize.width + spacing, y: floorToScreenPixels((height - labelLayoutResult.size.height) / 2.0) + textOffset), size: labelLayoutResult.size) transition.updateFrame(node: strongSelf.labelNode, frame: labelFrame) diff --git a/submodules/SearchUI/Sources/SearchDisplayController.swift b/submodules/SearchUI/Sources/SearchDisplayController.swift index e5bd24e29c..f23364e0f1 100644 --- a/submodules/SearchUI/Sources/SearchDisplayController.swift +++ b/submodules/SearchUI/Sources/SearchDisplayController.swift @@ -32,6 +32,9 @@ public final class SearchDisplayController { self.searchBar.textUpdated = { [weak contentNode] text, _ in contentNode?.searchTextUpdated(text: text) } + self.searchBar.tokensUpdated = { [weak contentNode] tokens in + contentNode?.searchTokensUpdated(tokens: tokens) + } self.searchBar.cancel = { [weak self] in self?.isDeactivating = true cancel() @@ -39,6 +42,9 @@ public final class SearchDisplayController { self.searchBar.clearPrefix = { [weak contentNode] in contentNode?.searchTextClearPrefix() } + self.searchBar.clearTokens = { [weak contentNode] in + contentNode?.searchTextClearTokens() + } self.contentNode.cancel = { [weak self] in self?.isDeactivating = true cancel() @@ -46,8 +52,9 @@ public final class SearchDisplayController { self.contentNode.dismissInput = { [weak self] in self?.searchBar.deactivate(clear: false) } - self.contentNode.setQuery = { [weak self] prefix, query in + self.contentNode.setQuery = { [weak self] prefix, tokens, query in self?.searchBar.prefixString = prefix + self?.searchBar.tokens = tokens self?.searchBar.text = query } if let placeholder = placeholder { @@ -101,7 +108,7 @@ public final class SearchDisplayController { self.containerLayout = (layout, navigationBarFrame.maxY) transition.updateFrame(node: self.contentNode, frame: CGRect(origin: CGPoint(), size: layout.size)) - self.contentNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: LayoutMetrics(), deviceMetrics: layout.deviceMetrics, intrinsicInsets: layout.intrinsicInsets, safeInsets: layout.safeInsets, statusBarHeight: nil, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), navigationBarHeight: navigationBarFrame.maxY, transition: transition) + self.contentNode.containerLayoutUpdated(ContainerViewLayout(size: layout.size, metrics: LayoutMetrics(), deviceMetrics: layout.deviceMetrics, intrinsicInsets: layout.intrinsicInsets, safeInsets: layout.safeInsets, statusBarHeight: nil, inputHeight: layout.inputHeight, inputHeightIsInteractivellyChanging: layout.inputHeightIsInteractivellyChanging, inVoiceOver: layout.inVoiceOver), navigationBarHeight: navigationBarHeight, transition: transition) } public func activate(insertSubnode: (ASDisplayNode, Bool) -> Void, placeholder: SearchBarPlaceholderNode?) { diff --git a/submodules/SearchUI/Sources/SearchDisplayControllerContentNode.swift b/submodules/SearchUI/Sources/SearchDisplayControllerContentNode.swift index 01e11f9db3..e9b8fd1fb8 100644 --- a/submodules/SearchUI/Sources/SearchDisplayControllerContentNode.swift +++ b/submodules/SearchUI/Sources/SearchDisplayControllerContentNode.swift @@ -4,11 +4,12 @@ import AsyncDisplayKit import Display import SwiftSignalKit import TelegramPresentationData +import SearchBarNode open class SearchDisplayControllerContentNode: ASDisplayNode { public final var dismissInput: (() -> Void)? public final var cancel: (() -> Void)? - public final var setQuery: ((NSAttributedString?, String) -> Void)? + public final var setQuery: ((NSAttributedString?, [SearchBarToken], String) -> Void)? public final var setPlaceholder: ((String) -> Void)? open var isSearching: Signal { @@ -25,9 +26,15 @@ open class SearchDisplayControllerContentNode: ASDisplayNode { open func searchTextUpdated(text: String) { } + open func searchTokensUpdated(tokens: [SearchBarToken]) { + } + open func searchTextClearPrefix() { } + open func searchTextClearTokens() { + } + open func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { } diff --git a/submodules/SettingsUI/Sources/CachedFaqInstantPage.swift b/submodules/SettingsUI/Sources/CachedFaqInstantPage.swift index 8fc2ba536c..30fecbd5b5 100644 --- a/submodules/SettingsUI/Sources/CachedFaqInstantPage.swift +++ b/submodules/SettingsUI/Sources/CachedFaqInstantPage.swift @@ -71,13 +71,13 @@ public func cachedFaqInstantPage(context: AccountContext) -> Signal Signal<[SettingsSearchableItem], NoError> { +func faqSearchableItems(context: AccountContext, resolvedUrl: Signal, suggestAccountDeletion: Bool) -> Signal<[SettingsSearchableItem], NoError> { let strings = context.sharedContext.currentPresentationData.with { $0 }.strings - return cachedFaqInstantPage(context: context) + return resolvedUrl |> map { resolvedUrl -> [SettingsSearchableItem] in var results: [SettingsSearchableItem] = [] var nextIndex: Int32 = 2 - if case let .instantView(webPage, _) = resolvedUrl { + if let resolvedUrl = resolvedUrl, case let .instantView(webPage, _) = resolvedUrl { if case let .Loaded(content) = webPage.content, let instantPage = content.instantPage { var processingQuestions = false var currentSection: String? diff --git a/submodules/SettingsUI/Sources/Search/SettingsSearchItem.swift b/submodules/SettingsUI/Sources/Search/SettingsSearchItem.swift index 4aac556f72..eed38f2aee 100644 --- a/submodules/SettingsUI/Sources/Search/SettingsSearchItem.swift +++ b/submodules/SettingsUI/Sources/Search/SettingsSearchItem.swift @@ -74,6 +74,7 @@ final class SettingsSearchItem: ItemListControllerSearch { let presentController: (ViewController, Any?) -> Void let pushController: (ViewController) -> Void let getNavigationController: (() -> NavigationController?)? + let resolvedFaqUrl: Signal let exceptionsList: Signal let archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError> let privacySettings: Signal @@ -85,7 +86,7 @@ final class SettingsSearchItem: ItemListControllerSearch { private var activity: ValuePromise = ValuePromise(ignoreRepeated: false) private let activityDisposable = MetaDisposable() - init(context: AccountContext, theme: PresentationTheme, placeholder: String, activated: Bool, updateActivated: @escaping (Bool) -> Void, presentController: @escaping (ViewController, Any?) -> Void, pushController: @escaping (ViewController) -> Void, getNavigationController: (() -> NavigationController?)?, exceptionsList: Signal, archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError>, privacySettings: Signal, hasWallet: Signal, activeSessionsContext: Signal, webSessionsContext: Signal) { + init(context: AccountContext, theme: PresentationTheme, placeholder: String, activated: Bool, updateActivated: @escaping (Bool) -> Void, presentController: @escaping (ViewController, Any?) -> Void, pushController: @escaping (ViewController) -> Void, getNavigationController: (() -> NavigationController?)?, resolvedFaqUrl: Signal, exceptionsList: Signal, archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError>, privacySettings: Signal, hasWallet: Signal, activeSessionsContext: Signal, webSessionsContext: Signal) { self.context = context self.theme = theme self.placeholder = placeholder @@ -94,6 +95,7 @@ final class SettingsSearchItem: ItemListControllerSearch { self.presentController = presentController self.pushController = pushController self.getNavigationController = getNavigationController + self.resolvedFaqUrl = resolvedFaqUrl self.exceptionsList = exceptionsList self.archivedStickerPacks = archivedStickerPacks self.privacySettings = privacySettings @@ -163,7 +165,7 @@ final class SettingsSearchItem: ItemListControllerSearch { pushController(c) }, presentController: { c, a in presentController(c, a) - }, getNavigationController: self.getNavigationController, exceptionsList: self.exceptionsList, archivedStickerPacks: self.archivedStickerPacks, privacySettings: self.privacySettings, hasWallet: self.hasWallet, activeSessionsContext: self.activeSessionsContext, webSessionsContext: self.webSessionsContext) + }, getNavigationController: self.getNavigationController, resolvedFaqUrl: self.resolvedFaqUrl, exceptionsList: self.exceptionsList, archivedStickerPacks: self.archivedStickerPacks, privacySettings: self.privacySettings, hasWallet: self.hasWallet, activeSessionsContext: self.activeSessionsContext, webSessionsContext: self.webSessionsContext) } } } @@ -360,7 +362,7 @@ public final class SettingsSearchContainerNode: SearchDisplayControllerContentNo private var presentationDataDisposable: Disposable? private let presentationDataPromise: Promise - public init(context: AccountContext, openResult: @escaping (SettingsSearchableItem) -> Void, exceptionsList: Signal, archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError>, privacySettings: Signal, hasWallet: Signal, activeSessionsContext: Signal, webSessionsContext: Signal) { + public init(context: AccountContext, openResult: @escaping (SettingsSearchableItem) -> Void, resolvedFaqUrl: Signal, exceptionsList: Signal, archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError>, privacySettings: Signal, hasWallet: Signal, activeSessionsContext: Signal, webSessionsContext: Signal) { self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.presentationDataPromise = Promise(self.presentationData) @@ -390,9 +392,9 @@ public final class SettingsSearchContainerNode: SearchDisplayControllerContentNo searchableItems.set(settingsSearchableItems(context: context, notificationExceptionsList: exceptionsList, archivedStickerPacks: archivedStickerPacks, privacySettings: privacySettings, hasWallet: hasWallet, activeSessionsContext: activeSessionsContext, webSessionsContext: webSessionsContext)) let faqItems = Promise<[SettingsSearchableItem]>() - faqItems.set(faqSearchableItems(context: context, suggestAccountDeletion: false)) + faqItems.set(faqSearchableItems(context: context, resolvedUrl: resolvedFaqUrl, suggestAccountDeletion: false)) - let queryAndFoundItems = combineLatest(searchableItems.get(), faqSearchableItems(context: context, suggestAccountDeletion: true)) + let queryAndFoundItems = combineLatest(searchableItems.get(), faqSearchableItems(context: context, resolvedUrl: resolvedFaqUrl, suggestAccountDeletion: true)) |> mapToSignal { searchableItems, faqSearchableItems -> Signal<(String, [SettingsSearchableItem])?, NoError> in return self.searchQuery.get() |> mapToSignal { query -> Signal<(String, [SettingsSearchableItem])?, NoError> in @@ -656,6 +658,7 @@ private final class SettingsSearchItemNode: ItemListControllerSearchNode { let pushController: (ViewController) -> Void let presentController: (ViewController, Any?) -> Void let getNavigationController: (() -> NavigationController?)? + let resolvedFaqUrl: Signal let exceptionsList: Signal let archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError> let privacySettings: Signal @@ -665,13 +668,14 @@ private final class SettingsSearchItemNode: ItemListControllerSearchNode { var cancel: () -> Void - init(context: AccountContext, cancel: @escaping () -> Void, updateActivity: @escaping(Bool) -> Void, pushController: @escaping (ViewController) -> Void, presentController: @escaping (ViewController, Any?) -> Void, getNavigationController: (() -> NavigationController?)?, exceptionsList: Signal, archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError>, privacySettings: Signal, hasWallet: Signal, activeSessionsContext: Signal, webSessionsContext: Signal) { + init(context: AccountContext, cancel: @escaping () -> Void, updateActivity: @escaping(Bool) -> Void, pushController: @escaping (ViewController) -> Void, presentController: @escaping (ViewController, Any?) -> Void, getNavigationController: (() -> NavigationController?)?, resolvedFaqUrl: Signal, exceptionsList: Signal, archivedStickerPacks: Signal<[ArchivedStickerPackItem]?, NoError>, privacySettings: Signal, hasWallet: Signal, activeSessionsContext: Signal, webSessionsContext: Signal) { self.context = context self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.cancel = cancel self.pushController = pushController self.presentController = presentController self.getNavigationController = getNavigationController + self.resolvedFaqUrl = resolvedFaqUrl self.exceptionsList = exceptionsList self.archivedStickerPacks = archivedStickerPacks self.privacySettings = privacySettings @@ -717,7 +721,7 @@ private final class SettingsSearchItemNode: ItemListControllerSearchNode { } }) } - }, exceptionsList: self.exceptionsList, archivedStickerPacks: self.archivedStickerPacks, privacySettings: self.privacySettings, hasWallet: self.hasWallet, activeSessionsContext: self.activeSessionsContext, webSessionsContext: self.webSessionsContext), cancel: { [weak self] in + }, resolvedFaqUrl: self.resolvedFaqUrl, exceptionsList: self.exceptionsList, archivedStickerPacks: self.archivedStickerPacks, privacySettings: self.privacySettings, hasWallet: self.hasWallet, activeSessionsContext: self.activeSessionsContext, webSessionsContext: self.webSessionsContext), cancel: { [weak self] in self?.cancel() }) diff --git a/submodules/SettingsUI/Sources/SettingsController.swift b/submodules/SettingsUI/Sources/SettingsController.swift index 19fb415862..66ec64ff69 100644 --- a/submodules/SettingsUI/Sources/SettingsController.swift +++ b/submodules/SettingsUI/Sources/SettingsController.swift @@ -1661,7 +1661,7 @@ public func settingsController(context: AccountContext, accountManager: AccountM presentControllerImpl?(c, a) }, pushController: { c in pushControllerImpl?(c) - }, getNavigationController: getNavigationControllerImpl, exceptionsList: notifyExceptions.get(), archivedStickerPacks: archivedPacks.get(), privacySettings: privacySettings.get(), hasWallet: hasWallet, activeSessionsContext: activeSessionsContextAndCountSignal |> map { $0.0 } |> distinctUntilChanged(isEqual: { $0 === $1 }), webSessionsContext: activeSessionsContextAndCountSignal |> map { $0.2 } |> distinctUntilChanged(isEqual: { $0 === $1 })) + }, getNavigationController: getNavigationControllerImpl, resolvedFaqUrl: .complete(), exceptionsList: notifyExceptions.get(), archivedStickerPacks: archivedPacks.get(), privacySettings: privacySettings.get(), hasWallet: hasWallet, activeSessionsContext: activeSessionsContextAndCountSignal |> map { $0.0 } |> distinctUntilChanged(isEqual: { $0 === $1 }), webSessionsContext: activeSessionsContextAndCountSignal |> map { $0.2 } |> distinctUntilChanged(isEqual: { $0 === $1 })) let (hasWallet, hasPassport, hasWatchApp, enableQRLogin, enableFilters) = hasWalletPassportAndWatch let listState = ItemListNodeState(presentationData: ItemListPresentationData(presentationData), entries: settingsEntries(account: context.account, presentationData: presentationData, state: state, view: view, proxySettings: proxySettings, notifyExceptions: preferencesAndExceptions.1, notificationsAuthorizationStatus: preferencesAndExceptions.2, notificationsWarningSuppressed: preferencesAndExceptions.3, unreadTrendingStickerPacks: unreadTrendingStickerPacks, archivedPacks: featuredAndArchived.1, privacySettings: preferencesAndExceptions.4, hasWallet: hasWallet, hasPassport: hasPassport, hasWatchApp: hasWatchApp, accountsAndPeers: accountsAndPeers.1, inAppNotificationSettings: inAppNotificationSettings, experimentalUISettings: experimentalUISettings, displayPhoneNumberConfirmation: preferencesAndExceptions.5, otherSessionCount: otherSessionCount, enableQRLogin: enableQRLogin, enableFilters: enableFilters), style: .blocks, searchItem: searchItem, initialScrollToItem: ListViewScrollToItem(index: 0, position: .top(-navigationBarSearchContentHeight), animated: false, curve: .Default(duration: 0.0), directionHint: .Up)) diff --git a/submodules/SettingsUI/Sources/Themes/ThemeGridSearchContentNode.swift b/submodules/SettingsUI/Sources/Themes/ThemeGridSearchContentNode.swift index 5574a938e9..ad9afdde09 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeGridSearchContentNode.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeGridSearchContentNode.swift @@ -674,7 +674,7 @@ final class ThemeGridSearchContentNode: SearchDisplayControllerContentNode { text = query placeholder = self.presentationData.strings.Wallpaper_SearchShort } - self.setQuery?(prefix, text) + self.setQuery?(prefix, [], text) self.setPlaceholder?(placeholder) } } diff --git a/submodules/TelegramBaseController/Sources/TelegramBaseController.swift b/submodules/TelegramBaseController/Sources/TelegramBaseController.swift index 894999317b..d248455df0 100644 --- a/submodules/TelegramBaseController/Sources/TelegramBaseController.swift +++ b/submodules/TelegramBaseController/Sources/TelegramBaseController.swift @@ -594,7 +594,7 @@ open class TelegramBaseController: ViewController, KeyShortcutResponder { } else { controllerContext = strongSelf.context.sharedContext.makeTempAccountContext(account: account) } - let controller = strongSelf.context.sharedContext.makeOverlayAudioPlayerController(context: controllerContext, peerId: id.messageId.peerId, type: type, initialMessageId: id.messageId, initialOrder: order, parentNavigationController: strongSelf.navigationController as? NavigationController) + let controller = strongSelf.context.sharedContext.makeOverlayAudioPlayerController(context: controllerContext, peerId: id.messageId.peerId, type: type, initialMessageId: id.messageId, initialOrder: order, isGlobalSearch: false, parentNavigationController: strongSelf.navigationController as? NavigationController) strongSelf.displayNode.view.window?.endEditing(true) strongSelf.present(controller, in: .window(.root)) } else if index.1 { diff --git a/submodules/TelegramCore/Sources/SearchMessages.swift b/submodules/TelegramCore/Sources/SearchMessages.swift index eab030886e..4e0ce26fb7 100644 --- a/submodules/TelegramCore/Sources/SearchMessages.swift +++ b/submodules/TelegramCore/Sources/SearchMessages.swift @@ -7,9 +7,9 @@ import MtProtoKit import SyncCore public enum SearchMessagesLocation: Equatable { - case general(tags: MessageTags?) + case general(tags: MessageTags?, minDate: Int32?, maxDate: Int32?) case group(PeerGroupId) - case peer(peerId: PeerId, fromId: PeerId?, tags: MessageTags?, topMsgId: MessageId?) + case peer(peerId: PeerId, fromId: PeerId?, tags: MessageTags?, topMsgId: MessageId?, minDate: Int32?, maxDate: Int32?) case publicForwards(messageId: MessageId, datacenterId: Int?) } @@ -47,6 +47,13 @@ public struct SearchMessagesResult { public let readStates: [PeerId: CombinedPeerReadState] public let totalCount: Int32 public let completed: Bool + + public init(messages: [Message], readStates: [PeerId: CombinedPeerReadState], totalCount: Int32, completed: Bool) { + self.messages = messages + self.readStates = readStates + self.totalCount = totalCount + self.completed = completed + } } public struct SearchMessagesState: Equatable { @@ -180,7 +187,7 @@ private func mergedResult(_ state: SearchMessagesState) -> SearchMessagesResult public func searchMessages(account: Account, location: SearchMessagesLocation, query: String, state: SearchMessagesState?, limit: Int32 = 100) -> Signal<(SearchMessagesResult, SearchMessagesState), NoError> { let remoteSearchResult: Signal<(Api.messages.Messages?, Api.messages.Messages?), NoError> switch location { - case let .peer(peerId, fromId, tags, topMsgId): + case let .peer(peerId, fromId, tags, topMsgId, minDate, maxDate): if peerId.namespace == Namespaces.Peer.SecretChat { return account.postbox.transaction { transaction -> (SearchMessagesResult, SearchMessagesState) in var readStates: [PeerId: CombinedPeerReadState] = [:] @@ -230,7 +237,7 @@ public func searchMessages(account: Account, location: SearchMessagesLocation, q peerMessages = .single(nil) } else { let lowerBound = state?.main.messages.last.flatMap({ $0.index }) - peerMessages = account.network.request(Api.functions.messages.search(flags: flags, peer: inputPeer, q: query, fromId: fromInputUser, topMsgId: topMsgId?.id, filter: filter, minDate: 0, maxDate: Int32.max - 1, offsetId: lowerBound?.id.id ?? 0, addOffset: 0, limit: limit, maxId: Int32.max - 1, minId: 0, hash: 0)) + peerMessages = account.network.request(Api.functions.messages.search(flags: flags, peer: inputPeer, q: query, fromId: fromInputUser, topMsgId: topMsgId?.id, filter: filter, minDate: minDate ?? 0, maxDate: maxDate ?? (Int32.max - 1), offsetId: lowerBound?.id.id ?? 0, addOffset: 0, limit: limit, maxId: Int32.max - 1, minId: 0, hash: 0)) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) @@ -244,7 +251,7 @@ public func searchMessages(account: Account, location: SearchMessagesLocation, q additionalPeerMessages = .single(nil) } else if mainCompleted || !hasAdditional { let lowerBound = state?.additional?.messages.last.flatMap({ $0.index }) - additionalPeerMessages = account.network.request(Api.functions.messages.search(flags: flags, peer: inputPeer, q: query, fromId: fromInputUser, topMsgId: topMsgId?.id, filter: filter, minDate: 0, maxDate: Int32.max - 1, offsetId: lowerBound?.id.id ?? 0, addOffset: 0, limit: limit, maxId: Int32.max - 1, minId: 0, hash: 0)) + additionalPeerMessages = account.network.request(Api.functions.messages.search(flags: flags, peer: inputPeer, q: query, fromId: fromInputUser, topMsgId: topMsgId?.id, filter: filter, minDate: minDate ?? 0, maxDate: maxDate ?? (Int32.max - 1), offsetId: lowerBound?.id.id ?? 0, addOffset: 0, limit: limit, maxId: Int32.max - 1, minId: 0, hash: 0)) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) @@ -259,7 +266,7 @@ public func searchMessages(account: Account, location: SearchMessagesLocation, q } case .group: remoteSearchResult = .single((nil, nil)) - case let .general(tags): + case let .general(tags, minDate, maxDate): let filter: Api.MessagesFilter = tags.flatMap { messageFilterForTagMask($0) } ?? .inputMessagesFilterEmpty remoteSearchResult = account.postbox.transaction { transaction -> (Int32, MessageIndex?, Api.InputPeer) in var lowerBound: MessageIndex? @@ -273,7 +280,7 @@ public func searchMessages(account: Account, location: SearchMessagesLocation, q } } |> mapToSignal { (nextRate, lowerBound, inputPeer) in - return account.network.request(Api.functions.messages.searchGlobal(flags: 0, folderId: nil, q: query, filter: .inputMessagesFilterEmpty, minDate: 0, maxDate: 0, offsetRate: nextRate, offsetPeer: inputPeer, offsetId: lowerBound?.id.id ?? 0, limit: limit), automaticFloodWait: false) + return account.network.request(Api.functions.messages.searchGlobal(flags: 0, folderId: nil, q: query, filter: filter, minDate: minDate ?? 0, maxDate: maxDate ?? (Int32.max - 1), offsetRate: nextRate, offsetPeer: inputPeer, offsetId: lowerBound?.id.id ?? 0, limit: limit), automaticFloodWait: false) |> map { result -> (Api.messages.Messages?, Api.messages.Messages?) in return (result, nil) } @@ -296,13 +303,12 @@ public func searchMessages(account: Account, location: SearchMessagesLocation, q return (inputChannel, 0, lowerBound, .inputPeerEmpty) } } - |> mapToSignal { (inputChannel, nextRate, lowerBound, inputPeer) -> Signal<(Api.messages.Messages?, Api.messages.Messages?), NoError> in + |> mapToSignal { (inputChannel, nextRate, lowerBound, inputPeer) in guard let inputChannel = inputChannel else { return .complete() } - return .single((nil, nil)) - /*let request = Api.functions.stats.getMessagePublicForwards(channel: inputChannel, msgId: messageId.id, offsetRate: nextRate, offsetPeer: inputPeer, offsetId: lowerBound?.id.id ?? 0, limit: limit) + let request = Api.functions.stats.getMessagePublicForwards(channel: inputChannel, msgId: messageId.id, offsetRate: nextRate, offsetPeer: inputPeer, offsetId: lowerBound?.id.id ?? 0, limit: limit) let signal: Signal if let datacenterId = datacenterId, account.network.datacenterId != datacenterId { signal = account.network.download(datacenterId: datacenterId, isMedia: false, tag: nil) @@ -319,7 +325,7 @@ public func searchMessages(account: Account, location: SearchMessagesLocation, q } |> `catch` { _ -> Signal<(Api.messages.Messages?, Api.messages.Messages?), NoError> in return .single((nil, nil)) - }*/ + } } } @@ -327,7 +333,7 @@ public func searchMessages(account: Account, location: SearchMessagesLocation, q |> mapToSignal { result, additionalResult -> Signal<(SearchMessagesResult, SearchMessagesState), NoError> in return account.postbox.transaction { transaction -> (SearchMessagesResult, SearchMessagesState) in var additional: SearchMessagesPeerState? = mergedState(transaction: transaction, state: state?.additional, result: additionalResult) - if state?.additional == nil, case let .general(tags) = location { + if state?.additional == nil, case let .general(tags, _, _) = location { let secretMessages = transaction.searchMessages(peerId: nil, query: query, tags: tags) var readStates: [PeerId: CombinedPeerReadState] = [:] for message in secretMessages { diff --git a/submodules/TelegramCore/Sources/SplitTest.swift b/submodules/TelegramCore/Sources/SplitTest.swift index 10cac1b41e..c0f8938470 100644 --- a/submodules/TelegramCore/Sources/SplitTest.swift +++ b/submodules/TelegramCore/Sources/SplitTest.swift @@ -25,7 +25,7 @@ extension SplitTest { public func addEvent(_ event: Self.Event, data: JSON = []) { if let bucket = self.bucket { //TODO: merge additional data - addAppLogEvent(postbox: self.postbox, time: Date().timeIntervalSince1970, type: event.rawValue, peerId: nil, data: ["bucket": bucket]) + addAppLogEvent(postbox: self.postbox, type: event.rawValue, data: ["bucket": bucket]) } } } diff --git a/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift b/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift index c02de703b2..e2aea13fd8 100644 --- a/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift +++ b/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift @@ -473,9 +473,9 @@ extension StoreMessage { attributes.append(ViewCountMessageAttribute(count: Int(views))) } - /*if let forwards = forwards { + if let forwards = forwards { attributes.append(ForwardCountMessageAttribute(count: Int(forwards))) - }*/ + } } if let editDate = editDate { diff --git a/submodules/TelegramCore/Sources/SynchronizeAppLogEventsOperation.swift b/submodules/TelegramCore/Sources/SynchronizeAppLogEventsOperation.swift index 99669da865..541fb91a73 100644 --- a/submodules/TelegramCore/Sources/SynchronizeAppLogEventsOperation.swift +++ b/submodules/TelegramCore/Sources/SynchronizeAppLogEventsOperation.swift @@ -5,7 +5,7 @@ import MtProtoKit import SyncCore -public func addAppLogEvent(postbox: Postbox, time: Double, type: String, peerId: PeerId?, data: JSON) { +public func addAppLogEvent(postbox: Postbox, time: Double = Date().timeIntervalSince1970, type: String, peerId: PeerId? = nil, data: JSON = .dictionary([:])) { let tag: PeerOperationLogTag = OperationLogTags.SynchronizeAppLogEvents let peerId = PeerId(namespace: 0, id: 0) let _ = (postbox.transaction { transaction in diff --git a/submodules/TelegramCore/Sources/WebpagePreview.swift b/submodules/TelegramCore/Sources/WebpagePreview.swift index 8fcf5fe9dc..5c9085b550 100644 --- a/submodules/TelegramCore/Sources/WebpagePreview.swift +++ b/submodules/TelegramCore/Sources/WebpagePreview.swift @@ -83,7 +83,6 @@ public func actualizedWebpage(postbox: Postbox, network: Network, webpage: Teleg return .single(nil) } |> mapToSignal { result -> Signal in - if let result = result, let updatedWebpage = telegramMediaWebpageFromApiWebpage(result, url: nil), case .Loaded = updatedWebpage.content, updatedWebpage.webpageId == webpage.webpageId { return postbox.transaction { transaction -> TelegramMediaWebpage in updateMessageMedia(transaction: transaction, id: webpage.webpageId, media: updatedWebpage) diff --git a/submodules/TelegramPresentationData/Sources/ChatPresentationData.swift b/submodules/TelegramPresentationData/Sources/ChatPresentationData.swift new file mode 100644 index 0000000000..614ea5416e --- /dev/null +++ b/submodules/TelegramPresentationData/Sources/ChatPresentationData.swift @@ -0,0 +1,71 @@ +import Foundation +import UIKit +import Display +import TelegramCore +import SyncCore +import TelegramPresentationData +import TelegramUIPreferences + +public final class ChatPresentationThemeData: Equatable { + public let theme: PresentationTheme + public let wallpaper: TelegramWallpaper + + public init(theme: PresentationTheme, wallpaper: TelegramWallpaper) { + self.theme = theme + self.wallpaper = wallpaper + } + + public static func ==(lhs: ChatPresentationThemeData, rhs: ChatPresentationThemeData) -> Bool { + return lhs.theme === rhs.theme && lhs.wallpaper == rhs.wallpaper + } +} + +public final class ChatPresentationData { + public let theme: ChatPresentationThemeData + public let fontSize: PresentationFontSize + public let strings: PresentationStrings + public let dateTimeFormat: PresentationDateTimeFormat + public let nameDisplayOrder: PresentationPersonNameOrder + public let disableAnimations: Bool + public let largeEmoji: Bool + public let chatBubbleCorners: PresentationChatBubbleCorners + public let animatedEmojiScale: CGFloat + public let isPreview: Bool + + public let messageFont: UIFont + public let messageEmojiFont: UIFont + public let messageBoldFont: UIFont + public let messageItalicFont: UIFont + public let messageBoldItalicFont: UIFont + public let messageFixedFont: UIFont + public let messageBlockQuoteFont: UIFont + + public init(theme: ChatPresentationThemeData, fontSize: PresentationFontSize, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, disableAnimations: Bool, largeEmoji: Bool, chatBubbleCorners: PresentationChatBubbleCorners, animatedEmojiScale: CGFloat = 1.0, isPreview: Bool = false) { + self.theme = theme + self.fontSize = fontSize + self.strings = strings + self.dateTimeFormat = dateTimeFormat + self.nameDisplayOrder = nameDisplayOrder + self.disableAnimations = disableAnimations + self.chatBubbleCorners = chatBubbleCorners + self.largeEmoji = largeEmoji + self.isPreview = isPreview + + let baseFontSize = fontSize.baseDisplaySize + self.messageFont = Font.regular(baseFontSize) + self.messageEmojiFont = Font.regular(53.0) + self.messageBoldFont = Font.bold(baseFontSize) + self.messageItalicFont = Font.italic(baseFontSize) + self.messageBoldItalicFont = Font.semiboldItalic(baseFontSize) + self.messageFixedFont = Font.monospace(baseFontSize) + self.messageBlockQuoteFont = Font.regular(baseFontSize - 1.0) + + self.animatedEmojiScale = animatedEmojiScale + } +} + +extension ChatPresentationData { + public convenience init(presentationData: PresentationData) { + self.init(theme: ChatPresentationThemeData(theme: presentationData.theme, wallpaper: presentationData.chatWallpaper), fontSize: presentationData.chatFontSize, strings: presentationData.strings, dateTimeFormat: presentationData.dateTimeFormat, nameDisplayOrder: presentationData.nameDisplayOrder, disableAnimations: presentationData.disableAnimations, largeEmoji: presentationData.largeEmoji, chatBubbleCorners: presentationData.chatBubbleCorners) + } +} diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index d820c37425..f6ac170ce8 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -291,4866 +291,4885 @@ public final class PresentationStrings: Equatable { return formatWithArgumentRanges(self._s[102]!, self._r[102]!, [_0]) } public var Wallet_Configuration_BlockchainIdPlaceholder: String { return self._s[103]! } - public var AccessDenied_LocationDenied: String { return self._s[104]! } - public var CallSettings_RecentCalls: String { return self._s[105]! } - public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[106]! } - public var Conversation_Dice_u1F3C0: String { return self._s[107]! } - public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[109]! } - public var Passport_Authorize: String { return self._s[110]! } - public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[111]! } - public var AutoDownloadSettings_Videos: String { return self._s[112]! } - public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[113]! } - public var Wallet_Info_Send: String { return self._s[114]! } - public var AuthSessions_AddDevice_UrlLoginHint: String { return self._s[115]! } - public var Wallet_TransactionInfo_SendGrams: String { return self._s[116]! } - public var Tour_StartButton: String { return self._s[117]! } - public var Watch_AppName: String { return self._s[119]! } - public var Settings_AddAnotherAccount: String { return self._s[120]! } - public var StickerPack_ErrorNotFound: String { return self._s[121]! } - public var Channel_Info_Subscribers: String { return self._s[122]! } + public var ChatList_Search_FilterMedia: String { return self._s[104]! } + public var AccessDenied_LocationDenied: String { return self._s[105]! } + public var CallSettings_RecentCalls: String { return self._s[106]! } + public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[107]! } + public var Conversation_Dice_u1F3C0: String { return self._s[108]! } + public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[110]! } + public var Passport_Authorize: String { return self._s[111]! } + public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[112]! } + public var AutoDownloadSettings_Videos: String { return self._s[113]! } + public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[114]! } + public var Wallet_Info_Send: String { return self._s[115]! } + public var AuthSessions_AddDevice_UrlLoginHint: String { return self._s[116]! } + public var Wallet_TransactionInfo_SendGrams: String { return self._s[117]! } + public var Tour_StartButton: String { return self._s[118]! } + public var Watch_AppName: String { return self._s[120]! } + public var Settings_AddAnotherAccount: String { return self._s[121]! } + public var StickerPack_ErrorNotFound: String { return self._s[122]! } + public var Channel_Info_Subscribers: String { return self._s[123]! } public func Channel_AdminLog_MessageGroupPreHistoryVisible(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[123]!, self._r[123]!, [_0]) - } - public func DialogList_PinLimitError(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[124]!, self._r[124]!, [_0]) } - public var Appearance_RemoveTheme: String { return self._s[125]! } + public func DialogList_PinLimitError(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[125]!, self._r[125]!, [_0]) + } + public var Appearance_RemoveTheme: String { return self._s[126]! } public func Wallet_Info_TransactionBlockchainFee(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[126]!, self._r[126]!, [_0]) + return formatWithArgumentRanges(self._s[127]!, self._r[127]!, [_0]) } - public var Conversation_StopLiveLocation: String { return self._s[129]! } - public var Channel_AdminLogFilter_EventsAll: String { return self._s[130]! } - public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[132]! } - public var Username_LinkCopied: String { return self._s[134]! } - public var GroupRemoved_Title: String { return self._s[135]! } - public var SecretVideo_Title: String { return self._s[136]! } + public var Conversation_StopLiveLocation: String { return self._s[130]! } + public var Channel_AdminLogFilter_EventsAll: String { return self._s[131]! } + public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[133]! } + public var Username_LinkCopied: String { return self._s[135]! } + public var GroupRemoved_Title: String { return self._s[136]! } + public var SecretVideo_Title: String { return self._s[137]! } public func PUSH_PINNED_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[137]!, self._r[137]!, [_1]) + return formatWithArgumentRanges(self._s[138]!, self._r[138]!, [_1]) } - public var AccessDenied_PhotosAndVideos: String { return self._s[138]! } - public var Appearance_ThemePreview_Chat_1_Text: String { return self._s[139]! } + public var AccessDenied_PhotosAndVideos: String { return self._s[139]! } + public var Appearance_ThemePreview_Chat_1_Text: String { return self._s[140]! } public func PUSH_CHANNEL_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[141]!, self._r[141]!, [_1]) + return formatWithArgumentRanges(self._s[142]!, self._r[142]!, [_1]) } - public var Map_OpenInGoogleMaps: String { return self._s[143]! } - public var Conversation_Dice_u26BD: String { return self._s[144]! } + public var Map_OpenInGoogleMaps: String { return self._s[144]! } + public var Conversation_Dice_u26BD: String { return self._s[145]! } public func Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[145]!, self._r[145]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[146]!, self._r[146]!, [_1, _2, _3]) } public func Channel_AdminLog_MessageKickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[146]!, self._r[146]!, [_1, _2]) + return formatWithArgumentRanges(self._s[147]!, self._r[147]!, [_1, _2]) } - public var Call_StatusRinging: String { return self._s[147]! } - public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[148]! } - public var Group_Username_InvalidStartsWithNumber: String { return self._s[149]! } - public var UserInfo_NotificationsEnabled: String { return self._s[150]! } - public var PeopleNearby_MakeVisibleDescription: String { return self._s[151]! } - public var Settings_RemoveConfirmation: String { return self._s[152]! } - public var ChatListFolder_CategoryRead: String { return self._s[153]! } - public var Map_Search: String { return self._s[154]! } - public var ClearCache_StorageFree: String { return self._s[156]! } - public var Login_TermsOfServiceHeader: String { return self._s[157]! } + public var Call_StatusRinging: String { return self._s[148]! } + public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[149]! } + public var Group_Username_InvalidStartsWithNumber: String { return self._s[150]! } + public var UserInfo_NotificationsEnabled: String { return self._s[151]! } + public var PeopleNearby_MakeVisibleDescription: String { return self._s[152]! } + public var Settings_RemoveConfirmation: String { return self._s[153]! } + public var ChatListFolder_CategoryRead: String { return self._s[154]! } + public var Map_Search: String { return self._s[155]! } + public var ClearCache_StorageFree: String { return self._s[157]! } + public var Login_TermsOfServiceHeader: String { return self._s[158]! } public func Notification_PinnedVideoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[158]!, self._r[158]!, [_0]) + return formatWithArgumentRanges(self._s[159]!, self._r[159]!, [_0]) } public func Channel_AdminLog_MessageToggleSignaturesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[160]!, self._r[160]!, [_0]) + return formatWithArgumentRanges(self._s[161]!, self._r[161]!, [_0]) } - public var ChatList_GenericPsaAlert: String { return self._s[161]! } - public var Wallet_Sent_Title: String { return self._s[162]! } - public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[163]! } - public var Weekday_Today: String { return self._s[164]! } - public var Stats_InstantViewInteractionsTitle: String { return self._s[165]! } + public var ChatList_GenericPsaAlert: String { return self._s[162]! } + public var Wallet_Sent_Title: String { return self._s[163]! } + public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[164]! } + public var Weekday_Today: String { return self._s[165]! } + public var Stats_InstantViewInteractionsTitle: String { return self._s[166]! } public func InstantPage_AuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[167]!, self._r[167]!, [_1, _2]) + return formatWithArgumentRanges(self._s[168]!, self._r[168]!, [_1, _2]) } public func Conversation_MessageDialogRetryAll(_ _1: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[168]!, self._r[168]!, ["\(_1)"]) + return formatWithArgumentRanges(self._s[169]!, self._r[169]!, ["\(_1)"]) } - public var Notification_PassportValuePersonalDetails: String { return self._s[170]! } - public var ProfilePhoto_SearchWeb: String { return self._s[171]! } - public var Channel_AdminLog_MessagePreviousLink: String { return self._s[172]! } - public var ChangePhoneNumberNumber_NewNumber: String { return self._s[173]! } - public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[174]! } - public var TwoStepAuth_ChangePasswordDescription: String { return self._s[175]! } - public var PhotoEditor_BlurToolLinear: String { return self._s[176]! } - public var Contacts_PermissionsAllowInSettings: String { return self._s[177]! } - public var Weekday_ShortMonday: String { return self._s[178]! } - public var Cache_KeepMedia: String { return self._s[179]! } - public var Passport_FieldIdentitySelfieHelp: String { return self._s[180]! } + public var Notification_PassportValuePersonalDetails: String { return self._s[171]! } + public var ChatList_Search_NoResults: String { return self._s[172]! } + public var ProfilePhoto_SearchWeb: String { return self._s[173]! } + public var Channel_AdminLog_MessagePreviousLink: String { return self._s[174]! } + public var ChangePhoneNumberNumber_NewNumber: String { return self._s[175]! } + public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[176]! } + public var TwoStepAuth_ChangePasswordDescription: String { return self._s[177]! } + public var PhotoEditor_BlurToolLinear: String { return self._s[178]! } + public var Contacts_PermissionsAllowInSettings: String { return self._s[179]! } + public var Weekday_ShortMonday: String { return self._s[180]! } + public var Cache_KeepMedia: String { return self._s[181]! } + public var Passport_FieldIdentitySelfieHelp: String { return self._s[182]! } public func PUSH_PINNED_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[181]!, self._r[181]!, [_1, _2]) + return formatWithArgumentRanges(self._s[183]!, self._r[183]!, [_1, _2]) } public func Chat_SlowmodeTooltip(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[182]!, self._r[182]!, [_0]) + return formatWithArgumentRanges(self._s[184]!, self._r[184]!, [_0]) } - public var Wallet_Receive_ShareUrlInfo: String { return self._s[183]! } - public var Conversation_ClousStorageInfo_Description4: String { return self._s[184]! } - public var Wallet_RestoreFailed_Title: String { return self._s[185]! } - public var Passport_Language_ru: String { return self._s[186]! } + public var Wallet_Receive_ShareUrlInfo: String { return self._s[185]! } + public var Conversation_ClousStorageInfo_Description4: String { return self._s[186]! } + public var Wallet_RestoreFailed_Title: String { return self._s[187]! } + public var Passport_Language_ru: String { return self._s[188]! } public func Notification_CreatedChatWithTitle(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[187]!, self._r[187]!, [_0, _1]) + return formatWithArgumentRanges(self._s[189]!, self._r[189]!, [_0, _1]) } - public var WallpaperPreview_PatternIntensity: String { return self._s[188]! } - public var ChatList_EditFolder: String { return self._s[191]! } - public var ChatList_AutoarchiveSuggestion_Title: String { return self._s[192]! } - public var WebBrowser_InAppSafari: String { return self._s[193]! } - public var TwoStepAuth_RecoveryUnavailable: String { return self._s[194]! } - public var EnterPasscode_TouchId: String { return self._s[195]! } - public var PhotoEditor_QualityVeryHigh: String { return self._s[198]! } - public var Checkout_NewCard_SaveInfo: String { return self._s[200]! } - public var Gif_NoGifsPlaceholder: String { return self._s[202]! } + public var WallpaperPreview_PatternIntensity: String { return self._s[190]! } + public var ChatList_Search_FilterPhotos: String { return self._s[193]! } + public var ChatList_EditFolder: String { return self._s[194]! } + public var ChatList_AutoarchiveSuggestion_Title: String { return self._s[195]! } + public var WebBrowser_InAppSafari: String { return self._s[196]! } + public var TwoStepAuth_RecoveryUnavailable: String { return self._s[197]! } + public var EnterPasscode_TouchId: String { return self._s[198]! } + public var PhotoEditor_QualityVeryHigh: String { return self._s[201]! } + public var Checkout_NewCard_SaveInfo: String { return self._s[203]! } + public var Gif_NoGifsPlaceholder: String { return self._s[205]! } public func Notification_InvitedMultiple(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[204]!, self._r[204]!, [_0, _1]) + return formatWithArgumentRanges(self._s[207]!, self._r[207]!, [_0, _1]) } - public var ChatSettings_AutoDownloadEnabled: String { return self._s[205]! } - public var NetworkUsageSettings_BytesSent: String { return self._s[206]! } - public var Checkout_PasswordEntry_Pay: String { return self._s[207]! } - public var AuthSessions_TerminateSession: String { return self._s[208]! } - public var Message_File: String { return self._s[209]! } - public var MediaPicker_VideoMuteDescription: String { return self._s[210]! } - public var SocksProxySetup_ProxyStatusConnected: String { return self._s[211]! } - public var TwoStepAuth_RecoveryCode: String { return self._s[212]! } - public var EnterPasscode_EnterCurrentPasscode: String { return self._s[213]! } + public var ChatSettings_AutoDownloadEnabled: String { return self._s[208]! } + public var NetworkUsageSettings_BytesSent: String { return self._s[209]! } + public var Checkout_PasswordEntry_Pay: String { return self._s[210]! } + public var AuthSessions_TerminateSession: String { return self._s[211]! } + public var Message_File: String { return self._s[212]! } + public var MediaPicker_VideoMuteDescription: String { return self._s[213]! } + public var SocksProxySetup_ProxyStatusConnected: String { return self._s[214]! } + public var TwoStepAuth_RecoveryCode: String { return self._s[215]! } + public var EnterPasscode_EnterCurrentPasscode: String { return self._s[216]! } public func TwoStepAuth_EnterPasswordHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[214]!, self._r[214]!, [_0]) + return formatWithArgumentRanges(self._s[217]!, self._r[217]!, [_0]) } - public var Conversation_Moderate_Report: String { return self._s[216]! } - public var TwoStepAuth_EmailInvalid: String { return self._s[217]! } - public var Passport_Language_ms: String { return self._s[218]! } - public var Channel_Edit_AboutItem: String { return self._s[220]! } - public var DialogList_SearchSectionGlobal: String { return self._s[224]! } - public var AttachmentMenu_WebSearch: String { return self._s[225]! } - public var ChatState_WaitingForNetwork: String { return self._s[226]! } - public var Channel_BanUser_Title: String { return self._s[227]! } - public var PasscodeSettings_TurnPasscodeOn: String { return self._s[228]! } - public var WallpaperPreview_SwipeTopText: String { return self._s[229]! } - public var ChatList_DeleteSavedMessagesConfirmationText: String { return self._s[230]! } - public var ArchivedChats_IntroText2: String { return self._s[231]! } - public var ChatSearch_SearchPlaceholder: String { return self._s[233]! } - public var Conversation_OpenBotLinkTitle: String { return self._s[234]! } - public var Passport_FieldAddressTranslationHelp: String { return self._s[235]! } - public var NotificationsSound_Aurora: String { return self._s[236]! } - public var Notification_Exceptions_DeleteAll: String { return self._s[237]! } + public var Conversation_Moderate_Report: String { return self._s[219]! } + public var TwoStepAuth_EmailInvalid: String { return self._s[220]! } + public var Passport_Language_ms: String { return self._s[221]! } + public var Channel_Edit_AboutItem: String { return self._s[223]! } + public var DialogList_SearchSectionGlobal: String { return self._s[227]! } + public var AttachmentMenu_WebSearch: String { return self._s[228]! } + public var ChatState_WaitingForNetwork: String { return self._s[229]! } + public var Channel_BanUser_Title: String { return self._s[230]! } + public var PasscodeSettings_TurnPasscodeOn: String { return self._s[231]! } + public var WallpaperPreview_SwipeTopText: String { return self._s[232]! } + public var ChatList_DeleteSavedMessagesConfirmationText: String { return self._s[233]! } + public var ArchivedChats_IntroText2: String { return self._s[234]! } + public var ChatSearch_SearchPlaceholder: String { return self._s[236]! } + public var Conversation_OpenBotLinkTitle: String { return self._s[237]! } + public var Passport_FieldAddressTranslationHelp: String { return self._s[238]! } + public var NotificationsSound_Aurora: String { return self._s[239]! } + public var Notification_Exceptions_DeleteAll: String { return self._s[240]! } public func FileSize_GB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[238]!, self._r[238]!, [_0]) + return formatWithArgumentRanges(self._s[241]!, self._r[241]!, [_0]) } - public var AuthSessions_LoggedInWithTelegram: String { return self._s[241]! } + public var AuthSessions_LoggedInWithTelegram: String { return self._s[244]! } public func Privacy_GroupsAndChannels_InviteToGroupError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[242]!, self._r[242]!, [_0, _1]) + return formatWithArgumentRanges(self._s[245]!, self._r[245]!, [_0, _1]) } - public var Passport_PasswordNext: String { return self._s[243]! } - public var Bot_GroupStatusReadsHistory: String { return self._s[244]! } - public var EmptyGroupInfo_Line2: String { return self._s[245]! } + public var Passport_PasswordNext: String { return self._s[246]! } + public var Bot_GroupStatusReadsHistory: String { return self._s[247]! } + public var EmptyGroupInfo_Line2: String { return self._s[248]! } public func Channel_AdminLog_MessageTransferedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[246]!, self._r[246]!, [_1, _2]) + return formatWithArgumentRanges(self._s[249]!, self._r[249]!, [_1, _2]) } - public var VoiceOver_Chat_SeenByRecipients: String { return self._s[247]! } - public var Settings_FAQ_Intro: String { return self._s[250]! } - public var PrivacySettings_PasscodeAndTouchId: String { return self._s[252]! } - public var FeaturedStickerPacks_Title: String { return self._s[253]! } - public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[255]! } - public var Username_Title: String { return self._s[256]! } + public var VoiceOver_Chat_SeenByRecipients: String { return self._s[250]! } + public var Settings_FAQ_Intro: String { return self._s[253]! } + public var PrivacySettings_PasscodeAndTouchId: String { return self._s[255]! } + public var FeaturedStickerPacks_Title: String { return self._s[256]! } + public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[258]! } + public var Username_Title: String { return self._s[259]! } public func Message_StickerText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[257]!, self._r[257]!, [_0]) + return formatWithArgumentRanges(self._s[260]!, self._r[260]!, [_0]) } - public var PeerInfo_PaneFiles: String { return self._s[258]! } - public var PasscodeSettings_AlphanumericCode: String { return self._s[259]! } - public var Localization_LanguageOther: String { return self._s[260]! } - public var Stickers_SuggestStickers: String { return self._s[261]! } + public var PeerInfo_PaneFiles: String { return self._s[261]! } + public var PasscodeSettings_AlphanumericCode: String { return self._s[262]! } + public var Localization_LanguageOther: String { return self._s[263]! } + public var Stickers_SuggestStickers: String { return self._s[264]! } public func Channel_AdminLog_MessageRemovedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[262]!, self._r[262]!, [_0]) + return formatWithArgumentRanges(self._s[265]!, self._r[265]!, [_0]) } - public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[263]! } - public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[264]! } - public var Conversation_DefaultRestrictedStickers: String { return self._s[265]! } + public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[266]! } + public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[267]! } + public var Conversation_DefaultRestrictedStickers: String { return self._s[268]! } public func Notification_PinnedDeletedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[266]!, self._r[266]!, [_0]) + return formatWithArgumentRanges(self._s[269]!, self._r[269]!, [_0]) } - public var Wallet_TransactionInfo_CopyAddress: String { return self._s[268]! } - public var Group_UpgradeConfirmation: String { return self._s[270]! } - public var DialogList_Unpin: String { return self._s[271]! } - public var Passport_Identity_DateOfBirth: String { return self._s[273]! } - public var Month_ShortOctober: String { return self._s[274]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[275]! } - public var TwoFactorSetup_Done_Text: String { return self._s[276]! } - public var Notification_CallCanceledShort: String { return self._s[277]! } - public var Conversation_StopQuiz: String { return self._s[278]! } - public var Passport_Phone_Help: String { return self._s[279]! } - public var Passport_Language_az: String { return self._s[281]! } - public var CreatePoll_TextPlaceholder: String { return self._s[283]! } - public var VoiceOver_Chat_AnonymousPoll: String { return self._s[284]! } - public var Passport_Identity_DocumentNumber: String { return self._s[285]! } - public var PhotoEditor_CurvesRed: String { return self._s[287]! } - public var PhoneNumberHelp_Alert: String { return self._s[289]! } - public var Stats_GroupTopPostersTitle: String { return self._s[290]! } - public var SocksProxySetup_Port: String { return self._s[291]! } - public var Checkout_PayNone: String { return self._s[292]! } - public var AutoDownloadSettings_WiFi: String { return self._s[293]! } - public var GroupInfo_GroupType: String { return self._s[294]! } - public var StickerSettings_ContextHide: String { return self._s[295]! } - public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[296]! } - public var Group_Setup_HistoryTitle: String { return self._s[298]! } - public var Passport_Identity_FilesUploadNew: String { return self._s[299]! } - public var PasscodeSettings_AutoLock: String { return self._s[300]! } - public var Passport_Title: String { return self._s[301]! } - public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[302]! } - public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[303]! } - public var GroupPermission_NoSendGifs: String { return self._s[304]! } - public var PrivacySettings_PasscodeOn: String { return self._s[305]! } + public var Wallet_TransactionInfo_CopyAddress: String { return self._s[271]! } + public var Group_UpgradeConfirmation: String { return self._s[273]! } + public var DialogList_Unpin: String { return self._s[274]! } + public var Passport_Identity_DateOfBirth: String { return self._s[276]! } + public var Month_ShortOctober: String { return self._s[277]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[278]! } + public var TwoFactorSetup_Done_Text: String { return self._s[279]! } + public var Notification_CallCanceledShort: String { return self._s[280]! } + public var Conversation_StopQuiz: String { return self._s[281]! } + public var Passport_Phone_Help: String { return self._s[282]! } + public var Passport_Language_az: String { return self._s[284]! } + public var CreatePoll_TextPlaceholder: String { return self._s[286]! } + public var VoiceOver_Chat_AnonymousPoll: String { return self._s[287]! } + public var Passport_Identity_DocumentNumber: String { return self._s[288]! } + public var PhotoEditor_CurvesRed: String { return self._s[290]! } + public var PhoneNumberHelp_Alert: String { return self._s[292]! } + public var Stats_GroupTopPostersTitle: String { return self._s[293]! } + public var SocksProxySetup_Port: String { return self._s[294]! } + public var Checkout_PayNone: String { return self._s[295]! } + public var AutoDownloadSettings_WiFi: String { return self._s[296]! } + public var GroupInfo_GroupType: String { return self._s[297]! } + public var StickerSettings_ContextHide: String { return self._s[298]! } + public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[299]! } + public var Group_Setup_HistoryTitle: String { return self._s[301]! } + public var Passport_Identity_FilesUploadNew: String { return self._s[302]! } + public var PasscodeSettings_AutoLock: String { return self._s[303]! } + public var Passport_Title: String { return self._s[304]! } + public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[305]! } + public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[306]! } + public var GroupPermission_NoSendGifs: String { return self._s[307]! } + public var PrivacySettings_PasscodeOn: String { return self._s[308]! } public func Conversation_ScheduleMessage_SendTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[306]!, self._r[306]!, [_0]) + return formatWithArgumentRanges(self._s[309]!, self._r[309]!, [_0]) } - public var ChatList_PeerTypeNonContact: String { return self._s[309]! } - public var State_WaitingForNetwork: String { return self._s[310]! } + public var ChatList_PeerTypeNonContact: String { return self._s[312]! } + public var State_WaitingForNetwork: String { return self._s[313]! } public func Notification_Invited(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[311]!, self._r[311]!, [_0, _1]) + return formatWithArgumentRanges(self._s[314]!, self._r[314]!, [_0, _1]) } - public var Calls_NotNow: String { return self._s[313]! } + public var Calls_NotNow: String { return self._s[316]! } public func Channel_DiscussionGroup_HeaderSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[314]!, self._r[314]!, [_0]) + return formatWithArgumentRanges(self._s[317]!, self._r[317]!, [_0]) } - public var UserInfo_SendMessage: String { return self._s[315]! } - public var PhotoEditor_SelectCoverFrame: String { return self._s[316]! } - public var ChatList_AutoarchiveSuggestion_Text: String { return self._s[317]! } - public var TwoStepAuth_PasswordSet: String { return self._s[318]! } - public var Passport_DeleteDocument: String { return self._s[319]! } - public var SocksProxySetup_AddProxyTitle: String { return self._s[320]! } + public var UserInfo_SendMessage: String { return self._s[318]! } + public var PhotoEditor_SelectCoverFrame: String { return self._s[319]! } + public var ChatList_AutoarchiveSuggestion_Text: String { return self._s[320]! } + public var TwoStepAuth_PasswordSet: String { return self._s[321]! } + public var Passport_DeleteDocument: String { return self._s[322]! } + public var SocksProxySetup_AddProxyTitle: String { return self._s[323]! } public func PUSH_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[321]!, self._r[321]!, [_1]) + return formatWithArgumentRanges(self._s[324]!, self._r[324]!, [_1]) } - public var AuthSessions_AddedDeviceTitle: String { return self._s[322]! } - public var GroupRemoved_Remove: String { return self._s[323]! } - public var Passport_FieldIdentity: String { return self._s[324]! } - public var Group_Setup_TypePrivateHelp: String { return self._s[325]! } - public var Conversation_Processing: String { return self._s[328]! } - public var Wallet_Settings_BackupWallet: String { return self._s[330]! } - public var ChatListFolder_NameNonMuted: String { return self._s[331]! } - public var ChatSettings_AutoPlayAnimations: String { return self._s[332]! } - public var AuthSessions_LogOutApplicationsHelp: String { return self._s[335]! } - public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[336]! } - public var Month_GenFebruary: String { return self._s[337]! } - public var ChatListFilter_AddChatsTitle: String { return self._s[338]! } - public var Wallet_Send_NetworkErrorTitle: String { return self._s[339]! } - public var Stats_GroupTopPoster_History: String { return self._s[341]! } + public var AuthSessions_AddedDeviceTitle: String { return self._s[325]! } + public var GroupRemoved_Remove: String { return self._s[326]! } + public var Passport_FieldIdentity: String { return self._s[327]! } + public var Group_Setup_TypePrivateHelp: String { return self._s[328]! } + public var Conversation_Processing: String { return self._s[331]! } + public var Wallet_Settings_BackupWallet: String { return self._s[333]! } + public var ChatListFolder_NameNonMuted: String { return self._s[334]! } + public var ChatSettings_AutoPlayAnimations: String { return self._s[335]! } + public var AuthSessions_LogOutApplicationsHelp: String { return self._s[338]! } + public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[339]! } + public var Month_GenFebruary: String { return self._s[340]! } + public var ChatListFilter_AddChatsTitle: String { return self._s[341]! } + public var Wallet_Send_NetworkErrorTitle: String { return self._s[342]! } + public var Stats_GroupTopPoster_History: String { return self._s[344]! } public func Login_InvalidPhoneEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[342]!, self._r[342]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[345]!, self._r[345]!, [_1, _2, _3, _4, _5]) } - public var Passport_Identity_TypeIdentityCard: String { return self._s[343]! } - public var Wallet_Month_ShortJune: String { return self._s[345]! } - public var AutoDownloadSettings_DataUsageMedium: String { return self._s[346]! } - public var GroupInfo_AddParticipant: String { return self._s[347]! } - public var KeyCommand_SendMessage: String { return self._s[348]! } - public var VoiceOver_Chat_YourContact: String { return self._s[350]! } - public var Map_LiveLocationShowAll: String { return self._s[351]! } - public var WallpaperSearch_ColorOrange: String { return self._s[353]! } - public var Appearance_AppIconDefaultX: String { return self._s[354]! } - public var Checkout_Receipt_Title: String { return self._s[355]! } - public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[356]! } - public var WallpaperPreview_PreviewTopText: String { return self._s[357]! } - public var Message_Contact: String { return self._s[359]! } - public var Call_StatusIncoming: String { return self._s[360]! } - public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[361]! } + public var Passport_Identity_TypeIdentityCard: String { return self._s[346]! } + public var Wallet_Month_ShortJune: String { return self._s[348]! } + public var AutoDownloadSettings_DataUsageMedium: String { return self._s[349]! } + public var GroupInfo_AddParticipant: String { return self._s[350]! } + public var KeyCommand_SendMessage: String { return self._s[351]! } + public var VoiceOver_Chat_YourContact: String { return self._s[353]! } + public var Map_LiveLocationShowAll: String { return self._s[354]! } + public var WallpaperSearch_ColorOrange: String { return self._s[356]! } + public var Appearance_AppIconDefaultX: String { return self._s[357]! } + public var Checkout_Receipt_Title: String { return self._s[358]! } + public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[359]! } + public var WallpaperPreview_PreviewTopText: String { return self._s[360]! } + public var Message_Contact: String { return self._s[362]! } + public var Call_StatusIncoming: String { return self._s[363]! } + public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[364]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[362]!, self._r[362]!, [_1]) + return formatWithArgumentRanges(self._s[365]!, self._r[365]!, [_1]) } public func PUSH_ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[364]!, self._r[364]!, [_1]) + return formatWithArgumentRanges(self._s[367]!, self._r[367]!, [_1]) } - public var VoiceOver_Media_PlaybackRate: String { return self._s[365]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[366]! } - public var Conversation_ViewChannel: String { return self._s[367]! } + public var VoiceOver_Media_PlaybackRate: String { return self._s[368]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[369]! } + public var Conversation_ViewChannel: String { return self._s[370]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[368]!, self._r[368]!, [_0]) + return formatWithArgumentRanges(self._s[371]!, self._r[371]!, [_0]) } - public var Theme_Colors_Accent: String { return self._s[369]! } - public var Paint_Arrow: String { return self._s[370]! } - public var Passport_Language_nl: String { return self._s[372]! } - public var Camera_Retake: String { return self._s[373]! } + public var Theme_Colors_Accent: String { return self._s[372]! } + public var Paint_Arrow: String { return self._s[373]! } + public var Passport_Language_nl: String { return self._s[375]! } + public var Camera_Retake: String { return self._s[376]! } public func UserInfo_BlockActionTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[374]!, self._r[374]!, [_0]) + return formatWithArgumentRanges(self._s[377]!, self._r[377]!, [_0]) } - public var AuthSessions_LogOutApplications: String { return self._s[375]! } - public var ApplyLanguage_ApplySuccess: String { return self._s[376]! } - public var Tour_Title6: String { return self._s[377]! } - public var Map_ChooseAPlace: String { return self._s[378]! } - public var CallSettings_Never: String { return self._s[380]! } + public var AuthSessions_LogOutApplications: String { return self._s[378]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[379]! } + public var Tour_Title6: String { return self._s[380]! } + public var Map_ChooseAPlace: String { return self._s[381]! } + public var CallSettings_Never: String { return self._s[383]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[381]!, self._r[381]!, [_0]) + return formatWithArgumentRanges(self._s[384]!, self._r[384]!, [_0]) } - public var ChannelRemoved_RemoveInfo: String { return self._s[382]! } + public var ChannelRemoved_RemoveInfo: String { return self._s[385]! } public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[383]!, self._r[383]!, [_0]) + return formatWithArgumentRanges(self._s[386]!, self._r[386]!, [_0]) } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[384]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[387]! } public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[385]!, self._r[385]!, [_0]) + return formatWithArgumentRanges(self._s[388]!, self._r[388]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[386]! } + public var GroupInfo_InviteLink_Title: String { return self._s[389]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[387]!, self._r[387]!, [_1, _2]) + return formatWithArgumentRanges(self._s[390]!, self._r[390]!, [_1, _2]) } - public var KeyCommand_ScrollUp: String { return self._s[388]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[389]! } - public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[390]! } + public var KeyCommand_ScrollUp: String { return self._s[391]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[392]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[393]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[391]!, self._r[391]!, [_0]) + return formatWithArgumentRanges(self._s[394]!, self._r[394]!, [_0]) } - public var TwoFactorSetup_Done_Title: String { return self._s[392]! } + public var TwoFactorSetup_Done_Title: String { return self._s[395]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[393]!, self._r[393]!, [_0]) + return formatWithArgumentRanges(self._s[396]!, self._r[396]!, [_0]) } - public var CallFeedback_ReasonDistortedSpeech: String { return self._s[394]! } - public var Watch_LastSeen_WithinAWeek: String { return self._s[395]! } - public var ContactList_Context_SendMessage: String { return self._s[397]! } - public var Weekday_Tuesday: String { return self._s[398]! } - public var Wallet_Created_Title: String { return self._s[400]! } - public var ScheduledMessages_Delete: String { return self._s[401]! } - public var UserInfo_StartSecretChat: String { return self._s[402]! } - public var Passport_Identity_FilesTitle: String { return self._s[403]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[404]! } - public var DialogList_DeleteConversationConfirmation: String { return self._s[406]! } - public var ChatList_UndoArchiveRevealedTitle: String { return self._s[407]! } + public var CallFeedback_ReasonDistortedSpeech: String { return self._s[397]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[398]! } + public var ContactList_Context_SendMessage: String { return self._s[400]! } + public var Weekday_Tuesday: String { return self._s[401]! } + public var Wallet_Created_Title: String { return self._s[403]! } + public var ScheduledMessages_Delete: String { return self._s[404]! } + public var UserInfo_StartSecretChat: String { return self._s[405]! } + public var Passport_Identity_FilesTitle: String { return self._s[406]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[407]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[409]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[410]! } public func Wallet_Configuration_ApplyErrorTextURLUnreachable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[408]!, self._r[408]!, [_0]) + return formatWithArgumentRanges(self._s[411]!, self._r[411]!, [_0]) } - public var AuthSessions_Sessions: String { return self._s[409]! } - public var Conversation_PeerNearbyText: String { return self._s[410]! } + public var AuthSessions_Sessions: String { return self._s[412]! } + public var Conversation_PeerNearbyText: String { return self._s[413]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[413]!, self._r[413]!, [_0]) + return formatWithArgumentRanges(self._s[416]!, self._r[416]!, [_0]) } - public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[414]! } - public var Call_StatusWaiting: String { return self._s[415]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[416]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[417]! } - public var WallpaperPreview_CustomColorBottomText: String { return self._s[418]! } - public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[419]! } - public var LogoutOptions_AddAccountText: String { return self._s[420]! } - public var PasscodeSettings_6DigitCode: String { return self._s[421]! } - public var Settings_LogoutConfirmationText: String { return self._s[422]! } - public var ProfilePhoto_OpenGallery: String { return self._s[423]! } - public var Passport_Identity_TypePassport: String { return self._s[425]! } - public var Map_Work: String { return self._s[428]! } + public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[417]! } + public var Call_StatusWaiting: String { return self._s[418]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[419]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[420]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[421]! } + public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[422]! } + public var LogoutOptions_AddAccountText: String { return self._s[423]! } + public var PasscodeSettings_6DigitCode: String { return self._s[424]! } + public var Settings_LogoutConfirmationText: String { return self._s[425]! } + public var ProfilePhoto_OpenGallery: String { return self._s[426]! } + public var Passport_Identity_TypePassport: String { return self._s[428]! } + public var Map_Work: String { return self._s[431]! } public func PUSH_MESSAGE_VIDEOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[429]!, self._r[429]!, [_1, _2]) + return formatWithArgumentRanges(self._s[432]!, self._r[432]!, [_1, _2]) } - public var SocksProxySetup_SaveProxy: String { return self._s[430]! } - public var AccessDenied_SaveMedia: String { return self._s[431]! } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[433]! } - public var CreatePoll_MultipleChoice: String { return self._s[434]! } - public var Settings_Title: String { return self._s[436]! } - public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[437]! } - public var Contacts_InviteSearchLabel: String { return self._s[439]! } - public var PrivacySettings_WebSessions: String { return self._s[440]! } - public var ConvertToSupergroup_Title: String { return self._s[441]! } + public var SocksProxySetup_SaveProxy: String { return self._s[433]! } + public var AccessDenied_SaveMedia: String { return self._s[434]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[436]! } + public var CreatePoll_MultipleChoice: String { return self._s[437]! } + public var Settings_Title: String { return self._s[439]! } + public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[440]! } + public var Contacts_InviteSearchLabel: String { return self._s[442]! } + public var PrivacySettings_WebSessions: String { return self._s[443]! } + public var ConvertToSupergroup_Title: String { return self._s[444]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[442]!, self._r[442]!, [_0]) + return formatWithArgumentRanges(self._s[445]!, self._r[445]!, [_0]) } - public var TwoFactorSetup_Hint_Text: String { return self._s[443]! } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[444]! } + public var TwoFactorSetup_Hint_Text: String { return self._s[446]! } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[447]! } public func PUSH_MESSAGE_CHANNEL_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[445]!, self._r[445]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[448]!, self._r[448]!, [_1, _2, _3]) } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[446]! } - public var UserInfo_BotHelp: String { return self._s[447]! } - public var PrivacySettings_LastSeenEverybody: String { return self._s[448]! } - public var Checkout_Name: String { return self._s[449]! } - public var AutoDownloadSettings_DataUsage: String { return self._s[450]! } - public var Channel_BanUser_BlockFor: String { return self._s[451]! } - public var Checkout_ShippingAddress: String { return self._s[452]! } - public var AutoDownloadSettings_MaxVideoSize: String { return self._s[453]! } - public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[454]! } - public var Privacy_Forwards: String { return self._s[455]! } - public var Channel_BanUser_PermissionSendPolls: String { return self._s[456]! } - public var Appearance_ThemeCarouselNewNight: String { return self._s[457]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[449]! } + public var UserInfo_BotHelp: String { return self._s[450]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[451]! } + public var Checkout_Name: String { return self._s[452]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[453]! } + public var Channel_BanUser_BlockFor: String { return self._s[454]! } + public var Checkout_ShippingAddress: String { return self._s[455]! } + public var AutoDownloadSettings_MaxVideoSize: String { return self._s[456]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[457]! } + public var Privacy_Forwards: String { return self._s[458]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[459]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[460]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[460]!, self._r[460]!, [_0]) + return formatWithArgumentRanges(self._s[463]!, self._r[463]!, [_0]) } - public var Contacts_SortedByName: String { return self._s[461]! } - public var Group_OwnershipTransfer_Title: String { return self._s[462]! } - public var PeerInfo_BioExpand: String { return self._s[464]! } - public var VoiceOver_Chat_OpenHint: String { return self._s[465]! } - public var Group_LeaveGroup: String { return self._s[466]! } - public var Settings_UsernameEmpty: String { return self._s[467]! } + public var Contacts_SortedByName: String { return self._s[464]! } + public var Group_OwnershipTransfer_Title: String { return self._s[465]! } + public var PeerInfo_BioExpand: String { return self._s[467]! } + public var VoiceOver_Chat_OpenHint: String { return self._s[468]! } + public var Group_LeaveGroup: String { return self._s[469]! } + public var Settings_UsernameEmpty: String { return self._s[470]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[468]!, self._r[468]!, [_0]) + return formatWithArgumentRanges(self._s[471]!, self._r[471]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[469]!, self._r[469]!, [_1]) + return formatWithArgumentRanges(self._s[472]!, self._r[472]!, [_1]) } public func Channel_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[470]!, self._r[470]!, [_1, _2]) + return formatWithArgumentRanges(self._s[473]!, self._r[473]!, [_1, _2]) } - public var Message_ImageExpired: String { return self._s[471]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[473]! } - public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[474]! } - public var UserInfo_AddToExisting: String { return self._s[475]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[476]! } - public var Wallet_Send_SyncInProgress: String { return self._s[477]! } - public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[478]! } - public var ChatListFolder_IncludeSectionInfo: String { return self._s[479]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[480]! } + public var Message_ImageExpired: String { return self._s[474]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[476]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[477]! } + public var UserInfo_AddToExisting: String { return self._s[478]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[479]! } + public var Wallet_Send_SyncInProgress: String { return self._s[480]! } + public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[481]! } + public func ChatList_Search_SearchBeforeDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[482]!, self._r[482]!, [_0]) + } + public var ChatListFolder_IncludeSectionInfo: String { return self._s[483]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[484]! } public func PUSH_CHANNEL_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[481]!, self._r[481]!, [_1]) + return formatWithArgumentRanges(self._s[485]!, self._r[485]!, [_1]) } - public var Notifications_GroupNotificationsAlert: String { return self._s[482]! } - public var Passport_Language_km: String { return self._s[483]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[485]! } - public var VoiceOver_Media_PlaybackPlay: String { return self._s[486]! } - public var Notification_CallMissedShort: String { return self._s[487]! } - public var Wallet_Info_YourBalance: String { return self._s[488]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[490]! } - public var Watch_Compose_Send: String { return self._s[491]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[494]! } - public var TwoFactorSetup_Email_Action: String { return self._s[495]! } - public var Conversation_HoldForVideo: String { return self._s[496]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[497]! } - public var AuthSessions_OtherDevices: String { return self._s[498]! } - public var Wallet_TransactionInfo_CommentHeader: String { return self._s[499]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[501]! } - public var Appearance_AutoNightThemeDisabled: String { return self._s[503]! } - public var Channel_LinkItem: String { return self._s[504]! } + public var Notifications_GroupNotificationsAlert: String { return self._s[486]! } + public var Passport_Language_km: String { return self._s[487]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[489]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[490]! } + public var Notification_CallMissedShort: String { return self._s[491]! } + public var Wallet_Info_YourBalance: String { return self._s[492]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[494]! } + public var Watch_Compose_Send: String { return self._s[495]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[498]! } + public var TwoFactorSetup_Email_Action: String { return self._s[499]! } + public var Conversation_HoldForVideo: String { return self._s[500]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[501]! } + public var AuthSessions_OtherDevices: String { return self._s[502]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[503]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[505]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[507]! } + public var Channel_LinkItem: String { return self._s[508]! } public func PrivacySettings_LastSeenContactsMinusPlus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[505]!, self._r[505]!, [_0, _1]) + return formatWithArgumentRanges(self._s[509]!, self._r[509]!, [_0, _1]) } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[508]!, self._r[508]!, [_0]) + return formatWithArgumentRanges(self._s[512]!, self._r[512]!, [_0]) } - public var VoiceOver_Recording_StopAndPreview: String { return self._s[509]! } - public var Passport_Language_dv: String { return self._s[510]! } - public var Undo_LeftChannel: String { return self._s[511]! } - public var Notifications_ExceptionsMuted: String { return self._s[512]! } - public var ChatList_UnhideAction: String { return self._s[513]! } - public var Conversation_ContextMenuShare: String { return self._s[515]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[516]! } - public var ShareFileTip_Title: String { return self._s[517]! } - public var NotificationsSound_Chord: String { return self._s[518]! } - public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[519]! } + public var VoiceOver_Recording_StopAndPreview: String { return self._s[513]! } + public var Passport_Language_dv: String { return self._s[514]! } + public var Undo_LeftChannel: String { return self._s[515]! } + public var Notifications_ExceptionsMuted: String { return self._s[516]! } + public var ChatList_UnhideAction: String { return self._s[517]! } + public var Conversation_ContextMenuShare: String { return self._s[519]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[520]! } + public var ShareFileTip_Title: String { return self._s[521]! } + public var NotificationsSound_Chord: String { return self._s[522]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[523]! } public func PUSH_CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[520]!, self._r[520]!, [_1, _2]) + return formatWithArgumentRanges(self._s[524]!, self._r[524]!, [_1, _2]) } - public var PeerInfo_ButtonVideoCall: String { return self._s[521]! } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[522]! } + public var PeerInfo_ButtonVideoCall: String { return self._s[525]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[526]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[523]!, self._r[523]!, [_0]) + return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_0]) } public func Wallet_Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[524]!, self._r[524]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[528]!, self._r[528]!, [_1, _2, _3]) } - public var Wallet_Settings_ConfigurationInfo: String { return self._s[525]! } - public var Wallpaper_ErrorNotFound: String { return self._s[526]! } - public var Notification_CallOutgoingShort: String { return self._s[528]! } - public var Wallet_WordImport_IncorrectText: String { return self._s[529]! } + public var Wallet_Settings_ConfigurationInfo: String { return self._s[529]! } + public var Wallpaper_ErrorNotFound: String { return self._s[530]! } + public var Notification_CallOutgoingShort: String { return self._s[532]! } + public var Wallet_WordImport_IncorrectText: String { return self._s[533]! } public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[530]!, self._r[530]!, [_1, _2]) + return formatWithArgumentRanges(self._s[534]!, self._r[534]!, [_1, _2]) } - public var Passport_Address_TypeUtilityBill: String { return self._s[531]! } - public var Privacy_Forwards_LinkIfAllowed: String { return self._s[532]! } - public var ReportPeer_Report: String { return self._s[533]! } - public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[534]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[535]! } + public var Passport_Address_TypeUtilityBill: String { return self._s[535]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[536]! } + public var ReportPeer_Report: String { return self._s[537]! } + public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[538]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[539]! } public func VoiceOver_Chat_MusicTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[536]!, self._r[536]!, [_1, _2]) + return formatWithArgumentRanges(self._s[540]!, self._r[540]!, [_1, _2]) } - public var StickerPack_Send: String { return self._s[537]! } - public var Login_CodeSentInternal: String { return self._s[538]! } - public var Wallet_Month_GenJanuary: String { return self._s[539]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[541]! } + public var StickerPack_Send: String { return self._s[541]! } + public var Login_CodeSentInternal: String { return self._s[542]! } + public var Wallet_Month_GenJanuary: String { return self._s[543]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[545]! } public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[542]!, self._r[542]!, [_0]) + return formatWithArgumentRanges(self._s[546]!, self._r[546]!, [_0]) } public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[544]!, self._r[544]!, [_0]) + return formatWithArgumentRanges(self._s[548]!, self._r[548]!, [_0]) } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[545]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[549]! } public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[546]!, self._r[546]!, [_1]) + return formatWithArgumentRanges(self._s[550]!, self._r[550]!, [_1]) } - public var ReportPeer_ReasonViolence: String { return self._s[548]! } - public var Appearance_ShareThemeColor: String { return self._s[549]! } - public var Map_Locating: String { return self._s[550]! } + public var ReportPeer_ReasonViolence: String { return self._s[552]! } + public var Appearance_ShareThemeColor: String { return self._s[553]! } + public var Map_Locating: String { return self._s[554]! } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[551]!, self._r[551]!, [_0]) + return formatWithArgumentRanges(self._s[555]!, self._r[555]!, [_0]) } public func PUSH_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[552]!, self._r[552]!, [_1]) + return formatWithArgumentRanges(self._s[556]!, self._r[556]!, [_1]) } - public var ChatListFolderSettings_FoldersSection: String { return self._s[553]! } - public var AutoDownloadSettings_GroupChats: String { return self._s[555]! } - public var CheckoutInfo_SaveInfo: String { return self._s[556]! } - public var ChatList_ChatTypesSection: String { return self._s[557]! } - public var SharedMedia_EmptyLinksText: String { return self._s[559]! } - public var Passport_Address_CityPlaceholder: String { return self._s[560]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[561]! } - public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[562]! } - public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[564]! } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[565]! } + public var ChatListFolderSettings_FoldersSection: String { return self._s[557]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[559]! } + public var CheckoutInfo_SaveInfo: String { return self._s[560]! } + public var ChatList_ChatTypesSection: String { return self._s[561]! } + public var SharedMedia_EmptyLinksText: String { return self._s[563]! } + public var Passport_Address_CityPlaceholder: String { return self._s[564]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[565]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[566]! } + public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[568]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[569]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[566]!, self._r[566]!, [_1]) + return formatWithArgumentRanges(self._s[570]!, self._r[570]!, [_1]) } public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[567]!, self._r[567]!, [_0]) + return formatWithArgumentRanges(self._s[571]!, self._r[571]!, [_0]) } - public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[568]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[569]! } - public var ChangePhoneNumberCode_Code: String { return self._s[570]! } - public var Appearance_CreateTheme: String { return self._s[571]! } + public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[572]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[573]! } + public var ChangePhoneNumberCode_Code: String { return self._s[574]! } + public var Appearance_CreateTheme: String { return self._s[575]! } public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[572]!, self._r[572]!, [_0]) + return formatWithArgumentRanges(self._s[576]!, self._r[576]!, [_0]) } - public var TwoStepAuth_SetupEmail: String { return self._s[573]! } - public var HashtagSearch_AllChats: String { return self._s[574]! } - public var MediaPlayer_UnknownTrack: String { return self._s[575]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[577]! } + public var TwoStepAuth_SetupEmail: String { return self._s[577]! } + public var HashtagSearch_AllChats: String { return self._s[578]! } + public var MediaPlayer_UnknownTrack: String { return self._s[579]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[581]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[578]!, self._r[578]!, [_0]) - } - public var Chat_Gifs_SavedSectionHeader: String { return self._s[579]! } - public var PhotoEditor_QualityHigh: String { return self._s[581]! } - public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[582]!, self._r[582]!, [_0]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[583]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[584]! } - public var Message_LiveLocation: String { return self._s[585]! } - public var Cache_LowDiskSpaceText: String { return self._s[586]! } - public var Wallet_Receive_ShareAddress: String { return self._s[587]! } - public var EditTheme_ErrorLinkTaken: String { return self._s[589]! } - public var Conversation_SendMessage: String { return self._s[590]! } - public var AuthSessions_EmptyTitle: String { return self._s[591]! } - public var Privacy_PhoneNumber: String { return self._s[592]! } - public var PeopleNearby_CreateGroup: String { return self._s[593]! } - public var Stats_SharesPerPost: String { return self._s[595]! } - public var CallSettings_UseLessData: String { return self._s[596]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[597]! } - public var Stickers_AddToFavorites: String { return self._s[598]! } - public var Wallet_WordImport_Title: String { return self._s[599]! } - public var PhotoEditor_QualityLow: String { return self._s[600]! } - public var Watch_UserInfo_Unblock: String { return self._s[601]! } - public var Settings_Logout: String { return self._s[602]! } + public var Chat_Gifs_SavedSectionHeader: String { return self._s[583]! } + public var PhotoEditor_QualityHigh: String { return self._s[585]! } + public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[586]!, self._r[586]!, [_0]) + } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[587]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[588]! } + public var Message_LiveLocation: String { return self._s[589]! } + public var ChatList_Search_FilterLinks: String { return self._s[590]! } + public var Cache_LowDiskSpaceText: String { return self._s[591]! } + public var Wallet_Receive_ShareAddress: String { return self._s[592]! } + public var EditTheme_ErrorLinkTaken: String { return self._s[594]! } + public var Conversation_SendMessage: String { return self._s[595]! } + public var AuthSessions_EmptyTitle: String { return self._s[596]! } + public var Privacy_PhoneNumber: String { return self._s[597]! } + public var PeopleNearby_CreateGroup: String { return self._s[598]! } + public var Stats_SharesPerPost: String { return self._s[600]! } + public var CallSettings_UseLessData: String { return self._s[601]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[602]! } + public var Stickers_AddToFavorites: String { return self._s[603]! } + public var Wallet_WordImport_Title: String { return self._s[604]! } + public var PhotoEditor_QualityLow: String { return self._s[605]! } + public var Watch_UserInfo_Unblock: String { return self._s[606]! } + public var Settings_Logout: String { return self._s[607]! } public func PUSH_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[603]!, self._r[603]!, [_1]) + return formatWithArgumentRanges(self._s[608]!, self._r[608]!, [_1]) } - public var ContactInfo_PhoneLabelWork: String { return self._s[604]! } - public var ChannelInfo_Stats: String { return self._s[605]! } - public var TextFormat_Link: String { return self._s[606]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[609]! } + public var ChannelInfo_Stats: String { return self._s[610]! } + public var TextFormat_Link: String { return self._s[611]! } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[607]!, self._r[607]!, [_1, _2]) + return formatWithArgumentRanges(self._s[612]!, self._r[612]!, [_1, _2]) } - public var Paint_Framed: String { return self._s[608]! } - public var Wallet_TransactionInfo_Title: String { return self._s[609]! } + public var Paint_Framed: String { return self._s[613]! } + public var Wallet_TransactionInfo_Title: String { return self._s[614]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[610]!, self._r[610]!, [_0]) + return formatWithArgumentRanges(self._s[615]!, self._r[615]!, [_0]) } - public var Watch_Notification_Joined: String { return self._s[611]! } - public var Group_Setup_TypePublicHelp: String { return self._s[612]! } - public var Passport_Scans_UploadNew: String { return self._s[613]! } - public var Checkout_LiabilityAlertTitle: String { return self._s[614]! } - public var DialogList_Title: String { return self._s[617]! } - public var NotificationSettings_ContactJoined: String { return self._s[618]! } - public var GroupInfo_LabelAdmin: String { return self._s[619]! } - public var KeyCommand_ChatInfo: String { return self._s[620]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[621]! } - public var Call_ReportIncludeLog: String { return self._s[622]! } + public var Watch_Notification_Joined: String { return self._s[616]! } + public var Group_Setup_TypePublicHelp: String { return self._s[617]! } + public var Passport_Scans_UploadNew: String { return self._s[618]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[619]! } + public var DialogList_Title: String { return self._s[622]! } + public var NotificationSettings_ContactJoined: String { return self._s[623]! } + public var GroupInfo_LabelAdmin: String { return self._s[624]! } + public var KeyCommand_ChatInfo: String { return self._s[625]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[626]! } + public var Call_ReportIncludeLog: String { return self._s[627]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[625]!, self._r[625]!, [_0]) + return formatWithArgumentRanges(self._s[630]!, self._r[630]!, [_0]) } - public var Stats_Followers: String { return self._s[626]! } - public var Stats_GroupLanguagesTitle: String { return self._s[627]! } - public var Cache_NoLimit: String { return self._s[628]! } - public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[629]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[630]! } - public var LocalGroup_IrrelevantWarning: String { return self._s[631]! } - public var Conversation_DefaultRestrictedInline: String { return self._s[632]! } - public var Message_Sticker: String { return self._s[633]! } - public var LastSeen_JustNow: String { return self._s[635]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[637]! } - public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[638]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[640]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[641]! } - public var TwoStepAuth_Email: String { return self._s[642]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[643]! } - public var PhotoEditor_BlurToolOff: String { return self._s[644]! } - public var Message_PinnedStickerMessage: String { return self._s[645]! } - public var ContactInfo_PhoneLabelPager: String { return self._s[646]! } - public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[647]! } - public var Passport_DiscardMessageTitle: String { return self._s[648]! } - public var Privacy_PaymentsTitle: String { return self._s[649]! } - public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[650]! } - public var ClearCache_StorageCache: String { return self._s[651]! } - public var Cache_KeepMediaHelp: String { return self._s[652]! } - public var Appearance_TextSizeSetting: String { return self._s[653]! } - public var Channel_DiscussionGroup_Header: String { return self._s[655]! } - public var VoiceOver_Chat_OptionSelected: String { return self._s[656]! } - public var Appearance_ColorTheme: String { return self._s[657]! } - public var UserInfo_ShareContact: String { return self._s[658]! } - public var Passport_Address_TypePassportRegistration: String { return self._s[659]! } - public var Common_More: String { return self._s[660]! } - public var Watch_Message_Call: String { return self._s[661]! } - public var Profile_EncryptionKey: String { return self._s[664]! } - public var Privacy_TopPeers: String { return self._s[665]! } - public var Conversation_StopPollConfirmation: String { return self._s[666]! } - public var Wallet_Words_NotDoneText: String { return self._s[668]! } - public var Privacy_TopPeersWarning: String { return self._s[670]! } - public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[671]! } - public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[672]! } - public var Media_SendWithTimer: String { return self._s[675]! } - public var Wallet_RestoreFailed_EnterWords: String { return self._s[676]! } - public var DialogList_SearchSectionMessages: String { return self._s[677]! } - public var ChatList_Context_AddToFolder: String { return self._s[678]! } - public var Notifications_ChannelNotifications: String { return self._s[679]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[680]! } - public var Notification_MessageLifetime1h: String { return self._s[681]! } - public var Passport_Language_sk: String { return self._s[682]! } - public var Wallpaper_ResetWallpapersInfo: String { return self._s[683]! } - public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[684]! } - public var PeerInfo_PaneGifs: String { return self._s[685]! } - public var Call_ReportSkip: String { return self._s[687]! } - public var Cache_ServiceFiles: String { return self._s[688]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[689]! } - public var VoiceOver_Chat_YourFile: String { return self._s[690]! } - public var Map_Hybrid: String { return self._s[691]! } - public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[693]! } + public var Stats_Followers: String { return self._s[631]! } + public var Stats_GroupLanguagesTitle: String { return self._s[632]! } + public var Cache_NoLimit: String { return self._s[633]! } + public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[634]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[635]! } + public var LocalGroup_IrrelevantWarning: String { return self._s[636]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[637]! } + public var Message_Sticker: String { return self._s[638]! } + public var LastSeen_JustNow: String { return self._s[640]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[642]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[643]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[645]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[646]! } + public var TwoStepAuth_Email: String { return self._s[647]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[648]! } + public var PhotoEditor_BlurToolOff: String { return self._s[649]! } + public var Message_PinnedStickerMessage: String { return self._s[650]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[651]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[652]! } + public var Passport_DiscardMessageTitle: String { return self._s[653]! } + public var Privacy_PaymentsTitle: String { return self._s[654]! } + public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[655]! } + public var ClearCache_StorageCache: String { return self._s[656]! } + public var Cache_KeepMediaHelp: String { return self._s[657]! } + public var Appearance_TextSizeSetting: String { return self._s[658]! } + public var Channel_DiscussionGroup_Header: String { return self._s[660]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[661]! } + public var Appearance_ColorTheme: String { return self._s[662]! } + public var UserInfo_ShareContact: String { return self._s[663]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[664]! } + public var Common_More: String { return self._s[665]! } + public var Watch_Message_Call: String { return self._s[666]! } + public var Profile_EncryptionKey: String { return self._s[669]! } + public var Privacy_TopPeers: String { return self._s[670]! } + public var Conversation_StopPollConfirmation: String { return self._s[671]! } + public var Wallet_Words_NotDoneText: String { return self._s[673]! } + public var Privacy_TopPeersWarning: String { return self._s[675]! } + public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[676]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[677]! } + public var Media_SendWithTimer: String { return self._s[680]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[681]! } + public var DialogList_SearchSectionMessages: String { return self._s[682]! } + public var ChatList_Context_AddToFolder: String { return self._s[683]! } + public var Notifications_ChannelNotifications: String { return self._s[684]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[685]! } + public var Notification_MessageLifetime1h: String { return self._s[686]! } + public var Passport_Language_sk: String { return self._s[687]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[688]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[689]! } + public var PeerInfo_PaneGifs: String { return self._s[690]! } + public var Call_ReportSkip: String { return self._s[692]! } + public var Cache_ServiceFiles: String { return self._s[693]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[694]! } + public var VoiceOver_Chat_YourFile: String { return self._s[695]! } + public var Map_Hybrid: String { return self._s[696]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[698]! } public func PUSH_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[694]!, self._r[694]!, [_1]) + return formatWithArgumentRanges(self._s[699]!, self._r[699]!, [_1]) } - public var ChatSettings_AutoDownloadVideos: String { return self._s[696]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[697]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[698]! } - public var SocksProxySetup_ProxyTelegram: String { return self._s[701]! } + public var ChatSettings_AutoDownloadVideos: String { return self._s[701]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[702]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[703]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[706]! } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[702]!, self._r[702]!, [_1]) + return formatWithArgumentRanges(self._s[707]!, self._r[707]!, [_1]) } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[704]! } - public var ScheduledMessages_ScheduledToday: String { return self._s[705]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[709]! } + public var ScheduledMessages_ScheduledToday: String { return self._s[710]! } public func PUSH_CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[706]!, self._r[706]!, [_1, _2]) + return formatWithArgumentRanges(self._s[711]!, self._r[711]!, [_1, _2]) } - public var Conversation_LiveLocationYou: String { return self._s[707]! } - public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[708]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[709]! } - public var UserInfo_ShareBot: String { return self._s[712]! } + public var Conversation_LiveLocationYou: String { return self._s[712]! } + public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[713]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[714]! } + public var UserInfo_ShareBot: String { return self._s[717]! } public func PUSH_AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[713]!, self._r[713]!, [_1, _2]) + return formatWithArgumentRanges(self._s[718]!, self._r[718]!, [_1, _2]) } - public var Conversation_ClearCache: String { return self._s[714]! } - public var PhotoEditor_ShadowsTint: String { return self._s[715]! } - public var ChatListFolderSettings_EditFoldersInfo: String { return self._s[716]! } - public var Message_Audio: String { return self._s[717]! } - public var Passport_Language_lt: String { return self._s[718]! } + public var Conversation_ClearCache: String { return self._s[719]! } + public var PhotoEditor_ShadowsTint: String { return self._s[720]! } + public var ChatListFolderSettings_EditFoldersInfo: String { return self._s[721]! } + public var Message_Audio: String { return self._s[722]! } + public var Passport_Language_lt: String { return self._s[723]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[719]!, self._r[719]!, [_0]) + return formatWithArgumentRanges(self._s[724]!, self._r[724]!, [_0]) } - public var Permissions_SiriText_v0: String { return self._s[720]! } - public var Conversation_FileICloudDrive: String { return self._s[721]! } - public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[722]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[723]! } + public var Permissions_SiriText_v0: String { return self._s[725]! } + public var Conversation_FileICloudDrive: String { return self._s[726]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[727]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[728]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[724]!, self._r[724]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[729]!, self._r[729]!, [_1, _2, _3, _4, _5, _6]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[725]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[730]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[726]!, self._r[726]!, [_0]) + return formatWithArgumentRanges(self._s[731]!, self._r[731]!, [_0]) } - public var Channel_SignMessages: String { return self._s[727]! } + public var Channel_SignMessages: String { return self._s[732]! } public func PUSH_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[728]!, self._r[728]!, [_1]) + return formatWithArgumentRanges(self._s[733]!, self._r[733]!, [_1]) } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[729]! } - public var Passport_ScanPassport: String { return self._s[730]! } - public var Watch_Suggestion_Thanks: String { return self._s[731]! } - public var BlockedUsers_AddNew: String { return self._s[732]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[734]! } + public var Passport_ScanPassport: String { return self._s[735]! } + public var Watch_Suggestion_Thanks: String { return self._s[736]! } + public var BlockedUsers_AddNew: String { return self._s[737]! } public func PUSH_CHAT_MESSAGE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[733]!, self._r[733]!, [_1, _2]) + return formatWithArgumentRanges(self._s[738]!, self._r[738]!, [_1, _2]) } - public var Watch_Message_Invoice: String { return self._s[734]! } - public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[735]! } - public var Month_GenJuly: String { return self._s[736]! } - public var CreatePoll_QuizInfo: String { return self._s[737]! } - public var UserInfo_StartSecretChatStart: String { return self._s[738]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[739]! } - public var IntentsSettings_SuggestByShare: String { return self._s[741]! } - public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[742]! } - public var Notification_ChannelInviterSelf: String { return self._s[743]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[744]! } + public var Watch_Message_Invoice: String { return self._s[739]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[740]! } + public var Month_GenJuly: String { return self._s[741]! } + public var CreatePoll_QuizInfo: String { return self._s[742]! } + public var UserInfo_StartSecretChatStart: String { return self._s[743]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[744]! } + public var IntentsSettings_SuggestByShare: String { return self._s[746]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[747]! } + public var Notification_ChannelInviterSelf: String { return self._s[748]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[749]! } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[745]!, self._r[745]!, [_1, _2]) + return formatWithArgumentRanges(self._s[750]!, self._r[750]!, [_1, _2]) } - public var Stats_FollowersTitle: String { return self._s[746]! } - public var CheckoutInfo_Title: String { return self._s[747]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[748]! } + public var Stats_FollowersTitle: String { return self._s[751]! } + public var CheckoutInfo_Title: String { return self._s[752]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[753]! } public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[749]!, self._r[749]!, [_0]) + return formatWithArgumentRanges(self._s[754]!, self._r[754]!, [_0]) } - public var Passport_Identity_MainPage: String { return self._s[750]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[751]! } - public var Passport_Language_de: String { return self._s[752]! } - public var Update_Title: String { return self._s[753]! } - public var ContactInfo_PhoneLabelWorkFax: String { return self._s[754]! } - public var Channel_AdminLog_BanEmbedLinks: String { return self._s[755]! } - public var Passport_Email_UseTelegramEmailHelp: String { return self._s[756]! } - public var Notifications_ChannelNotificationsPreview: String { return self._s[757]! } - public var NotificationsSound_Telegraph: String { return self._s[758]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[759]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[760]! } + public var Passport_Identity_MainPage: String { return self._s[755]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[756]! } + public var Passport_Language_de: String { return self._s[757]! } + public var Update_Title: String { return self._s[758]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[759]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[760]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[761]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[762]! } + public var NotificationsSound_Telegraph: String { return self._s[763]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[764]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[765]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[761]!, self._r[761]!, [_0]) - } - public var ClearCache_Description: String { return self._s[762]! } - public var Stickers_SuggestAll: String { return self._s[763]! } - public var Conversation_ForwardTitle: String { return self._s[764]! } - public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[765]! } - public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[766]!, self._r[766]!, [_0]) } - public var Calls_NewCall: String { return self._s[767]! } - public var Call_StatusEnded: String { return self._s[768]! } - public var AutoDownloadSettings_DataUsageLow: String { return self._s[770]! } - public var Settings_ProxyConnected: String { return self._s[771]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[772]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[773]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[774]! } - public var Passport_PasswordPlaceholder: String { return self._s[775]! } - public var Message_PinnedInvoice: String { return self._s[776]! } - public var Passport_Identity_IssueDate: String { return self._s[777]! } - public var Stats_GroupTopHoursTitle: String { return self._s[778]! } + public var ClearCache_Description: String { return self._s[767]! } + public var Stickers_SuggestAll: String { return self._s[768]! } + public var Conversation_ForwardTitle: String { return self._s[769]! } + public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[770]! } + public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[771]!, self._r[771]!, [_0]) + } + public var Calls_NewCall: String { return self._s[772]! } + public var Call_StatusEnded: String { return self._s[773]! } + public func ChatList_Search_SearchAfterDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[775]!, self._r[775]!, [_0]) + } + public var AutoDownloadSettings_DataUsageLow: String { return self._s[776]! } + public var Settings_ProxyConnected: String { return self._s[777]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[778]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[779]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[780]! } + public var Passport_PasswordPlaceholder: String { return self._s[781]! } + public var Message_PinnedInvoice: String { return self._s[782]! } + public var Passport_Identity_IssueDate: String { return self._s[783]! } + public var Stats_GroupTopHoursTitle: String { return self._s[784]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[779]!, self._r[779]!, [_0]) + return formatWithArgumentRanges(self._s[785]!, self._r[785]!, [_0]) } - public var Passport_Language_pl: String { return self._s[780]! } - public var Call_StatusConnecting: String { return self._s[781]! } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[782]! } + public var Passport_Language_pl: String { return self._s[786]! } + public var Call_StatusConnecting: String { return self._s[787]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[788]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[783]!, self._r[783]!, [_0]) + return formatWithArgumentRanges(self._s[789]!, self._r[789]!, [_0]) } - public var ChatSettings_ConnectionType_UseProxy: String { return self._s[785]! } - public var Common_Edit: String { return self._s[786]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[787]! } + public var ChatSettings_ConnectionType_UseProxy: String { return self._s[791]! } + public var Common_Edit: String { return self._s[792]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[793]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[788]!, self._r[788]!, [_0]) + return formatWithArgumentRanges(self._s[794]!, self._r[794]!, [_0]) } - public var GroupInfo_ChatAdmins: String { return self._s[789]! } - public var PrivateDataSettings_Title: String { return self._s[790]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[791]! } - public var ChatList_Read: String { return self._s[792]! } - public var Wallet_WordImport_Text: String { return self._s[793]! } - public var Undo_ChatClearedForBothSides: String { return self._s[794]! } - public var ChatListFolder_AddChats: String { return self._s[795]! } - public var GroupPermission_SectionTitle: String { return self._s[796]! } - public var Settings_ViewVideo: String { return self._s[797]! } - public var TwoFactorSetup_Intro_Title: String { return self._s[799]! } + public var GroupInfo_ChatAdmins: String { return self._s[795]! } + public var PrivateDataSettings_Title: String { return self._s[796]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[797]! } + public var ChatList_Read: String { return self._s[798]! } + public var Wallet_WordImport_Text: String { return self._s[799]! } + public var Undo_ChatClearedForBothSides: String { return self._s[800]! } + public var ChatListFolder_AddChats: String { return self._s[801]! } + public var GroupPermission_SectionTitle: String { return self._s[802]! } + public var Settings_ViewVideo: String { return self._s[803]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[805]! } public func PUSH_CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[800]!, self._r[800]!, [_1, _2]) + return formatWithArgumentRanges(self._s[806]!, self._r[806]!, [_1, _2]) } - public var Checkout_ErrorPaymentFailed: String { return self._s[801]! } - public var Update_UpdateApp: String { return self._s[803]! } - public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[804]! } - public var Settings_Appearance: String { return self._s[805]! } - public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[809]! } - public var Watch_Location_Access: String { return self._s[810]! } - public var ShareMenu_CopyShareLink: String { return self._s[812]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[813]! } - public var Conversation_Theme: String { return self._s[815]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[807]! } + public var Update_UpdateApp: String { return self._s[809]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[810]! } + public var Settings_Appearance: String { return self._s[811]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[815]! } + public var Watch_Location_Access: String { return self._s[816]! } + public var ShareMenu_CopyShareLink: String { return self._s[818]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[819]! } + public var Conversation_Theme: String { return self._s[821]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[816]!, self._r[816]!, [_0]) + return formatWithArgumentRanges(self._s[822]!, self._r[822]!, [_0]) } - public var Notifications_ClassicTones: String { return self._s[817]! } - public var Weekday_ShortWednesday: String { return self._s[818]! } - public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[819]! } - public var Undo_LeftGroup: String { return self._s[822]! } - public var ChatListFolder_DiscardCancel: String { return self._s[823]! } - public var Wallet_RestoreFailed_Text: String { return self._s[824]! } - public var Conversation_LinkDialogCopy: String { return self._s[825]! } - public var Wallet_TransactionInfo_NoAddress: String { return self._s[827]! } - public var Wallet_Navigation_Back: String { return self._s[828]! } - public var KeyCommand_FocusOnInputField: String { return self._s[829]! } - public var Contacts_SelectAll: String { return self._s[830]! } - public var Preview_SaveToCameraRoll: String { return self._s[831]! } - public var PrivacySettings_PasscodeOff: String { return self._s[832]! } - public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[833]! } + public var Notifications_ClassicTones: String { return self._s[823]! } + public var Weekday_ShortWednesday: String { return self._s[824]! } + public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[825]! } + public var Undo_LeftGroup: String { return self._s[828]! } + public var ChatListFolder_DiscardCancel: String { return self._s[829]! } + public var Wallet_RestoreFailed_Text: String { return self._s[830]! } + public var Conversation_LinkDialogCopy: String { return self._s[831]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[833]! } + public var Wallet_Navigation_Back: String { return self._s[834]! } + public var KeyCommand_FocusOnInputField: String { return self._s[835]! } + public var Contacts_SelectAll: String { return self._s[836]! } + public var Preview_SaveToCameraRoll: String { return self._s[837]! } + public var PrivacySettings_PasscodeOff: String { return self._s[838]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[839]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[834]!, self._r[834]!, [_1]) + return formatWithArgumentRanges(self._s[840]!, self._r[840]!, [_1]) } - public var Wallpaper_Title: String { return self._s[835]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[836]! } - public var AccessDenied_Camera: String { return self._s[837]! } - public var Watch_Compose_CurrentLocation: String { return self._s[838]! } - public var PeerInfo_ButtonMessage: String { return self._s[840]! } - public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[841]! } + public var Wallpaper_Title: String { return self._s[841]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[842]! } + public var AccessDenied_Camera: String { return self._s[843]! } + public var Watch_Compose_CurrentLocation: String { return self._s[844]! } + public var PeerInfo_ButtonMessage: String { return self._s[846]! } + public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[847]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[842]!, self._r[842]!, [_0]) - } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[843]! } - public var Passport_Language_ro: String { return self._s[844]! } - public var EditTheme_UploadNewTheme: String { return self._s[845]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[846]! } - public var Wallet_Intro_Terms: String { return self._s[847]! } - public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[848]!, self._r[848]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[849]! } - public var State_ConnectingToProxy: String { return self._s[850]! } - public var Calls_RatingTitle: String { return self._s[851]! } - public var Generic_ErrorMoreInfo: String { return self._s[852]! } - public var ChatList_Search_ShowMore: String { return self._s[853]! } - public var Appearance_PreviewReplyText: String { return self._s[854]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[855]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[849]! } + public var Passport_Language_ro: String { return self._s[850]! } + public var EditTheme_UploadNewTheme: String { return self._s[851]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[852]! } + public var Wallet_Intro_Terms: String { return self._s[853]! } + public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[854]!, self._r[854]!, [_0]) + } + public var Login_CancelPhoneVerification: String { return self._s[855]! } + public var State_ConnectingToProxy: String { return self._s[856]! } + public var Calls_RatingTitle: String { return self._s[857]! } + public var Generic_ErrorMoreInfo: String { return self._s[858]! } + public var ChatList_Search_ShowMore: String { return self._s[859]! } + public var Appearance_PreviewReplyText: String { return self._s[860]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[861]! } public func Wallet_Send_Balance(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[856]!, self._r[856]!, [_0]) + return formatWithArgumentRanges(self._s[862]!, self._r[862]!, [_0]) } - public var IntentsSettings_SuggestedChatsContacts: String { return self._s[857]! } - public var SharedMedia_CategoryLinks: String { return self._s[858]! } - public var Calls_Missed: String { return self._s[859]! } - public var Settings_AddAnotherAccount_Help: String { return self._s[863]! } - public var Cache_Photos: String { return self._s[864]! } - public var GroupPermission_NoAddMembers: String { return self._s[865]! } - public var ScheduledMessages_Title: String { return self._s[866]! } + public var IntentsSettings_SuggestedChatsContacts: String { return self._s[863]! } + public var SharedMedia_CategoryLinks: String { return self._s[864]! } + public var Calls_Missed: String { return self._s[865]! } + public var Settings_AddAnotherAccount_Help: String { return self._s[869]! } + public var Cache_Photos: String { return self._s[870]! } + public var GroupPermission_NoAddMembers: String { return self._s[871]! } + public var ScheduledMessages_Title: String { return self._s[872]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[867]!, self._r[867]!, [_0]) + return formatWithArgumentRanges(self._s[873]!, self._r[873]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[868]! } - public var Settings_ProxyDisabled: String { return self._s[869]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[874]! } + public var Settings_ProxyDisabled: String { return self._s[875]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[870]!, self._r[870]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[876]!, self._r[876]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[871]!, self._r[871]!, [_0]) + return formatWithArgumentRanges(self._s[877]!, self._r[877]!, [_0]) } - public var Stats_ViewsPerPost: String { return self._s[873]! } - public var ChatList_AutoarchiveSuggestion_OpenSettings: String { return self._s[874]! } - public var ChatList_Context_RemoveFromRecents: String { return self._s[875]! } - public var Appearance_Title: String { return self._s[876]! } + public var Stats_ViewsPerPost: String { return self._s[879]! } + public var ChatList_AutoarchiveSuggestion_OpenSettings: String { return self._s[880]! } + public var ChatList_Context_RemoveFromRecents: String { return self._s[881]! } + public var Appearance_Title: String { return self._s[882]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[878]!, self._r[878]!, [_0]) + return formatWithArgumentRanges(self._s[884]!, self._r[884]!, [_0]) } public func Call_CameraOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[879]!, self._r[879]!, [_0]) + return formatWithArgumentRanges(self._s[885]!, self._r[885]!, [_0]) } - public var Conversation_WalletRequiredText: String { return self._s[880]! } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[881]! } - public var OldChannels_NoticeCreateText: String { return self._s[882]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[883]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[884]! } - public var Preview_DeletePhoto: String { return self._s[885]! } - public var Appearance_AppIconFilledX: String { return self._s[886]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[887]! } + public var Conversation_WalletRequiredText: String { return self._s[886]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[887]! } + public var OldChannels_NoticeCreateText: String { return self._s[888]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[889]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[890]! } + public var Preview_DeletePhoto: String { return self._s[891]! } + public var Appearance_AppIconFilledX: String { return self._s[892]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[893]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[888]!, self._r[888]!, [_0]) + return formatWithArgumentRanges(self._s[894]!, self._r[894]!, [_0]) } - public var ChatListFolder_TitleEdit: String { return self._s[891]! } - public var MuteFor_Forever: String { return self._s[892]! } - public var Coub_TapForSound: String { return self._s[893]! } - public var Map_LocatingError: String { return self._s[894]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[896]! } - public var Conversation_SendMessage_SendSilently: String { return self._s[897]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[898]! } + public var ChatListFolder_TitleEdit: String { return self._s[897]! } + public var MuteFor_Forever: String { return self._s[898]! } + public var Coub_TapForSound: String { return self._s[899]! } + public var Map_LocatingError: String { return self._s[900]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[902]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[903]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[904]! } public func Wallet_Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[899]!, self._r[899]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[905]!, self._r[905]!, [_1, _2, _3]) } - public var Passport_ForgottenPassword: String { return self._s[900]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[901]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[902]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[904]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[905]! } - public var Message_Location: String { return self._s[906]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[907]! } - public var Channel_Management_Title: String { return self._s[908]! } - public var DialogList_SearchSectionDialogs: String { return self._s[910]! } - public var Compose_NewChannel_Members: String { return self._s[911]! } + public var Passport_ForgottenPassword: String { return self._s[906]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[907]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[908]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[910]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[911]! } + public var Message_Location: String { return self._s[912]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[913]! } + public var Channel_Management_Title: String { return self._s[914]! } + public var DialogList_SearchSectionDialogs: String { return self._s[916]! } + public var Compose_NewChannel_Members: String { return self._s[917]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[912]!, self._r[912]!, [_0]) + return formatWithArgumentRanges(self._s[918]!, self._r[918]!, [_0]) } - public var GroupInfo_Location: String { return self._s[913]! } - public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[914]! } - public var ClearCache_Clear: String { return self._s[915]! } - public var InstantPage_FeedbackButtonShort: String { return self._s[916]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[917]! } - public var PhotoEditor_WarmthTool: String { return self._s[918]! } + public var GroupInfo_Location: String { return self._s[919]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[920]! } + public var ClearCache_Clear: String { return self._s[921]! } + public var InstantPage_FeedbackButtonShort: String { return self._s[922]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[923]! } + public var PhotoEditor_WarmthTool: String { return self._s[924]! } public func PUSH_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[919]!, self._r[919]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[925]!, self._r[925]!, [_1, _2, _3]) } - public var Passport_Language_tr: String { return self._s[920]! } - public var OldChannels_NoticeUpgradeText: String { return self._s[921]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[923]! } - public var Watch_PhotoView_Title: String { return self._s[924]! } - public var Passport_Phone_Delete: String { return self._s[925]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[926]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[927]! } - public var GroupInfo_Permissions: String { return self._s[928]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[929]! } - public var Profile_ShareContactButton: String { return self._s[930]! } - public var ChatSettings_Other: String { return self._s[931]! } - public var UserInfo_NotificationsDisabled: String { return self._s[932]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[933]! } - public var LastSeen_WithinAMonth: String { return self._s[934]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[935]! } - public var Conversation_ReportGroupLocation: String { return self._s[936]! } - public var Conversation_EncryptionCanceled: String { return self._s[937]! } - public var MediaPicker_GroupDescription: String { return self._s[938]! } - public var WebSearch_Images: String { return self._s[939]! } + public var Passport_Language_tr: String { return self._s[926]! } + public var OldChannels_NoticeUpgradeText: String { return self._s[927]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[929]! } + public var Watch_PhotoView_Title: String { return self._s[930]! } + public var Passport_Phone_Delete: String { return self._s[931]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[932]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[933]! } + public var GroupInfo_Permissions: String { return self._s[934]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[935]! } + public var Profile_ShareContactButton: String { return self._s[936]! } + public var ChatSettings_Other: String { return self._s[937]! } + public var UserInfo_NotificationsDisabled: String { return self._s[938]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[939]! } + public var LastSeen_WithinAMonth: String { return self._s[940]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[941]! } + public var Conversation_ReportGroupLocation: String { return self._s[942]! } + public var Conversation_EncryptionCanceled: String { return self._s[943]! } + public var MediaPicker_GroupDescription: String { return self._s[944]! } + public var WebSearch_Images: String { return self._s[945]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[940]!, self._r[940]!, [_0]) + return formatWithArgumentRanges(self._s[946]!, self._r[946]!, [_0]) } - public var Message_Photo: String { return self._s[941]! } - public var PasscodeSettings_HelpBottom: String { return self._s[942]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[943]! } - public var Conversation_ContextMenuSendMessage: String { return self._s[944]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[945]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[946]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[947]! } - public var NotificationsSound_Calypso: String { return self._s[948]! } - public var Map_Map: String { return self._s[949]! } + public var Message_Photo: String { return self._s[947]! } + public var PasscodeSettings_HelpBottom: String { return self._s[948]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[949]! } + public var Conversation_ContextMenuSendMessage: String { return self._s[950]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[951]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[952]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[953]! } + public var NotificationsSound_Calypso: String { return self._s[954]! } + public var Map_Map: String { return self._s[955]! } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[950]!, self._r[950]!, [_0]) + return formatWithArgumentRanges(self._s[956]!, self._r[956]!, [_0]) } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[953]! } - public var ChatSettings_TextSizeUnits: String { return self._s[954]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[959]! } + public var ChatSettings_TextSizeUnits: String { return self._s[960]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[955]!, self._r[955]!, [_0]) + return formatWithArgumentRanges(self._s[961]!, self._r[961]!, [_0]) } - public var Common_of: String { return self._s[956]! } - public var Conversation_ForwardContacts: String { return self._s[959]! } - public var IntentsSettings_SuggestByAll: String { return self._s[961]! } + public var Common_of: String { return self._s[962]! } + public var Conversation_ForwardContacts: String { return self._s[965]! } + public var IntentsSettings_SuggestByAll: String { return self._s[967]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[962]!, self._r[962]!, [_0]) + return formatWithArgumentRanges(self._s[968]!, self._r[968]!, [_0]) } - public var Call_CameraConfirmationText: String { return self._s[963]! } - public var Passport_Language_hy: String { return self._s[964]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[965]! } - public var AutoDownloadSettings_Reset: String { return self._s[966]! } - public var Wallet_TransactionInfo_AddressCopied: String { return self._s[967]! } - public var Paint_ClearConfirm: String { return self._s[968]! } - public var Camera_VideoMode: String { return self._s[969]! } + public var Call_CameraConfirmationText: String { return self._s[969]! } + public var Passport_Language_hy: String { return self._s[970]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[971]! } + public var AutoDownloadSettings_Reset: String { return self._s[972]! } + public var Wallet_TransactionInfo_AddressCopied: String { return self._s[973]! } + public var Paint_ClearConfirm: String { return self._s[974]! } + public var Camera_VideoMode: String { return self._s[975]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[970]!, self._r[970]!, [_0]) + return formatWithArgumentRanges(self._s[976]!, self._r[976]!, [_0]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[971]! } - public var Conversation_ViewBackground: String { return self._s[972]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[977]! } + public var Conversation_ViewBackground: String { return self._s[978]! } public func Wallet_Info_TransactionDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[973]!, self._r[973]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[979]!, self._r[979]!, [_1, _2, _3]) } - public var Passport_Language_el: String { return self._s[974]! } - public var PhotoEditor_Original: String { return self._s[975]! } - public var Settings_FAQ_Button: String { return self._s[978]! } - public var Channel_Setup_PublicNoLink: String { return self._s[980]! } - public var Conversation_UnsupportedMedia: String { return self._s[981]! } - public var Conversation_SlideToCancel: String { return self._s[982]! } - public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[983]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[984]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[985]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[986]! } - public var Stats_GroupViewers: String { return self._s[987]! } - public var AutoNightTheme_NotAvailable: String { return self._s[988]! } - public var Conversation_Owner: String { return self._s[989]! } - public var Common_Create: String { return self._s[990]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[991]! } - public var ContactList_Context_Call: String { return self._s[992]! } - public var Localization_ChooseLanguage: String { return self._s[994]! } - public var ChatList_Context_AddToContacts: String { return self._s[996]! } - public var OldChannels_NoticeTitle: String { return self._s[997]! } - public var Settings_Proxy: String { return self._s[999]! } - public var Privacy_TopPeersHelp: String { return self._s[1000]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[1001]! } - public var Chat_UnsendMyMessages: String { return self._s[1002]! } + public var Passport_Language_el: String { return self._s[980]! } + public var PhotoEditor_Original: String { return self._s[981]! } + public var Settings_FAQ_Button: String { return self._s[984]! } + public var Channel_Setup_PublicNoLink: String { return self._s[986]! } + public var Conversation_UnsupportedMedia: String { return self._s[987]! } + public var Conversation_SlideToCancel: String { return self._s[988]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[989]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[990]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[991]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[992]! } + public var Stats_GroupViewers: String { return self._s[993]! } + public var AutoNightTheme_NotAvailable: String { return self._s[994]! } + public var Conversation_Owner: String { return self._s[995]! } + public var Common_Create: String { return self._s[996]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[997]! } + public var ContactList_Context_Call: String { return self._s[998]! } + public var Localization_ChooseLanguage: String { return self._s[1000]! } + public var ChatList_Context_AddToContacts: String { return self._s[1002]! } + public var OldChannels_NoticeTitle: String { return self._s[1003]! } + public var Settings_Proxy: String { return self._s[1005]! } + public var Privacy_TopPeersHelp: String { return self._s[1006]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[1007]! } + public var Chat_UnsendMyMessages: String { return self._s[1008]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1003]!, self._r[1003]!, [_0]) + return formatWithArgumentRanges(self._s[1009]!, self._r[1009]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[1004]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[1010]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1006]!, self._r[1006]!, [_0]) + return formatWithArgumentRanges(self._s[1012]!, self._r[1012]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[1007]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[1008]! } - public var Cache_Title: String { return self._s[1009]! } + public var Contacts_SortedByPresence: String { return self._s[1013]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[1014]! } + public var Cache_Title: String { return self._s[1015]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1010]!, self._r[1010]!, [_0]) + return formatWithArgumentRanges(self._s[1016]!, self._r[1016]!, [_0]) + } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[1017]! } + public var Channel_Moderator_Title: String { return self._s[1018]! } + public var InstantPage_AutoNightTheme: String { return self._s[1020]! } + public func ChatList_Search_NoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1021]!, self._r[1021]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[1011]! } - public var Channel_Moderator_Title: String { return self._s[1012]! } - public var InstantPage_AutoNightTheme: String { return self._s[1014]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1017]!, self._r[1017]!, [_1]) + return formatWithArgumentRanges(self._s[1024]!, self._r[1024]!, [_1]) } - public var Passport_Scans_Upload: String { return self._s[1018]! } - public var Undo_Undo: String { return self._s[1020]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[1021]! } - public var TwoStepAuth_RemovePassword: String { return self._s[1022]! } - public var Common_Delete: String { return self._s[1023]! } - public var Contacts_AddPeopleNearby: String { return self._s[1025]! } - public var Conversation_ContextMenuDelete: String { return self._s[1026]! } - public var SocksProxySetup_Credentials: String { return self._s[1027]! } - public var Appearance_EditTheme: String { return self._s[1029]! } - public var ClearCache_StorageOtherApps: String { return self._s[1030]! } + public var Passport_Scans_Upload: String { return self._s[1025]! } + public var Undo_Undo: String { return self._s[1027]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[1028]! } + public var TwoStepAuth_RemovePassword: String { return self._s[1029]! } + public var Common_Delete: String { return self._s[1030]! } + public var Contacts_AddPeopleNearby: String { return self._s[1032]! } + public var Conversation_ContextMenuDelete: String { return self._s[1033]! } + public var SocksProxySetup_Credentials: String { return self._s[1034]! } + public var Appearance_EditTheme: String { return self._s[1036]! } + public var ClearCache_StorageOtherApps: String { return self._s[1037]! } public func Conversation_PeerNearbyTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1032]!, self._r[1032]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1039]!, self._r[1039]!, [_1, _2]) } - public var Settings_EditPhoto: String { return self._s[1033]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[1034]! } - public var Wallet_Send_NetworkErrorText: String { return self._s[1035]! } - public var AuthSessions_DevicesTitle: String { return self._s[1037]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[1039]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[1040]! } - public var Passport_Language_id: String { return self._s[1042]! } - public var Chat_Gifs_TrendingSectionHeader: String { return self._s[1043]! } - public var WallpaperSearch_ColorTeal: String { return self._s[1044]! } - public var ChannelIntro_Title: String { return self._s[1045]! } + public var Settings_EditPhoto: String { return self._s[1040]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[1041]! } + public var Wallet_Send_NetworkErrorText: String { return self._s[1042]! } + public var AuthSessions_DevicesTitle: String { return self._s[1044]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[1046]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[1047]! } + public var Passport_Language_id: String { return self._s[1049]! } + public var Chat_Gifs_TrendingSectionHeader: String { return self._s[1050]! } + public var WallpaperSearch_ColorTeal: String { return self._s[1051]! } + public var ChannelIntro_Title: String { return self._s[1052]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1046]!, self._r[1046]!, [_0]) + return formatWithArgumentRanges(self._s[1053]!, self._r[1053]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[1048]! } - public var VoiceOver_Chat_Reply: String { return self._s[1049]! } - public var ScheduledMessages_BotActionUnavailable: String { return self._s[1050]! } - public var Channel_Info_Description: String { return self._s[1051]! } - public var Stickers_FavoriteStickers: String { return self._s[1052]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[1053]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[1054]! } - public var ChatSearch_ResultsTooltip: String { return self._s[1055]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[1056]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[1057]! } - public var Group_PublicLink_Placeholder: String { return self._s[1058]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[1059]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[1055]! } + public var VoiceOver_Chat_Reply: String { return self._s[1056]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[1057]! } + public var Channel_Info_Description: String { return self._s[1058]! } + public var Stickers_FavoriteStickers: String { return self._s[1059]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[1060]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[1061]! } + public var ChatSearch_ResultsTooltip: String { return self._s[1062]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[1063]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[1064]! } + public var Group_PublicLink_Placeholder: String { return self._s[1065]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[1066]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1060]!, self._r[1060]!, [_1]) + return formatWithArgumentRanges(self._s[1067]!, self._r[1067]!, [_1]) } - public var TextFormat_Underline: String { return self._s[1061]! } + public var TextFormat_Underline: String { return self._s[1068]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1063]!, self._r[1063]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1070]!, self._r[1070]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1064]!, self._r[1064]!, [_0]) + return formatWithArgumentRanges(self._s[1071]!, self._r[1071]!, [_0]) } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1065]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1072]! } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_1, _2]) - } - public var Wallet_Intro_ImportExisting: String { return self._s[1067]! } - public var GroupPermission_Delete: String { return self._s[1068]! } - public var Passport_Language_uk: String { return self._s[1069]! } - public var StickerPack_HideStickers: String { return self._s[1071]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1072]! } - public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1073]!, self._r[1073]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[1074]! } + public var Wallet_Intro_ImportExisting: String { return self._s[1074]! } + public var GroupPermission_Delete: String { return self._s[1075]! } + public var Passport_Language_uk: String { return self._s[1076]! } + public var StickerPack_HideStickers: String { return self._s[1078]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1079]! } + public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1080]!, self._r[1080]!, [_1, _2]) + } + public var Activity_UploadingVideoMessage: String { return self._s[1081]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1075]!, self._r[1075]!, [_0]) + return formatWithArgumentRanges(self._s[1082]!, self._r[1082]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[1076]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1077]! } - public var Settings_CallSettings: String { return self._s[1078]! } - public var Camera_SquareMode: String { return self._s[1079]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1080]! } - public var GroupInfo_SharedMediaNone: String { return self._s[1081]! } + public var Channel_TitleInfo: String { return self._s[1083]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1084]! } + public var Settings_CallSettings: String { return self._s[1085]! } + public var Camera_SquareMode: String { return self._s[1086]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1087]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1088]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1082]!, self._r[1082]!, [_1]) + return formatWithArgumentRanges(self._s[1089]!, self._r[1089]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[1083]! } - public var Application_Update: String { return self._s[1085]! } - public var Month_ShortJanuary: String { return self._s[1086]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[1087]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[1088]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[1089]! } - public var Passport_Address_Street2Placeholder: String { return self._s[1090]! } + public var Bot_GenericBotStatus: String { return self._s[1090]! } + public var Application_Update: String { return self._s[1092]! } + public var Month_ShortJanuary: String { return self._s[1093]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[1094]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[1095]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1096]! } + public var Passport_Address_Street2Placeholder: String { return self._s[1097]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1091]!, self._r[1091]!, [_0]) + return formatWithArgumentRanges(self._s[1098]!, self._r[1098]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[1092]! } - public var Appearance_PreviewOutgoingText: String { return self._s[1093]! } + public var NetworkUsageSettings_Cellular: String { return self._s[1099]! } + public var Appearance_PreviewOutgoingText: String { return self._s[1100]! } public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1094]!, self._r[1094]!, [_0]) + return formatWithArgumentRanges(self._s[1101]!, self._r[1101]!, [_0]) } - public var Notifications_PermissionsAllowInSettings: String { return self._s[1095]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[1098]! } - public var Map_Directions: String { return self._s[1099]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[1101]! } - public var Appearance_ThemeDay: String { return self._s[1102]! } - public var LogoutOptions_LogOut: String { return self._s[1103]! } - public var Group_PublicLink_Title: String { return self._s[1105]! } - public var Channel_AddBotErrorNoRights: String { return self._s[1106]! } - public var ChatList_Search_ShowLess: String { return self._s[1109]! } - public var Passport_Identity_AddPassport: String { return self._s[1110]! } - public var LocalGroup_ButtonTitle: String { return self._s[1111]! } - public var Stats_InteractionsTitle: String { return self._s[1112]! } - public var Stats_GroupActionsTitle: String { return self._s[1113]! } - public var Call_Message: String { return self._s[1114]! } - public var PhotoEditor_ExposureTool: String { return self._s[1115]! } - public var Wallet_Receive_CommentInfo: String { return self._s[1117]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[1118]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[1120]! } - public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1121]! } - public var Appearance_Preview: String { return self._s[1122]! } - public var Compose_ChannelMembers: String { return self._s[1123]! } - public var Conversation_DeleteManyMessages: String { return self._s[1124]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[1125]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1126]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1127]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1130]! } - public var Conversation_UpdateTelegram: String { return self._s[1131]! } - public var EditTheme_Create_TopInfo: String { return self._s[1132]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[1102]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[1105]! } + public var Map_Directions: String { return self._s[1106]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1108]! } + public var Appearance_ThemeDay: String { return self._s[1109]! } + public var LogoutOptions_LogOut: String { return self._s[1110]! } + public var Group_PublicLink_Title: String { return self._s[1112]! } + public var Channel_AddBotErrorNoRights: String { return self._s[1113]! } + public var ChatList_Search_ShowLess: String { return self._s[1116]! } + public var Passport_Identity_AddPassport: String { return self._s[1117]! } + public var LocalGroup_ButtonTitle: String { return self._s[1118]! } + public var Stats_InteractionsTitle: String { return self._s[1119]! } + public var Stats_GroupActionsTitle: String { return self._s[1120]! } + public var Call_Message: String { return self._s[1121]! } + public var PhotoEditor_ExposureTool: String { return self._s[1122]! } + public var Wallet_Receive_CommentInfo: String { return self._s[1124]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1125]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[1127]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1128]! } + public var Appearance_Preview: String { return self._s[1129]! } + public var Compose_ChannelMembers: String { return self._s[1130]! } + public var Conversation_DeleteManyMessages: String { return self._s[1131]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1132]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1133]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1134]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1137]! } + public var Conversation_UpdateTelegram: String { return self._s[1138]! } + public var EditTheme_Create_TopInfo: String { return self._s[1139]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1133]!, self._r[1133]!, [_0]) + return formatWithArgumentRanges(self._s[1140]!, self._r[1140]!, [_0]) } - public var Wallet_WordCheck_Continue: String { return self._s[1134]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[1135]! } - public var IntentsSettings_ResetAll: String { return self._s[1136]! } + public var Wallet_WordCheck_Continue: String { return self._s[1141]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1142]! } + public var IntentsSettings_ResetAll: String { return self._s[1143]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1137]!, self._r[1137]!, [_1]) + return formatWithArgumentRanges(self._s[1144]!, self._r[1144]!, [_1]) } - public var ChatList_RemoveFolder: String { return self._s[1138]! } - public var GroupInfo_Administrators_Title: String { return self._s[1139]! } - public var Stats_GroupPosters: String { return self._s[1140]! } - public var Stats_MessageTitle: String { return self._s[1141]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[1142]! } + public var ChatList_RemoveFolder: String { return self._s[1145]! } + public var GroupInfo_Administrators_Title: String { return self._s[1146]! } + public var Stats_GroupPosters: String { return self._s[1147]! } + public var Stats_MessageTitle: String { return self._s[1148]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1149]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1143]!, self._r[1143]!, [_0]) + return formatWithArgumentRanges(self._s[1150]!, self._r[1150]!, [_0]) } - public var Tour_Title3: String { return self._s[1144]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1145]! } - public var Settings_RemoveVideo: String { return self._s[1148]! } - public var Clipboard_SendPhoto: String { return self._s[1150]! } - public var MediaPicker_Videos: String { return self._s[1151]! } - public var Passport_Email_Title: String { return self._s[1152]! } + public var Tour_Title3: String { return self._s[1151]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1152]! } + public var Settings_RemoveVideo: String { return self._s[1155]! } + public var Clipboard_SendPhoto: String { return self._s[1157]! } + public var MediaPicker_Videos: String { return self._s[1158]! } + public var Passport_Email_Title: String { return self._s[1159]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1153]!, self._r[1153]!, [_0]) + return formatWithArgumentRanges(self._s[1160]!, self._r[1160]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[1154]! } - public var Conversation_MessageDialogDelete: String { return self._s[1155]! } - public var Privacy_Calls_CustomHelp: String { return self._s[1157]! } - public var Message_Wallpaper: String { return self._s[1158]! } - public var MemberSearch_BotSection: String { return self._s[1159]! } - public var GroupInfo_SetSound: String { return self._s[1160]! } - public var Wallet_Send_EncryptComment: String { return self._s[1161]! } + public var StickerPacksSettings_Title: String { return self._s[1161]! } + public var Conversation_MessageDialogDelete: String { return self._s[1162]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1164]! } + public var Message_Wallpaper: String { return self._s[1165]! } + public var MemberSearch_BotSection: String { return self._s[1166]! } + public var GroupInfo_SetSound: String { return self._s[1167]! } + public var Wallet_Send_EncryptComment: String { return self._s[1168]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1162]!, self._r[1162]!, [_0]) + return formatWithArgumentRanges(self._s[1169]!, self._r[1169]!, [_0]) } - public var Core_ServiceUserStatus: String { return self._s[1163]! } - public var LiveLocationUpdated_JustNow: String { return self._s[1164]! } - public var Call_StatusFailed: String { return self._s[1165]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[1166]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1167]! } - public var TwoStepAuth_SetPassword: String { return self._s[1168]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[1169]! } + public var Core_ServiceUserStatus: String { return self._s[1170]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1171]! } + public var Call_StatusFailed: String { return self._s[1172]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1173]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1174]! } + public var TwoStepAuth_SetPassword: String { return self._s[1175]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1176]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1171]!, self._r[1171]!, [_0]) + return formatWithArgumentRanges(self._s[1178]!, self._r[1178]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[1172]! } - public var Map_NoPlacesNearby: String { return self._s[1173]! } - public var Profile_Username: String { return self._s[1174]! } - public var Bot_DescriptionTitle: String { return self._s[1175]! } - public var MaskStickerSettings_Title: String { return self._s[1176]! } - public var SharedMedia_CategoryOther: String { return self._s[1177]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1178]! } - public var Common_NotNow: String { return self._s[1179]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[1180]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[1181]! } - public var Map_Location: String { return self._s[1182]! } - public var Invitation_JoinGroup: String { return self._s[1183]! } - public var AutoDownloadSettings_Title: String { return self._s[1185]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1186]! } - public var Channel_ErrorAddBlocked: String { return self._s[1187]! } - public var ChatList_AddChatsToFolder: String { return self._s[1188]! } - public var Conversation_UnblockUser: String { return self._s[1189]! } - public var EditTheme_Edit_TopInfo: String { return self._s[1190]! } - public var Watch_Bot_Restart: String { return self._s[1191]! } - public var TwoStepAuth_Title: String { return self._s[1192]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1193]! } - public var Checkout_ShippingMethod: String { return self._s[1194]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1195]! } + public var Calls_SubmitRating: String { return self._s[1179]! } + public var Map_NoPlacesNearby: String { return self._s[1180]! } + public var Profile_Username: String { return self._s[1181]! } + public var Bot_DescriptionTitle: String { return self._s[1182]! } + public var MaskStickerSettings_Title: String { return self._s[1183]! } + public var SharedMedia_CategoryOther: String { return self._s[1184]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1185]! } + public var Common_NotNow: String { return self._s[1186]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1187]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1188]! } + public var Map_Location: String { return self._s[1189]! } + public var Invitation_JoinGroup: String { return self._s[1190]! } + public var AutoDownloadSettings_Title: String { return self._s[1192]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1193]! } + public var Channel_ErrorAddBlocked: String { return self._s[1194]! } + public var ChatList_AddChatsToFolder: String { return self._s[1195]! } + public var Conversation_UnblockUser: String { return self._s[1196]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1197]! } + public var Watch_Bot_Restart: String { return self._s[1198]! } + public var TwoStepAuth_Title: String { return self._s[1199]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1200]! } + public var Checkout_ShippingMethod: String { return self._s[1201]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1202]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1196]!, self._r[1196]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1203]!, self._r[1203]!, [_1, _2, _3]) } - public var PeerInfo_ButtonDiscuss: String { return self._s[1197]! } - public var EditTheme_ChangeColors: String { return self._s[1199]! } + public var PeerInfo_ButtonDiscuss: String { return self._s[1204]! } + public var EditTheme_ChangeColors: String { return self._s[1206]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1200]!, self._r[1200]!, [_0]) + return formatWithArgumentRanges(self._s[1207]!, self._r[1207]!, [_0]) } public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1201]!, self._r[1201]!, [_0]) + return formatWithArgumentRanges(self._s[1208]!, self._r[1208]!, [_0]) } - public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1202]! } - public var Notification_VideoCallMissed: String { return self._s[1204]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1205]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[1207]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[1208]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[1209]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1210]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1211]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[1212]! } - public var Checkout_PaymentMethod_Title: String { return self._s[1213]! } - public var SocksProxySetup_Connection: String { return self._s[1214]! } - public var Group_MessagePhotoRemoved: String { return self._s[1215]! } - public var PeopleNearby_MakeInvisible: String { return self._s[1217]! } - public var Channel_Stickers_NotFound: String { return self._s[1219]! } - public var Group_About_Help: String { return self._s[1220]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[1221]! } - public var PeopleNearby_Title: String { return self._s[1223]! } + public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1209]! } + public var Notification_VideoCallMissed: String { return self._s[1211]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1212]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1214]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1215]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1216]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1217]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1218]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1219]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1220]! } + public var SocksProxySetup_Connection: String { return self._s[1221]! } + public var Group_MessagePhotoRemoved: String { return self._s[1222]! } + public var PeopleNearby_MakeInvisible: String { return self._s[1224]! } + public var Channel_Stickers_NotFound: String { return self._s[1226]! } + public var Group_About_Help: String { return self._s[1227]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1228]! } + public var PeopleNearby_Title: String { return self._s[1230]! } public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1224]!, self._r[1224]!, [_1]) + return formatWithArgumentRanges(self._s[1231]!, self._r[1231]!, [_1]) } - public var Map_Home: String { return self._s[1225]! } - public var Stats_ZoomOut: String { return self._s[1226]! } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1228]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1229]! } - public var SocksProxySetup_Password: String { return self._s[1230]! } - public var Notifications_PermissionsEnable: String { return self._s[1231]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[1233]! } + public var Map_Home: String { return self._s[1232]! } + public var Stats_ZoomOut: String { return self._s[1233]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1235]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1236]! } + public var SocksProxySetup_Password: String { return self._s[1237]! } + public var Notifications_PermissionsEnable: String { return self._s[1238]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1240]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1234]!, self._r[1234]!, [_1]) + return formatWithArgumentRanges(self._s[1241]!, self._r[1241]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1236]!, self._r[1236]!, [_0]) + return formatWithArgumentRanges(self._s[1243]!, self._r[1243]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[1237]! } - public var ArchivedPacksAlert_Title: String { return self._s[1238]! } - public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1239]! } - public var Map_PlacesNearby: String { return self._s[1240]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[1244]! } + public var ArchivedPacksAlert_Title: String { return self._s[1245]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1246]! } + public var Map_PlacesNearby: String { return self._s[1247]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1241]!, self._r[1241]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1248]!, self._r[1248]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1242]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1245]! } - public var Conversation_StatusTyping: String { return self._s[1246]! } - public var Widget_ApplicationStartRequired: String { return self._s[1247]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[1248]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1249]! } - public var UserInfo_CreateNewContact: String { return self._s[1250]! } - public var Passport_Identity_FrontSide: String { return self._s[1251]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1252]! } - public var Calls_CallTabTitle: String { return self._s[1253]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1254]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1249]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1252]! } + public var Conversation_StatusTyping: String { return self._s[1253]! } + public var Widget_ApplicationStartRequired: String { return self._s[1254]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1255]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1256]! } + public var UserInfo_CreateNewContact: String { return self._s[1257]! } + public var Passport_Identity_FrontSide: String { return self._s[1258]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1259]! } + public var Calls_CallTabTitle: String { return self._s[1260]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1261]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1256]!, self._r[1256]!, [_0]) + return formatWithArgumentRanges(self._s[1263]!, self._r[1263]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[1257]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1258]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1259]! } - public var Wallet_Completed_Text: String { return self._s[1260]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1261]! } - public var Paint_Stickers: String { return self._s[1262]! } - public var Privacy_GroupsAndChannels: String { return self._s[1263]! } - public var ChatList_Context_Delete: String { return self._s[1265]! } - public var UserInfo_AddContact: String { return self._s[1266]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1264]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1265]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1266]! } + public var Wallet_Completed_Text: String { return self._s[1267]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1268]! } + public var Paint_Stickers: String { return self._s[1269]! } + public var Privacy_GroupsAndChannels: String { return self._s[1270]! } + public var ChatList_Context_Delete: String { return self._s[1272]! } + public var UserInfo_AddContact: String { return self._s[1273]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1267]!, self._r[1267]!, [_0]) + return formatWithArgumentRanges(self._s[1274]!, self._r[1274]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1269]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1276]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1271]!, self._r[1271]!, [_0]) + return formatWithArgumentRanges(self._s[1278]!, self._r[1278]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1272]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1273]! } - public var BlockedUsers_BlockUser: String { return self._s[1274]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1275]! } - public var MediaPicker_UngroupDescription: String { return self._s[1278]! } - public var Watch_NoConnection: String { return self._s[1279]! } - public var Month_GenSeptember: String { return self._s[1280]! } - public var Conversation_ViewGroup: String { return self._s[1282]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1285]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1286]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1287]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1288]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1289]! } - public var MediaPicker_CameraRoll: String { return self._s[1291]! } - public var Month_GenAugust: String { return self._s[1292]! } - public var Wallet_Configuration_SourceHeader: String { return self._s[1293]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1294]! } - public var SharedMedia_EmptyText: String { return self._s[1295]! } - public var Map_ShareLiveLocation: String { return self._s[1296]! } - public var Calls_All: String { return self._s[1297]! } - public var Map_SendThisPlace: String { return self._s[1299]! } - public var Appearance_ThemeNight: String { return self._s[1301]! } - public var Conversation_HoldForAudio: String { return self._s[1302]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1305]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1306]! } - public var SocksProxySetup_Secret: String { return self._s[1307]! } + public var DialogList_NoMessagesTitle: String { return self._s[1279]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1280]! } + public var BlockedUsers_BlockUser: String { return self._s[1281]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1282]! } + public var MediaPicker_UngroupDescription: String { return self._s[1285]! } + public var Watch_NoConnection: String { return self._s[1286]! } + public var Month_GenSeptember: String { return self._s[1287]! } + public var Conversation_ViewGroup: String { return self._s[1289]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1292]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1293]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1294]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1295]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1296]! } + public var MediaPicker_CameraRoll: String { return self._s[1298]! } + public var Month_GenAugust: String { return self._s[1299]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1300]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1301]! } + public var SharedMedia_EmptyText: String { return self._s[1302]! } + public var Map_ShareLiveLocation: String { return self._s[1303]! } + public var Calls_All: String { return self._s[1304]! } + public var Map_SendThisPlace: String { return self._s[1306]! } + public var Appearance_ThemeNight: String { return self._s[1308]! } + public var Conversation_HoldForAudio: String { return self._s[1309]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1312]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1313]! } + public var SocksProxySetup_Secret: String { return self._s[1314]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1308]!, self._r[1308]!, [_0]) + return formatWithArgumentRanges(self._s[1315]!, self._r[1315]!, [_0]) } - public var Channel_BanList_RestrictedTitle: String { return self._s[1310]! } - public var Conversation_Location: String { return self._s[1311]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1317]! } + public var Conversation_Location: String { return self._s[1318]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1312]!, self._r[1312]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1319]!, self._r[1319]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1314]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1315]! } - public var Notifications_PermissionsText: String { return self._s[1316]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1317]! } - public var Call_Flip: String { return self._s[1318]! } - public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1320]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1321]! } - public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1322]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1323]! } - public var Stats_GroupTopAdmin_Promote: String { return self._s[1325]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1326]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1328]! } - public var ChatList_EditFolders: String { return self._s[1330]! } - public var Channel_TooMuchBots: String { return self._s[1331]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1332]! } - public var Login_InvalidCodeError: String { return self._s[1333]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1334]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1321]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1322]! } + public var Notifications_PermissionsText: String { return self._s[1323]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1324]! } + public var Call_Flip: String { return self._s[1325]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1327]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1328]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1329]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1330]! } + public var Stats_GroupTopAdmin_Promote: String { return self._s[1332]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1333]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1335]! } + public var ChatList_EditFolders: String { return self._s[1337]! } + public var Channel_TooMuchBots: String { return self._s[1338]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1339]! } + public var Login_InvalidCodeError: String { return self._s[1340]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1341]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1335]!, self._r[1335]!, [_0]) + return formatWithArgumentRanges(self._s[1342]!, self._r[1342]!, [_0]) } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1336]!, self._r[1336]!, [_0]) + return formatWithArgumentRanges(self._s[1343]!, self._r[1343]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1337]! } - public var Call_CallInProgressTitle: String { return self._s[1338]! } - public var Month_ShortSeptember: String { return self._s[1339]! } - public var Watch_ChannelInfo_Title: String { return self._s[1340]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1343]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1344]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1345]! } - public var Wallet_Receive_Title: String { return self._s[1346]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1347]! } - public var EditProfile_NameAndPhotoOrVideoHelp: String { return self._s[1348]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1349]! } - public var PhotoEditor_CropReset: String { return self._s[1350]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1352]! } - public var Channel_Management_LabelEditor: String { return self._s[1353]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1355]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1356]! } - public var Wallet_Info_WalletCreated: String { return self._s[1357]! } - public var UserInfo_Title: String { return self._s[1358]! } - public var ChatList_HideAction: String { return self._s[1359]! } - public var AccessDenied_Title: String { return self._s[1360]! } - public var DialogList_SearchLabel: String { return self._s[1361]! } - public var Group_Setup_HistoryHidden: String { return self._s[1362]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1363]! } - public var State_Updating: String { return self._s[1365]! } - public var Contacts_TabTitle: String { return self._s[1366]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1368]! } - public var GroupInfo_GroupHistory: String { return self._s[1369]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1370]! } - public var Wallpaper_SetColor: String { return self._s[1371]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1372]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1373]! } - public var ChatList_ReorderTabs: String { return self._s[1374]! } - public var ChatListFolder_IncludeChatsTitle: String { return self._s[1375]! } - public var Chat_AttachmentLimitReached: String { return self._s[1376]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1377]! } - public var Contacts_NotRegisteredSection: String { return self._s[1378]! } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1344]! } + public var Call_CallInProgressTitle: String { return self._s[1345]! } + public var Month_ShortSeptember: String { return self._s[1346]! } + public var Watch_ChannelInfo_Title: String { return self._s[1347]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1350]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1351]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1352]! } + public var Wallet_Receive_Title: String { return self._s[1353]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1354]! } + public var EditProfile_NameAndPhotoOrVideoHelp: String { return self._s[1355]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1356]! } + public var PhotoEditor_CropReset: String { return self._s[1357]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1359]! } + public var Channel_Management_LabelEditor: String { return self._s[1360]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1362]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1363]! } + public var Wallet_Info_WalletCreated: String { return self._s[1364]! } + public var UserInfo_Title: String { return self._s[1365]! } + public var ChatList_HideAction: String { return self._s[1366]! } + public var AccessDenied_Title: String { return self._s[1367]! } + public var DialogList_SearchLabel: String { return self._s[1368]! } + public var Group_Setup_HistoryHidden: String { return self._s[1369]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1370]! } + public var State_Updating: String { return self._s[1372]! } + public var Contacts_TabTitle: String { return self._s[1373]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1375]! } + public var GroupInfo_GroupHistory: String { return self._s[1376]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1377]! } + public var Wallpaper_SetColor: String { return self._s[1378]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1379]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1380]! } + public var ChatList_ReorderTabs: String { return self._s[1381]! } + public var ChatListFolder_IncludeChatsTitle: String { return self._s[1382]! } + public var Chat_AttachmentLimitReached: String { return self._s[1383]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1384]! } + public var Contacts_NotRegisteredSection: String { return self._s[1385]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1379]!, self._r[1379]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1386]!, self._r[1386]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1380]! } - public var Call_Audio: String { return self._s[1381]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1382]! } - public var SocksProxySetup_Connecting: String { return self._s[1383]! } - public var ExplicitContent_AlertChannel: String { return self._s[1384]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1385]! } - public var Conversation_Contact: String { return self._s[1386]! } - public var Login_CodeExpired: String { return self._s[1387]! } - public var Passport_DiscardMessageAction: String { return self._s[1388]! } - public var ChatList_Context_Unpin: String { return self._s[1389]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1390]! } + public var Paint_Clear: String { return self._s[1387]! } + public var Call_Audio: String { return self._s[1388]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1389]! } + public var SocksProxySetup_Connecting: String { return self._s[1390]! } + public var ExplicitContent_AlertChannel: String { return self._s[1391]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1392]! } + public var Conversation_Contact: String { return self._s[1393]! } + public var Login_CodeExpired: String { return self._s[1394]! } + public var Passport_DiscardMessageAction: String { return self._s[1395]! } + public var ChatList_Context_Unpin: String { return self._s[1396]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1397]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1391]!, self._r[1391]!, [_0]) + return formatWithArgumentRanges(self._s[1398]!, self._r[1398]!, [_0]) } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1392]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1393]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1399]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1400]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1394]!, self._r[1394]!, [_0]) + return formatWithArgumentRanges(self._s[1401]!, self._r[1401]!, [_0]) } - public var Month_ShortApril: String { return self._s[1395]! } - public var AuthSessions_CurrentSession: String { return self._s[1396]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1399]! } - public var Wallet_Navigation_Cancel: String { return self._s[1401]! } - public var WallpaperPreview_CropTopText: String { return self._s[1402]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1403]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1405]! } + public var Month_ShortApril: String { return self._s[1402]! } + public var AuthSessions_CurrentSession: String { return self._s[1403]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1406]! } + public var Wallet_Navigation_Cancel: String { return self._s[1408]! } + public var WallpaperPreview_CropTopText: String { return self._s[1409]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1410]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1412]! } public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1406]!, self._r[1406]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1413]!, self._r[1413]!, [_0, _1]) } - public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1407]! } - public var Channel_Setup_TypePrivate: String { return self._s[1409]! } - public var Forward_ChannelReadOnly: String { return self._s[1412]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1413]! } - public var AddContact_SharedContactException: String { return self._s[1414]! } - public var UserInfo_BotPrivacy: String { return self._s[1416]! } - public var Wallet_CreateInvoice_Title: String { return self._s[1417]! } - public var Notification_PassportValueEmail: String { return self._s[1418]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1419]! } - public var GroupPermission_NewTitle: String { return self._s[1420]! } - public var CallFeedback_ReasonDropped: String { return self._s[1421]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1422]! } - public var Channel_SignMessages_Help: String { return self._s[1425]! } - public var Undo_ChatDeleted: String { return self._s[1427]! } - public var Conversation_ChatBackground: String { return self._s[1428]! } + public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1414]! } + public var Channel_Setup_TypePrivate: String { return self._s[1416]! } + public var Forward_ChannelReadOnly: String { return self._s[1419]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1420]! } + public var AddContact_SharedContactException: String { return self._s[1421]! } + public var UserInfo_BotPrivacy: String { return self._s[1423]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1424]! } + public var Notification_PassportValueEmail: String { return self._s[1425]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1426]! } + public var GroupPermission_NewTitle: String { return self._s[1427]! } + public var CallFeedback_ReasonDropped: String { return self._s[1428]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1429]! } + public var Channel_SignMessages_Help: String { return self._s[1432]! } + public var Undo_ChatDeleted: String { return self._s[1434]! } + public var Conversation_ChatBackground: String { return self._s[1435]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1429]!, self._r[1429]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1436]!, self._r[1436]!, [_1, _2, _3]) } public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1432]!, self._r[1432]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1439]!, self._r[1439]!, [_1, _2, _3]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1433]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1434]! } - public var Passport_Language_pt: String { return self._s[1435]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1436]! } - public var NotificationsSound_Popcorn: String { return self._s[1439]! } - public var AutoNightTheme_Disabled: String { return self._s[1440]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1441]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1442]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1443]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1444]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1440]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1441]! } + public var Passport_Language_pt: String { return self._s[1442]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1443]! } + public var NotificationsSound_Popcorn: String { return self._s[1446]! } + public var AutoNightTheme_Disabled: String { return self._s[1447]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1448]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1449]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1450]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1451]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1445]!, self._r[1445]!, [_0]) + return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, [_0]) } - public var ChatListFolder_TitleCreate: String { return self._s[1446]! } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1447]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1448]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1450]! } - public var PeerInfo_PaneGroups: String { return self._s[1451]! } + public var ChatListFolder_TitleCreate: String { return self._s[1453]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1454]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1455]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1457]! } + public var PeerInfo_PaneGroups: String { return self._s[1458]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1459]!, self._r[1459]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1455]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1456]! } - public var Compose_NewEncryptedChat: String { return self._s[1457]! } - public var Login_CodeFloodError: String { return self._s[1458]! } - public var Calls_TabTitle: String { return self._s[1459]! } - public var Privacy_ProfilePhoto: String { return self._s[1460]! } - public var Passport_Language_he: String { return self._s[1461]! } + public var SocksProxySetup_Hostname: String { return self._s[1462]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1463]! } + public var Compose_NewEncryptedChat: String { return self._s[1464]! } + public var Login_CodeFloodError: String { return self._s[1465]! } + public var Calls_TabTitle: String { return self._s[1466]! } + public var Privacy_ProfilePhoto: String { return self._s[1467]! } + public var Passport_Language_he: String { return self._s[1468]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1462]!, self._r[1462]!, [_0]) + return formatWithArgumentRanges(self._s[1469]!, self._r[1469]!, [_0]) } - public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[1463]! } - public var GroupPermission_Title: String { return self._s[1464]! } + public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[1470]! } + public var GroupPermission_Title: String { return self._s[1471]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1465]!, self._r[1465]!, [_0]) + return formatWithArgumentRanges(self._s[1472]!, self._r[1472]!, [_0]) } - public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1466]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1467]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1468]! } - public var Tour_Text1: String { return self._s[1469]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1470]! } - public var Month_ShortFebruary: String { return self._s[1471]! } - public var Call_ExternalCallInProgressMessage: String { return self._s[1472]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1473]! } - public var ContactList_Context_VideoCall: String { return self._s[1474]! } + public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1473]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1474]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1475]! } + public var Tour_Text1: String { return self._s[1476]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1477]! } + public var Month_ShortFebruary: String { return self._s[1478]! } + public var Call_ExternalCallInProgressMessage: String { return self._s[1479]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1480]! } + public var ContactList_Context_VideoCall: String { return self._s[1481]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1475]!, self._r[1475]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1482]!, self._r[1482]!, [_1, _2, _3]) } - public var NotificationsSound_Glass: String { return self._s[1476]! } - public var Appearance_ThemeNightBlue: String { return self._s[1477]! } - public var CheckoutInfo_Pay: String { return self._s[1478]! } - public var Stats_LanguagesTitle: String { return self._s[1480]! } - public var PeerInfo_ButtonLeave: String { return self._s[1481]! } - public var SettingsSearch_Synonyms_ChatFolders: String { return self._s[1482]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1483]! } - public var Call_CallAgain: String { return self._s[1485]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1486]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1487]! } - public var Passport_InvalidPasswordError: String { return self._s[1488]! } - public var Watch_Message_Game: String { return self._s[1489]! } - public var Stickers_Install: String { return self._s[1490]! } - public var VoiceOver_Chat_Message: String { return self._s[1491]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1492]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1494]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1495]! } - public var AuthSessions_OtherSessions: String { return self._s[1496]! } - public var Channel_Username_Help: String { return self._s[1497]! } - public var Camera_Title: String { return self._s[1498]! } - public var IntentsSettings_Title: String { return self._s[1500]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1502]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1503]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1504]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1505]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1506]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1507]! } - public var ScheduledMessages_DeleteMany: String { return self._s[1508]! } - public var Conversation_RestrictedStickers: String { return self._s[1509]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1511]! } - public var UserInfo_TelegramCall: String { return self._s[1513]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1514]! } - public var CreatePoll_OptionsHeader: String { return self._s[1515]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1516]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1517]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1518]! } - public var Theme_Colors_Proceed: String { return self._s[1519]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1520]! } + public var NotificationsSound_Glass: String { return self._s[1483]! } + public var Appearance_ThemeNightBlue: String { return self._s[1484]! } + public var CheckoutInfo_Pay: String { return self._s[1485]! } + public var Stats_LanguagesTitle: String { return self._s[1487]! } + public var PeerInfo_ButtonLeave: String { return self._s[1488]! } + public var SettingsSearch_Synonyms_ChatFolders: String { return self._s[1489]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1490]! } + public var Call_CallAgain: String { return self._s[1492]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1493]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1494]! } + public var Passport_InvalidPasswordError: String { return self._s[1495]! } + public var Watch_Message_Game: String { return self._s[1496]! } + public var Stickers_Install: String { return self._s[1497]! } + public var VoiceOver_Chat_Message: String { return self._s[1498]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1499]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1501]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1502]! } + public var AuthSessions_OtherSessions: String { return self._s[1503]! } + public var Channel_Username_Help: String { return self._s[1504]! } + public var Camera_Title: String { return self._s[1505]! } + public var IntentsSettings_Title: String { return self._s[1507]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1509]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1510]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1511]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1512]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1513]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1514]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1515]! } + public var Conversation_RestrictedStickers: String { return self._s[1516]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1518]! } + public var UserInfo_TelegramCall: String { return self._s[1520]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1521]! } + public var CreatePoll_OptionsHeader: String { return self._s[1522]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1523]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1524]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1525]! } + public var Theme_Colors_Proceed: String { return self._s[1526]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1527]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1521]!, self._r[1521]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1528]!, self._r[1528]!, [_1, _2, _3]) } - public var Wallet_Month_GenAugust: String { return self._s[1522]! } - public var Settings_SaveEditedPhotos: String { return self._s[1523]! } - public var Stats_FollowersBySourceTitle: String { return self._s[1524]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1525]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1526]! } - public var Conversation_MessageDialogRetry: String { return self._s[1527]! } - public var ChatList_Context_MarkAsUnread: String { return self._s[1528]! } - public var MessagePoll_SubmitVote: String { return self._s[1529]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1530]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1531]! } - public var ChatList_Context_Back: String { return self._s[1532]! } - public var Group_Setup_TypeHeader: String { return self._s[1533]! } - public var Paint_RecentStickers: String { return self._s[1534]! } - public var PhotoEditor_GrainTool: String { return self._s[1535]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1536]! } - public var EmptyGroupInfo_Line4: String { return self._s[1537]! } - public var Watch_AuthRequired: String { return self._s[1539]! } + public var Wallet_Month_GenAugust: String { return self._s[1529]! } + public var Settings_SaveEditedPhotos: String { return self._s[1530]! } + public var Stats_FollowersBySourceTitle: String { return self._s[1531]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1532]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1533]! } + public var Conversation_MessageDialogRetry: String { return self._s[1534]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1535]! } + public var MessagePoll_SubmitVote: String { return self._s[1536]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1537]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1538]! } + public var ChatList_Context_Back: String { return self._s[1539]! } + public var Group_Setup_TypeHeader: String { return self._s[1540]! } + public var Paint_RecentStickers: String { return self._s[1541]! } + public var PhotoEditor_GrainTool: String { return self._s[1542]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1543]! } + public var EmptyGroupInfo_Line4: String { return self._s[1544]! } + public var Watch_AuthRequired: String { return self._s[1546]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1540]!, self._r[1540]!, [_0]) + return formatWithArgumentRanges(self._s[1547]!, self._r[1547]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1541]! } - public var ChannelIntro_Text: String { return self._s[1542]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1543]! } - public var GroupPermission_NoSendMedia: String { return self._s[1544]! } - public var Calls_AddTab: String { return self._s[1545]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1546]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1547]! } - public var Conversation_WalletRequiredSetup: String { return self._s[1548]! } - public var Notification_MessageLifetime1d: String { return self._s[1549]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1550]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1551]! } - public var Passport_Identity_GenderFemale: String { return self._s[1552]! } - public var BlockedUsers_BlockTitle: String { return self._s[1553]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1548]! } + public var ChannelIntro_Text: String { return self._s[1549]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1550]! } + public var GroupPermission_NoSendMedia: String { return self._s[1551]! } + public var Calls_AddTab: String { return self._s[1552]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1553]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1554]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1555]! } + public var Notification_MessageLifetime1d: String { return self._s[1556]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1557]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1558]! } + public var Passport_Identity_GenderFemale: String { return self._s[1559]! } + public var BlockedUsers_BlockTitle: String { return self._s[1560]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1554]!, self._r[1554]!, [_1]) + return formatWithArgumentRanges(self._s[1561]!, self._r[1561]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1555]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1556]! } - public var Settings_Context_Logout: String { return self._s[1557]! } - public var Wallet_Info_UnknownTransaction: String { return self._s[1558]! } - public var ChatList_ArchiveAction: String { return self._s[1559]! } - public var AutoNightTheme_Scheduled: String { return self._s[1560]! } - public var TwoFactorSetup_Email_SkipAction: String { return self._s[1561]! } - public var Settings_Devices: String { return self._s[1562]! } - public var ContactInfo_Note: String { return self._s[1563]! } + public var Weekday_Yesterday: String { return self._s[1562]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1563]! } + public var Settings_Context_Logout: String { return self._s[1564]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1565]! } + public var ChatList_ArchiveAction: String { return self._s[1566]! } + public var AutoNightTheme_Scheduled: String { return self._s[1567]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1568]! } + public var Settings_Devices: String { return self._s[1569]! } + public var ContactInfo_Note: String { return self._s[1570]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1564]!, self._r[1564]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1571]!, self._r[1571]!, [_1, _2, _3, _4, _5, _6]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1565]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[1566]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1567]! } - public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1568]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1572]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1573]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1574]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1575]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1569]!, self._r[1569]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1576]!, self._r[1576]!, [_1, _2]) } - public var CreatePoll_Create: String { return self._s[1570]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1571]! } + public var CreatePoll_Create: String { return self._s[1577]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1578]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1572]!, self._r[1572]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1579]!, self._r[1579]!, [_1, _2]) } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1573]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1574]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1576]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1580]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1581]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1583]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1577]!, self._r[1577]!, [_1]) + return formatWithArgumentRanges(self._s[1584]!, self._r[1584]!, [_1]) } - public var Preview_OpenInInstagram: String { return self._s[1578]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1579]! } + public var Preview_OpenInInstagram: String { return self._s[1585]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1586]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1580]!, self._r[1580]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1587]!, self._r[1587]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1581]!, self._r[1581]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1588]!, self._r[1588]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1582]! } - public var ArchivedChats_IntroText3: String { return self._s[1583]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1584]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1585]! } - public var Wallet_Month_GenSeptember: String { return self._s[1586]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1587]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1589]! } + public var ArchivedChats_IntroText3: String { return self._s[1590]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1591]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1592]! } + public var Wallet_Month_GenSeptember: String { return self._s[1593]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1594]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1588]!, self._r[1588]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1595]!, self._r[1595]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1590]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1591]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1592]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1593]! } - public var Gif_NoGifsFound: String { return self._s[1594]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1595]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1596]! } - public var EditTheme_Preview: String { return self._s[1597]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1597]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1598]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1599]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1600]! } + public var Gif_NoGifsFound: String { return self._s[1601]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1602]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1603]! } + public var EditTheme_Preview: String { return self._s[1604]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1598]!, self._r[1598]!, [_0]) + return formatWithArgumentRanges(self._s[1605]!, self._r[1605]!, [_0]) } - public var GroupInfo_ActionPromote: String { return self._s[1599]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1600]! } - public var GroupInfo_Permissions_Title: String { return self._s[1601]! } - public var Permissions_ContactsText_v0: String { return self._s[1602]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1603]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1604]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1607]! } - public var Passport_FieldEmailHelp: String { return self._s[1608]! } + public var GroupInfo_ActionPromote: String { return self._s[1606]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1607]! } + public var GroupInfo_Permissions_Title: String { return self._s[1608]! } + public var Permissions_ContactsText_v0: String { return self._s[1609]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1610]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1611]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1614]! } + public var Passport_FieldEmailHelp: String { return self._s[1615]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1609]!, self._r[1609]!, [_0]) + return formatWithArgumentRanges(self._s[1616]!, self._r[1616]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1610]! } - public var Weekday_ShortSaturday: String { return self._s[1611]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1612]! } - public var Watch_Conversation_UserInfo: String { return self._s[1613]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1614]! } - public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1615]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1616]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1618]! } - public var PhotoEditor_VignetteTool: String { return self._s[1619]! } - public var Conversation_ContextMenuDiscuss: String { return self._s[1620]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1621]! } - public var Passport_Language_et: String { return self._s[1622]! } - public var AppUpgrade_Running: String { return self._s[1623]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1625]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1626]! } - public var Passport_Language_bg: String { return self._s[1627]! } - public var Stickers_NoStickersFound: String { return self._s[1629]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1617]! } + public var Weekday_ShortSaturday: String { return self._s[1618]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1619]! } + public var Watch_Conversation_UserInfo: String { return self._s[1620]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1621]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1622]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1623]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1625]! } + public var PhotoEditor_VignetteTool: String { return self._s[1626]! } + public var Conversation_ContextMenuDiscuss: String { return self._s[1627]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1628]! } + public var Passport_Language_et: String { return self._s[1629]! } + public var AppUpgrade_Running: String { return self._s[1630]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1632]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1633]! } + public var Passport_Language_bg: String { return self._s[1634]! } + public var Stickers_NoStickersFound: String { return self._s[1636]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1631]!, self._r[1631]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1638]!, self._r[1638]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1632]!, self._r[1632]!, [_0]) + return formatWithArgumentRanges(self._s[1639]!, self._r[1639]!, [_0]) } - public var Wallet_Month_GenJuly: String { return self._s[1633]! } - public var Wallet_Receive_AddressHeader: String { return self._s[1635]! } - public var Wallet_Send_AmountText: String { return self._s[1636]! } - public var Settings_About: String { return self._s[1637]! } + public var Wallet_Month_GenJuly: String { return self._s[1640]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1642]! } + public var Wallet_Send_AmountText: String { return self._s[1643]! } + public var Settings_About: String { return self._s[1644]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1638]!, self._r[1638]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1645]!, self._r[1645]!, [_0, _1, _2]) } - public var ChatList_Context_MarkAsRead: String { return self._s[1640]! } - public var KeyCommand_NewMessage: String { return self._s[1641]! } - public var Group_ErrorAddBlocked: String { return self._s[1642]! } + public var ChatList_Context_MarkAsRead: String { return self._s[1647]! } + public var KeyCommand_NewMessage: String { return self._s[1648]! } + public var Group_ErrorAddBlocked: String { return self._s[1649]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1643]!, self._r[1643]!, [_0]) - } - public var Map_LocationTitle: String { return self._s[1644]! } - public var ReportGroupLocation_Title: String { return self._s[1645]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1646]! } - public var Cache_ClearProgress: String { return self._s[1647]! } - public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1648]!, self._r[1648]!, [_0]) - } - public var GroupRemoved_AddToGroup: String { return self._s[1649]! } - public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1650]!, self._r[1650]!, [_0]) } - public var Passport_UpdateRequiredError: String { return self._s[1651]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1652]! } + public var Map_LocationTitle: String { return self._s[1651]! } + public var ReportGroupLocation_Title: String { return self._s[1652]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1653]! } + public var Cache_ClearProgress: String { return self._s[1654]! } + public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1655]!, self._r[1655]!, [_0]) + } + public var GroupRemoved_AddToGroup: String { return self._s[1656]! } + public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1657]!, self._r[1657]!, [_0]) + } + public var Passport_UpdateRequiredError: String { return self._s[1658]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1659]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1653]!, self._r[1653]!, [_1]) + return formatWithArgumentRanges(self._s[1660]!, self._r[1660]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1655]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1656]! } - public var PeerInfo_ButtonSearch: String { return self._s[1657]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1658]! } - public var Passport_Language_ka: String { return self._s[1659]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1662]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1663]! } + public var PeerInfo_ButtonSearch: String { return self._s[1664]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1665]! } + public var Passport_Language_ka: String { return self._s[1666]! } public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1660]!, self._r[1660]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1667]!, self._r[1667]!, [_1, _2, _3]) } - public var Call_Decline: String { return self._s[1661]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1662]! } - public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1665]! } + public var Call_Decline: String { return self._s[1668]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1669]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1672]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1666]!, self._r[1666]!, [_0]) + return formatWithArgumentRanges(self._s[1673]!, self._r[1673]!, [_0]) } - public var CallFeedback_Send: String { return self._s[1667]! } - public var EditTheme_EditTitle: String { return self._s[1668]! } + public var CallFeedback_Send: String { return self._s[1674]! } + public var EditTheme_EditTitle: String { return self._s[1675]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1669]!, self._r[1669]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1676]!, self._r[1676]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1670]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1677]! } public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1672]!, self._r[1672]!, [_0]) + return formatWithArgumentRanges(self._s[1679]!, self._r[1679]!, [_0]) } - public var Media_SendingOptionsTooltip: String { return self._s[1673]! } - public var Call_YourMicrophoneOff: String { return self._s[1674]! } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1675]! } - public var Passport_DeletePassport: String { return self._s[1676]! } - public var Appearance_AppIconFilled: String { return self._s[1677]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1678]! } - public var Month_ShortDecember: String { return self._s[1679]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1681]! } + public var Media_SendingOptionsTooltip: String { return self._s[1680]! } + public var Call_YourMicrophoneOff: String { return self._s[1681]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1682]! } + public var Passport_DeletePassport: String { return self._s[1683]! } + public var Appearance_AppIconFilled: String { return self._s[1684]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1685]! } + public var Month_ShortDecember: String { return self._s[1686]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1688]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_0]) + return formatWithArgumentRanges(self._s[1689]!, self._r[1689]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1683]! } - public var Conversation_EncryptedDescription1: String { return self._s[1684]! } - public var Conversation_EncryptedDescription2: String { return self._s[1685]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1686]! } - public var ChatListFolder_NameUnread: String { return self._s[1688]! } - public var Conversation_EncryptedDescription3: String { return self._s[1689]! } - public var PhotoEditor_SharpenTool: String { return self._s[1690]! } - public var Wallet_Configuration_Title: String { return self._s[1691]! } + public var Channel_Stickers_Searching: String { return self._s[1690]! } + public var Conversation_EncryptedDescription1: String { return self._s[1691]! } + public var Conversation_EncryptedDescription2: String { return self._s[1692]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1693]! } + public var ChatListFolder_NameUnread: String { return self._s[1695]! } + public var Conversation_EncryptedDescription3: String { return self._s[1696]! } + public var PhotoEditor_SharpenTool: String { return self._s[1697]! } + public var Wallet_Configuration_Title: String { return self._s[1698]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1692]!, self._r[1692]!, [_0]) - } - public var Conversation_EncryptedDescription4: String { return self._s[1695]! } - public var Channel_Members_AddMembers: String { return self._s[1696]! } - public var Wallpaper_Search: String { return self._s[1697]! } - public func Message_GenericForwardedPsa(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1699]!, self._r[1699]!, [_0]) } - public var Weekday_Friday: String { return self._s[1700]! } - public var Privacy_ContactsSync: String { return self._s[1701]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1702]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1703]! } + public var Conversation_EncryptedDescription4: String { return self._s[1702]! } + public var Channel_Members_AddMembers: String { return self._s[1703]! } + public var Wallpaper_Search: String { return self._s[1704]! } + public func Message_GenericForwardedPsa(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1706]!, self._r[1706]!, [_0]) + } + public var Weekday_Friday: String { return self._s[1707]! } + public var Privacy_ContactsSync: String { return self._s[1708]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1709]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1710]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1704]!, self._r[1704]!, [_0]) + return formatWithArgumentRanges(self._s[1711]!, self._r[1711]!, [_0]) } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1705]! } - public var GroupInfo_Permissions_Removed: String { return self._s[1706]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[1707]! } - public var Passport_Identity_GenderMale: String { return self._s[1708]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1712]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1713]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1714]! } + public var Passport_Identity_GenderMale: String { return self._s[1715]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1709]!, self._r[1709]!, [_0]) + return formatWithArgumentRanges(self._s[1716]!, self._r[1716]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1710]! } - public var Conversation_JumpToDate: String { return self._s[1711]! } - public var Contacts_GlobalSearch: String { return self._s[1712]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1713]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1714]! } - public var ChatListFolderSettings_NewFolder: String { return self._s[1715]! } - public var Profile_MessageLifetime1d: String { return self._s[1716]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1717]! } + public var Conversation_JumpToDate: String { return self._s[1718]! } + public var Contacts_GlobalSearch: String { return self._s[1719]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1720]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1721]! } + public var ChatListFolderSettings_NewFolder: String { return self._s[1722]! } + public var Profile_MessageLifetime1d: String { return self._s[1723]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1717]!, self._r[1717]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1724]!, self._r[1724]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1720]! } + public var StickerPack_BuiltinPackName: String { return self._s[1727]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1721]!, self._r[1721]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1728]!, self._r[1728]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1722]! } - public var Passport_InfoTitle: String { return self._s[1724]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1725]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1729]! } + public var Passport_InfoTitle: String { return self._s[1731]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1732]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1729]!, self._r[1729]!, [_0]) + return formatWithArgumentRanges(self._s[1736]!, self._r[1736]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1730]!, self._r[1730]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1737]!, self._r[1737]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1731]! } - public var Profile_BotInfo: String { return self._s[1732]! } - public var Watch_Compose_CreateMessage: String { return self._s[1733]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1734]! } - public var Month_ShortNovember: String { return self._s[1735]! } - public var Conversation_ScamWarning: String { return self._s[1736]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1737]! } - public var Appearance_TextSize_Title: String { return self._s[1738]! } - public var Conversation_ContextMenuOpenProfile: String { return self._s[1739]! } - public var ChatList_EmptyChatListFilterTitle: String { return self._s[1740]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1738]! } + public var Profile_BotInfo: String { return self._s[1739]! } + public var Watch_Compose_CreateMessage: String { return self._s[1740]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1741]! } + public var Month_ShortNovember: String { return self._s[1742]! } + public var Conversation_ScamWarning: String { return self._s[1743]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1744]! } + public var Appearance_TextSize_Title: String { return self._s[1745]! } + public var Conversation_ContextMenuOpenProfile: String { return self._s[1746]! } + public var ChatList_EmptyChatListFilterTitle: String { return self._s[1747]! } public func Call_BatteryLow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1741]!, self._r[1741]!, [_0]) + return formatWithArgumentRanges(self._s[1748]!, self._r[1748]!, [_0]) } - public var Passport_Identity_TranslationsHelp: String { return self._s[1742]! } - public var NotificationsSound_Chime: String { return self._s[1743]! } - public var Passport_Language_ko: String { return self._s[1745]! } - public var InviteText_URL: String { return self._s[1746]! } - public var TextFormat_Monospace: String { return self._s[1747]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1749]! } + public var NotificationsSound_Chime: String { return self._s[1750]! } + public var Passport_Language_ko: String { return self._s[1752]! } + public var InviteText_URL: String { return self._s[1753]! } + public var TextFormat_Monospace: String { return self._s[1754]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1748]!, self._r[1748]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1755]!, self._r[1755]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1749]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1756]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1750]!, self._r[1750]!, [_0]) + return formatWithArgumentRanges(self._s[1757]!, self._r[1757]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1751]!, self._r[1751]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1758]!, self._r[1758]!, [_1, _2]) } - public var Wallet_Words_Title: String { return self._s[1752]! } - public var Wallet_Month_ShortMay: String { return self._s[1753]! } - public var EditTheme_CreateTitle: String { return self._s[1755]! } - public var Passport_InfoLearnMore: String { return self._s[1756]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1757]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1758]! } - public var Your_card_has_expired: String { return self._s[1759]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1760]! } - public var Call_AudioRouteMute: String { return self._s[1761]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1762]! } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1766]! } - public var Conversation_Report: String { return self._s[1768]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1769]! } - public var Notification_MessageLifetime1m: String { return self._s[1770]! } - public var Privacy_ContactsTitle: String { return self._s[1771]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1772]! } - public var Wallet_WordCheck_Title: String { return self._s[1773]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1774]! } - public var Channel_Members_Title: String { return self._s[1775]! } - public var Map_OpenInWaze: String { return self._s[1776]! } - public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1777]! } - public var Stats_GroupTopWeekdaysTitle: String { return self._s[1778]! } - public var Login_PhoneBannedError: String { return self._s[1779]! } - public var PeerInfo_GroupAboutItem: String { return self._s[1780]! } + public var Wallet_Words_Title: String { return self._s[1759]! } + public var Wallet_Month_ShortMay: String { return self._s[1760]! } + public var EditTheme_CreateTitle: String { return self._s[1762]! } + public var Passport_InfoLearnMore: String { return self._s[1763]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1764]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1765]! } + public var Your_card_has_expired: String { return self._s[1766]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1767]! } + public var Call_AudioRouteMute: String { return self._s[1768]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1769]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1773]! } + public var Conversation_Report: String { return self._s[1775]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1776]! } + public var Notification_MessageLifetime1m: String { return self._s[1777]! } + public var Privacy_ContactsTitle: String { return self._s[1778]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1779]! } + public var Wallet_WordCheck_Title: String { return self._s[1780]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1781]! } + public var Channel_Members_Title: String { return self._s[1782]! } + public var Map_OpenInWaze: String { return self._s[1783]! } + public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1784]! } + public var Stats_GroupTopWeekdaysTitle: String { return self._s[1785]! } + public var Login_PhoneBannedError: String { return self._s[1786]! } + public var PeerInfo_GroupAboutItem: String { return self._s[1787]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1781]!, self._r[1781]!, [_0]) + return formatWithArgumentRanges(self._s[1788]!, self._r[1788]!, [_0]) } - public var IntentsSettings_MainAccount: String { return self._s[1782]! } - public var Group_Management_AddModeratorHelp: String { return self._s[1783]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1784]! } - public var Common_OK: String { return self._s[1785]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1786]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[1787]! } - public var Cache_Music: String { return self._s[1788]! } - public var Wallet_Configuration_SourceURL: String { return self._s[1789]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1790]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1793]! } - public var ChatList_EmptyChatListEditFilter: String { return self._s[1794]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1795]! } + public var IntentsSettings_MainAccount: String { return self._s[1789]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1790]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1791]! } + public var Common_OK: String { return self._s[1792]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1793]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1794]! } + public var Cache_Music: String { return self._s[1795]! } + public var ChatList_Search_FilterFiles: String { return self._s[1796]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1797]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1798]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1801]! } + public var ChatList_EmptyChatListEditFilter: String { return self._s[1802]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1803]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1796]!, self._r[1796]!, [_1]) + return formatWithArgumentRanges(self._s[1804]!, self._r[1804]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1797]!, self._r[1797]!, [_0]) + return formatWithArgumentRanges(self._s[1805]!, self._r[1805]!, [_0]) } - public var TwoFactorSetup_Done_Action: String { return self._s[1798]! } + public var TwoFactorSetup_Done_Action: String { return self._s[1806]! } public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1799]!, self._r[1799]!, [_0]) + return formatWithArgumentRanges(self._s[1807]!, self._r[1807]!, [_0]) } - public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1800]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1802]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1803]! } - public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1805]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1806]! } - public var State_ConnectingToProxyInfo: String { return self._s[1807]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[1808]! } - public var Message_VideoMessage: String { return self._s[1810]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1811]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1812]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1813]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1814]! } + public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1808]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1810]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1811]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1813]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1814]! } + public var State_ConnectingToProxyInfo: String { return self._s[1815]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1816]! } + public var Message_VideoMessage: String { return self._s[1818]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1819]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1820]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1821]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1822]! } public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1815]!, self._r[1815]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1823]!, self._r[1823]!, [_1, _2, _3]) } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1816]! } - public var Activity_RecordingAudio: String { return self._s[1817]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1818]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1819]! } - public var Wallet_Info_Address: String { return self._s[1820]! } - public var Notification_VideoCallCanceled: String { return self._s[1821]! } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1824]! } + public var Activity_RecordingAudio: String { return self._s[1825]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1826]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1827]! } + public var Wallet_Info_Address: String { return self._s[1828]! } + public var Notification_VideoCallCanceled: String { return self._s[1829]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1823]!, self._r[1823]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1831]!, self._r[1831]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1827]!, self._r[1827]!, [_0]) - } - public var ChatList_RemoveFolderConfirmation: String { return self._s[1828]! } - public var Conversation_ApplyLocalization: String { return self._s[1829]! } - public func Conversation_PeerNearbyDistance(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1830]!, self._r[1830]!, [_1, _2]) - } - public var TwoFactorSetup_Intro_Action: String { return self._s[1831]! } - public var UserInfo_AddPhone: String { return self._s[1833]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1834]! } - public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1835]!, self._r[1835]!, [_0]) } - public var ChatListFolder_CategoryArchived: String { return self._s[1837]! } - public var Call_IncomingVideoCall: String { return self._s[1838]! } - public var Passport_Scans: String { return self._s[1839]! } - public var BlockedUsers_Unblock: String { return self._s[1840]! } + public var ChatList_RemoveFolderConfirmation: String { return self._s[1836]! } + public var Conversation_ApplyLocalization: String { return self._s[1837]! } + public func Conversation_PeerNearbyDistance(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_1, _2]) + } + public var TwoFactorSetup_Intro_Action: String { return self._s[1839]! } + public var UserInfo_AddPhone: String { return self._s[1841]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1842]! } + public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1843]!, self._r[1843]!, [_0]) + } + public var ChatListFolder_CategoryArchived: String { return self._s[1845]! } + public var Call_IncomingVideoCall: String { return self._s[1846]! } + public var Passport_Scans: String { return self._s[1847]! } + public var BlockedUsers_Unblock: String { return self._s[1848]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1841]!, self._r[1841]!, [_1]) + return formatWithArgumentRanges(self._s[1849]!, self._r[1849]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1842]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1843]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1844]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1845]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1846]! } + public var Channel_Management_LabelCreator: String { return self._s[1850]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1851]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1852]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1853]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1854]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1847]!, self._r[1847]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1855]!, self._r[1855]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1848]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1849]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1850]! } - public var ChannelIntro_CreateChannel: String { return self._s[1851]! } - public var Conversation_UnreadMessages: String { return self._s[1852]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1853]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1854]! } - public var Theme_Context_Apply: String { return self._s[1855]! } - public var Notification_GroupActivated: String { return self._s[1856]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1857]! } - public var Wallet_Intro_CreateWallet: String { return self._s[1858]! } + public var Login_PhoneNumberHelp: String { return self._s[1856]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1857]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1858]! } + public var ChannelIntro_CreateChannel: String { return self._s[1859]! } + public var Conversation_UnreadMessages: String { return self._s[1860]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1861]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1862]! } + public var Theme_Context_Apply: String { return self._s[1863]! } + public var Notification_GroupActivated: String { return self._s[1864]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1865]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1866]! } public func Call_MicrophoneOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1859]!, self._r[1859]!, [_0]) - } - public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1860]!, self._r[1860]!, [_0]) - } - public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1861]!, self._r[1861]!, [_0, _1]) - } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1863]! } - public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1864]!, self._r[1864]!, [_0]) - } - public var Undo_DeletedChannel: String { return self._s[1865]! } - public var CallFeedback_AddComment: String { return self._s[1866]! } - public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1867]!, self._r[1867]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1868]! } + public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1868]!, self._r[1868]!, [_0]) + } + public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1869]!, self._r[1869]!, [_0, _1]) + } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1871]! } + public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1872]!, self._r[1872]!, [_0]) + } + public var Undo_DeletedChannel: String { return self._s[1873]! } + public var CallFeedback_AddComment: String { return self._s[1874]! } + public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1875]!, self._r[1875]!, [_0]) + } + public var Document_TargetConfirmationFormat: String { return self._s[1876]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1869]!, self._r[1869]!, [_0]) + return formatWithArgumentRanges(self._s[1877]!, self._r[1877]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1870]! } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1878]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1871]!, self._r[1871]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1879]!, self._r[1879]!, [_1, _2, _3, _4]) } - public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1872]! } - public var Theme_ErrorNotFound: String { return self._s[1873]! } - public var Contacts_SortByName: String { return self._s[1874]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1875]! } + public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1880]! } + public var Theme_ErrorNotFound: String { return self._s[1881]! } + public var Contacts_SortByName: String { return self._s[1882]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1883]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1878]!, self._r[1878]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1886]!, self._r[1886]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1879]! } - public var ScheduledMessages_EditTime: String { return self._s[1880]! } - public var Conversation_ClearSelfHistory: String { return self._s[1881]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1882]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1883]! } - public var Stickers_SuggestNone: String { return self._s[1884]! } - public var ChatSettings_Cache: String { return self._s[1885]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1886]! } - public var Media_ShareThisPhoto: String { return self._s[1887]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1888]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1889]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1890]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1891]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1892]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1893]! } - public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1894]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1887]! } + public var ScheduledMessages_EditTime: String { return self._s[1888]! } + public var Conversation_ClearSelfHistory: String { return self._s[1889]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1890]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1891]! } + public var Stickers_SuggestNone: String { return self._s[1892]! } + public var ChatSettings_Cache: String { return self._s[1893]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1894]! } + public var Media_ShareThisPhoto: String { return self._s[1895]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1896]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1897]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1898]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1899]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1900]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1901]! } + public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1902]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1895]!, self._r[1895]!, [_0]) + return formatWithArgumentRanges(self._s[1903]!, self._r[1903]!, [_0]) } - public var PhotoEditor_BlurToolPortrait: String { return self._s[1896]! } - public var Permissions_CellularDataTitle_v0: String { return self._s[1897]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1899]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1900]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1901]! } - public var Map_OpenIn: String { return self._s[1902]! } - public var PeerInfo_ButtonCall: String { return self._s[1903]! } + public var PhotoEditor_BlurToolPortrait: String { return self._s[1904]! } + public var ChatList_Search_FilterVideos: String { return self._s[1905]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1906]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1908]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1909]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1910]! } + public var Map_OpenIn: String { return self._s[1911]! } + public var PeerInfo_ButtonCall: String { return self._s[1912]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1907]!, self._r[1907]!, [_1]) + return formatWithArgumentRanges(self._s[1916]!, self._r[1916]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1908]!, self._r[1908]!, [_0]) + return formatWithArgumentRanges(self._s[1917]!, self._r[1917]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1909]! } - public var MessagePoll_LabelClosed: String { return self._s[1910]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1912]! } - public var Wallet_Send_SendAnyway: String { return self._s[1913]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1914]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1915]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1916]! } - public var Map_SetThisPlace: String { return self._s[1917]! } - public var Stats_GroupTopAdmin_Actions: String { return self._s[1918]! } - public var Login_SelectCountry_Title: String { return self._s[1919]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1920]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1918]! } + public var MessagePoll_LabelClosed: String { return self._s[1919]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1921]! } + public var Wallet_Send_SendAnyway: String { return self._s[1922]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1923]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1924]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1925]! } + public var Map_SetThisPlace: String { return self._s[1926]! } + public var Stats_GroupTopAdmin_Actions: String { return self._s[1927]! } + public var Login_SelectCountry_Title: String { return self._s[1928]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1929]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1921]!, self._r[1921]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1930]!, self._r[1930]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1922]! } - public var Watch_Suggestion_BRB: String { return self._s[1923]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1924]! } - public var Contacts_PermissionsTitle: String { return self._s[1925]! } - public var Conversation_RestrictedInline: String { return self._s[1926]! } - public var Appearance_RemoveThemeColor: String { return self._s[1928]! } - public var StickerPack_ViewPack: String { return self._s[1929]! } - public var Wallet_UnknownError: String { return self._s[1930]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1931]! } + public var Watch_Suggestion_BRB: String { return self._s[1932]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1933]! } + public var Contacts_PermissionsTitle: String { return self._s[1934]! } + public var Conversation_RestrictedInline: String { return self._s[1935]! } + public var Appearance_RemoveThemeColor: String { return self._s[1937]! } + public var StickerPack_ViewPack: String { return self._s[1938]! } + public var Wallet_UnknownError: String { return self._s[1939]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1931]!, self._r[1931]!, [_0]) + return formatWithArgumentRanges(self._s[1940]!, self._r[1940]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1933]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1937]! } - public var MessagePoll_LabelQuiz: String { return self._s[1939]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1940]! } - public var Channel_Info_Stickers: String { return self._s[1941]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1942]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1943]! } - public var Passport_DeletePersonalDetails: String { return self._s[1944]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1945]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1946]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1947]! } - public var Stats_LoadingText: String { return self._s[1950]! } - public var Conversation_SearchNoResults: String { return self._s[1951]! } - public var ChatList_AddFolder: String { return self._s[1952]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1953]! } - public var ChatListFolder_NameNonContacts: String { return self._s[1954]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1955]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1956]! } - public var Login_Code: String { return self._s[1957]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1958]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1959]! } - public var Weekday_ShortThursday: String { return self._s[1960]! } - public var Notification_VideoCallOutgoing: String { return self._s[1961]! } - public var Resolve_ErrorNotFound: String { return self._s[1962]! } - public var LastSeen_Offline: String { return self._s[1964]! } - public var PeopleNearby_NoMembers: String { return self._s[1965]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1966]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1967]! } - public var Conversation_Dice_u1F3AF: String { return self._s[1969]! } - public var GroupInfo_Title: String { return self._s[1970]! } - public var NotificationsSound_Note: String { return self._s[1971]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1972]! } - public var Watch_Message_Poll: String { return self._s[1973]! } - public var Privacy_Calls: String { return self._s[1974]! } + public var Compose_NewChannel: String { return self._s[1942]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1946]! } + public var MessagePoll_LabelQuiz: String { return self._s[1948]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1949]! } + public var Channel_Info_Stickers: String { return self._s[1950]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1951]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1952]! } + public var Passport_DeletePersonalDetails: String { return self._s[1953]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1954]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1955]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1956]! } + public var Stats_LoadingText: String { return self._s[1959]! } + public var Conversation_SearchNoResults: String { return self._s[1960]! } + public var ChatList_AddFolder: String { return self._s[1961]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1962]! } + public var ChatListFolder_NameNonContacts: String { return self._s[1963]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1964]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1965]! } + public var Login_Code: String { return self._s[1966]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1967]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1968]! } + public var Weekday_ShortThursday: String { return self._s[1969]! } + public var Notification_VideoCallOutgoing: String { return self._s[1970]! } + public var Resolve_ErrorNotFound: String { return self._s[1971]! } + public var LastSeen_Offline: String { return self._s[1973]! } + public var PeopleNearby_NoMembers: String { return self._s[1974]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1975]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1976]! } + public var Conversation_Dice_u1F3AF: String { return self._s[1978]! } + public var GroupInfo_Title: String { return self._s[1979]! } + public var NotificationsSound_Note: String { return self._s[1980]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1981]! } + public var Watch_Message_Poll: String { return self._s[1982]! } + public var Privacy_Calls: String { return self._s[1983]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1975]!, self._r[1975]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1984]!, self._r[1984]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1976]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1977]! } - public var Notifications_Reset: String { return self._s[1978]! } - public var Conversation_Pin: String { return self._s[1979]! } - public var Passport_Language_lv: String { return self._s[1980]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1981]! } - public var BlockedUsers_Info: String { return self._s[1982]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1984]! } - public var Watch_Conversation_Unblock: String { return self._s[1986]! } + public var Month_ShortAugust: String { return self._s[1985]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1986]! } + public var Notifications_Reset: String { return self._s[1987]! } + public var Conversation_Pin: String { return self._s[1988]! } + public var Passport_Language_lv: String { return self._s[1989]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1990]! } + public var BlockedUsers_Info: String { return self._s[1991]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1993]! } + public var Watch_Conversation_Unblock: String { return self._s[1995]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1987]!, self._r[1987]!, [_0]) + return formatWithArgumentRanges(self._s[1996]!, self._r[1996]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1988]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1989]! } + public var CloudStorage_Title: String { return self._s[1997]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1998]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1990]!, self._r[1990]!, [_0]) + return formatWithArgumentRanges(self._s[1999]!, self._r[1999]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1991]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1992]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1993]! } - public var Passport_Address_EditBankStatement: String { return self._s[1994]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[2000]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[2001]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[2002]! } + public var Passport_Address_EditBankStatement: String { return self._s[2003]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1995]!, self._r[1995]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1996]! } - public var ShareMenu_Comment: String { return self._s[1997]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1998]! } - public var Notifications_PermissionsTitle: String { return self._s[1999]! } - public var GroupPermission_NoSendLinks: String { return self._s[2000]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[2001]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[2002]! } - public var PeerInfo_PaneLinks: String { return self._s[2003]! } - public var Settings_Support: String { return self._s[2004]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[2005]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[2006]! } - public var Settings_SetNewProfilePhotoOrVideo: String { return self._s[2007]! } - public var Privacy_Forwards_Preview: String { return self._s[2008]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[2009]! } - public var Watch_Stickers_StickerPacks: String { return self._s[2010]! } - public var Common_Select: String { return self._s[2012]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[2013]! } - public var WallpaperSearch_ColorGray: String { return self._s[2016]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[2017]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[2018]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[2019]! } - public var PollResults_Title: String { return self._s[2020]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[2021]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[2022]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[2023]! } - public var Widget_AuthRequired: String { return self._s[2024]! } - public var ProfilePhoto_OpenInEditor: String { return self._s[2025]! } - public var Camera_FlashOn: String { return self._s[2026]! } - public var Conversation_ContextMenuLookUp: String { return self._s[2027]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[2028]! } - public var Watch_Suggestion_OK: String { return self._s[2029]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[2005]! } + public var ShareMenu_Comment: String { return self._s[2006]! } + public var Permissions_ContactsTitle_v0: String { return self._s[2007]! } + public var Notifications_PermissionsTitle: String { return self._s[2008]! } + public var GroupPermission_NoSendLinks: String { return self._s[2009]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[2010]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[2011]! } + public var PeerInfo_PaneLinks: String { return self._s[2012]! } + public var Settings_Support: String { return self._s[2013]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[2014]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[2015]! } + public var Settings_SetNewProfilePhotoOrVideo: String { return self._s[2016]! } + public var Privacy_Forwards_Preview: String { return self._s[2017]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[2018]! } + public var Watch_Stickers_StickerPacks: String { return self._s[2019]! } + public var Common_Select: String { return self._s[2021]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[2022]! } + public var WallpaperSearch_ColorGray: String { return self._s[2025]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[2026]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[2027]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[2028]! } + public var PollResults_Title: String { return self._s[2029]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[2030]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[2031]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[2032]! } + public var Widget_AuthRequired: String { return self._s[2033]! } + public var ProfilePhoto_OpenInEditor: String { return self._s[2034]! } + public var Camera_FlashOn: String { return self._s[2035]! } + public var Conversation_ContextMenuLookUp: String { return self._s[2036]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[2037]! } + public var Watch_Suggestion_OK: String { return self._s[2038]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2031]!, self._r[2031]!, [_0]) + return formatWithArgumentRanges(self._s[2040]!, self._r[2040]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2033]!, self._r[2033]!, [_0]) + return formatWithArgumentRanges(self._s[2042]!, self._r[2042]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[2034]! } - public var DialogList_AdLabel: String { return self._s[2035]! } - public var WatchRemote_NotificationText: String { return self._s[2036]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[2037]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[2038]! } - public var Conversation_ReportSpam: String { return self._s[2039]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[2040]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[2042]! } - public var PhoneLabel_Title: String { return self._s[2043]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[2044]! } - public var Settings_ChangePhoneNumber: String { return self._s[2045]! } - public var Notifications_ExceptionsTitle: String { return self._s[2046]! } - public var Notifications_AlertTones: String { return self._s[2047]! } - public var Call_ReportIncludeLogDescription: String { return self._s[2048]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[2049]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[2050]! } - public var VoiceOver_Chat_Photo: String { return self._s[2052]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[2053]! } - public var Stats_PostsTitle: String { return self._s[2054]! } - public var ReportPeer_ReasonOther: String { return self._s[2055]! } - public var ChatList_Context_JoinChannel: String { return self._s[2056]! } - public var PhotoEditor_SkinTool: String { return self._s[2057]! } - public var KeyCommand_ScrollDown: String { return self._s[2059]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[2060]! } + public var TextFormat_Strikethrough: String { return self._s[2043]! } + public var DialogList_AdLabel: String { return self._s[2044]! } + public var WatchRemote_NotificationText: String { return self._s[2045]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[2046]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[2047]! } + public var Conversation_ReportSpam: String { return self._s[2048]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[2049]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[2051]! } + public var PhoneLabel_Title: String { return self._s[2052]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[2053]! } + public var Settings_ChangePhoneNumber: String { return self._s[2054]! } + public var Notifications_ExceptionsTitle: String { return self._s[2055]! } + public var Notifications_AlertTones: String { return self._s[2056]! } + public var Call_ReportIncludeLogDescription: String { return self._s[2057]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[2058]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[2059]! } + public var VoiceOver_Chat_Photo: String { return self._s[2061]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[2062]! } + public var Stats_PostsTitle: String { return self._s[2063]! } + public var ReportPeer_ReasonOther: String { return self._s[2064]! } + public var ChatList_Context_JoinChannel: String { return self._s[2065]! } + public var PhotoEditor_SkinTool: String { return self._s[2066]! } + public var KeyCommand_ScrollDown: String { return self._s[2068]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[2069]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2061]!, self._r[2061]!, [_0]) + return formatWithArgumentRanges(self._s[2070]!, self._r[2070]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[2063]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[2064]! } - public var AuthSessions_LogOut: String { return self._s[2065]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[2072]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[2073]! } + public var AuthSessions_LogOut: String { return self._s[2074]! } public func PUSH_VIDEO_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2066]!, self._r[2066]!, [_1]) + return formatWithArgumentRanges(self._s[2075]!, self._r[2075]!, [_1]) } - public var Passport_Identity_TypeInternalPassport: String { return self._s[2067]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[2068]! } - public var Passport_Phone_Title: String { return self._s[2069]! } - public var ContactList_Context_StartSecretChat: String { return self._s[2070]! } - public var Settings_PhoneNumber: String { return self._s[2071]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[2076]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[2077]! } + public var Passport_Phone_Title: String { return self._s[2078]! } + public var ContactList_Context_StartSecretChat: String { return self._s[2079]! } + public var Settings_PhoneNumber: String { return self._s[2080]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2072]!, self._r[2072]!, [_0]) + return formatWithArgumentRanges(self._s[2081]!, self._r[2081]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[2074]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[2075]! } - public var WebSearch_SearchNoResults: String { return self._s[2076]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[2078]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[2079]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[2080]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[2081]! } - public var PhotoEditor_CurvesTool: String { return self._s[2082]! } - public var Checkout_PaymentMethod: String { return self._s[2084]! } + public var NotificationsSound_Alert: String { return self._s[2083]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[2084]! } + public var WebSearch_SearchNoResults: String { return self._s[2085]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[2087]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[2088]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[2089]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[2090]! } + public var PhotoEditor_CurvesTool: String { return self._s[2091]! } + public var Checkout_PaymentMethod: String { return self._s[2093]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2085]!, self._r[2085]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2094]!, self._r[2094]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[2086]! } - public var Camera_PhotoMode: String { return self._s[2089]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[2090]! } - public var Appearance_TextSize_Apply: String { return self._s[2091]! } - public var Passport_Address_AddUtilityBill: String { return self._s[2093]! } - public var ChatListFolderSettings_RecommendedNewFolder: String { return self._s[2094]! } - public var CallSettings_OnMobile: String { return self._s[2095]! } - public var Tour_Text2: String { return self._s[2096]! } + public var Contacts_AccessDeniedError: String { return self._s[2095]! } + public var Camera_PhotoMode: String { return self._s[2098]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[2099]! } + public var Appearance_TextSize_Apply: String { return self._s[2100]! } + public var Passport_Address_AddUtilityBill: String { return self._s[2102]! } + public var ChatListFolderSettings_RecommendedNewFolder: String { return self._s[2103]! } + public var CallSettings_OnMobile: String { return self._s[2104]! } + public var Tour_Text2: String { return self._s[2105]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2097]!, self._r[2097]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2106]!, self._r[2106]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[2099]! } - public var Permissions_Skip: String { return self._s[2100]! } - public var Wallet_Words_NotDoneOk: String { return self._s[2101]! } - public var SecretImage_Title: String { return self._s[2102]! } - public var Watch_MessageView_Title: String { return self._s[2103]! } - public var Channel_DiscussionGroupAdd: String { return self._s[2104]! } - public var AttachmentMenu_Poll: String { return self._s[2105]! } + public var DialogList_EncryptionProcessing: String { return self._s[2108]! } + public var Permissions_Skip: String { return self._s[2109]! } + public var Wallet_Words_NotDoneOk: String { return self._s[2110]! } + public var SecretImage_Title: String { return self._s[2111]! } + public var Watch_MessageView_Title: String { return self._s[2112]! } + public var Channel_DiscussionGroupAdd: String { return self._s[2113]! } + public var AttachmentMenu_Poll: String { return self._s[2114]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2106]!, self._r[2106]!, [_0]) + return formatWithArgumentRanges(self._s[2115]!, self._r[2115]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2107]!, self._r[2107]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2116]!, self._r[2116]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[2108]! } - public var WallpaperPreview_Title: String { return self._s[2109]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[2110]! } - public var Settings_ProxyConnecting: String { return self._s[2111]! } - public var Settings_CheckPhoneNumberText: String { return self._s[2113]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[2114]! } - public var Wallet_Intro_Title: String { return self._s[2115]! } - public var TwoFactorSetup_Password_Action: String { return self._s[2116]! } - public var Profile_MessageLifetime5s: String { return self._s[2117]! } - public var Username_InvalidCharacters: String { return self._s[2118]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[2119]! } - public var ScheduledMessages_ClearAll: String { return self._s[2120]! } - public var Group_MessageVideoUpdated: String { return self._s[2121]! } - public var WallpaperPreview_CropBottomText: String { return self._s[2122]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[2123]! } - public var Settings_AddAccount: String { return self._s[2124]! } - public var Notification_CreatedChannel: String { return self._s[2127]! } + public var Notification_CallCanceled: String { return self._s[2117]! } + public var WallpaperPreview_Title: String { return self._s[2118]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[2119]! } + public var Settings_ProxyConnecting: String { return self._s[2120]! } + public var Settings_CheckPhoneNumberText: String { return self._s[2122]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[2123]! } + public var Wallet_Intro_Title: String { return self._s[2124]! } + public var TwoFactorSetup_Password_Action: String { return self._s[2125]! } + public var Profile_MessageLifetime5s: String { return self._s[2126]! } + public var Username_InvalidCharacters: String { return self._s[2127]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[2128]! } + public var ScheduledMessages_ClearAll: String { return self._s[2129]! } + public var Group_MessageVideoUpdated: String { return self._s[2130]! } + public var WallpaperPreview_CropBottomText: String { return self._s[2131]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[2132]! } + public var Settings_AddAccount: String { return self._s[2133]! } + public var Notification_CreatedChannel: String { return self._s[2136]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2128]!, self._r[2128]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2137]!, self._r[2137]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[2130]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[2131]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[2132]! } - public var Contacts_TopSection: String { return self._s[2133]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[2134]! } + public var Passcode_AppLockedAlert: String { return self._s[2139]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[2140]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[2141]! } + public var Contacts_TopSection: String { return self._s[2142]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[2143]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2135]!, self._r[2135]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2144]!, self._r[2144]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[2136]! } - public var Wallet_Completed_ViewWallet: String { return self._s[2138]! } + public var Wallet_Info_Receive: String { return self._s[2145]! } + public var Wallet_Completed_ViewWallet: String { return self._s[2147]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2139]!, self._r[2139]!, [_0]) + return formatWithArgumentRanges(self._s[2148]!, self._r[2148]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[2140]! } - public var UserInfo_TapToCall: String { return self._s[2141]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[2143]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[2144]! } - public var Common_Search: String { return self._s[2145]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2146]! } + public var ReportPeer_ReasonSpam: String { return self._s[2149]! } + public var UserInfo_TapToCall: String { return self._s[2150]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[2152]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[2153]! } + public var Common_Search: String { return self._s[2154]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2155]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2147]!, self._r[2147]!, [_0]) + return formatWithArgumentRanges(self._s[2156]!, self._r[2156]!, [_0]) } - public var Wallet_Month_ShortJuly: String { return self._s[2148]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2150]! } - public var Message_InvoiceLabel: String { return self._s[2151]! } - public var Conversation_InputTextPlaceholder: String { return self._s[2152]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2153]! } + public var Wallet_Month_ShortJuly: String { return self._s[2157]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2159]! } + public var Message_InvoiceLabel: String { return self._s[2160]! } + public var Conversation_InputTextPlaceholder: String { return self._s[2161]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2162]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2154]!, self._r[2154]!, [_0]) + return formatWithArgumentRanges(self._s[2163]!, self._r[2163]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[2155]! } - public var Conversation_Info: String { return self._s[2156]! } - public var Login_InfoDeletePhoto: String { return self._s[2157]! } - public var ChatListFolder_DiscardDiscard: String { return self._s[2159]! } - public var Passport_Language_vi: String { return self._s[2160]! } - public var UserInfo_ScamUserWarning: String { return self._s[2161]! } - public var Conversation_Search: String { return self._s[2162]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2164]! } - public var ChatListFolder_NameGroups: String { return self._s[2165]! } - public var ReportPeer_ReasonPornography: String { return self._s[2166]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[2167]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2168]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2169]! } - public var Channel_Setup_TypeHeader: String { return self._s[2170]! } - public var AuthSessions_LoggedIn: String { return self._s[2171]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2172]! } - public var Login_SmsRequestState3: String { return self._s[2173]! } - public var Passport_Address_EditUtilityBill: String { return self._s[2174]! } - public var Appearance_ReduceMotionInfo: String { return self._s[2175]! } - public var Join_ChannelsTooMuch: String { return self._s[2176]! } - public var Channel_Edit_LinkItem: String { return self._s[2177]! } - public var Privacy_Calls_P2PNever: String { return self._s[2178]! } - public var Conversation_AddToReadingList: String { return self._s[2180]! } - public var Share_MultipleMessagesDisabled: String { return self._s[2181]! } - public var Message_Animation: String { return self._s[2182]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[2183]! } - public var Map_Unknown: String { return self._s[2184]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[2185]! } + public var IntentsSettings_Reset: String { return self._s[2164]! } + public var Conversation_Info: String { return self._s[2165]! } + public var Login_InfoDeletePhoto: String { return self._s[2166]! } + public var ChatListFolder_DiscardDiscard: String { return self._s[2168]! } + public var Passport_Language_vi: String { return self._s[2169]! } + public var UserInfo_ScamUserWarning: String { return self._s[2170]! } + public var Conversation_Search: String { return self._s[2171]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2173]! } + public var ChatListFolder_NameGroups: String { return self._s[2174]! } + public var ReportPeer_ReasonPornography: String { return self._s[2175]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[2176]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2177]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2178]! } + public var Channel_Setup_TypeHeader: String { return self._s[2179]! } + public var AuthSessions_LoggedIn: String { return self._s[2180]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2181]! } + public var Login_SmsRequestState3: String { return self._s[2182]! } + public var Passport_Address_EditUtilityBill: String { return self._s[2183]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2184]! } + public var Join_ChannelsTooMuch: String { return self._s[2185]! } + public var Channel_Edit_LinkItem: String { return self._s[2186]! } + public var Privacy_Calls_P2PNever: String { return self._s[2187]! } + public var Conversation_AddToReadingList: String { return self._s[2189]! } + public var Share_MultipleMessagesDisabled: String { return self._s[2190]! } + public var Message_Animation: String { return self._s[2191]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[2192]! } + public var Map_Unknown: String { return self._s[2193]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[2194]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2186]!, self._r[2186]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2195]!, self._r[2195]!, [_1, _2]) } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2187]!, self._r[2187]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2196]!, self._r[2196]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[2188]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[2189]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2190]! } - public var Stats_MessageInteractionsTitle: String { return self._s[2191]! } + public var Call_StatusRequesting: String { return self._s[2197]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[2198]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2199]! } + public var Stats_MessageInteractionsTitle: String { return self._s[2200]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2192]!, self._r[2192]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2201]!, self._r[2201]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2193]!, self._r[2193]!, [_0]) + return formatWithArgumentRanges(self._s[2202]!, self._r[2202]!, [_0]) } - public var Update_Skip: String { return self._s[2194]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2195]! } - public var BlockedUsers_Title: String { return self._s[2196]! } - public var Weekday_Monday: String { return self._s[2197]! } + public var Update_Skip: String { return self._s[2203]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2204]! } + public var BlockedUsers_Title: String { return self._s[2205]! } + public var Weekday_Monday: String { return self._s[2206]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2198]!, self._r[2198]!, [_1]) + return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[2199]! } - public var NotificationsSound_Bell: String { return self._s[2200]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[2201]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2202]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2203]! } + public var Username_CheckingUsername: String { return self._s[2208]! } + public var NotificationsSound_Bell: String { return self._s[2209]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[2210]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2211]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2212]! } public func Notification_ChangedGroupVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2204]!, self._r[2204]!, [_0]) + return formatWithArgumentRanges(self._s[2213]!, self._r[2213]!, [_0]) } - public var ChatSettings_Groups: String { return self._s[2205]! } - public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2206]! } - public var ChatList_PeerTypeContact: String { return self._s[2207]! } + public var ChatSettings_Groups: String { return self._s[2214]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2215]! } + public var ChatList_PeerTypeContact: String { return self._s[2216]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2208]!, self._r[2208]!, [_0]) + return formatWithArgumentRanges(self._s[2217]!, self._r[2217]!, [_0]) } - public var Your_card_was_declined: String { return self._s[2209]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2211]! } - public var Wallet_Month_ShortApril: String { return self._s[2212]! } - public var ChatList_Unmute: String { return self._s[2213]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2214]! } - public var PhotoEditor_CurvesAll: String { return self._s[2215]! } - public var Weekday_ShortTuesday: String { return self._s[2216]! } - public var DialogList_Read: String { return self._s[2217]! } - public var Appearance_AppIconClassic: String { return self._s[2218]! } - public var Conversation_Dice_u1F3B2: String { return self._s[2219]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2220]! } - public var Passport_Identity_Gender: String { return self._s[2221]! } + public var Your_card_was_declined: String { return self._s[2218]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2220]! } + public var Wallet_Month_ShortApril: String { return self._s[2221]! } + public var ChatList_Unmute: String { return self._s[2222]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2223]! } + public var PhotoEditor_CurvesAll: String { return self._s[2224]! } + public var Weekday_ShortTuesday: String { return self._s[2225]! } + public var DialogList_Read: String { return self._s[2226]! } + public var Appearance_AppIconClassic: String { return self._s[2227]! } + public var Conversation_Dice_u1F3B2: String { return self._s[2228]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2229]! } + public var Passport_Identity_Gender: String { return self._s[2230]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2222]!, self._r[2222]!, [_0]) + return formatWithArgumentRanges(self._s[2231]!, self._r[2231]!, [_0]) } - public var Target_SelectGroup: String { return self._s[2223]! } - public var Map_HomeAndWorkInfo: String { return self._s[2225]! } + public var Target_SelectGroup: String { return self._s[2232]! } + public var Map_HomeAndWorkInfo: String { return self._s[2234]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2226]!, self._r[2226]!, [_0]) + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_0]) } - public var Passport_Language_en: String { return self._s[2227]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2228]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2229]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[2230]! } - public var ScheduledMessages_SendNow: String { return self._s[2231]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[2233]! } - public var Login_InfoHelp: String { return self._s[2234]! } - public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2235]! } - public var ProfilePhoto_SetMainPhoto: String { return self._s[2236]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2237]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2238]! } + public var Passport_Language_en: String { return self._s[2236]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2237]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2238]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2239]! } + public var ScheduledMessages_SendNow: String { return self._s[2240]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2242]! } + public var Login_InfoHelp: String { return self._s[2243]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2244]! } + public var ProfilePhoto_SetMainPhoto: String { return self._s[2245]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2246]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2247]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2239]!, self._r[2239]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2248]!, self._r[2248]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2242]! } - public var CreatePoll_Title: String { return self._s[2243]! } - public var MessagePoll_QuizNoUsers: String { return self._s[2244]! } - public var Conversation_ViewTheme: String { return self._s[2245]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2246]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2247]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2248]! } - public var UserInfo_GroupsInCommon: String { return self._s[2249]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2250]! } - public var Stats_ViewsByHoursTitle: String { return self._s[2251]! } - public var Conversation_PrivateChannelTimeLimitedAlertTitle: String { return self._s[2252]! } - public var Call_AudioRouteHide: String { return self._s[2253]! } + public var SocksProxySetup_AddProxy: String { return self._s[2251]! } + public var CreatePoll_Title: String { return self._s[2252]! } + public var MessagePoll_QuizNoUsers: String { return self._s[2253]! } + public var Conversation_ViewTheme: String { return self._s[2254]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2255]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2256]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2257]! } + public var UserInfo_GroupsInCommon: String { return self._s[2258]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2259]! } + public var Stats_ViewsByHoursTitle: String { return self._s[2260]! } + public var Conversation_PrivateChannelTimeLimitedAlertTitle: String { return self._s[2261]! } + public var Call_AudioRouteHide: String { return self._s[2262]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2264]!, self._r[2264]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2256]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2257]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[2258]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2265]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2266]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[2267]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2259]!, self._r[2259]!, [_0]) + return formatWithArgumentRanges(self._s[2268]!, self._r[2268]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2260]! } - public var CreatePoll_ExplanationInfo: String { return self._s[2261]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2262]! } - public var StickerPackActionInfo_AddedTitle: String { return self._s[2263]! } - public var Notifications_Title: String { return self._s[2264]! } - public var Group_Username_InvalidTooShort: String { return self._s[2265]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2266]! } + public var TextFormat_Bold: String { return self._s[2269]! } + public var CreatePoll_ExplanationInfo: String { return self._s[2270]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2271]! } + public var StickerPackActionInfo_AddedTitle: String { return self._s[2272]! } + public var Notifications_Title: String { return self._s[2273]! } + public var Group_Username_InvalidTooShort: String { return self._s[2274]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2275]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2267]!, self._r[2267]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2276]!, self._r[2276]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2269]! } - public var Stickers_SuggestAdded: String { return self._s[2270]! } - public var Login_CountryCode: String { return self._s[2271]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2272]! } - public var Map_GetDirections: String { return self._s[2273]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2274]! } - public var Stats_GroupNewMembersBySourceTitle: String { return self._s[2275]! } - public var Login_PhoneFloodError: String { return self._s[2276]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2278]! } + public var Stickers_SuggestAdded: String { return self._s[2279]! } + public var Login_CountryCode: String { return self._s[2280]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2281]! } + public var Map_GetDirections: String { return self._s[2282]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2283]! } + public var Stats_GroupNewMembersBySourceTitle: String { return self._s[2284]! } + public var Login_PhoneFloodError: String { return self._s[2285]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2277]!, self._r[2277]!, [_0]) + return formatWithArgumentRanges(self._s[2286]!, self._r[2286]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2278]!, self._r[2278]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2287]!, self._r[2287]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2279]! } - public var Settings_SetUsername: String { return self._s[2281]! } - public var Group_Location_ChangeLocation: String { return self._s[2282]! } - public var Notification_GroupInviterSelf: String { return self._s[2283]! } - public var InstantPage_TapToOpenLink: String { return self._s[2284]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2288]! } + public var Settings_SetUsername: String { return self._s[2290]! } + public var Group_Location_ChangeLocation: String { return self._s[2291]! } + public var Notification_GroupInviterSelf: String { return self._s[2292]! } + public var InstantPage_TapToOpenLink: String { return self._s[2293]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2285]!, self._r[2285]!, [_0]) + return formatWithArgumentRanges(self._s[2294]!, self._r[2294]!, [_0]) } - public var PrivacySettings_AutoArchiveInfo: String { return self._s[2286]! } - public var Watch_Suggestion_TalkLater: String { return self._s[2287]! } - public var SecretChat_Title: String { return self._s[2288]! } - public var Group_UpgradeNoticeText1: String { return self._s[2289]! } - public var AuthSessions_Title: String { return self._s[2290]! } + public var PrivacySettings_AutoArchiveInfo: String { return self._s[2295]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2296]! } + public var SecretChat_Title: String { return self._s[2297]! } + public var Group_UpgradeNoticeText1: String { return self._s[2298]! } + public var AuthSessions_Title: String { return self._s[2299]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2291]!, self._r[2291]!, [_0]) + return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2292]! } - public var Channel_About_Title: String { return self._s[2294]! } - public var Theme_ThemeChanged: String { return self._s[2295]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2296]! } + public var PhotoEditor_CropAuto: String { return self._s[2301]! } + public var Channel_About_Title: String { return self._s[2303]! } + public var Theme_ThemeChanged: String { return self._s[2304]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2305]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2299]!, self._r[2299]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2308]!, self._r[2308]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2300]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2302]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2303]! } + public var VoiceOver_MessageContextReport: String { return self._s[2309]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2311]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2312]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2304]!, self._r[2304]!, [_1]) + return formatWithArgumentRanges(self._s[2313]!, self._r[2313]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2306]!, self._r[2306]!, [_0]) + return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2307]!, self._r[2307]!, [_0]) + return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2308]! } - public var PeopleNearby_DiscoverDescription: String { return self._s[2310]! } - public var Presence_online: String { return self._s[2312]! } - public var PasscodeSettings_Title: String { return self._s[2313]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2314]! } - public var Web_OpenExternal: String { return self._s[2315]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2317]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2318]! } - public var LocalGroup_Title: String { return self._s[2319]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2317]! } + public var PeopleNearby_DiscoverDescription: String { return self._s[2319]! } + public var Presence_online: String { return self._s[2321]! } + public var PasscodeSettings_Title: String { return self._s[2322]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2323]! } + public var Web_OpenExternal: String { return self._s[2324]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2326]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2327]! } + public var LocalGroup_Title: String { return self._s[2328]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2320]!, self._r[2320]!, [_0]) - } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2321]! } - public var Conversation_StopQuizConfirmation: String { return self._s[2322]! } - public var Map_YouAreHere: String { return self._s[2323]! } - public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_0]) - } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_0]) - } - public var Theme_Context_ChangeColors: String { return self._s[2326]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2327]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2328]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2329]!, self._r[2329]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2330]!, self._r[2330]!, [_0]) - } - public var SocksProxySetup_Username: String { return self._s[2331]! } - public var Bot_Start: String { return self._s[2332]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2330]! } + public var Conversation_StopQuizConfirmation: String { return self._s[2331]! } + public var Map_YouAreHere: String { return self._s[2332]! } + public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2333]!, self._r[2333]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2334]!, self._r[2334]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[2335]! } - public var AccentColor_Title: String { return self._s[2338]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2339]! } + public var Theme_Context_ChangeColors: String { return self._s[2335]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2336]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2337]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2338]!, self._r[2338]!, [_0]) + } + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2339]!, self._r[2339]!, [_0]) + } + public var SocksProxySetup_Username: String { return self._s[2340]! } + public var Bot_Start: String { return self._s[2341]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2342]!, self._r[2342]!, [_0]) + } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2343]!, self._r[2343]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[2344]! } + public var AccentColor_Title: String { return self._s[2347]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2348]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2340]!, self._r[2340]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2341]!, self._r[2341]!, [_0]) + return formatWithArgumentRanges(self._s[2350]!, self._r[2350]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2342]!, self._r[2342]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2351]!, self._r[2351]!, [_1, _2]) } - public var Stats_GroupOverview: String { return self._s[2343]! } - public var Passport_Email_EnterOtherEmail: String { return self._s[2344]! } - public var Login_InfoAvatarPhoto: String { return self._s[2345]! } + public var Stats_GroupOverview: String { return self._s[2352]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[2353]! } + public var Login_InfoAvatarPhoto: String { return self._s[2354]! } public func ChatList_RemovedFromFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2346]!, self._r[2346]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2355]!, self._r[2355]!, [_1, _2]) } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2347]! } - public var Tour_Title4: String { return self._s[2348]! } - public var Passport_Identity_Translation: String { return self._s[2349]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2350]! } - public var Login_TermsOfServiceLabel: String { return self._s[2352]! } - public var CallFeedback_VideoReasonLowQuality: String { return self._s[2353]! } - public var Passport_Language_it: String { return self._s[2354]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2355]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2356]! } - public var Conversation_ClearAll: String { return self._s[2358]! } - public var Wallet_Send_UninitializedText: String { return self._s[2360]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2361]! } - public var TwoStepAuth_FloodError: String { return self._s[2362]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2356]! } + public var Tour_Title4: String { return self._s[2357]! } + public var Passport_Identity_Translation: String { return self._s[2358]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2359]! } + public var Login_TermsOfServiceLabel: String { return self._s[2361]! } + public var CallFeedback_VideoReasonLowQuality: String { return self._s[2362]! } + public var Passport_Language_it: String { return self._s[2363]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2364]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2365]! } + public var Conversation_ClearAll: String { return self._s[2367]! } + public var Wallet_Send_UninitializedText: String { return self._s[2369]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2370]! } + public var TwoStepAuth_FloodError: String { return self._s[2371]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2363]!, self._r[2363]!, [_1]) + return formatWithArgumentRanges(self._s[2372]!, self._r[2372]!, [_1]) } - public var Paint_Delete: String { return self._s[2364]! } + public var Paint_Delete: String { return self._s[2373]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2365]!, self._r[2365]!, [_0]) + return formatWithArgumentRanges(self._s[2374]!, self._r[2374]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2366]! } + public var Privacy_AddNewPeer: String { return self._s[2375]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2367]!, self._r[2367]!, [_1]) + return formatWithArgumentRanges(self._s[2376]!, self._r[2376]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2368]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2377]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2369]!, self._r[2369]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2378]!, self._r[2378]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2370]! } + public var Message_PinnedAudioMessage: String { return self._s[2379]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2371]!, self._r[2371]!, [_0]) + return formatWithArgumentRanges(self._s[2380]!, self._r[2380]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2372]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2373]! } - public var Wallet_Month_GenNovember: String { return self._s[2374]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2376]! } - public var Conversation_MessageEditedLabel: String { return self._s[2377]! } + public var Notification_Mute1hMin: String { return self._s[2381]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2382]! } + public var Wallet_Month_GenNovember: String { return self._s[2383]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2385]! } + public var Conversation_MessageEditedLabel: String { return self._s[2386]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2378]!, self._r[2378]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2387]!, self._r[2387]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2379]! } - public var Conversation_ContextMenuOpenChannelProfile: String { return self._s[2380]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2381]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2388]! } + public var Conversation_ContextMenuOpenChannelProfile: String { return self._s[2389]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2390]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2382]!, self._r[2382]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2391]!, self._r[2391]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2383]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2392]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2384]!, self._r[2384]!, [_1]) + return formatWithArgumentRanges(self._s[2393]!, self._r[2393]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2385]! } - public var Month_GenOctober: String { return self._s[2386]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2387]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2388]! } - public var Call_CameraConfirmationConfirm: String { return self._s[2390]! } - public var MediaPicker_TimerTooltip: String { return self._s[2391]! } - public var SharedMedia_TitleAll: String { return self._s[2392]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2395]! } - public var Conversation_RestrictedMedia: String { return self._s[2396]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2397]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2399]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2400]! } + public var AccessDenied_LocationTracking: String { return self._s[2394]! } + public var Month_GenOctober: String { return self._s[2395]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2396]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2397]! } + public var Call_CameraConfirmationConfirm: String { return self._s[2399]! } + public var MediaPicker_TimerTooltip: String { return self._s[2400]! } + public var SharedMedia_TitleAll: String { return self._s[2401]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2404]! } + public var Conversation_RestrictedMedia: String { return self._s[2405]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2406]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2408]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2409]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2401]!, self._r[2401]!, [_0]) + return formatWithArgumentRanges(self._s[2410]!, self._r[2410]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2404]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2406]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2407]! } + public var Conversation_SavedMessages: String { return self._s[2413]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2415]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2416]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2409]!, self._r[2409]!, [_0]) + return formatWithArgumentRanges(self._s[2418]!, self._r[2418]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2410]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2419]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2411]!, self._r[2411]!, [_0]) - } - public var ReportPeer_AlertSuccess: String { return self._s[2412]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2413]! } - public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2414]!, self._r[2414]!, [_1, _2]) - } - public var Checkout_PasswordEntry_Title: String { return self._s[2415]! } - public var PhotoEditor_FadeTool: String { return self._s[2416]! } - public var Privacy_ContactsReset: String { return self._s[2417]! } - public var Conversation_PrivateChannelTimeLimitedAlertText: String { return self._s[2418]! } - public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2420]!, self._r[2420]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2421]! } - public var ChatList_Mute: String { return self._s[2422]! } + public var ReportPeer_AlertSuccess: String { return self._s[2421]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2422]! } + public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2423]!, self._r[2423]!, [_1, _2]) + } + public var Checkout_PasswordEntry_Title: String { return self._s[2424]! } + public var PhotoEditor_FadeTool: String { return self._s[2425]! } + public var Privacy_ContactsReset: String { return self._s[2426]! } + public var Conversation_PrivateChannelTimeLimitedAlertText: String { return self._s[2427]! } + public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2429]!, self._r[2429]!, [_0]) + } + public var Message_PinnedVideoMessage: String { return self._s[2430]! } + public var ChatList_Mute: String { return self._s[2431]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2423]!, self._r[2423]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2432]!, self._r[2432]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2424]! } - public var Conversation_PinnedQuiz: String { return self._s[2426]! } - public var ShareMenu_SelectChats: String { return self._s[2428]! } - public var ChatList_Context_Unarchive: String { return self._s[2429]! } - public var MusicPlayer_VoiceNote: String { return self._s[2430]! } - public var Conversation_RestrictedText: String { return self._s[2431]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2432]! } - public var Wallet_Month_GenApril: String { return self._s[2433]! } - public var Wallet_Month_ShortMarch: String { return self._s[2434]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2435]! } - public var Chat_PsaTooltip_covid: String { return self._s[2436]! } - public var Cache_Videos: String { return self._s[2437]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2438]! } - public var Wallet_Month_GenFebruary: String { return self._s[2439]! } - public var FeatureDisabled_Oops: String { return self._s[2441]! } - public var ChatList_RemoveFolderAction: String { return self._s[2442]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2443]! } + public var Permissions_CellularDataText_v0: String { return self._s[2433]! } + public var Conversation_PinnedQuiz: String { return self._s[2435]! } + public var ShareMenu_SelectChats: String { return self._s[2437]! } + public var ChatList_Context_Unarchive: String { return self._s[2438]! } + public var MusicPlayer_VoiceNote: String { return self._s[2439]! } + public var Conversation_RestrictedText: String { return self._s[2440]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2441]! } + public var Wallet_Month_GenApril: String { return self._s[2442]! } + public var Wallet_Month_ShortMarch: String { return self._s[2443]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2444]! } + public var Chat_PsaTooltip_covid: String { return self._s[2445]! } + public var Cache_Videos: String { return self._s[2446]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2447]! } + public var Wallet_Month_GenFebruary: String { return self._s[2448]! } + public var FeatureDisabled_Oops: String { return self._s[2450]! } + public var ChatList_RemoveFolderAction: String { return self._s[2451]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2452]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2444]!, self._r[2444]!, [_0]) + return formatWithArgumentRanges(self._s[2453]!, self._r[2453]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2446]! } - public var GroupPermission_NoSendPolls: String { return self._s[2447]! } - public var Wallet_Qr_ScanCode: String { return self._s[2448]! } - public var Message_VideoExpired: String { return self._s[2450]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2451]! } - public var Notifications_Badge: String { return self._s[2452]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2453]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2454]! } - public var Username_InvalidTooShort: String { return self._s[2455]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2456]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2457]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2458]! } + public var Stickers_GroupStickersHelp: String { return self._s[2455]! } + public var GroupPermission_NoSendPolls: String { return self._s[2456]! } + public var Wallet_Qr_ScanCode: String { return self._s[2457]! } + public var Message_VideoExpired: String { return self._s[2459]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2460]! } + public var Notifications_Badge: String { return self._s[2461]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2462]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2463]! } + public var Username_InvalidTooShort: String { return self._s[2464]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2465]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2466]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2467]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2459]!, self._r[2459]!, [_1]) + return formatWithArgumentRanges(self._s[2468]!, self._r[2468]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2460]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2461]! } - public var SharedMedia_CategoryDocs: String { return self._s[2464]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2469]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2470]! } + public var SharedMedia_CategoryDocs: String { return self._s[2473]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2465]!, self._r[2465]!, [_1]) + return formatWithArgumentRanges(self._s[2474]!, self._r[2474]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2466]! } - public var CallFeedback_VideoReasonDistorted: String { return self._s[2467]! } - public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2468]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2470]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2475]! } + public var CallFeedback_VideoReasonDistorted: String { return self._s[2476]! } + public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2477]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2479]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2471]!, self._r[2471]!, [_1]) + return formatWithArgumentRanges(self._s[2480]!, self._r[2480]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2472]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2481]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2473]!, self._r[2473]!, [_0]) + return formatWithArgumentRanges(self._s[2482]!, self._r[2482]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2474]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2475]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2476]! } - public var Channel_UpdatePhotoItem: String { return self._s[2477]! } - public var GroupInfo_LeftStatus: String { return self._s[2478]! } - public var Watch_MessageView_Forward: String { return self._s[2480]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2481]! } - public var Cache_ClearEmpty: String { return self._s[2483]! } - public var Localization_LanguageName: String { return self._s[2485]! } - public var Wallet_AccessDenied_Title: String { return self._s[2486]! } - public var WebSearch_GIFs: String { return self._s[2487]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2488]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2489]! } - public var AccessDenied_VideoCallCamera: String { return self._s[2490]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2491]! } - public var Common_Back: String { return self._s[2492]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2493]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2494]! } - public var Wallet_Send_Send: String { return self._s[2495]! } + public var ChatSettings_PrivateChats: String { return self._s[2483]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2484]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2485]! } + public var Channel_UpdatePhotoItem: String { return self._s[2486]! } + public var GroupInfo_LeftStatus: String { return self._s[2487]! } + public var Watch_MessageView_Forward: String { return self._s[2489]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2490]! } + public var Cache_ClearEmpty: String { return self._s[2492]! } + public var Localization_LanguageName: String { return self._s[2494]! } + public var Wallet_AccessDenied_Title: String { return self._s[2495]! } + public var WebSearch_GIFs: String { return self._s[2496]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2497]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2498]! } + public var AccessDenied_VideoCallCamera: String { return self._s[2499]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2500]! } + public var Common_Back: String { return self._s[2501]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2502]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2503]! } + public var Wallet_Send_Send: String { return self._s[2504]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2497]!, self._r[2497]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2506]!, self._r[2506]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2498]! } - public var ChatList_Tabs_All: String { return self._s[2499]! } - public var Wallet_Month_GenJune: String { return self._s[2500]! } - public var Passport_Email_Help: String { return self._s[2501]! } - public var Watch_Conversation_Reply: String { return self._s[2503]! } - public var Stats_GroupTopInvitersTitle: String { return self._s[2504]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2507]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2508]! } - public var Channel_BanUser_Unban: String { return self._s[2510]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2511]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2512]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2514]! } - public var Wallet_Send_AddressHeader: String { return self._s[2515]! } - public var Passport_Identity_Name: String { return self._s[2516]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2507]! } + public var ChatList_Tabs_All: String { return self._s[2508]! } + public var Wallet_Month_GenJune: String { return self._s[2509]! } + public var Passport_Email_Help: String { return self._s[2510]! } + public var Watch_Conversation_Reply: String { return self._s[2512]! } + public var Stats_GroupTopInvitersTitle: String { return self._s[2513]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2516]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2517]! } + public var Channel_BanUser_Unban: String { return self._s[2519]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2520]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2521]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2523]! } + public var Wallet_Send_AddressHeader: String { return self._s[2524]! } + public var Passport_Identity_Name: String { return self._s[2525]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2517]!, self._r[2517]!, [_0]) + return formatWithArgumentRanges(self._s[2526]!, self._r[2526]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2518]! } - public var Stats_MessageOverview: String { return self._s[2519]! } - public var Conversation_BlockUser: String { return self._s[2520]! } - public var Month_GenJanuary: String { return self._s[2521]! } - public var ChatSettings_TextSize: String { return self._s[2522]! } - public var Notification_PassportValuePhone: String { return self._s[2523]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2524]! } - public var Passport_Language_ne: String { return self._s[2525]! } - public var Notification_CallBack: String { return self._s[2526]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2527]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2528]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2527]! } + public var Stats_MessageOverview: String { return self._s[2528]! } + public var Conversation_BlockUser: String { return self._s[2529]! } + public var Month_GenJanuary: String { return self._s[2530]! } + public var ChatSettings_TextSize: String { return self._s[2531]! } + public var Notification_PassportValuePhone: String { return self._s[2532]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2533]! } + public var Passport_Language_ne: String { return self._s[2534]! } + public var Notification_CallBack: String { return self._s[2535]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2536]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2537]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2529]!, self._r[2529]!, [_0]) + return formatWithArgumentRanges(self._s[2538]!, self._r[2538]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2530]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2531]! } - public var Stickers_FrequentlyUsed: String { return self._s[2533]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2534]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2536]! } + public var Channel_Info_Management: String { return self._s[2539]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2540]! } + public var Stickers_FrequentlyUsed: String { return self._s[2542]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2543]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2545]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2537]!, self._r[2537]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2546]!, self._r[2546]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2538]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2539]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2540]! } - public var CreatePoll_TextHeader: String { return self._s[2541]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2547]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2548]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2549]! } + public var CreatePoll_TextHeader: String { return self._s[2550]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2542]!, self._r[2542]!, [_0]) + return formatWithArgumentRanges(self._s[2551]!, self._r[2551]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2543]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2544]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2546]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2547]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2548]! } + public var PhotoEditor_QualityMedium: String { return self._s[2552]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2553]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2555]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2556]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2557]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_0]) + return formatWithArgumentRanges(self._s[2558]!, self._r[2558]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2550]!, self._r[2550]!, [_1]) + return formatWithArgumentRanges(self._s[2559]!, self._r[2559]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2551]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2552]! } - public var Conversation_LinkDialogOpen: String { return self._s[2554]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2555]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2556]! } - public var Settings_Username: String { return self._s[2558]! } - public var Conversation_Block: String { return self._s[2560]! } - public var Wallpaper_Wallpaper: String { return self._s[2561]! } - public var SocksProxySetup_UseProxy: String { return self._s[2563]! } - public var Wallet_Send_Confirmation: String { return self._s[2564]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2565]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2566]! } - public var MessageTimer_Forever: String { return self._s[2567]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2568]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2569]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2570]! } - public var Passport_Language_da: String { return self._s[2571]! } - public var Conversation_PrivateChannelTimeLimitedAlertJoin: String { return self._s[2573]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2574]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2560]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2561]! } + public var Conversation_LinkDialogOpen: String { return self._s[2563]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2564]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2565]! } + public var Settings_Username: String { return self._s[2567]! } + public var Conversation_Block: String { return self._s[2569]! } + public var Wallpaper_Wallpaper: String { return self._s[2570]! } + public var SocksProxySetup_UseProxy: String { return self._s[2572]! } + public var Wallet_Send_Confirmation: String { return self._s[2573]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2574]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2575]! } + public var MessageTimer_Forever: String { return self._s[2576]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2577]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2578]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2579]! } + public var Passport_Language_da: String { return self._s[2580]! } + public var Conversation_PrivateChannelTimeLimitedAlertJoin: String { return self._s[2582]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2583]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2575]!, self._r[2575]!, [_0]) + return formatWithArgumentRanges(self._s[2584]!, self._r[2584]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2576]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2585]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2578]!, self._r[2578]!, [_0]) + return formatWithArgumentRanges(self._s[2587]!, self._r[2587]!, [_0]) } - public var Settings_AddDevice: String { return self._s[2579]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2581]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2582]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2583]! } - public var Conversation_PinnedPoll: String { return self._s[2584]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2585]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2586]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2587]! } + public var Settings_AddDevice: String { return self._s[2588]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2590]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2591]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2592]! } + public var Conversation_PinnedPoll: String { return self._s[2593]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2594]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2595]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2596]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2588]!, self._r[2588]!, [_1]) + return formatWithArgumentRanges(self._s[2597]!, self._r[2597]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2589]! } - public var Cache_ByPeerHeader: String { return self._s[2590]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2598]! } + public var Cache_ByPeerHeader: String { return self._s[2599]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2591]!, self._r[2591]!, [_0]) + return formatWithArgumentRanges(self._s[2600]!, self._r[2600]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2592]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2595]! } - public var Wallet_Completed_Title: String { return self._s[2596]! } - public var Notification_PinnedMessage: String { return self._s[2597]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2598]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2600]! } - public var Contacts_SortBy: String { return self._s[2601]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2601]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2604]! } + public var Wallet_Completed_Title: String { return self._s[2605]! } + public var Notification_PinnedMessage: String { return self._s[2606]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2607]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2609]! } + public var Contacts_SortBy: String { return self._s[2610]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2602]!, self._r[2602]!, [_1]) + return formatWithArgumentRanges(self._s[2611]!, self._r[2611]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2604]! } + public var Appearance_ColorThemeNight: String { return self._s[2613]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2605]!, self._r[2605]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2614]!, self._r[2614]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2606]! } - public var Watch_UserInfo_Service: String { return self._s[2607]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2609]! } - public var Conversation_Unpin: String { return self._s[2611]! } - public var CancelResetAccount_Title: String { return self._s[2612]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2613]! } + public var Call_EncryptionKey_Title: String { return self._s[2615]! } + public var Watch_UserInfo_Service: String { return self._s[2616]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2618]! } + public var Conversation_Unpin: String { return self._s[2620]! } + public var CancelResetAccount_Title: String { return self._s[2621]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2622]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2615]!, self._r[2615]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2624]!, self._r[2624]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2616]! } - public var Appearance_BubbleCorners_Title: String { return self._s[2617]! } - public var CallSettings_Title: String { return self._s[2618]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2619]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2621]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2622]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2625]! } + public var Appearance_BubbleCorners_Title: String { return self._s[2626]! } + public var CallSettings_Title: String { return self._s[2627]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2628]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2630]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2631]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2623]!, self._r[2623]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_1, _2]) } - public var ChatList_Tabs_AllChats: String { return self._s[2624]! } - public var Passport_Identity_DocumentDetails: String { return self._s[2625]! } - public var LoginPassword_PasswordHelp: String { return self._s[2626]! } - public var ChatListFolderSettings_Info: String { return self._s[2627]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2628]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2629]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2630]! } - public var ChatListFolder_CategoryGroups: String { return self._s[2631]! } - public var Checkout_TotalPaidAmount: String { return self._s[2633]! } + public var ChatList_Tabs_AllChats: String { return self._s[2633]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2634]! } + public var LoginPassword_PasswordHelp: String { return self._s[2635]! } + public var ChatListFolderSettings_Info: String { return self._s[2636]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2637]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2638]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2639]! } + public var ChatListFolder_CategoryGroups: String { return self._s[2640]! } + public var Checkout_TotalPaidAmount: String { return self._s[2642]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2634]!, self._r[2634]!, [_0]) + return formatWithArgumentRanges(self._s[2643]!, self._r[2643]!, [_0]) } - public var ChatState_Updating: String { return self._s[2635]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[2636]! } - public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2637]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2639]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2640]! } + public var ChatState_Updating: String { return self._s[2644]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2645]! } + public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2646]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2648]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2649]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2641]!, self._r[2641]!, [_1]) + return formatWithArgumentRanges(self._s[2650]!, self._r[2650]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2642]! } - public var Contacts_InviteFriends: String { return self._s[2644]! } - public var Map_ChooseLocationTitle: String { return self._s[2645]! } - public var Conversation_StopPoll: String { return self._s[2647]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2651]! } + public var Contacts_InviteFriends: String { return self._s[2653]! } + public var Map_ChooseLocationTitle: String { return self._s[2654]! } + public var Conversation_StopPoll: String { return self._s[2656]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2648]!, self._r[2648]!, [_0]) + return formatWithArgumentRanges(self._s[2657]!, self._r[2657]!, [_0]) } - public var Call_Camera: String { return self._s[2649]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2650]! } - public var AppWallet_Intro_Text: String { return self._s[2651]! } - public var Appearance_BubbleCornersSetting: String { return self._s[2652]! } - public var Calls_RatingFeedback: String { return self._s[2653]! } + public var Call_Camera: String { return self._s[2658]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2659]! } + public var AppWallet_Intro_Text: String { return self._s[2660]! } + public var Appearance_BubbleCornersSetting: String { return self._s[2661]! } + public var Calls_RatingFeedback: String { return self._s[2662]! } public func Conversation_NoticeInvitedByInGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2655]!, self._r[2655]!, [_0]) + return formatWithArgumentRanges(self._s[2664]!, self._r[2664]!, [_0]) } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2656]! } - public var Wallet_Alert_OK: String { return self._s[2657]! } - public var NotificationsSound_Pulse: String { return self._s[2658]! } - public var Watch_LastSeen_Lately: String { return self._s[2659]! } - public var ReportGroupLocation_Report: String { return self._s[2662]! } - public var Widget_NoUsers: String { return self._s[2663]! } - public var Conversation_UnvotePoll: String { return self._s[2664]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2666]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2667]! } - public var NotificationsSound_Circles: String { return self._s[2668]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2671]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2672]! } - public var ChatListFolder_CategoryBots: String { return self._s[2673]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2674]! } - public var Proxy_TooltipUnavailable: String { return self._s[2675]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2677]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2679]! } - public var Conversation_FileDropbox: String { return self._s[2680]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2681]! } - public var Tour_Text3: String { return self._s[2683]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2686]! } - public var ChatListFolder_NamePlaceholder: String { return self._s[2687]! } - public var Settings_FrequentlyAskedQuestions: String { return self._s[2688]! } - public var GroupPermission_NoSendMessages: String { return self._s[2689]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2690]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2691]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2665]! } + public var Wallet_Alert_OK: String { return self._s[2666]! } + public var NotificationsSound_Pulse: String { return self._s[2667]! } + public var Watch_LastSeen_Lately: String { return self._s[2668]! } + public var ReportGroupLocation_Report: String { return self._s[2671]! } + public var Widget_NoUsers: String { return self._s[2672]! } + public var Conversation_UnvotePoll: String { return self._s[2673]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2675]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2676]! } + public var NotificationsSound_Circles: String { return self._s[2677]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2680]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2681]! } + public var ChatListFolder_CategoryBots: String { return self._s[2682]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2683]! } + public var Proxy_TooltipUnavailable: String { return self._s[2684]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2686]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2688]! } + public var Conversation_FileDropbox: String { return self._s[2689]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2690]! } + public var Tour_Text3: String { return self._s[2692]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2695]! } + public var ChatListFolder_NamePlaceholder: String { return self._s[2696]! } + public var Settings_FrequentlyAskedQuestions: String { return self._s[2697]! } + public var GroupPermission_NoSendMessages: String { return self._s[2698]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2699]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2700]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2693]!, self._r[2693]!, [_0]) + return formatWithArgumentRanges(self._s[2702]!, self._r[2702]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2694]! } - public var Checkout_ShippingOption_Title: String { return self._s[2695]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2696]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2703]! } + public var Checkout_ShippingOption_Title: String { return self._s[2704]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2705]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2697]!, self._r[2697]!, [_0]) + return formatWithArgumentRanges(self._s[2706]!, self._r[2706]!, [_0]) } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2698]!, self._r[2698]!, [_0]) + return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2699]! } - public var EditTheme_FileReadError: String { return self._s[2700]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2701]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2702]! } - public var AutoDownloadSettings_Photos: String { return self._s[2704]! } - public var Appearance_PreviewIncomingText: String { return self._s[2705]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2706]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2707]! } - public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2708]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2709]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2710]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2711]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2712]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2713]! } - public var Notification_SecretChatScreenshot: String { return self._s[2714]! } - public var AccessDenied_Wallpapers: String { return self._s[2715]! } - public var ChatList_Context_Mute: String { return self._s[2717]! } - public var Passport_Address_City: String { return self._s[2718]! } - public var Settings_EditVideo: String { return self._s[2719]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2720]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2721]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2722]! } - public var AccessDenied_LocationDisabled: String { return self._s[2723]! } - public var Group_Location_Title: String { return self._s[2724]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2726]! } - public var GroupInfo_Sound: String { return self._s[2727]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2728]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2729]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2730]! } - public var Contacts_Title: String { return self._s[2731]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2732]! } - public var Passport_Language_fr: String { return self._s[2733]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2734]! } - public var Notifications_ResetAllNotifications: String { return self._s[2735]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2737]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2739]! } - public var Checkout_NewCard_Title: String { return self._s[2740]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2741]! } - public var Conversation_ForwardChats: String { return self._s[2742]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2744]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2746]! } - public var Settings_FAQ: String { return self._s[2748]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2749]! } - public var Conversation_ContextMenuForward: String { return self._s[2750]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2753]! } - public var PrivacyPolicy_Title: String { return self._s[2756]! } - public var Notifications_TextTone: String { return self._s[2757]! } - public var Profile_CreateNewContact: String { return self._s[2758]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2759]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2761]! } - public var Call_Speaker: String { return self._s[2762]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2763]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2765]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2766]! } + public var Channel_Management_LabelAdministrator: String { return self._s[2708]! } + public var EditTheme_FileReadError: String { return self._s[2709]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2710]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2711]! } + public var AutoDownloadSettings_Photos: String { return self._s[2713]! } + public var Appearance_PreviewIncomingText: String { return self._s[2714]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2715]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2716]! } + public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2717]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2718]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2719]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2720]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2721]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2722]! } + public var Notification_SecretChatScreenshot: String { return self._s[2723]! } + public var AccessDenied_Wallpapers: String { return self._s[2724]! } + public var ChatList_Context_Mute: String { return self._s[2726]! } + public var Passport_Address_City: String { return self._s[2727]! } + public var Settings_EditVideo: String { return self._s[2728]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2729]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2730]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2731]! } + public var AccessDenied_LocationDisabled: String { return self._s[2732]! } + public var Group_Location_Title: String { return self._s[2733]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2735]! } + public var GroupInfo_Sound: String { return self._s[2736]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2737]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2738]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2739]! } + public var Contacts_Title: String { return self._s[2740]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2741]! } + public var Passport_Language_fr: String { return self._s[2742]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2743]! } + public var Notifications_ResetAllNotifications: String { return self._s[2744]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2746]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2748]! } + public var Checkout_NewCard_Title: String { return self._s[2749]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2750]! } + public var Conversation_ForwardChats: String { return self._s[2751]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2753]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2755]! } + public var Settings_FAQ: String { return self._s[2757]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2758]! } + public var Conversation_ContextMenuForward: String { return self._s[2759]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2762]! } + public var PrivacyPolicy_Title: String { return self._s[2765]! } + public var Notifications_TextTone: String { return self._s[2766]! } + public var Profile_CreateNewContact: String { return self._s[2767]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2768]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2770]! } + public var Call_Speaker: String { return self._s[2771]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2772]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2774]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2775]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2767]!, self._r[2767]!, [_0]) + return formatWithArgumentRanges(self._s[2776]!, self._r[2776]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2768]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2769]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2770]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2771]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2772]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2773]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2774]! } - public var Bot_Unblock: String { return self._s[2775]! } - public var TextFormat_Italic: String { return self._s[2776]! } - public var WallpaperSearch_ColorPink: String { return self._s[2777]! } - public var Settings_About_Help: String { return self._s[2779]! } - public var SearchImages_Title: String { return self._s[2780]! } - public var Weekday_Wednesday: String { return self._s[2781]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2782]! } - public var ExplicitContent_AlertTitle: String { return self._s[2783]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2777]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2778]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2779]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2780]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2781]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2782]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2783]! } + public var Bot_Unblock: String { return self._s[2784]! } + public var TextFormat_Italic: String { return self._s[2785]! } + public var WallpaperSearch_ColorPink: String { return self._s[2786]! } + public var Settings_About_Help: String { return self._s[2788]! } + public var SearchImages_Title: String { return self._s[2789]! } + public var Weekday_Wednesday: String { return self._s[2790]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2791]! } + public var ExplicitContent_AlertTitle: String { return self._s[2792]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2784]!, self._r[2784]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2793]!, self._r[2793]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2785]! } - public var Weekday_Thursday: String { return self._s[2786]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2787]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2788]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2794]! } + public var Weekday_Thursday: String { return self._s[2795]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2796]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2797]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2789]!, self._r[2789]!, [_0]) + return formatWithArgumentRanges(self._s[2798]!, self._r[2798]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2790]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2791]! } - public var Passport_RequestedInformation: String { return self._s[2792]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2793]! } - public var Conversation_EncryptionProcessing: String { return self._s[2795]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2796]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2798]! } - public var Channel_Setup_Title: String { return self._s[2799]! } - public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2800]! } - public var Conversation_SearchPlaceholder: String { return self._s[2801]! } - public var OldChannels_GroupEmptyFormat: String { return self._s[2802]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2803]! } - public var Checkout_ErrorGeneric: String { return self._s[2804]! } - public var Passport_Language_hu: String { return self._s[2805]! } - public var GroupPermission_EditingDisabled: String { return self._s[2806]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2808]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2799]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2800]! } + public var Passport_RequestedInformation: String { return self._s[2801]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2802]! } + public var Conversation_EncryptionProcessing: String { return self._s[2804]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2805]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2807]! } + public var Channel_Setup_Title: String { return self._s[2808]! } + public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2809]! } + public var Conversation_SearchPlaceholder: String { return self._s[2810]! } + public var OldChannels_GroupEmptyFormat: String { return self._s[2811]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2812]! } + public var Checkout_ErrorGeneric: String { return self._s[2813]! } + public var Passport_Language_hu: String { return self._s[2814]! } + public var GroupPermission_EditingDisabled: String { return self._s[2815]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2817]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2809]!, self._r[2809]!, [_0]) + return formatWithArgumentRanges(self._s[2818]!, self._r[2818]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2812]!, self._r[2812]!, [_1]) + return formatWithArgumentRanges(self._s[2821]!, self._r[2821]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2813]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2822]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2814]!, self._r[2814]!, [_0]) + return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2815]! } - public var Group_Location_Info: String { return self._s[2816]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2817]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2818]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2824]! } + public var Group_Location_Info: String { return self._s[2825]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2826]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2827]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2820]!, self._r[2820]!, [_0]) + return formatWithArgumentRanges(self._s[2829]!, self._r[2829]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2821]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2822]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2823]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2824]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2830]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2831]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2832]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2833]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2825]!, self._r[2825]!, [_0]) + return formatWithArgumentRanges(self._s[2834]!, self._r[2834]!, [_0]) } - public var Cache_MaximumCacheSizeHelp: String { return self._s[2826]! } + public var Cache_MaximumCacheSizeHelp: String { return self._s[2835]! } public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_0]) + return formatWithArgumentRanges(self._s[2836]!, self._r[2836]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2828]! } - public var Message_PinnedAnimationMessage: String { return self._s[2830]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2832]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2833]! } - public var Wallet_Info_TransactionTo: String { return self._s[2835]! } - public var Stats_ViewsBySourceTitle: String { return self._s[2836]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2837]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2838]! } - public var Embed_PlayingInPIP: String { return self._s[2839]! } - public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2840]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2841]! } - public var Stats_GroupMessages: String { return self._s[2842]! } + public var Passport_Language_cs: String { return self._s[2837]! } + public var Message_PinnedAnimationMessage: String { return self._s[2839]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2841]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2842]! } + public var Wallet_Info_TransactionTo: String { return self._s[2844]! } + public var Stats_ViewsBySourceTitle: String { return self._s[2845]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2846]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2847]! } + public var Embed_PlayingInPIP: String { return self._s[2848]! } + public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2849]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2850]! } + public var Stats_GroupMessages: String { return self._s[2851]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2843]!, self._r[2843]!, [_0]) + return formatWithArgumentRanges(self._s[2852]!, self._r[2852]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2844]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2853]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2845]!, self._r[2845]!, [_1]) + return formatWithArgumentRanges(self._s[2854]!, self._r[2854]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2846]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2847]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2848]! } - public var AutoNightTheme_System: String { return self._s[2849]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2850]! } - public var CreatePoll_QuizTitle: String { return self._s[2851]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2852]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2853]! } + public var Notification_PaymentSent: String { return self._s[2855]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2856]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2857]! } + public var AutoNightTheme_System: String { return self._s[2858]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2859]! } + public var CreatePoll_QuizTitle: String { return self._s[2860]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2861]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2862]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2856]!, self._r[2856]!, [_1]) + return formatWithArgumentRanges(self._s[2865]!, self._r[2865]!, [_1]) } public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2857]!, self._r[2857]!, [_1]) + return formatWithArgumentRanges(self._s[2866]!, self._r[2866]!, [_1]) } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2858]!, self._r[2858]!, [_1]) + return formatWithArgumentRanges(self._s[2867]!, self._r[2867]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2860]! } - public var PasscodeSettings_HelpTop: String { return self._s[2861]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2862]! } - public var PeerInfo_AddToContacts: String { return self._s[2863]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2864]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2865]! } - public var FeaturedStickers_OtherSection: String { return self._s[2866]! } - public var EditTheme_ShortLink: String { return self._s[2868]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2869]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2870]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2871]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2872]! } - public var Call_Accept: String { return self._s[2874]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2875]! } - public var Month_GenMarch: String { return self._s[2877]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2878]! } - public var LoginPassword_Title: String { return self._s[2879]! } - public var Call_End: String { return self._s[2880]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2881]! } - public var VoiceOver_Chat_Contact: String { return self._s[2882]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2883]! } - public var CallSettings_Always: String { return self._s[2884]! } - public var CallFeedback_Success: String { return self._s[2885]! } - public var TwoStepAuth_SetupHint: String { return self._s[2886]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2869]! } + public var PasscodeSettings_HelpTop: String { return self._s[2870]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2871]! } + public var PeerInfo_AddToContacts: String { return self._s[2872]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2873]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2874]! } + public var FeaturedStickers_OtherSection: String { return self._s[2875]! } + public var EditTheme_ShortLink: String { return self._s[2877]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2878]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2879]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2880]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2881]! } + public var Call_Accept: String { return self._s[2883]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2884]! } + public var Month_GenMarch: String { return self._s[2886]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2887]! } + public var LoginPassword_Title: String { return self._s[2888]! } + public var Call_End: String { return self._s[2889]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2890]! } + public var VoiceOver_Chat_Contact: String { return self._s[2891]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2892]! } + public var CallSettings_Always: String { return self._s[2893]! } + public var CallFeedback_Success: String { return self._s[2894]! } + public var TwoStepAuth_SetupHint: String { return self._s[2895]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2887]!, self._r[2887]!, [_1]) + return formatWithArgumentRanges(self._s[2896]!, self._r[2896]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2888]! } - public var PeerInfo_ButtonAddMember: String { return self._s[2889]! } - public var Login_PhoneTitle: String { return self._s[2890]! } - public var Passport_FieldPhoneHelp: String { return self._s[2891]! } - public var Weekday_ShortSunday: String { return self._s[2892]! } - public var Passport_InfoFAQ_URL: String { return self._s[2893]! } - public var ContactInfo_Job: String { return self._s[2895]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2896]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2897]! } - public var CreatePoll_QuizTip: String { return self._s[2898]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2899]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2900]! } - public var Invite_ChannelsTooMuch: String { return self._s[2901]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2902]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2903]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2904]! } - public var Wallet_Receive_AmountText: String { return self._s[2905]! } - public var TwoStepAuth_Disable: String { return self._s[2906]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2907]! } - public var CallFeedback_ReasonNoise: String { return self._s[2908]! } - public var Appearance_AppIconDefault: String { return self._s[2910]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2911]! } - public var MediaPicker_AddCaption: String { return self._s[2912]! } - public var CallSettings_TabIconDescription: String { return self._s[2913]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2897]! } + public var PeerInfo_ButtonAddMember: String { return self._s[2898]! } + public var Login_PhoneTitle: String { return self._s[2899]! } + public var Passport_FieldPhoneHelp: String { return self._s[2900]! } + public var Weekday_ShortSunday: String { return self._s[2901]! } + public var Passport_InfoFAQ_URL: String { return self._s[2902]! } + public var ContactInfo_Job: String { return self._s[2904]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2905]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2906]! } + public var CreatePoll_QuizTip: String { return self._s[2907]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2908]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2909]! } + public var Invite_ChannelsTooMuch: String { return self._s[2910]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2911]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2912]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2913]! } + public var Wallet_Receive_AmountText: String { return self._s[2914]! } + public var TwoStepAuth_Disable: String { return self._s[2915]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2916]! } + public var CallFeedback_ReasonNoise: String { return self._s[2917]! } + public var Appearance_AppIconDefault: String { return self._s[2919]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2920]! } + public var MediaPicker_AddCaption: String { return self._s[2921]! } + public var CallSettings_TabIconDescription: String { return self._s[2922]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2914]!, self._r[2914]!, [_0]) + return formatWithArgumentRanges(self._s[2923]!, self._r[2923]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2915]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2924]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2916]!, self._r[2916]!, [_0]) + return formatWithArgumentRanges(self._s[2925]!, self._r[2925]!, [_0]) } - public var CreatePoll_ExplanationHeader: String { return self._s[2918]! } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2919]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2920]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2921]! } - public var DialogList_SearchSectionRecent: String { return self._s[2922]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2923]! } - public var CreatePoll_Anonymous: String { return self._s[2924]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2927]! } - public var Stats_GroupTopInviter_Promote: String { return self._s[2928]! } - public var LastSeen_WithinAWeek: String { return self._s[2929]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2930]! } - public var SettingsSearch_Synonyms_ChatSettings_IntentsSettings: String { return self._s[2932]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2933]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2935]! } + public var CreatePoll_ExplanationHeader: String { return self._s[2927]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2928]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2929]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2930]! } + public var DialogList_SearchSectionRecent: String { return self._s[2931]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2932]! } + public var CreatePoll_Anonymous: String { return self._s[2933]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2936]! } + public var Stats_GroupTopInviter_Promote: String { return self._s[2937]! } + public var LastSeen_WithinAWeek: String { return self._s[2938]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2939]! } + public var SettingsSearch_Synonyms_ChatSettings_IntentsSettings: String { return self._s[2941]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2942]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2944]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2936]!, self._r[2936]!, [_0]) + return formatWithArgumentRanges(self._s[2945]!, self._r[2945]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2937]! } - public var Conversation_StatusLeftGroup: String { return self._s[2938]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2939]! } - public var OwnershipTransfer_Transfer: String { return self._s[2941]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2942]! } - public var ProfilePhoto_MainPhoto: String { return self._s[2943]! } - public var GroupPermission_AddSuccess: String { return self._s[2945]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2947]! } - public var Conversation_ContextMenuCopy: String { return self._s[2948]! } - public var AccessDenied_CallMicrophone: String { return self._s[2949]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2946]! } + public var Conversation_StatusLeftGroup: String { return self._s[2947]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2948]! } + public var OwnershipTransfer_Transfer: String { return self._s[2950]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2951]! } + public var ProfilePhoto_MainPhoto: String { return self._s[2952]! } + public var GroupPermission_AddSuccess: String { return self._s[2954]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2956]! } + public var Conversation_ContextMenuCopy: String { return self._s[2957]! } + public var AccessDenied_CallMicrophone: String { return self._s[2958]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2950]!, self._r[2950]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2959]!, self._r[2959]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2951]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2952]! } - public var Checkout_PaymentMethod_New: String { return self._s[2953]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2954]! } - public var PhotoEditor_QualityTool: String { return self._s[2955]! } - public var Login_SendCodeViaSms: String { return self._s[2956]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2957]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2958]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2959]! } - public var Login_EmailNotConfiguredError: String { return self._s[2960]! } - public var Stats_GroupTopAdminsTitle: String { return self._s[2961]! } - public var SocksProxySetup_Status: String { return self._s[2962]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2963]! } - public var PrivacyPolicy_Accept: String { return self._s[2964]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2965]! } - public var Appearance_AppIconClassicX: String { return self._s[2966]! } + public var Login_InvalidFirstNameError: String { return self._s[2960]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2961]! } + public var Checkout_PaymentMethod_New: String { return self._s[2962]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2963]! } + public var PhotoEditor_QualityTool: String { return self._s[2964]! } + public var Login_SendCodeViaSms: String { return self._s[2965]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2966]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2967]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2968]! } + public var Login_EmailNotConfiguredError: String { return self._s[2969]! } + public var Stats_GroupTopAdminsTitle: String { return self._s[2970]! } + public var SocksProxySetup_Status: String { return self._s[2971]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2972]! } + public var PrivacyPolicy_Accept: String { return self._s[2973]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2974]! } + public var Appearance_AppIconClassicX: String { return self._s[2975]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2976]!, self._r[2976]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2968]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2970]! } - public var AutoNightTheme_Automatic: String { return self._s[2971]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2972]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2973]! } - public var Cache_Help: String { return self._s[2974]! } - public var Group_ErrorAccessDenied: String { return self._s[2975]! } - public var Passport_Language_fa: String { return self._s[2976]! } - public var Wallet_Intro_Text: String { return self._s[2977]! } - public var ProfilePhoto_SetMainVideo: String { return self._s[2978]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2979]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2980]! } - public var PrivacySettings_LastSeen: String { return self._s[2981]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2977]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2979]! } + public var AutoNightTheme_Automatic: String { return self._s[2980]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2981]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2982]! } + public var Cache_Help: String { return self._s[2983]! } + public var Group_ErrorAccessDenied: String { return self._s[2984]! } + public var Passport_Language_fa: String { return self._s[2985]! } + public var Wallet_Intro_Text: String { return self._s[2986]! } + public var ProfilePhoto_SetMainVideo: String { return self._s[2987]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2988]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2989]! } + public var PrivacySettings_LastSeen: String { return self._s[2990]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2982]!, self._r[2982]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2991]!, self._r[2991]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2986]! } - public var Preview_SaveGif: String { return self._s[2987]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2988]! } - public var Profile_About: String { return self._s[2989]! } - public var Channel_About_Placeholder: String { return self._s[2991]! } - public var Login_InfoTitle: String { return self._s[2992]! } + public var Wallet_Configuration_Apply: String { return self._s[2995]! } + public var Preview_SaveGif: String { return self._s[2996]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2997]! } + public var Profile_About: String { return self._s[2998]! } + public var Channel_About_Placeholder: String { return self._s[3000]! } + public var Login_InfoTitle: String { return self._s[3001]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2993]!, self._r[2993]!, [_0]) + return formatWithArgumentRanges(self._s[3002]!, self._r[3002]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2994]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2997]! } - public var ContactInfo_Title: String { return self._s[2998]! } - public var Media_ShareThisVideo: String { return self._s[2999]! } - public var Chat_GenericPsaTooltip: String { return self._s[3000]! } - public var Weekday_ShortFriday: String { return self._s[3001]! } - public var AccessDenied_Contacts: String { return self._s[3003]! } - public var Notification_CallIncomingShort: String { return self._s[3004]! } - public var Group_Setup_TypePublic: String { return self._s[3005]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[3006]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[3007]! } - public var Settings_EditAccount: String { return self._s[3010]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[3011]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[3012]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[3013]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[3014]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[3015]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[3003]! } + public var Watch_Suggestion_CantTalk: String { return self._s[3006]! } + public var ContactInfo_Title: String { return self._s[3007]! } + public var Media_ShareThisVideo: String { return self._s[3008]! } + public var Chat_GenericPsaTooltip: String { return self._s[3009]! } + public var Weekday_ShortFriday: String { return self._s[3010]! } + public var AccessDenied_Contacts: String { return self._s[3012]! } + public var Notification_CallIncomingShort: String { return self._s[3013]! } + public var Group_Setup_TypePublic: String { return self._s[3014]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[3015]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[3016]! } + public var Settings_EditAccount: String { return self._s[3019]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[3020]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[3021]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[3022]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[3023]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[3024]! } public func Call_RemoteVideoPaused(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3016]!, self._r[3016]!, [_0]) + return formatWithArgumentRanges(self._s[3025]!, self._r[3025]!, [_0]) } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3017]!, self._r[3017]!, [_0]) + return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_0]) } - public var DialogList_Typing: String { return self._s[3018]! } - public var CallFeedback_IncludeLogs: String { return self._s[3020]! } - public var Checkout_Phone: String { return self._s[3022]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[3025]! } - public var Privacy_Calls_Integration: String { return self._s[3026]! } - public var Notifications_PermissionsAllow: String { return self._s[3027]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[3033]! } - public var Settings_ChatSettings: String { return self._s[3034]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[3035]! } + public var DialogList_Typing: String { return self._s[3027]! } + public var CallFeedback_IncludeLogs: String { return self._s[3029]! } + public var Checkout_Phone: String { return self._s[3031]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[3034]! } + public var Privacy_Calls_Integration: String { return self._s[3035]! } + public var Notifications_PermissionsAllow: String { return self._s[3036]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[3042]! } + public var Settings_ChatSettings: String { return self._s[3043]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[3044]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3037]!, self._r[3037]!, [_0]) + return formatWithArgumentRanges(self._s[3046]!, self._r[3046]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3038]!, self._r[3038]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3047]!, self._r[3047]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[3040]! } + public var GroupRemoved_DeleteUser: String { return self._s[3049]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3041]!, self._r[3041]!, [_0]) + return formatWithArgumentRanges(self._s[3050]!, self._r[3050]!, [_0]) } - public var ChatListFolder_CategoryMuted: String { return self._s[3042]! } + public var ChatListFolder_CategoryMuted: String { return self._s[3051]! } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3043]!, self._r[3043]!, [_1]) + return formatWithArgumentRanges(self._s[3052]!, self._r[3052]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[3044]! } - public var Watch_Message_ForwardedFrom: String { return self._s[3045]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[3047]! } - public var Notification_VideoCallIncoming: String { return self._s[3048]! } - public var Conversation_Unblock: String { return self._s[3049]! } - public var PrivacySettings_DataSettings: String { return self._s[3050]! } - public var WallpaperPreview_PatternPaternApply: String { return self._s[3051]! } - public var Group_PublicLink_Info: String { return self._s[3052]! } + public var Login_ContinueWithLocalization: String { return self._s[3053]! } + public var Watch_Message_ForwardedFrom: String { return self._s[3054]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[3056]! } + public var Notification_VideoCallIncoming: String { return self._s[3057]! } + public var Conversation_Unblock: String { return self._s[3058]! } + public var PrivacySettings_DataSettings: String { return self._s[3059]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[3060]! } + public var Group_PublicLink_Info: String { return self._s[3061]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3053]!, self._r[3053]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[3054]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[3063]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3055]!, self._r[3055]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3064]!, self._r[3064]!, [_0, _1]) } - public var ChatList_FolderAllChats: String { return self._s[3056]! } - public var OldChannels_ChannelsHeader: String { return self._s[3058]! } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[3059]! } - public var PrivacySettings_Passcode: String { return self._s[3061]! } - public var Call_Mute: String { return self._s[3062]! } - public var Call_CameraTooltip: String { return self._s[3063]! } - public var Wallet_Weekday_Yesterday: String { return self._s[3064]! } - public var Passport_Language_dz: String { return self._s[3065]! } - public var Wallet_Receive_AmountHeader: String { return self._s[3066]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[3067]! } - public var Passport_Language_tk: String { return self._s[3068]! } + public var ChatList_FolderAllChats: String { return self._s[3065]! } + public var OldChannels_ChannelsHeader: String { return self._s[3067]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[3068]! } + public var PrivacySettings_Passcode: String { return self._s[3070]! } + public var Call_Mute: String { return self._s[3071]! } + public var Call_CameraTooltip: String { return self._s[3072]! } + public var Wallet_Weekday_Yesterday: String { return self._s[3073]! } + public var Passport_Language_dz: String { return self._s[3074]! } + public var Wallet_Receive_AmountHeader: String { return self._s[3075]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[3076]! } + public var Passport_Language_tk: String { return self._s[3077]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3069]!, self._r[3069]!, [_0]) + return formatWithArgumentRanges(self._s[3078]!, self._r[3078]!, [_0]) } - public var Settings_Search: String { return self._s[3070]! } - public var Wallet_Month_ShortFebruary: String { return self._s[3071]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[3072]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[3073]! } - public var Conversation_ContextMenuReply: String { return self._s[3074]! } - public var WallpaperSearch_ColorBrown: String { return self._s[3075]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[3076]! } - public var Tour_Title1: String { return self._s[3077]! } - public var Wallet_Alert_Cancel: String { return self._s[3078]! } - public var Stats_Total: String { return self._s[3080]! } - public var Conversation_ClearGroupHistory: String { return self._s[3081]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[3082]! } - public var WallpaperPreview_Motion: String { return self._s[3083]! } + public var Settings_Search: String { return self._s[3079]! } + public var Wallet_Month_ShortFebruary: String { return self._s[3080]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[3081]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[3082]! } + public var Conversation_ContextMenuReply: String { return self._s[3083]! } + public var WallpaperSearch_ColorBrown: String { return self._s[3084]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[3085]! } + public var Tour_Title1: String { return self._s[3086]! } + public var Wallet_Alert_Cancel: String { return self._s[3087]! } + public var Stats_Total: String { return self._s[3089]! } + public var Conversation_ClearGroupHistory: String { return self._s[3090]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[3091]! } + public var WallpaperPreview_Motion: String { return self._s[3092]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3084]!, self._r[3084]!, [_0]) - } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[3085]! } - public var Call_RateCall: String { return self._s[3086]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[3087]! } - public var Passport_PasswordCompleteSetup: String { return self._s[3088]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[3089]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[3091]! } - public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3093]!, self._r[3093]!, [_0]) } - public var Compose_Create: String { return self._s[3094]! } - public var Contacts_InviteToTelegram: String { return self._s[3095]! } - public var GroupInfo_Notifications: String { return self._s[3096]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[3098]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[3099]! } - public var Month_GenApril: String { return self._s[3100]! } - public var Appearance_AutoNightTheme: String { return self._s[3101]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[3103]! } - public var Login_CodeSentSms: String { return self._s[3105]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[3094]! } + public var Call_RateCall: String { return self._s[3095]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[3096]! } + public var Passport_PasswordCompleteSetup: String { return self._s[3097]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[3098]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[3100]! } + public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3102]!, self._r[3102]!, [_0]) + } + public var Compose_Create: String { return self._s[3103]! } + public var Contacts_InviteToTelegram: String { return self._s[3104]! } + public var GroupInfo_Notifications: String { return self._s[3105]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[3107]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[3108]! } + public var Month_GenApril: String { return self._s[3109]! } + public var Appearance_AutoNightTheme: String { return self._s[3110]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[3112]! } + public var Login_CodeSentSms: String { return self._s[3114]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3106]!, self._r[3106]!, [_0]) + return formatWithArgumentRanges(self._s[3115]!, self._r[3115]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[3107]! } - public var LogoutOptions_ContactSupportText: String { return self._s[3108]! } - public var Passport_Language_hr: String { return self._s[3109]! } - public var Common_ActionNotAllowedError: String { return self._s[3110]! } + public var EmptyGroupInfo_Line3: String { return self._s[3116]! } + public var LogoutOptions_ContactSupportText: String { return self._s[3117]! } + public var Passport_Language_hr: String { return self._s[3118]! } + public var Common_ActionNotAllowedError: String { return self._s[3119]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3111]!, self._r[3111]!, [_0]) + return formatWithArgumentRanges(self._s[3120]!, self._r[3120]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[3112]! } - public var Wallet_Info_TransactionFrom: String { return self._s[3113]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[3114]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[3115]! } - public var Privacy_SecretChatsTitle: String { return self._s[3116]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[3118]! } - public var GroupInfo_AddUserLeftError: String { return self._s[3119]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[3120]! } - public var ChatListFolder_NameSectionHeader: String { return self._s[3121]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[3122]! } - public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[3123]! } - public var Conversation_Unarchive: String { return self._s[3124]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[3125]! } - public var Preview_DeleteGif: String { return self._s[3126]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[3127]! } - public var Group_ErrorNotMutualContact: String { return self._s[3128]! } - public var Notification_MessageLifetime5s: String { return self._s[3129]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[3130]! } - public var OldChannels_ChannelFormat: String { return self._s[3131]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[3121]! } + public var Wallet_Info_TransactionFrom: String { return self._s[3122]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[3123]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[3124]! } + public var Privacy_SecretChatsTitle: String { return self._s[3125]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[3127]! } + public var GroupInfo_AddUserLeftError: String { return self._s[3128]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[3129]! } + public var ChatListFolder_NameSectionHeader: String { return self._s[3130]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[3131]! } + public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[3132]! } + public var Conversation_Unarchive: String { return self._s[3133]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[3134]! } + public var Preview_DeleteGif: String { return self._s[3135]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[3136]! } + public var Group_ErrorNotMutualContact: String { return self._s[3137]! } + public var Notification_MessageLifetime5s: String { return self._s[3138]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[3139]! } + public var OldChannels_ChannelFormat: String { return self._s[3140]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3132]!, self._r[3132]!, [_0]) + return formatWithArgumentRanges(self._s[3141]!, self._r[3141]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[3133]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3135]! } - public var ReportSpam_DeleteThisChat: String { return self._s[3136]! } - public var Passport_Address_AddBankStatement: String { return self._s[3137]! } - public var Notification_CallIncoming: String { return self._s[3138]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[3139]! } - public var Compose_NewGroupTitle: String { return self._s[3140]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3142]! } - public var Passport_Address_Postcode: String { return self._s[3144]! } + public var VoiceOver_Chat_Video: String { return self._s[3142]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3144]! } + public var ReportSpam_DeleteThisChat: String { return self._s[3145]! } + public var Passport_Address_AddBankStatement: String { return self._s[3146]! } + public var Notification_CallIncoming: String { return self._s[3147]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[3148]! } + public var Compose_NewGroupTitle: String { return self._s[3149]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3151]! } + public var Passport_Address_Postcode: String { return self._s[3153]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3145]!, self._r[3145]!, [_0]) + return formatWithArgumentRanges(self._s[3154]!, self._r[3154]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[3146]! } - public var Wallet_Month_ShortOctober: String { return self._s[3147]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[3148]! } - public var WallpaperColors_Title: String { return self._s[3149]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3150]! } - public var VoiceOver_MessageContextForward: String { return self._s[3151]! } - public var GroupPermission_Duration: String { return self._s[3152]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[3155]! } + public var Wallet_Month_ShortOctober: String { return self._s[3156]! } + public func Call_AccountIsLoggedOnCurrentDevice(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3157]!, self._r[3157]!, [_0]) + } + public var VoiceOver_Chat_YourMusic: String { return self._s[3158]! } + public var WallpaperColors_Title: String { return self._s[3159]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3160]! } + public var VoiceOver_MessageContextForward: String { return self._s[3161]! } + public var GroupPermission_Duration: String { return self._s[3162]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3153]!, self._r[3153]!, [_0]) + return formatWithArgumentRanges(self._s[3163]!, self._r[3163]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[3154]! } - public var Username_Placeholder: String { return self._s[3155]! } - public var CallFeedback_WhatWentWrong: String { return self._s[3156]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[3157]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3158]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[3164]! } + public var Username_Placeholder: String { return self._s[3165]! } + public var CallFeedback_WhatWentWrong: String { return self._s[3166]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[3167]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3168]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3161]!, self._r[3161]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3171]!, self._r[3171]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[3162]! } - public var Channel_MessagePhotoUpdated: String { return self._s[3163]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[3164]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3165]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[3166]! } - public var Conversation_ContextMenuMore: String { return self._s[3167]! } - public var Privacy_PaymentsClearInfo: String { return self._s[3168]! } - public var CallSettings_TabIcon: String { return self._s[3169]! } - public var KeyCommand_Find: String { return self._s[3170]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[3171]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3172]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3173]! } + public var Passport_PasswordDescription: String { return self._s[3172]! } + public var Channel_MessagePhotoUpdated: String { return self._s[3173]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[3174]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3175]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[3176]! } + public var Conversation_ContextMenuMore: String { return self._s[3177]! } + public var Privacy_PaymentsClearInfo: String { return self._s[3178]! } + public var CallSettings_TabIcon: String { return self._s[3179]! } + public var KeyCommand_Find: String { return self._s[3180]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[3181]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3182]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3183]! } public func Conversation_NoticeInvitedByInChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3174]!, self._r[3174]!, [_0]) + return formatWithArgumentRanges(self._s[3184]!, self._r[3184]!, [_0]) } - public var Message_PinnedGame: String { return self._s[3175]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3176]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3178]! } - public var Login_CallRequestState2: String { return self._s[3180]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3182]! } + public var Message_PinnedGame: String { return self._s[3185]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3186]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3188]! } + public var Login_CallRequestState2: String { return self._s[3190]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3192]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3183]!, self._r[3183]!, [_0]) + return formatWithArgumentRanges(self._s[3193]!, self._r[3193]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3185]!, self._r[3185]!, [_0]) + return formatWithArgumentRanges(self._s[3195]!, self._r[3195]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[3186]! } - public var WallpaperPreview_Blurred: String { return self._s[3187]! } - public var Conversation_InstantPagePreview: String { return self._s[3188]! } - public var PeerInfo_ButtonUnmute: String { return self._s[3189]! } + public var AuthSessions_AddDevice: String { return self._s[3196]! } + public var WallpaperPreview_Blurred: String { return self._s[3197]! } + public var Conversation_InstantPagePreview: String { return self._s[3198]! } + public var PeerInfo_ButtonUnmute: String { return self._s[3199]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3190]!, self._r[3190]!, [_0]) + return formatWithArgumentRanges(self._s[3200]!, self._r[3200]!, [_0]) } - public var ChatList_PeerTypeChannel: String { return self._s[3191]! } - public var SecretTimer_VideoDescription: String { return self._s[3194]! } - public var WallpaperSearch_ColorRed: String { return self._s[3195]! } - public var GroupPermission_NoPinMessages: String { return self._s[3196]! } - public var Passport_Language_es: String { return self._s[3197]! } - public var Permissions_ContactsAllow_v0: String { return self._s[3199]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3200]! } + public var ChatList_PeerTypeChannel: String { return self._s[3201]! } + public var SecretTimer_VideoDescription: String { return self._s[3204]! } + public var WallpaperSearch_ColorRed: String { return self._s[3205]! } + public var GroupPermission_NoPinMessages: String { return self._s[3206]! } + public var Passport_Language_es: String { return self._s[3207]! } + public var Permissions_ContactsAllow_v0: String { return self._s[3209]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3210]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3201]!, self._r[3201]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3211]!, self._r[3211]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[3202]! } - public var WebPreview_GettingLinkInfo: String { return self._s[3204]! } - public var Watch_UserInfo_Unmute: String { return self._s[3205]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3206]! } - public var AccessDenied_CameraRestricted: String { return self._s[3208]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[3212]! } + public var WebPreview_GettingLinkInfo: String { return self._s[3214]! } + public var Watch_UserInfo_Unmute: String { return self._s[3215]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3216]! } + public var AccessDenied_CameraRestricted: String { return self._s[3218]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3209]!, self._r[3209]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[3211]! } - public var Settings_CopyUsername: String { return self._s[3212]! } - public var Contacts_SearchLabel: String { return self._s[3213]! } - public var Map_OpenInYandexNavigator: String { return self._s[3215]! } - public var PasscodeSettings_EncryptData: String { return self._s[3216]! } - public var Settings_Wallet: String { return self._s[3217]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3218]! } - public var ChatList_PeerTypeBot: String { return self._s[3219]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[3220]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[3221]! } - public var DialogList_AdNoticeAlert: String { return self._s[3222]! } - public var Wallet_Month_GenMay: String { return self._s[3224]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3225]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3226]! } - public var Localization_LanguageCustom: String { return self._s[3227]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3228]! } - public var CallFeedback_Title: String { return self._s[3229]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3232]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3233]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[3234]! } - public var Conversation_InfoGroup: String { return self._s[3235]! } - public var Compose_NewMessage: String { return self._s[3236]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3237]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3238]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3239]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3240]! } + public var ChatList_ReadAll: String { return self._s[3221]! } + public var Settings_CopyUsername: String { return self._s[3222]! } + public var Contacts_SearchLabel: String { return self._s[3223]! } + public var Map_OpenInYandexNavigator: String { return self._s[3225]! } + public var PasscodeSettings_EncryptData: String { return self._s[3226]! } + public var Settings_Wallet: String { return self._s[3227]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3228]! } + public var ChatList_PeerTypeBot: String { return self._s[3229]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[3230]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[3231]! } + public var DialogList_AdNoticeAlert: String { return self._s[3232]! } + public var Wallet_Month_GenMay: String { return self._s[3234]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3235]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3236]! } + public var Localization_LanguageCustom: String { return self._s[3237]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3238]! } + public var CallFeedback_Title: String { return self._s[3239]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3242]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3243]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[3244]! } + public var Conversation_InfoGroup: String { return self._s[3245]! } + public var Compose_NewMessage: String { return self._s[3246]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3247]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3248]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3249]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3250]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3241]!, self._r[3241]!, [_0]) + return formatWithArgumentRanges(self._s[3251]!, self._r[3251]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3242]! } - public var Login_CancelSignUpConfirmation: String { return self._s[3243]! } - public var ChangePhoneNumberCode_Help: String { return self._s[3244]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[3245]! } - public var ChatList_Context_RemoveFromFolder: String { return self._s[3246]! } - public var Channel_BlackList_Title: String { return self._s[3247]! } - public var UserInfo_PhoneCall: String { return self._s[3248]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3250]! } - public var Wallet_Month_ShortJanuary: String { return self._s[3251]! } - public var State_connecting: String { return self._s[3252]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3253]! } - public var Wallet_Month_GenMarch: String { return self._s[3254]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[3255]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[3256]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3252]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3253]! } + public var ChangePhoneNumberCode_Help: String { return self._s[3254]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[3255]! } + public var ChatList_Context_RemoveFromFolder: String { return self._s[3256]! } + public var Channel_BlackList_Title: String { return self._s[3257]! } + public var UserInfo_PhoneCall: String { return self._s[3258]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3260]! } + public var Wallet_Month_ShortJanuary: String { return self._s[3261]! } + public var State_connecting: String { return self._s[3262]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3263]! } + public var Wallet_Month_GenMarch: String { return self._s[3264]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[3265]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[3266]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3257]!, self._r[3257]!, [_0]) + return formatWithArgumentRanges(self._s[3267]!, self._r[3267]!, [_0]) } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3258]!, self._r[3258]!, [_0]) + return formatWithArgumentRanges(self._s[3268]!, self._r[3268]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[3259]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3260]! } - public var Passport_Identity_EditPassport: String { return self._s[3261]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[3263]! } - public var Localization_EnglishLanguageName: String { return self._s[3264]! } - public var Share_AuthDescription: String { return self._s[3265]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3266]! } - public var Passport_Identity_Surname: String { return self._s[3267]! } - public var Compose_TokenListPlaceholder: String { return self._s[3268]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3269]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[3270]! } - public var Settings_AboutEmpty: String { return self._s[3271]! } - public var Conversation_Unmute: String { return self._s[3272]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[3274]! } - public var Wallet_Sending_Text: String { return self._s[3275]! } + public var Notifications_GroupNotifications: String { return self._s[3269]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3270]! } + public var Passport_Identity_EditPassport: String { return self._s[3271]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[3273]! } + public var Localization_EnglishLanguageName: String { return self._s[3274]! } + public var Share_AuthDescription: String { return self._s[3275]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3276]! } + public var Passport_Identity_Surname: String { return self._s[3277]! } + public var Compose_TokenListPlaceholder: String { return self._s[3278]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3279]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[3280]! } + public var Settings_AboutEmpty: String { return self._s[3281]! } + public var Conversation_Unmute: String { return self._s[3282]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[3284]! } + public var Wallet_Sending_Text: String { return self._s[3285]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3276]!, self._r[3276]!, [_1]) - } - public var Login_CodeSentCall: String { return self._s[3277]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3279]! } - public var ChatSettings_Appearance: String { return self._s[3280]! } - public var ClearCache_StorageUsage: String { return self._s[3281]! } - public var ChatListFolder_NameContacts: String { return self._s[3282]! } - public var Appearance_PickAccentColor: String { return self._s[3284]! } - public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3285]!, self._r[3285]!, [_1, _2]) - } - public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3286]!, self._r[3286]!, [_1]) } - public var Notification_CallMissed: String { return self._s[3287]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3288]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3289]! } - public var Wallet_Month_GenOctober: String { return self._s[3291]! } - public var ChatAdmins_AdminLabel: String { return self._s[3292]! } - public var KeyCommand_JumpToNextChat: String { return self._s[3293]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[3295]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3296]! } - public var Month_GenJune: String { return self._s[3297]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[3298]! } - public var Watch_Location_Current: String { return self._s[3299]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3300]! } - public var Conversation_TitleMute: String { return self._s[3301]! } - public var Map_PlacesInThisArea: String { return self._s[3302]! } + public var Login_CodeSentCall: String { return self._s[3287]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3289]! } + public var ChatSettings_Appearance: String { return self._s[3290]! } + public var ClearCache_StorageUsage: String { return self._s[3291]! } + public var ChatListFolder_NameContacts: String { return self._s[3292]! } + public var Appearance_PickAccentColor: String { return self._s[3294]! } + public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3295]!, self._r[3295]!, [_1, _2]) + } + public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3296]!, self._r[3296]!, [_1]) + } + public var Notification_CallMissed: String { return self._s[3297]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3298]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3299]! } + public var Wallet_Month_GenOctober: String { return self._s[3301]! } + public var ChatAdmins_AdminLabel: String { return self._s[3302]! } + public var KeyCommand_JumpToNextChat: String { return self._s[3303]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[3305]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3306]! } + public var Month_GenJune: String { return self._s[3307]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[3308]! } + public var Watch_Location_Current: String { return self._s[3309]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3310]! } + public var Conversation_TitleMute: String { return self._s[3311]! } + public var Map_PlacesInThisArea: String { return self._s[3312]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3303]!, self._r[3303]!, [_1]) + return formatWithArgumentRanges(self._s[3313]!, self._r[3313]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3304]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3314]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3305]!, self._r[3305]!, [_0]) + return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[3306]! } - public var Chat_SlowmodeSendError: String { return self._s[3307]! } - public var MaskStickerSettings_Info: String { return self._s[3308]! } - public var EditTheme_Expand_TopInfo: String { return self._s[3309]! } + public var Call_ReportPlaceholder: String { return self._s[3316]! } + public var Chat_SlowmodeSendError: String { return self._s[3317]! } + public var MaskStickerSettings_Info: String { return self._s[3318]! } + public var EditTheme_Expand_TopInfo: String { return self._s[3319]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3310]!, self._r[3310]!, [_0]) + return formatWithArgumentRanges(self._s[3320]!, self._r[3320]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[3311]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3313]! } - public var Contacts_ShareTelegram: String { return self._s[3314]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3315]! } - public var Map_AddressOnMap: String { return self._s[3316]! } - public var Channel_ErrorAccessDenied: String { return self._s[3317]! } - public var UserInfo_ScamBotWarning: String { return self._s[3319]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[3320]! } - public var Call_ConnectionErrorTitle: String { return self._s[3321]! } - public var UserInfo_NotificationsEnable: String { return self._s[3322]! } - public var ArchivedChats_IntroText1: String { return self._s[3323]! } - public var Tour_Text4: String { return self._s[3326]! } - public var WallpaperSearch_Recent: String { return self._s[3327]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3328]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3329]! } - public var Profile_MessageLifetime2s: String { return self._s[3331]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3332]! } - public var Notification_MessageLifetime2s: String { return self._s[3333]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[3321]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3323]! } + public var Contacts_ShareTelegram: String { return self._s[3324]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3325]! } + public var Map_AddressOnMap: String { return self._s[3326]! } + public var Channel_ErrorAccessDenied: String { return self._s[3327]! } + public var UserInfo_ScamBotWarning: String { return self._s[3329]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[3330]! } + public var Call_ConnectionErrorTitle: String { return self._s[3331]! } + public var UserInfo_NotificationsEnable: String { return self._s[3332]! } + public var ArchivedChats_IntroText1: String { return self._s[3333]! } + public var Tour_Text4: String { return self._s[3336]! } + public var WallpaperSearch_Recent: String { return self._s[3337]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3338]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3339]! } + public var Profile_MessageLifetime2s: String { return self._s[3341]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3342]! } + public var Notification_MessageLifetime2s: String { return self._s[3343]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3334]!, self._r[3334]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3344]!, self._r[3344]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[3335]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3336]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3337]! } + public var Cache_ClearCache: String { return self._s[3345]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3346]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3347]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3341]!, self._r[3341]!, [_0]) + return formatWithArgumentRanges(self._s[3351]!, self._r[3351]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) + return formatWithArgumentRanges(self._s[3353]!, self._r[3353]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3344]! } - public var PeerInfo_PaneMembers: String { return self._s[3345]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3346]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3347]! } - public var ChatList_UnarchiveAction: String { return self._s[3348]! } - public var AutoNightTheme_Title: String { return self._s[3349]! } - public var InstantPage_FeedbackButton: String { return self._s[3350]! } - public var Passport_FieldAddress: String { return self._s[3351]! } + public var LocalGroup_Text: String { return self._s[3354]! } + public var PeerInfo_PaneMembers: String { return self._s[3355]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3356]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3357]! } + public var ChatList_UnarchiveAction: String { return self._s[3358]! } + public var AutoNightTheme_Title: String { return self._s[3359]! } + public var InstantPage_FeedbackButton: String { return self._s[3360]! } + public var Passport_FieldAddress: String { return self._s[3361]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3352]!, self._r[3352]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3362]!, self._r[3362]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3353]! } + public var Month_ShortMarch: String { return self._s[3363]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3354]!, self._r[3354]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3364]!, self._r[3364]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3355]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3356]! } - public var Passport_FloodError: String { return self._s[3357]! } - public var SecretGif_Title: String { return self._s[3358]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3359]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3360]! } - public var Passport_Language_th: String { return self._s[3362]! } - public var Passport_Address_Address: String { return self._s[3363]! } - public var Login_InvalidLastNameError: String { return self._s[3364]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3365]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3366]! } - public var ChatList_Context_Archive: String { return self._s[3367]! } - public var SettingsSearch_FAQ: String { return self._s[3368]! } - public var ShareMenu_Send: String { return self._s[3369]! } - public var ChatState_Connecting: String { return self._s[3370]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3372]! } - public var Month_GenNovember: String { return self._s[3374]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3376]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3365]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3366]! } + public var Passport_FloodError: String { return self._s[3367]! } + public var SecretGif_Title: String { return self._s[3368]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3369]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3370]! } + public var Passport_Language_th: String { return self._s[3372]! } + public var Passport_Address_Address: String { return self._s[3373]! } + public var Login_InvalidLastNameError: String { return self._s[3374]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3375]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3376]! } + public var ChatList_Context_Archive: String { return self._s[3377]! } + public var SettingsSearch_FAQ: String { return self._s[3378]! } + public var ShareMenu_Send: String { return self._s[3379]! } + public var ChatState_Connecting: String { return self._s[3380]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3382]! } + public var Month_GenNovember: String { return self._s[3384]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3386]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3377]!, self._r[3377]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3387]!, self._r[3387]!, [_1, _2]) } - public var ChatListFolder_CategoryChannels: String { return self._s[3378]! } - public var Conversation_SwipeToReplyHintText: String { return self._s[3379]! } - public var Checkout_Email: String { return self._s[3380]! } - public var NotificationsSound_Tritone: String { return self._s[3381]! } - public var Paint_Marker: String { return self._s[3383]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3385]! } - public var Wallet_ContextMenuCopy: String { return self._s[3387]! } + public var ChatListFolder_CategoryChannels: String { return self._s[3388]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3389]! } + public var Checkout_Email: String { return self._s[3390]! } + public var NotificationsSound_Tritone: String { return self._s[3391]! } + public var Paint_Marker: String { return self._s[3393]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3395]! } + public var Wallet_ContextMenuCopy: String { return self._s[3397]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3389]!, self._r[3389]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3399]!, self._r[3399]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3390]! } - public var Stickers_Installed: String { return self._s[3392]! } + public var Appearance_TextSize_Automatic: String { return self._s[3400]! } + public var Stickers_Installed: String { return self._s[3402]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3393]!, self._r[3393]!, [_1]) + return formatWithArgumentRanges(self._s[3403]!, self._r[3403]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3394]!, self._r[3394]!, [_0]) + return formatWithArgumentRanges(self._s[3404]!, self._r[3404]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3395]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3405]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3396]!, self._r[3396]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3406]!, self._r[3406]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3397]! } - public var Notification_Exceptions_Add: String { return self._s[3398]! } - public var DialogList_You: String { return self._s[3399]! } - public var ChatList_PsaLabel_covid: String { return self._s[3401]! } - public var MediaPicker_Send: String { return self._s[3403]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3404]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3405]! } - public var Call_AudioRouteSpeaker: String { return self._s[3406]! } - public var Watch_UserInfo_Title: String { return self._s[3407]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3408]! } - public var Appearance_AccentColor: String { return self._s[3410]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3407]! } + public var Notification_Exceptions_Add: String { return self._s[3408]! } + public var DialogList_You: String { return self._s[3409]! } + public var ChatList_PsaLabel_covid: String { return self._s[3411]! } + public var MediaPicker_Send: String { return self._s[3413]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3414]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3415]! } + public var Call_AudioRouteSpeaker: String { return self._s[3416]! } + public var Watch_UserInfo_Title: String { return self._s[3417]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3418]! } + public var Appearance_AccentColor: String { return self._s[3420]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3411]!, self._r[3411]!, [_0]) + return formatWithArgumentRanges(self._s[3421]!, self._r[3421]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3412]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3422]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3413]!, self._r[3413]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3423]!, self._r[3423]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3414]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3415]! } - public var Notification_CallOutgoing: String { return self._s[3416]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3417]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3418]! } - public var Call_RecordingDisabledMessage: String { return self._s[3419]! } - public var Message_Game: String { return self._s[3420]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3421]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3422]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3423]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3424]! } - public var Date_DialogDateFormat: String { return self._s[3426]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3427]! } - public var Notifications_InAppNotifications: String { return self._s[3428]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3424]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3425]! } + public var Notification_CallOutgoing: String { return self._s[3426]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3427]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3428]! } + public var Call_RecordingDisabledMessage: String { return self._s[3429]! } + public var Message_Game: String { return self._s[3430]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3431]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3432]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3433]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3434]! } + public var Date_DialogDateFormat: String { return self._s[3436]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3437]! } + public var Notifications_InAppNotifications: String { return self._s[3438]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3429]!, self._r[3429]!, [_0]) + return formatWithArgumentRanges(self._s[3439]!, self._r[3439]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3430]!, self._r[3430]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3440]!, self._r[3440]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3431]! } + public var NewContact_Title: String { return self._s[3441]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3432]!, self._r[3432]!, [_0]) + return formatWithArgumentRanges(self._s[3442]!, self._r[3442]!, [_0]) } - public var Stats_GroupTopPoster_Promote: String { return self._s[3433]! } - public var Conversation_ViewContactDetails: String { return self._s[3434]! } + public var Stats_GroupTopPoster_Promote: String { return self._s[3443]! } + public var Conversation_ViewContactDetails: String { return self._s[3444]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1]) + return formatWithArgumentRanges(self._s[3446]!, self._r[3446]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3437]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3438]! } - public var PrivacySettings_Title: String { return self._s[3439]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3442]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3443]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3444]! } - public var Contacts_PhoneNumber: String { return self._s[3445]! } - public var PeerInfo_ButtonMute: String { return self._s[3446]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3448]! } - public var Map_ShowPlaces: String { return self._s[3449]! } - public var ChatAdmins_Title: String { return self._s[3450]! } - public var InstantPage_Reference: String { return self._s[3452]! } - public var Wallet_Info_Updating: String { return self._s[3453]! } - public var ReportGroupLocation_Text: String { return self._s[3454]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3447]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3448]! } + public var PrivacySettings_Title: String { return self._s[3449]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3452]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3453]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3454]! } + public var Contacts_PhoneNumber: String { return self._s[3455]! } + public var PeerInfo_ButtonMute: String { return self._s[3456]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3458]! } + public var Map_ShowPlaces: String { return self._s[3459]! } + public var ChatAdmins_Title: String { return self._s[3460]! } + public var InstantPage_Reference: String { return self._s[3462]! } + public var Wallet_Info_Updating: String { return self._s[3463]! } + public var ReportGroupLocation_Text: String { return self._s[3464]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3455]!, self._r[3455]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3465]!, self._r[3465]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3456]! } - public var Watch_UserInfo_Block: String { return self._s[3457]! } - public var ChatSettings_Stickers: String { return self._s[3458]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3459]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3460]! } + public var Camera_FlashOff: String { return self._s[3466]! } + public var Watch_UserInfo_Block: String { return self._s[3467]! } + public var ChatSettings_Stickers: String { return self._s[3468]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3469]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3470]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3461]!, self._r[3461]!, [_0]) + return formatWithArgumentRanges(self._s[3471]!, self._r[3471]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3462]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3463]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3464]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3465]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3466]! } - public var VoiceOver_MessageContextShare: String { return self._s[3467]! } + public var Settings_ViewPhoto: String { return self._s[3472]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3473]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3474]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3475]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3476]! } + public var VoiceOver_MessageContextShare: String { return self._s[3477]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3469]!, self._r[3469]!, [_0]) + return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3470]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3471]! } + public var Privacy_DeleteDrafts: String { return self._s[3480]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3481]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3472]!, self._r[3472]!, [_0]) + return formatWithArgumentRanges(self._s[3482]!, self._r[3482]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3473]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3474]! } - public var DialogList_SavedMessages: String { return self._s[3475]! } - public var GroupInfo_UpgradeButton: String { return self._s[3476]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3478]! } - public var DialogList_Pin: String { return self._s[3479]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3483]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3484]! } + public var DialogList_SavedMessages: String { return self._s[3485]! } + public var GroupInfo_UpgradeButton: String { return self._s[3486]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3488]! } + public var DialogList_Pin: String { return self._s[3489]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3480]!, self._r[3480]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3490]!, self._r[3490]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3481]!, self._r[3481]!, [_0]) + return formatWithArgumentRanges(self._s[3491]!, self._r[3491]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3482]! } - public var UserInfo_NotificationsDisable: String { return self._s[3483]! } - public var Conversation_UnarchiveDone: String { return self._s[3484]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[3485]! } - public var Paint_Outlined: String { return self._s[3486]! } - public var Activity_PlayingGame: String { return self._s[3487]! } - public var SearchImages_NoImagesFound: String { return self._s[3488]! } - public var SocksProxySetup_ProxyType: String { return self._s[3489]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3491]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3492]! } - public var Settings_AppLanguage: String { return self._s[3493]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3494]! } - public var Common_ChoosePhoto: String { return self._s[3495]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3496]! } - public var CallFeedback_ReasonEcho: String { return self._s[3497]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3492]! } + public var UserInfo_NotificationsDisable: String { return self._s[3493]! } + public var Conversation_UnarchiveDone: String { return self._s[3494]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[3495]! } + public var Paint_Outlined: String { return self._s[3496]! } + public var Activity_PlayingGame: String { return self._s[3497]! } + public var SearchImages_NoImagesFound: String { return self._s[3498]! } + public var SocksProxySetup_ProxyType: String { return self._s[3499]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3501]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3502]! } + public var Settings_AppLanguage: String { return self._s[3503]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3504]! } + public var Common_ChoosePhoto: String { return self._s[3505]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3506]! } + public var CallFeedback_ReasonEcho: String { return self._s[3507]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3498]!, self._r[3498]!, [_1]) + return formatWithArgumentRanges(self._s[3508]!, self._r[3508]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3499]! } - public var PollResults_Collapse: String { return self._s[3500]! } - public var Activity_UploadingVideo: String { return self._s[3501]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3502]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3503]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3504]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3505]! } - public var PUSH_SENDER_YOU: String { return self._s[3506]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3507]! } - public var Checkout_PayWithTouchId: String { return self._s[3508]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3509]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3509]! } + public var PollResults_Collapse: String { return self._s[3510]! } + public var Activity_UploadingVideo: String { return self._s[3511]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3512]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3513]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3514]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3515]! } + public var PUSH_SENDER_YOU: String { return self._s[3516]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3517]! } + public var Checkout_PayWithTouchId: String { return self._s[3518]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3519]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3511]!, self._r[3511]!, [_1]) + return formatWithArgumentRanges(self._s[3521]!, self._r[3521]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3512]! } + public var Notifications_ExceptionsNone: String { return self._s[3522]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_0]) + return formatWithArgumentRanges(self._s[3523]!, self._r[3523]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_1]) + return formatWithArgumentRanges(self._s[3524]!, self._r[3524]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3516]! } - public var Passport_Address_Region: String { return self._s[3519]! } - public var ChatList_DeleteChat: String { return self._s[3520]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3521]! } - public var PhotoEditor_TiltShift: String { return self._s[3522]! } - public var Settings_FAQ_URL: String { return self._s[3523]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3524]! } - public var SharedMedia_TitleLink: String { return self._s[3527]! } - public var Settings_PrivacySettings: String { return self._s[3528]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3529]! } - public var Passport_Language_sl: String { return self._s[3530]! } - public var Settings_SetProfilePhoto: String { return self._s[3531]! } - public var Channel_About_Help: String { return self._s[3532]! } - public var Contacts_PermissionsEnable: String { return self._s[3533]! } - public var Wallet_Sending_Title: String { return self._s[3534]! } - public var PeerInfo_PaneMedia: String { return self._s[3535]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3536]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3537]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3539]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3540]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3541]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3542]! } - public var OldChannels_Title: String { return self._s[3543]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3544]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3546]! } - public var Map_OpenInYandexMaps: String { return self._s[3548]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3549]! } - public var VoiceOver_MessageContextReply: String { return self._s[3550]! } - public var ChatListFolder_DiscardConfirmation: String { return self._s[3552]! } - public var PhotoEditor_SaturationTool: String { return self._s[3553]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3526]! } + public var Passport_Address_Region: String { return self._s[3529]! } + public var ChatList_DeleteChat: String { return self._s[3530]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3531]! } + public var PhotoEditor_TiltShift: String { return self._s[3532]! } + public var Settings_FAQ_URL: String { return self._s[3533]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3534]! } + public var SharedMedia_TitleLink: String { return self._s[3537]! } + public var Settings_PrivacySettings: String { return self._s[3538]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3539]! } + public var Passport_Language_sl: String { return self._s[3540]! } + public var Settings_SetProfilePhoto: String { return self._s[3541]! } + public var Channel_About_Help: String { return self._s[3542]! } + public var Contacts_PermissionsEnable: String { return self._s[3543]! } + public var Wallet_Sending_Title: String { return self._s[3544]! } + public var PeerInfo_PaneMedia: String { return self._s[3545]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3546]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3547]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3549]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3550]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3551]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3552]! } + public var OldChannels_Title: String { return self._s[3553]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3554]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3556]! } + public var Map_OpenInYandexMaps: String { return self._s[3558]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3559]! } + public var VoiceOver_MessageContextReply: String { return self._s[3560]! } + public var ChatListFolder_DiscardConfirmation: String { return self._s[3562]! } + public var PhotoEditor_SaturationTool: String { return self._s[3563]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3554]!, self._r[3554]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3564]!, self._r[3564]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3555]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3556]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3557]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3565]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3566]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3567]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3558]!, self._r[3558]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3568]!, self._r[3568]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3559]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3561]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3562]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3569]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3571]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3572]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3563]!, self._r[3563]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3573]!, self._r[3573]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3564]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3574]! } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3565]!, self._r[3565]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3575]!, self._r[3575]!, [_1, _2, _3]) } - public var WallpaperPreview_PatternTitle: String { return self._s[3566]! } - public var GroupInfo_PublicLinkAdd: String { return self._s[3567]! } - public var Passport_PassportInformation: String { return self._s[3570]! } - public var Theme_Unsupported: String { return self._s[3571]! } - public var WatchRemote_AlertTitle: String { return self._s[3572]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3573]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3575]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3576]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3577]! } + public var Passport_PassportInformation: String { return self._s[3580]! } + public var Theme_Unsupported: String { return self._s[3581]! } + public var WatchRemote_AlertTitle: String { return self._s[3582]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3583]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3585]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3576]!, self._r[3576]!, [_0]) + return formatWithArgumentRanges(self._s[3586]!, self._r[3586]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3577]!, self._r[3577]!, [_1]) + return formatWithArgumentRanges(self._s[3587]!, self._r[3587]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3578]! } - public var Wallet_Navigation_Done: String { return self._s[3580]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3581]! } - public var AccessDenied_CameraDisabled: String { return self._s[3582]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3588]! } + public var Wallet_Navigation_Done: String { return self._s[3590]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3591]! } + public var AccessDenied_CameraDisabled: String { return self._s[3592]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3583]!, self._r[3583]!, [_0]) - } - public var ClearCache_Forever: String { return self._s[3584]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3585]! } - public var CreatePoll_Quiz: String { return self._s[3586]! } - public var PhotoEditor_ContrastTool: String { return self._s[3589]! } - public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3590]!, self._r[3590]!, [_1]) - } - public var DialogList_Draft: String { return self._s[3591]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3592]! } - public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3593]!, self._r[3593]!, [_0]) } - public var ChatList_PsaAlert_covid: String { return self._s[3594]! } - public var Privacy_TopPeersDelete: String { return self._s[3596]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3597]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3598]! } - public var WebSearch_RecentSectionClear: String { return self._s[3599]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3600]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3602]! } - public var PeerInfo_ButtonMore: String { return self._s[3604]! } - public var Common_Done: String { return self._s[3605]! } - public var Shortcut_SwitchAccount: String { return self._s[3606]! } - public var AuthSessions_EmptyText: String { return self._s[3607]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3608]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3609]! } - public var Tour_Title5: String { return self._s[3611]! } - public var Wallet_Settings_Title: String { return self._s[3612]! } + public var ClearCache_Forever: String { return self._s[3594]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3595]! } + public var CreatePoll_Quiz: String { return self._s[3596]! } + public var PhotoEditor_ContrastTool: String { return self._s[3599]! } + public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_1]) + } + public var DialogList_Draft: String { return self._s[3601]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3602]! } + public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3603]!, self._r[3603]!, [_0]) + } + public var ChatList_PsaAlert_covid: String { return self._s[3604]! } + public var Privacy_TopPeersDelete: String { return self._s[3606]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3607]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3608]! } + public var WebSearch_RecentSectionClear: String { return self._s[3609]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3610]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3612]! } + public var PeerInfo_ButtonMore: String { return self._s[3614]! } + public var Common_Done: String { return self._s[3615]! } + public var Shortcut_SwitchAccount: String { return self._s[3616]! } + public var AuthSessions_EmptyText: String { return self._s[3617]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3618]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3619]! } + public var Tour_Title5: String { return self._s[3621]! } + public var Wallet_Settings_Title: String { return self._s[3622]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3613]!, self._r[3613]!, [_0]) + return formatWithArgumentRanges(self._s[3623]!, self._r[3623]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3614]! } - public var Conversation_LinkDialogSave: String { return self._s[3615]! } - public var GroupInfo_ActionRestrict: String { return self._s[3616]! } - public var Checkout_Title: String { return self._s[3618]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3620]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3622]! } - public var Notification_RenamedGroup: String { return self._s[3623]! } - public var PeopleNearby_Groups: String { return self._s[3624]! } - public var Checkout_PayWithFaceId: String { return self._s[3625]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3626]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3628]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3629]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3630]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3624]! } + public var Conversation_LinkDialogSave: String { return self._s[3625]! } + public var GroupInfo_ActionRestrict: String { return self._s[3626]! } + public var Checkout_Title: String { return self._s[3628]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3630]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3632]! } + public var Notification_RenamedGroup: String { return self._s[3633]! } + public var PeopleNearby_Groups: String { return self._s[3634]! } + public var Checkout_PayWithFaceId: String { return self._s[3635]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3636]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3638]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3639]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3640]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3631]!, self._r[3631]!, [_0]) + return formatWithArgumentRanges(self._s[3641]!, self._r[3641]!, [_0]) } - public var Stats_GroupGrowthTitle: String { return self._s[3632]! } - public var Profile_AddToExisting: String { return self._s[3634]! } + public var Stats_GroupGrowthTitle: String { return self._s[3642]! } + public var Profile_AddToExisting: String { return self._s[3644]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3635]!, self._r[3635]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3645]!, self._r[3645]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3637]! } - public var Permissions_PrivacyPolicy: String { return self._s[3639]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3640]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3641]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3643]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3645]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3646]! } + public var Cache_Files: String { return self._s[3647]! } + public var Permissions_PrivacyPolicy: String { return self._s[3649]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3650]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3651]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3653]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3655]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3656]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3647]!, self._r[3647]!, [_0]) + return formatWithArgumentRanges(self._s[3657]!, self._r[3657]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3648]! } - public var VoiceOver_AttachMedia: String { return self._s[3651]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3652]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3658]! } + public var VoiceOver_AttachMedia: String { return self._s[3661]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3662]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3653]!, self._r[3653]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3663]!, self._r[3663]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3654]! } - public var Conversation_SetReminder_Title: String { return self._s[3655]! } - public var Passport_FieldAddressHelp: String { return self._s[3656]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3657]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3658]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3664]! } + public var Conversation_SetReminder_Title: String { return self._s[3665]! } + public var Passport_FieldAddressHelp: String { return self._s[3666]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3667]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3668]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3659]!, self._r[3659]!, [_0]) + return formatWithArgumentRanges(self._s[3669]!, self._r[3669]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3660]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3661]! } - public var Login_UnknownError: String { return self._s[3662]! } - public var Group_UpgradeNoticeText2: String { return self._s[3665]! } - public var Watch_Compose_AddContact: String { return self._s[3666]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3667]! } - public var Web_Error: String { return self._s[3668]! } - public var Paint_Neon: String { return self._s[3669]! } - public var Gif_Search: String { return self._s[3670]! } - public var Profile_MessageLifetime1h: String { return self._s[3671]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3672]! } - public var Channel_Username_CheckingUsername: String { return self._s[3673]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3674]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3675]! } - public var Channel_AboutItem: String { return self._s[3676]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3679]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3680]! } - public var GroupInfo_SharedMedia: String { return self._s[3681]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3670]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3671]! } + public var Login_UnknownError: String { return self._s[3672]! } + public var Group_UpgradeNoticeText2: String { return self._s[3675]! } + public var Watch_Compose_AddContact: String { return self._s[3676]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3677]! } + public var Web_Error: String { return self._s[3678]! } + public var Paint_Neon: String { return self._s[3679]! } + public var Gif_Search: String { return self._s[3680]! } + public var Profile_MessageLifetime1h: String { return self._s[3681]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3682]! } + public var Channel_Username_CheckingUsername: String { return self._s[3683]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3684]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3685]! } + public var Channel_AboutItem: String { return self._s[3686]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3689]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3690]! } + public var GroupInfo_SharedMedia: String { return self._s[3691]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3682]!, self._r[3682]!, [_1]) + return formatWithArgumentRanges(self._s[3692]!, self._r[3692]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3683]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3693]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3684]!, self._r[3684]!, [_1]) + return formatWithArgumentRanges(self._s[3694]!, self._r[3694]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3685]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3686]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3687]! } - public var CreatePoll_AddOption: String { return self._s[3688]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3689]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3690]! } - public var Channel_Management_AddModerator: String { return self._s[3691]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3692]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3693]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3694]! } - public var Theme_Colors_Background: String { return self._s[3695]! } - public var NotificationsSound_Hello: String { return self._s[3698]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3700]! } - public var Channel_Stickers_Placeholder: String { return self._s[3702]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3695]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3696]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3697]! } + public var CreatePoll_AddOption: String { return self._s[3698]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3699]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3700]! } + public var Channel_Management_AddModerator: String { return self._s[3701]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3702]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3703]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3704]! } + public var Theme_Colors_Background: String { return self._s[3705]! } + public var NotificationsSound_Hello: String { return self._s[3708]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3710]! } + public var Channel_Stickers_Placeholder: String { return self._s[3712]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3703]!, self._r[3703]!, [_0]) + return formatWithArgumentRanges(self._s[3713]!, self._r[3713]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3704]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3705]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3706]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3707]! } - public var AutoDownloadSettings_Channels: String { return self._s[3708]! } - public var Passport_Language_mn: String { return self._s[3709]! } - public var Settings_ChatFolders: String { return self._s[3710]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3714]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3715]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3716]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3717]! } + public var AutoDownloadSettings_Channels: String { return self._s[3718]! } + public var Passport_Language_mn: String { return self._s[3719]! } + public var Settings_ChatFolders: String { return self._s[3720]! } public func ChatList_AddedToFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3711]!, self._r[3711]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3721]!, self._r[3721]!, [_1, _2]) } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3714]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3715]! } - public var Passport_Language_ja: String { return self._s[3717]! } - public var Settings_About_Title: String { return self._s[3718]! } - public var Settings_NotificationsAndSounds: String { return self._s[3719]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3720]! } - public var Settings_BlockedUsers: String { return self._s[3721]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3724]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3725]! } + public var Passport_Language_ja: String { return self._s[3727]! } + public var Settings_About_Title: String { return self._s[3728]! } + public var Settings_NotificationsAndSounds: String { return self._s[3729]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3730]! } + public var Settings_BlockedUsers: String { return self._s[3731]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3722]!, self._r[3722]!, [_0]) + return formatWithArgumentRanges(self._s[3732]!, self._r[3732]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3723]! } - public var Wallet_Weekday_Today: String { return self._s[3724]! } - public var ChatListFolderSettings_AddRecommended: String { return self._s[3725]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3726]! } - public var Widget_ApplicationLocked: String { return self._s[3727]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3728]! } - public var Channel_Username_Title: String { return self._s[3729]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3733]! } + public var Wallet_Weekday_Today: String { return self._s[3734]! } + public var ChatListFolderSettings_AddRecommended: String { return self._s[3735]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3736]! } + public var Widget_ApplicationLocked: String { return self._s[3737]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3738]! } + public var Channel_Username_Title: String { return self._s[3739]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3730]!, self._r[3730]!, [_0]) + return formatWithArgumentRanges(self._s[3740]!, self._r[3740]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3732]! } - public var AppleWatch_Title: String { return self._s[3733]! } - public var Activity_RecordingVideoMessage: String { return self._s[3734]! } + public var AttachmentMenu_File: String { return self._s[3742]! } + public var AppleWatch_Title: String { return self._s[3743]! } + public var Activity_RecordingVideoMessage: String { return self._s[3744]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3735]!, self._r[3735]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3745]!, self._r[3745]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3736]! } - public var Weekday_Saturday: String { return self._s[3737]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3738]! } - public var Conversation_Timer_Send: String { return self._s[3739]! } - public var Settings_CancelUpload: String { return self._s[3740]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3741]! } - public var Common_Next: String { return self._s[3743]! } - public var Channel_Stickers_YourStickers: String { return self._s[3745]! } - public var Message_Theme: String { return self._s[3746]! } - public var Call_AudioRouteHeadphones: String { return self._s[3747]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3749]! } - public var Watch_Contacts_NoResults: String { return self._s[3751]! } - public var PhotoEditor_TintTool: String { return self._s[3754]! } - public var LoginPassword_ResetAccount: String { return self._s[3756]! } - public var Settings_SavedMessages: String { return self._s[3757]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3758]! } - public var Bot_GenericSupportStatus: String { return self._s[3759]! } - public var StickerPack_Add: String { return self._s[3760]! } - public var Checkout_TotalAmount: String { return self._s[3761]! } - public var Your_cards_number_is_invalid: String { return self._s[3762]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3763]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3764]! } + public var Theme_Colors_Messages: String { return self._s[3746]! } + public var Weekday_Saturday: String { return self._s[3747]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3748]! } + public var Conversation_Timer_Send: String { return self._s[3749]! } + public var Settings_CancelUpload: String { return self._s[3750]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3751]! } + public var Common_Next: String { return self._s[3753]! } + public var Channel_Stickers_YourStickers: String { return self._s[3755]! } + public var Message_Theme: String { return self._s[3756]! } + public var Call_AudioRouteHeadphones: String { return self._s[3757]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3759]! } + public var Watch_Contacts_NoResults: String { return self._s[3761]! } + public var PhotoEditor_TintTool: String { return self._s[3764]! } + public var LoginPassword_ResetAccount: String { return self._s[3766]! } + public var Settings_SavedMessages: String { return self._s[3767]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3768]! } + public var Bot_GenericSupportStatus: String { return self._s[3769]! } + public var StickerPack_Add: String { return self._s[3770]! } + public var Checkout_TotalAmount: String { return self._s[3771]! } + public var Your_cards_number_is_invalid: String { return self._s[3772]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3773]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3774]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3765]!, self._r[3765]!, [_0]) + return formatWithArgumentRanges(self._s[3775]!, self._r[3775]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3766]!, self._r[3766]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3776]!, self._r[3776]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3767]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3777]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3769]!, self._r[3769]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3779]!, self._r[3779]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3770]!, self._r[3770]!, [_0]) + return formatWithArgumentRanges(self._s[3780]!, self._r[3780]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3771]! } - public var StickerPack_Share: String { return self._s[3772]! } - public var Passport_DeleteAddress: String { return self._s[3773]! } - public var Settings_Passport: String { return self._s[3774]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3775]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3776]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3777]! } - public var Contacts_PermissionsText: String { return self._s[3778]! } - public var Group_Setup_HistoryVisible: String { return self._s[3779]! } - public var Wallet_Month_ShortDecember: String { return self._s[3781]! } - public var PrivacySettings_AutoArchiveTitle: String { return self._s[3783]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3784]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3785]! } - public var SocksProxySetup_Title: String { return self._s[3786]! } - public var Notification_Mute1h: String { return self._s[3787]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3781]! } + public var StickerPack_Share: String { return self._s[3782]! } + public var Passport_DeleteAddress: String { return self._s[3783]! } + public var Settings_Passport: String { return self._s[3784]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3785]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3786]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3787]! } + public var Contacts_PermissionsText: String { return self._s[3788]! } + public var Group_Setup_HistoryVisible: String { return self._s[3789]! } + public var Wallet_Month_ShortDecember: String { return self._s[3791]! } + public var PrivacySettings_AutoArchiveTitle: String { return self._s[3793]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3794]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3795]! } + public var SocksProxySetup_Title: String { return self._s[3796]! } + public var Notification_Mute1h: String { return self._s[3797]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3788]!, self._r[3788]!, [_0]) + return formatWithArgumentRanges(self._s[3798]!, self._r[3798]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3789]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3799]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3790]!, self._r[3790]!, [_1]) + return formatWithArgumentRanges(self._s[3800]!, self._r[3800]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3791]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3794]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3796]! } - public var DialogList_NoMessagesText: String { return self._s[3797]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3798]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3799]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3801]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3802]! } - public var Common_TakePhotoOrVideo: String { return self._s[3803]! } - public var Wallet_Words_Text: String { return self._s[3804]! } - public var Call_StatusBusy: String { return self._s[3805]! } - public var Conversation_PinnedMessage: String { return self._s[3806]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3807]! } - public var ChatList_EmptyChatListNewMessage: String { return self._s[3808]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3809]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3810]! } - public var Undo_ChatCleared: String { return self._s[3811]! } - public var CreatePoll_Explanation: String { return self._s[3812]! } - public var AppleWatch_ReplyPresets: String { return self._s[3813]! } - public var Passport_DiscardMessageDescription: String { return self._s[3815]! } - public var Login_NetworkError: String { return self._s[3816]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3801]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3804]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3806]! } + public var DialogList_NoMessagesText: String { return self._s[3807]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3808]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3809]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3811]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3812]! } + public var Common_TakePhotoOrVideo: String { return self._s[3813]! } + public var Wallet_Words_Text: String { return self._s[3814]! } + public var Call_StatusBusy: String { return self._s[3815]! } + public var Conversation_PinnedMessage: String { return self._s[3816]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3817]! } + public var ChatList_EmptyChatListNewMessage: String { return self._s[3818]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3819]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3820]! } + public var Undo_ChatCleared: String { return self._s[3821]! } + public var CreatePoll_Explanation: String { return self._s[3822]! } + public var AppleWatch_ReplyPresets: String { return self._s[3823]! } + public var Passport_DiscardMessageDescription: String { return self._s[3825]! } + public var Login_NetworkError: String { return self._s[3826]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3817]!, self._r[3817]!, [_0]) + return formatWithArgumentRanges(self._s[3827]!, self._r[3827]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3818]!, self._r[3818]!, [_0]) + return formatWithArgumentRanges(self._s[3828]!, self._r[3828]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3819]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3821]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3822]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3829]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3831]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3832]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3824]!, self._r[3824]!, [_0]) + return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3825]! } - public var VoiceOver_Chat_Music: String { return self._s[3826]! } - public var ChatListFolder_CategoryContacts: String { return self._s[3827]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3828]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3830]! } - public var ConversationMedia_Title: String { return self._s[3831]! } - public var EncryptionKey_Title: String { return self._s[3833]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3834]! } - public var Notification_Exceptions_AddException: String { return self._s[3835]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3836]! } - public var Profile_MessageLifetime1m: String { return self._s[3837]! } + public var Call_ConnectionErrorMessage: String { return self._s[3835]! } + public var VoiceOver_Chat_Music: String { return self._s[3836]! } + public var ChatListFolder_CategoryContacts: String { return self._s[3837]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3838]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3840]! } + public var ConversationMedia_Title: String { return self._s[3841]! } + public var EncryptionKey_Title: String { return self._s[3843]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3844]! } + public var Notification_Exceptions_AddException: String { return self._s[3845]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3846]! } + public var Profile_MessageLifetime1m: String { return self._s[3847]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3838]!, self._r[3838]!, [_1]) + return formatWithArgumentRanges(self._s[3848]!, self._r[3848]!, [_1]) } - public var Month_GenMay: String { return self._s[3839]! } + public var Month_GenMay: String { return self._s[3849]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3840]!, self._r[3840]!, [_0]) + return formatWithArgumentRanges(self._s[3850]!, self._r[3850]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3841]! } - public var Wallet_Send_AddressInfo: String { return self._s[3842]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3843]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3844]! } + public var PeopleNearby_Users: String { return self._s[3851]! } + public var Wallet_Send_AddressInfo: String { return self._s[3852]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3853]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3854]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3846]!, self._r[3846]!, [_0]) + return formatWithArgumentRanges(self._s[3856]!, self._r[3856]!, [_0]) } - public var Stats_LoadingTitle: String { return self._s[3847]! } - public var Conversation_EmptyPlaceholder: String { return self._s[3848]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3849]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3850]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3851]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3852]! } - public var Channel_JoinChannel: String { return self._s[3855]! } - public var Appearance_Animations: String { return self._s[3858]! } + public var Stats_LoadingTitle: String { return self._s[3857]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3858]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3859]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3860]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3861]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3862]! } + public var Channel_JoinChannel: String { return self._s[3865]! } + public var Appearance_Animations: String { return self._s[3868]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3859]!, self._r[3859]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3869]!, self._r[3869]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3861]! } - public var Appearance_ShareTheme: String { return self._s[3862]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3863]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3867]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3868]! } - public var Passport_Address_Street: String { return self._s[3869]! } - public var Conversation_AddContact: String { return self._s[3870]! } - public var Login_PhonePlaceholder: String { return self._s[3871]! } - public var Channel_Members_InviteLink: String { return self._s[3873]! } - public var Bot_Stop: String { return self._s[3874]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3876]! } - public var Notification_PassportValueAddress: String { return self._s[3877]! } - public var Month_ShortJuly: String { return self._s[3878]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3879]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3880]! } - public var Passport_Identity_ReverseSide: String { return self._s[3881]! } + public var Stickers_GroupStickers: String { return self._s[3871]! } + public var Appearance_ShareTheme: String { return self._s[3872]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3873]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3877]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3878]! } + public var Passport_Address_Street: String { return self._s[3879]! } + public var Conversation_AddContact: String { return self._s[3880]! } + public var Login_PhonePlaceholder: String { return self._s[3881]! } + public var Channel_Members_InviteLink: String { return self._s[3883]! } + public var Bot_Stop: String { return self._s[3884]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3886]! } + public var Notification_PassportValueAddress: String { return self._s[3887]! } + public var Month_ShortJuly: String { return self._s[3888]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3889]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3890]! } + public var Passport_Identity_ReverseSide: String { return self._s[3891]! } public func Call_ParticipantVideoVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3883]!, self._r[3883]!, [_0]) + return formatWithArgumentRanges(self._s[3893]!, self._r[3893]!, [_0]) } - public var Watch_Stickers_Recents: String { return self._s[3886]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3888]! } - public var Map_SendThisLocation: String { return self._s[3889]! } + public var Watch_Stickers_Recents: String { return self._s[3896]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3898]! } + public var Map_SendThisLocation: String { return self._s[3899]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3890]!, self._r[3890]!, [_0]) + return formatWithArgumentRanges(self._s[3900]!, self._r[3900]!, [_0]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3891]!, self._r[3891]!, [_0]) + return formatWithArgumentRanges(self._s[3901]!, self._r[3901]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3892]! } - public var Wallet_Intro_NotNow: String { return self._s[3893]! } - public var Stats_GroupMembers: String { return self._s[3894]! } + public var ConvertToSupergroup_Note: String { return self._s[3902]! } + public var Wallet_Intro_NotNow: String { return self._s[3903]! } + public var Stats_GroupMembers: String { return self._s[3904]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3895]!, self._r[3895]!, [_0]) + return formatWithArgumentRanges(self._s[3905]!, self._r[3905]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3896]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3906]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3897]!, self._r[3897]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3907]!, self._r[3907]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3899]! } - public var Wallpaper_SearchShort: String { return self._s[3900]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3902]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3903]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3904]! } + public var Login_CallRequestState3: String { return self._s[3909]! } + public var Wallpaper_SearchShort: String { return self._s[3910]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3912]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3913]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3914]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3905]!, self._r[3905]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3915]!, self._r[3915]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3906]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3908]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3911]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3916]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3918]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3921]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3912]!, self._r[3912]!, [_0]) + return formatWithArgumentRanges(self._s[3922]!, self._r[3922]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3913]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3914]! } + public var Passport_CorrectErrors: String { return self._s[3923]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3924]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3915]!, self._r[3915]!, [_0]) + return formatWithArgumentRanges(self._s[3925]!, self._r[3925]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3916]! } - public var Channel_DiscussionGroup: String { return self._s[3918]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3919]! } + public var Map_SendMyCurrentLocation: String { return self._s[3926]! } + public var Channel_DiscussionGroup: String { return self._s[3928]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3929]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3920]!, self._r[3920]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3930]!, self._r[3930]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3921]! } - public var Permissions_NotificationsText_v0: String { return self._s[3922]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3923]! } - public var Appearance_AppIcon: String { return self._s[3924]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3925]! } - public var LoginPassword_FloodError: String { return self._s[3926]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3928]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3929]! } + public var SharedMedia_SearchNoResults: String { return self._s[3931]! } + public var Permissions_NotificationsText_v0: String { return self._s[3932]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3933]! } + public var Appearance_AppIcon: String { return self._s[3934]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3935]! } + public var LoginPassword_FloodError: String { return self._s[3936]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3938]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3939]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3930]!, self._r[3930]!, [_0]) + return formatWithArgumentRanges(self._s[3940]!, self._r[3940]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3931]! } + public var Passport_Language_bn: String { return self._s[3941]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3932]!, self._r[3932]!, [_0]) + return formatWithArgumentRanges(self._s[3942]!, self._r[3942]!, [_0]) } - public var ChatList_Context_Pin: String { return self._s[3933]! } + public var ChatList_Context_Pin: String { return self._s[3943]! } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3934]!, self._r[3934]!, [_0]) + return formatWithArgumentRanges(self._s[3944]!, self._r[3944]!, [_0]) } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3935]!, self._r[3935]!, [_0]) + return formatWithArgumentRanges(self._s[3945]!, self._r[3945]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3936]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3940]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3942]! } - public var Wallet_Month_GenDecember: String { return self._s[3943]! } - public var Contacts_PermissionsAllow: String { return self._s[3944]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3945]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3946]! } - public var WallpaperPreview_Pattern: String { return self._s[3947]! } - public var Paint_Duplicate: String { return self._s[3948]! } - public var Passport_Address_Country: String { return self._s[3949]! } - public var Notification_RenamedChannel: String { return self._s[3951]! } - public var DialogList_UnknownPinLimitError: String { return self._s[3952]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3953]! } - public var ChatList_Context_Unmute: String { return self._s[3954]! } - public var KeyCommand_SearchInChat: String { return self._s[3955]! } - public var Group_MessagePhotoUpdated: String { return self._s[3956]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3957]! } - public var Conversation_ContextMenuBan: String { return self._s[3958]! } - public var TwoStepAuth_EmailSent: String { return self._s[3959]! } - public var Settings_SetProfilePhotoOrVideo: String { return self._s[3960]! } - public var MessagePoll_NoVotes: String { return self._s[3961]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3962]! } - public var Passport_Language_is: String { return self._s[3964]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3966]! } - public var Tour_Text5: String { return self._s[3967]! } + public var Wallet_Navigation_Close: String { return self._s[3946]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3950]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3952]! } + public var Wallet_Month_GenDecember: String { return self._s[3953]! } + public var Contacts_PermissionsAllow: String { return self._s[3954]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3955]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3956]! } + public var WallpaperPreview_Pattern: String { return self._s[3957]! } + public var Paint_Duplicate: String { return self._s[3958]! } + public var Passport_Address_Country: String { return self._s[3959]! } + public var Notification_RenamedChannel: String { return self._s[3961]! } + public var DialogList_UnknownPinLimitError: String { return self._s[3962]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3963]! } + public var ChatList_Context_Unmute: String { return self._s[3964]! } + public var KeyCommand_SearchInChat: String { return self._s[3965]! } + public var Group_MessagePhotoUpdated: String { return self._s[3966]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3967]! } + public var Conversation_ContextMenuBan: String { return self._s[3968]! } + public var TwoStepAuth_EmailSent: String { return self._s[3969]! } + public var Settings_SetProfilePhotoOrVideo: String { return self._s[3970]! } + public var MessagePoll_NoVotes: String { return self._s[3971]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3972]! } + public var Passport_Language_is: String { return self._s[3974]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3976]! } + public var Tour_Text5: String { return self._s[3977]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3970]!, self._r[3970]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3980]!, self._r[3980]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3971]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3972]! } + public var Undo_SecretChatDeleted: String { return self._s[3981]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3982]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3973]!, self._r[3973]!, [_0]) + return formatWithArgumentRanges(self._s[3983]!, self._r[3983]!, [_0]) } - public var Forward_ErrorDisabledForChat: String { return self._s[3974]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3976]! } - public var Paint_Edit: String { return self._s[3978]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3980]! } - public var Undo_DeletedGroup: String { return self._s[3982]! } - public var LoginPassword_ForgotPassword: String { return self._s[3983]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3984]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3985]! } + public var Forward_ErrorDisabledForChat: String { return self._s[3984]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3986]! } + public var Paint_Edit: String { return self._s[3988]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3990]! } + public var Undo_DeletedGroup: String { return self._s[3992]! } + public var LoginPassword_ForgotPassword: String { return self._s[3993]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3994]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3995]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3986]!, self._r[3986]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3996]!, self._r[3996]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3987]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3988]! } - public var Conversation_ContextMenuMention: String { return self._s[3989]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3990]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3991]! } - public var Passport_Language_uz: String { return self._s[3992]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3993]! } - public var Channel_MessageVideoUpdated: String { return self._s[3995]! } - public var Map_StopLiveLocation: String { return self._s[3996]! } - public var VoiceOver_MessageContextSend: String { return self._s[3998]! } - public var PasscodeSettings_Help: String { return self._s[3999]! } - public var NotificationsSound_Input: String { return self._s[4000]! } - public var ProfilePhoto_MainVideo: String { return self._s[4002]! } - public var Share_Title: String { return self._s[4004]! } - public var LogoutOptions_Title: String { return self._s[4005]! } - public var Wallet_Send_AddressText: String { return self._s[4006]! } - public var Login_TermsOfServiceAgree: String { return self._s[4007]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[4008]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[4009]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[4010]! } - public var EnterPasscode_EnterTitle: String { return self._s[4011]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3997]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3998]! } + public var Conversation_ContextMenuMention: String { return self._s[3999]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[4000]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[4001]! } + public var Passport_Language_uz: String { return self._s[4002]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[4003]! } + public var Channel_MessageVideoUpdated: String { return self._s[4005]! } + public var Map_StopLiveLocation: String { return self._s[4006]! } + public var VoiceOver_MessageContextSend: String { return self._s[4008]! } + public var PasscodeSettings_Help: String { return self._s[4009]! } + public var NotificationsSound_Input: String { return self._s[4010]! } + public var ProfilePhoto_MainVideo: String { return self._s[4012]! } + public var Share_Title: String { return self._s[4014]! } + public var LogoutOptions_Title: String { return self._s[4015]! } + public var Wallet_Send_AddressText: String { return self._s[4016]! } + public var Login_TermsOfServiceAgree: String { return self._s[4017]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[4018]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[4019]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[4020]! } + public var EnterPasscode_EnterTitle: String { return self._s[4021]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4012]!, self._r[4012]!, [_0]) + return formatWithArgumentRanges(self._s[4022]!, self._r[4022]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[4013]! } - public var Conversation_AddToContacts: String { return self._s[4014]! } + public var Settings_CopyPhoneNumber: String { return self._s[4023]! } + public var Conversation_AddToContacts: String { return self._s[4024]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4015]!, self._r[4015]!, [_0]) + return formatWithArgumentRanges(self._s[4025]!, self._r[4025]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[4016]! } + public var NotificationsSound_Keys: String { return self._s[4026]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4017]!, self._r[4017]!, [_0]) - } - public var Notification_MessageLifetime1w: String { return self._s[4018]! } - public var Message_Video: String { return self._s[4019]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[4020]! } - public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4021]!, self._r[4021]!, [_1]) - } - public var Wallet_Receive_AmountInfo: String { return self._s[4024]! } - public var Stats_Overview: String { return self._s[4025]! } - public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4026]!, self._r[4026]!, [_0]) - } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4027]!, self._r[4027]!, [_0]) } - public var ChatListFolder_ExcludeChatsTitle: String { return self._s[4028]! } - public var Passport_Language_mk: String { return self._s[4029]! } - public var ChatListFolder_CategoryNonContacts: String { return self._s[4030]! } - public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4031]!, self._r[4031]!, [_1, _2, _3]) + public var Notification_MessageLifetime1w: String { return self._s[4028]! } + public var Message_Video: String { return self._s[4029]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[4030]! } + public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4031]!, self._r[4031]!, [_1]) } - public var CreatePoll_CancelConfirmation: String { return self._s[4032]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[4033]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[4035]! } - public var PrivacyPolicy_Decline: String { return self._s[4036]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[4037]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[4038]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[4039]! } - public var Permissions_SiriAllow_v0: String { return self._s[4041]! } - public var Wallet_Month_ShortAugust: String { return self._s[4042]! } - public var Appearance_ThemeCarouselNight: String { return self._s[4043]! } + public var Wallet_Receive_AmountInfo: String { return self._s[4034]! } + public var Stats_Overview: String { return self._s[4035]! } + public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4036]!, self._r[4036]!, [_0]) + } + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4037]!, self._r[4037]!, [_0]) + } + public var ChatListFolder_ExcludeChatsTitle: String { return self._s[4038]! } + public var Passport_Language_mk: String { return self._s[4039]! } + public var ChatListFolder_CategoryNonContacts: String { return self._s[4040]! } + public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4041]!, self._r[4041]!, [_1, _2, _3]) + } + public var CreatePoll_CancelConfirmation: String { return self._s[4042]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[4043]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[4045]! } + public var PrivacyPolicy_Decline: String { return self._s[4046]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[4047]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[4048]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[4049]! } + public var Permissions_SiriAllow_v0: String { return self._s[4051]! } + public var Wallet_Month_ShortAugust: String { return self._s[4052]! } + public var Appearance_ThemeCarouselNight: String { return self._s[4053]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4044]!, self._r[4044]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[4054]!, self._r[4054]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4045]!, self._r[4045]!, [_0]) + return formatWithArgumentRanges(self._s[4055]!, self._r[4055]!, [_0]) } - public var Paint_Regular: String { return self._s[4046]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[4047]! } - public var SocksProxySetup_ShareLink: String { return self._s[4048]! } - public var Wallet_Qr_Title: String { return self._s[4049]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[4050]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[4052]! } - public var Wallet_Settings_Configuration: String { return self._s[4053]! } - public var GroupInfo_InviteByLink: String { return self._s[4054]! } - public var MessageTimer_Custom: String { return self._s[4055]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[4056]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[4057]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[4059]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[4060]! } - public var VoiceOver_Chat_Selected: String { return self._s[4061]! } - public var Paint_Pen: String { return self._s[4062]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[4063]! } - public var Channel_Username_InvalidTaken: String { return self._s[4064]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[4065]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[4066]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[4067]! } - public var Settings_ChatBackground: String { return self._s[4068]! } - public var Channel_Subscribers_Title: String { return self._s[4069]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[4070]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[4071]! } - public var Watch_ConnectionDescription: String { return self._s[4072]! } - public var OldChannels_NoticeText: String { return self._s[4075]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[4076]! } - public var IntentsSettings_SuggestBy: String { return self._s[4078]! } - public var Theme_ThemeChangedText: String { return self._s[4079]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[4080]! } - public var Wallpaper_ResetWallpapers: String { return self._s[4081]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[4082]! } - public var Conversation_SendDice: String { return self._s[4083]! } - public var EditProfile_Title: String { return self._s[4084]! } - public var NotificationsSound_Bamboo: String { return self._s[4086]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[4088]! } - public var Login_SmsRequestState2: String { return self._s[4089]! } - public var Passport_Language_ar: String { return self._s[4090]! } + public var Paint_Regular: String { return self._s[4056]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[4057]! } + public var SocksProxySetup_ShareLink: String { return self._s[4058]! } + public var Wallet_Qr_Title: String { return self._s[4059]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[4060]! } + public var ChatList_Search_FilterMusic: String { return self._s[4061]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[4063]! } + public var Wallet_Settings_Configuration: String { return self._s[4064]! } + public var GroupInfo_InviteByLink: String { return self._s[4065]! } + public var MessageTimer_Custom: String { return self._s[4066]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[4067]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[4068]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[4070]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[4071]! } + public var VoiceOver_Chat_Selected: String { return self._s[4072]! } + public var Paint_Pen: String { return self._s[4073]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[4074]! } + public var Channel_Username_InvalidTaken: String { return self._s[4075]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[4076]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[4077]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[4078]! } + public var Settings_ChatBackground: String { return self._s[4079]! } + public var Channel_Subscribers_Title: String { return self._s[4080]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[4081]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[4082]! } + public var Watch_ConnectionDescription: String { return self._s[4083]! } + public var OldChannels_NoticeText: String { return self._s[4086]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[4087]! } + public var IntentsSettings_SuggestBy: String { return self._s[4089]! } + public var Theme_ThemeChangedText: String { return self._s[4090]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[4091]! } + public var Wallpaper_ResetWallpapers: String { return self._s[4092]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[4093]! } + public var Conversation_SendDice: String { return self._s[4094]! } + public var EditProfile_Title: String { return self._s[4095]! } + public var NotificationsSound_Bamboo: String { return self._s[4097]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[4099]! } + public var Login_SmsRequestState2: String { return self._s[4100]! } + public var Passport_Language_ar: String { return self._s[4101]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4091]!, self._r[4091]!, [_0]) + return formatWithArgumentRanges(self._s[4102]!, self._r[4102]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[4092]! } - public var Wallet_Created_Text: String { return self._s[4093]! } - public var Conversation_MessageDialogEdit: String { return self._s[4095]! } - public var Wallet_Created_Proceed: String { return self._s[4096]! } - public var Wallet_Words_Done: String { return self._s[4097]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[4098]! } - public var ChatListFolder_NameChannels: String { return self._s[4099]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[4103]! } + public var Wallet_Created_Text: String { return self._s[4104]! } + public var Conversation_MessageDialogEdit: String { return self._s[4106]! } + public var Wallet_Created_Proceed: String { return self._s[4107]! } + public var Wallet_Words_Done: String { return self._s[4108]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[4109]! } + public var ChatListFolder_NameChannels: String { return self._s[4110]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4100]!, self._r[4100]!, [_1]) + return formatWithArgumentRanges(self._s[4111]!, self._r[4111]!, [_1]) } - public var Common_Close: String { return self._s[4102]! } - public var GroupInfo_PublicLink: String { return self._s[4103]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[4104]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[4105]! } - public var Conversation_ContextMenuOpenChannel: String { return self._s[4109]! } + public var Common_Close: String { return self._s[4113]! } + public var GroupInfo_PublicLink: String { return self._s[4114]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[4115]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[4116]! } + public var Conversation_ContextMenuOpenChannel: String { return self._s[4120]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4110]!, self._r[4110]!, [_0]) + return formatWithArgumentRanges(self._s[4121]!, self._r[4121]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[4111]! } + public var UserInfo_About_Placeholder: String { return self._s[4122]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4112]!, self._r[4112]!, [_0]) + return formatWithArgumentRanges(self._s[4123]!, self._r[4123]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[4113]! } - public var Channel_Info_Banned: String { return self._s[4115]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[4124]! } + public var Channel_Info_Banned: String { return self._s[4126]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4116]!, self._r[4116]!, [_0]) + return formatWithArgumentRanges(self._s[4127]!, self._r[4127]!, [_0]) } - public var Appearance_Other: String { return self._s[4117]! } - public var Passport_Language_my: String { return self._s[4118]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[4119]! } + public var Appearance_Other: String { return self._s[4128]! } + public var Passport_Language_my: String { return self._s[4129]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[4130]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4120]!, self._r[4120]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4131]!, self._r[4131]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[4121]! } - public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[4122]! } - public var Preview_CopyAddress: String { return self._s[4123]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[4132]! } + public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[4133]! } + public var Preview_CopyAddress: String { return self._s[4134]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4124]!, self._r[4124]!, [_0]) + return formatWithArgumentRanges(self._s[4135]!, self._r[4135]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[4125]! } - public var UserInfo_BotSettings: String { return self._s[4126]! } - public var LiveLocation_MenuStopAll: String { return self._s[4128]! } - public var Passport_PasswordCreate: String { return self._s[4129]! } - public var StickerSettings_MaskContextInfo: String { return self._s[4130]! } - public var Message_PinnedLocationMessage: String { return self._s[4131]! } - public var Map_Satellite: String { return self._s[4132]! } - public var Watch_Message_Unsupported: String { return self._s[4133]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[4134]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[4135]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[4136]! } + public var UserInfo_BotSettings: String { return self._s[4137]! } + public var LiveLocation_MenuStopAll: String { return self._s[4139]! } + public var Passport_PasswordCreate: String { return self._s[4140]! } + public var StickerSettings_MaskContextInfo: String { return self._s[4141]! } + public var Message_PinnedLocationMessage: String { return self._s[4142]! } + public var Map_Satellite: String { return self._s[4143]! } + public var Watch_Message_Unsupported: String { return self._s[4144]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[4145]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[4146]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4136]!, self._r[4136]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4147]!, self._r[4147]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4137]!, self._r[4137]!, [_0]) + return formatWithArgumentRanges(self._s[4148]!, self._r[4148]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[4138]! } + public var Wallet_WordImport_Continue: String { return self._s[4149]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4139]!, self._r[4139]!, [_0]) + return formatWithArgumentRanges(self._s[4150]!, self._r[4150]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[4140]! } - public var Privacy_Calls_P2PContacts: String { return self._s[4141]! } - public var NotificationsSound_None: String { return self._s[4142]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[4143]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[4145]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[4146]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[4151]! } + public var Privacy_Calls_P2PContacts: String { return self._s[4152]! } + public var NotificationsSound_None: String { return self._s[4153]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[4154]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[4156]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[4157]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4147]!, self._r[4147]!, [_1]) + return formatWithArgumentRanges(self._s[4158]!, self._r[4158]!, [_1]) } - public var Cache_Indexing: String { return self._s[4148]! } - public var DialogList_RecentTitlePeople: String { return self._s[4150]! } - public var DialogList_EncryptionRejected: String { return self._s[4151]! } - public var GroupInfo_Administrators: String { return self._s[4152]! } - public var Passport_ScanPassportHelp: String { return self._s[4153]! } - public var Application_Name: String { return self._s[4154]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[4155]! } - public var Conversation_Timer_Title: String { return self._s[4156]! } - public var ChatList_PeerTypeGroup: String { return self._s[4157]! } - public var PeopleNearby_MakeVisible: String { return self._s[4159]! } - public var Appearance_ThemeCarouselDay: String { return self._s[4160]! } - public var Stats_GrowthTitle: String { return self._s[4161]! } - public var Passport_Identity_TranslationHelp: String { return self._s[4162]! } + public var Cache_Indexing: String { return self._s[4159]! } + public var DialogList_RecentTitlePeople: String { return self._s[4161]! } + public var DialogList_EncryptionRejected: String { return self._s[4162]! } + public var GroupInfo_Administrators: String { return self._s[4163]! } + public var Passport_ScanPassportHelp: String { return self._s[4164]! } + public var Application_Name: String { return self._s[4165]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[4166]! } + public var Conversation_Timer_Title: String { return self._s[4167]! } + public var ChatList_PeerTypeGroup: String { return self._s[4168]! } + public var PeopleNearby_MakeVisible: String { return self._s[4170]! } + public var Appearance_ThemeCarouselDay: String { return self._s[4171]! } + public var Stats_GrowthTitle: String { return self._s[4172]! } + public var Passport_Identity_TranslationHelp: String { return self._s[4173]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4163]!, self._r[4163]!, [_0]) + return formatWithArgumentRanges(self._s[4174]!, self._r[4174]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4164]!, self._r[4164]!, [_0]) + return formatWithArgumentRanges(self._s[4175]!, self._r[4175]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4165]!, self._r[4165]!, [_0]) + return formatWithArgumentRanges(self._s[4176]!, self._r[4176]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[4166]! } - public var Privacy_ChatsTitle: String { return self._s[4167]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[4168]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4169]! } - public var Watch_Suggestion_HoldOn: String { return self._s[4170]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[4171]! } - public var WebBrowser_Title: String { return self._s[4172]! } - public var Group_LinkedChannel: String { return self._s[4173]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4174]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[4175]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4176]! } - public var Appearance_TextSize_UseSystem: String { return self._s[4177]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[4178]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[4180]! } - public var Channel_Setup_TypePublic: String { return self._s[4182]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[4177]! } + public var Privacy_ChatsTitle: String { return self._s[4178]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[4179]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4180]! } + public var Watch_Suggestion_HoldOn: String { return self._s[4181]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[4182]! } + public var WebBrowser_Title: String { return self._s[4183]! } + public var Group_LinkedChannel: String { return self._s[4184]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4185]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[4186]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4187]! } + public var Appearance_TextSize_UseSystem: String { return self._s[4188]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[4189]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[4191]! } + public var Channel_Setup_TypePublic: String { return self._s[4193]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4183]!, self._r[4183]!, [_0]) + return formatWithArgumentRanges(self._s[4194]!, self._r[4194]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[4185]! } - public var MessagePoll_ViewResults: String { return self._s[4186]! } - public var Map_OpenInMaps: String { return self._s[4188]! } + public var Channel_TypeSetup_Title: String { return self._s[4196]! } + public var MessagePoll_ViewResults: String { return self._s[4197]! } + public var Map_OpenInMaps: String { return self._s[4199]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4189]!, self._r[4189]!, [_1]) + return formatWithArgumentRanges(self._s[4200]!, self._r[4200]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[4191]! } + public var NotificationsSound_Tremolo: String { return self._s[4202]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4192]!, self._r[4192]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4203]!, self._r[4203]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[4193]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4194]! } - public var Passport_PasswordHelp: String { return self._s[4196]! } - public var Login_CodeExpiredError: String { return self._s[4197]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4198]! } - public var Conversation_TitleUnmute: String { return self._s[4199]! } - public var Passport_Identity_ScansHelp: String { return self._s[4200]! } - public var Passport_Language_lo: String { return self._s[4201]! } - public var Camera_FlashAuto: String { return self._s[4202]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[4203]! } - public var Common_Cancel: String { return self._s[4204]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[4205]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4206]! } - public var Appearance_TintAllColors: String { return self._s[4207]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[4204]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4205]! } + public var Passport_PasswordHelp: String { return self._s[4207]! } + public var Login_CodeExpiredError: String { return self._s[4208]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4209]! } + public var Conversation_TitleUnmute: String { return self._s[4210]! } + public var Passport_Identity_ScansHelp: String { return self._s[4211]! } + public var Passport_Language_lo: String { return self._s[4212]! } + public var Camera_FlashAuto: String { return self._s[4213]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[4214]! } + public var Common_Cancel: String { return self._s[4215]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[4216]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4217]! } + public var Appearance_TintAllColors: String { return self._s[4218]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4208]!, self._r[4208]!, [_1]) + return formatWithArgumentRanges(self._s[4219]!, self._r[4219]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[4209]! } - public var ChatSettings_Title: String { return self._s[4211]! } - public var Passport_PasswordReset: String { return self._s[4212]! } - public var SocksProxySetup_TypeNone: String { return self._s[4213]! } - public var EditTheme_Title: String { return self._s[4216]! } - public var PhoneNumberHelp_Help: String { return self._s[4217]! } - public var Checkout_EnterPassword: String { return self._s[4218]! } - public var Activity_UploadingDocument: String { return self._s[4220]! } - public var Share_AuthTitle: String { return self._s[4221]! } - public var State_Connecting: String { return self._s[4222]! } - public var Profile_MessageLifetime1w: String { return self._s[4223]! } - public var Conversation_ContextMenuReport: String { return self._s[4224]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4225]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[4226]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[4220]! } + public var ChatSettings_Title: String { return self._s[4222]! } + public var Passport_PasswordReset: String { return self._s[4223]! } + public var SocksProxySetup_TypeNone: String { return self._s[4224]! } + public var EditTheme_Title: String { return self._s[4227]! } + public var PhoneNumberHelp_Help: String { return self._s[4228]! } + public var Checkout_EnterPassword: String { return self._s[4229]! } + public var Activity_UploadingDocument: String { return self._s[4231]! } + public var Share_AuthTitle: String { return self._s[4232]! } + public var State_Connecting: String { return self._s[4233]! } + public var Profile_MessageLifetime1w: String { return self._s[4234]! } + public var Conversation_ContextMenuReport: String { return self._s[4235]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4236]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[4237]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4227]!, self._r[4227]!, [_0]) + return formatWithArgumentRanges(self._s[4238]!, self._r[4238]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[4228]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[4229]! } - public var PeerInfo_PaneAudio: String { return self._s[4230]! } + public var AuthSessions_Terminate: String { return self._s[4239]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[4240]! } + public var PeerInfo_PaneAudio: String { return self._s[4241]! } public func Message_ForwardedPsa_covid(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4231]!, self._r[4231]!, [_0]) + return formatWithArgumentRanges(self._s[4242]!, self._r[4242]!, [_0]) } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[4233]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4234]! } - public var PhotoEditor_Set: String { return self._s[4235]! } - public var EmptyGroupInfo_Title: String { return self._s[4236]! } - public var Login_PadPhoneHelp: String { return self._s[4238]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4240]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4242]! } - public var NotificationsSound_Complete: String { return self._s[4243]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4244]! } - public var Group_Info_AdminLog: String { return self._s[4245]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4246]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[4244]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4245]! } + public var PhotoEditor_Set: String { return self._s[4246]! } + public var EmptyGroupInfo_Title: String { return self._s[4247]! } + public var Login_PadPhoneHelp: String { return self._s[4249]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4251]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4253]! } + public var NotificationsSound_Complete: String { return self._s[4254]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4255]! } + public var Group_Info_AdminLog: String { return self._s[4256]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4257]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4247]!, self._r[4247]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4258]!, self._r[4258]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[4248]! } - public var Group_Location_CreateInThisPlace: String { return self._s[4250]! } - public var Conversation_Admin: String { return self._s[4251]! } - public var Conversation_GifTooltip: String { return self._s[4252]! } - public var Passport_NotLoggedInMessage: String { return self._s[4253]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[4259]! } + public var Group_Location_CreateInThisPlace: String { return self._s[4261]! } + public var Conversation_Admin: String { return self._s[4262]! } + public var Conversation_GifTooltip: String { return self._s[4263]! } + public var Passport_NotLoggedInMessage: String { return self._s[4264]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4255]!, self._r[4255]!, [_0]) + return formatWithArgumentRanges(self._s[4266]!, self._r[4266]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[4256]! } - public var SharedMedia_EmptyTitle: String { return self._s[4258]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4260]! } - public var Username_Help: String { return self._s[4261]! } - public var DialogList_LanguageTooltip: String { return self._s[4263]! } - public var Map_LoadError: String { return self._s[4264]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4265]! } - public var Channel_AdminLog_AddMembers: String { return self._s[4266]! } - public var ArchivedChats_IntroTitle2: String { return self._s[4267]! } - public var Notification_Exceptions_NewException: String { return self._s[4268]! } - public var TwoStepAuth_EmailTitle: String { return self._s[4269]! } - public var WatchRemote_AlertText: String { return self._s[4270]! } + public var Profile_MessageLifetimeForever: String { return self._s[4267]! } + public var SharedMedia_EmptyTitle: String { return self._s[4269]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4271]! } + public var Username_Help: String { return self._s[4272]! } + public var DialogList_LanguageTooltip: String { return self._s[4274]! } + public var Map_LoadError: String { return self._s[4275]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4276]! } + public var Channel_AdminLog_AddMembers: String { return self._s[4277]! } + public var ArchivedChats_IntroTitle2: String { return self._s[4278]! } + public var Notification_Exceptions_NewException: String { return self._s[4279]! } + public var TwoStepAuth_EmailTitle: String { return self._s[4280]! } + public var WatchRemote_AlertText: String { return self._s[4281]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4271]!, self._r[4271]!, [_1, _2, _3]) - } - public var ChatSettings_ConnectionType_Title: String { return self._s[4275]! } - public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4276]!, self._r[4276]!, [_1, _2]) - } - public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4277]!, self._r[4277]!, [_0]) - } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[4278]! } - public var WebBrowser_DefaultBrowser: String { return self._s[4279]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[4280]! } - public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4281]!, self._r[4281]!, [_0]) - } - public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4282]!, self._r[4282]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[4283]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4284]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[4286]! } - public var Wallet_Created_ExportErrorText: String { return self._s[4287]! } - public var ChatList_UndoArchiveText1: String { return self._s[4288]! } - public var ChatListFolder_IncludedSectionHeader: String { return self._s[4289]! } - public var AccessDenied_VideoMicrophone: String { return self._s[4290]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4291]! } - public var Stats_GroupTopInviter_History: String { return self._s[4292]! } - public var Cache_ClearNone: String { return self._s[4293]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[4294]! } - public var Call_ShareStats: String { return self._s[4295]! } - public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4296]!, self._r[4296]!, [_0]) + public var ChatSettings_ConnectionType_Title: String { return self._s[4286]! } + public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4287]!, self._r[4287]!, [_1, _2]) } - public var Permissions_NotificationsTitle_v0: String { return self._s[4297]! } - public var Passport_Identity_Country: String { return self._s[4298]! } + public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4288]!, self._r[4288]!, [_0]) + } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[4289]! } + public var WebBrowser_DefaultBrowser: String { return self._s[4290]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[4291]! } + public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4292]!, self._r[4292]!, [_0]) + } + public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4293]!, self._r[4293]!, [_1, _2, _3]) + } + public var Group_AdminLog_EmptyText: String { return self._s[4294]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4295]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[4297]! } + public var Wallet_Created_ExportErrorText: String { return self._s[4298]! } + public var ChatList_UndoArchiveText1: String { return self._s[4299]! } + public var ChatListFolder_IncludedSectionHeader: String { return self._s[4300]! } + public var AccessDenied_VideoMicrophone: String { return self._s[4301]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4302]! } + public var Stats_GroupTopInviter_History: String { return self._s[4303]! } + public var Cache_ClearNone: String { return self._s[4304]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[4305]! } + public var Call_ShareStats: String { return self._s[4306]! } + public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4307]!, self._r[4307]!, [_0]) + } + public var Permissions_NotificationsTitle_v0: String { return self._s[4308]! } + public var Passport_Identity_Country: String { return self._s[4309]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4299]!, self._r[4299]!, [_0]) + return formatWithArgumentRanges(self._s[4310]!, self._r[4310]!, [_0]) } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4300]!, self._r[4300]!, [_0]) + return formatWithArgumentRanges(self._s[4311]!, self._r[4311]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[4301]! } - public var AccessDenied_Settings: String { return self._s[4302]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4303]! } - public var Month_ShortMay: String { return self._s[4305]! } - public var Compose_NewGroup: String { return self._s[4307]! } - public var Group_Setup_TypePrivate: String { return self._s[4309]! } - public var Login_PadPhoneHelpTitle: String { return self._s[4311]! } - public var Appearance_ThemeDayClassic: String { return self._s[4312]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4313]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[4314]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4315]! } - public var Conversation_typing: String { return self._s[4317]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[4318]! } - public var Paint_Masks: String { return self._s[4319]! } - public var Contacts_DeselectAll: String { return self._s[4320]! } + public var Exceptions_AddToExceptions: String { return self._s[4312]! } + public var AccessDenied_Settings: String { return self._s[4313]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4314]! } + public var Month_ShortMay: String { return self._s[4316]! } + public var Compose_NewGroup: String { return self._s[4318]! } + public var Group_Setup_TypePrivate: String { return self._s[4320]! } + public var Login_PadPhoneHelpTitle: String { return self._s[4322]! } + public var Appearance_ThemeDayClassic: String { return self._s[4323]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4324]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[4325]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4326]! } + public var Conversation_typing: String { return self._s[4328]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[4329]! } + public var Paint_Masks: String { return self._s[4330]! } + public var Contacts_DeselectAll: String { return self._s[4331]! } public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4321]!, self._r[4321]!, [_0]) + return formatWithArgumentRanges(self._s[4332]!, self._r[4332]!, [_0]) } - public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4322]! } - public var Stats_GroupMembersTitle: String { return self._s[4323]! } - public var Username_InvalidTaken: String { return self._s[4324]! } - public var Call_StatusNoAnswer: String { return self._s[4325]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[4326]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4327]! } - public var Passport_Identity_Selfie: String { return self._s[4328]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4329]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4330]! } - public var Conversation_ClearSecretHistory: String { return self._s[4331]! } - public var PeopleNearby_Description: String { return self._s[4333]! } - public var NetworkUsageSettings_Title: String { return self._s[4334]! } - public var Your_cards_security_code_is_invalid: String { return self._s[4336]! } - public var Stats_EnabledNotifications: String { return self._s[4337]! } + public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4333]! } + public var Stats_GroupMembersTitle: String { return self._s[4334]! } + public var Username_InvalidTaken: String { return self._s[4335]! } + public var Call_StatusNoAnswer: String { return self._s[4336]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[4337]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4338]! } + public var Passport_Identity_Selfie: String { return self._s[4339]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4340]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4341]! } + public var Conversation_ClearSecretHistory: String { return self._s[4342]! } + public var PeopleNearby_Description: String { return self._s[4344]! } + public var NetworkUsageSettings_Title: String { return self._s[4345]! } + public var Your_cards_security_code_is_invalid: String { return self._s[4347]! } + public var Stats_EnabledNotifications: String { return self._s[4348]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4340]!, self._r[4340]!, [_0]) + return formatWithArgumentRanges(self._s[4351]!, self._r[4351]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4341]!, self._r[4341]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4352]!, self._r[4352]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[4343]! } - public var VoiceOver_Navigation_Search: String { return self._s[4344]! } - public var Map_LiveLocationTitle: String { return self._s[4345]! } - public var Login_InfoAvatarAdd: String { return self._s[4346]! } - public var Passport_Identity_FilesView: String { return self._s[4347]! } - public var ChatListFolderSettings_Title: String { return self._s[4348]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[4349]! } - public var Privacy_Calls_NeverAllow: String { return self._s[4350]! } - public var VoiceOver_Chat_File: String { return self._s[4351]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4352]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[4354]! } + public var VoiceOver_Navigation_Search: String { return self._s[4355]! } + public var Map_LiveLocationTitle: String { return self._s[4356]! } + public var Login_InfoAvatarAdd: String { return self._s[4357]! } + public var Passport_Identity_FilesView: String { return self._s[4358]! } + public var ChatListFolderSettings_Title: String { return self._s[4359]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[4360]! } + public var Privacy_Calls_NeverAllow: String { return self._s[4361]! } + public var VoiceOver_Chat_File: String { return self._s[4362]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4363]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4353]!, self._r[4353]!, [_0]) + return formatWithArgumentRanges(self._s[4364]!, self._r[4364]!, [_0]) } - public var ChatList_EmptyChatList: String { return self._s[4355]! } - public var ContactInfo_PhoneNumberHidden: String { return self._s[4356]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[4357]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4358]! } + public var ChatList_EmptyChatList: String { return self._s[4366]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[4367]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[4368]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4369]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4359]!, self._r[4359]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4370]!, self._r[4370]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4360]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[4361]! } - public var Tour_Title2: String { return self._s[4362]! } - public var Wallet_Sent_ViewWallet: String { return self._s[4363]! } - public var Stats_GroupMessagesTitle: String { return self._s[4364]! } - public var Conversation_FileOpenIn: String { return self._s[4365]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4366]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4367]! } - public var Wallpaper_Set: String { return self._s[4368]! } - public var Passport_Identity_Translations: String { return self._s[4371]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4371]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[4372]! } + public var Tour_Title2: String { return self._s[4373]! } + public var Wallet_Sent_ViewWallet: String { return self._s[4374]! } + public var Stats_GroupMessagesTitle: String { return self._s[4375]! } + public var Conversation_FileOpenIn: String { return self._s[4376]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4377]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4378]! } + public var Wallpaper_Set: String { return self._s[4379]! } + public var Passport_Identity_Translations: String { return self._s[4382]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4372]!, self._r[4372]!, [_0]) + return formatWithArgumentRanges(self._s[4383]!, self._r[4383]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4374]! } + public var Channel_LeaveChannel: String { return self._s[4385]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4375]!, self._r[4375]!, [_1]) + return formatWithArgumentRanges(self._s[4386]!, self._r[4386]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4377]! } - public var PhotoEditor_HighlightsTint: String { return self._s[4378]! } - public var MessagePoll_LabelPoll: String { return self._s[4379]! } - public var Passport_Email_Delete: String { return self._s[4380]! } - public var Conversation_Mute: String { return self._s[4382]! } - public var Channel_AddBotAsAdmin: String { return self._s[4383]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[4385]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4386]! } - public var ChatSettings_IntentsSettings: String { return self._s[4388]! } - public var Channel_Management_LabelOwner: String { return self._s[4389]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4388]! } + public var PhotoEditor_HighlightsTint: String { return self._s[4389]! } + public var MessagePoll_LabelPoll: String { return self._s[4390]! } + public var Passport_Email_Delete: String { return self._s[4391]! } + public var Conversation_Mute: String { return self._s[4393]! } + public var Channel_AddBotAsAdmin: String { return self._s[4394]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[4396]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4397]! } + public var ChatSettings_IntentsSettings: String { return self._s[4399]! } + public var Channel_Management_LabelOwner: String { return self._s[4400]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4390]!, self._r[4390]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4401]!, self._r[4401]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[4391]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[4392]! } - public var Common_No: String { return self._s[4393]! } - public var Weekday_Sunday: String { return self._s[4394]! } - public var Notification_Reply: String { return self._s[4395]! } - public var Conversation_ViewMessage: String { return self._s[4396]! } + public var Calls_CallTabDescription: String { return self._s[4402]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[4403]! } + public var Common_No: String { return self._s[4404]! } + public var Weekday_Sunday: String { return self._s[4405]! } + public var Notification_Reply: String { return self._s[4406]! } + public var Conversation_ViewMessage: String { return self._s[4407]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4397]!, self._r[4397]!, [_0]) + return formatWithArgumentRanges(self._s[4408]!, self._r[4408]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4398]!, self._r[4398]!, [_0]) + return formatWithArgumentRanges(self._s[4409]!, self._r[4409]!, [_0]) } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4399]!, self._r[4399]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4410]!, self._r[4410]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4400]! } - public var Wallet_Send_Title: String { return self._s[4401]! } - public var Message_PinnedDocumentMessage: String { return self._s[4402]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[4403]! } - public var DialogList_TabTitle: String { return self._s[4405]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4406]! } - public var Passport_FieldEmail: String { return self._s[4407]! } - public var Conversation_UnpinMessageAlert: String { return self._s[4408]! } - public var Passport_Address_TypeBankStatement: String { return self._s[4409]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[4410]! } - public var Passport_Identity_ExpiryDate: String { return self._s[4411]! } - public var Privacy_Calls_P2P: String { return self._s[4412]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4411]! } + public var Wallet_Send_Title: String { return self._s[4412]! } + public var Message_PinnedDocumentMessage: String { return self._s[4413]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[4414]! } + public var DialogList_TabTitle: String { return self._s[4416]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4417]! } + public var Passport_FieldEmail: String { return self._s[4418]! } + public var Conversation_UnpinMessageAlert: String { return self._s[4419]! } + public var Passport_Address_TypeBankStatement: String { return self._s[4420]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[4421]! } + public var Passport_Identity_ExpiryDate: String { return self._s[4422]! } + public var Privacy_Calls_P2P: String { return self._s[4423]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4414]!, self._r[4414]!, [_0]) + return formatWithArgumentRanges(self._s[4425]!, self._r[4425]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4415]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[4426]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4416]!, self._r[4416]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4427]!, self._r[4427]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[4417]! } - public var EnterPasscode_ChangeTitle: String { return self._s[4418]! } - public var TwoFactorSetup_Email_Title: String { return self._s[4419]! } - public var Passport_InfoText: String { return self._s[4420]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4421]! } + public var Stickers_ClearRecent: String { return self._s[4428]! } + public var EnterPasscode_ChangeTitle: String { return self._s[4429]! } + public var TwoFactorSetup_Email_Title: String { return self._s[4430]! } + public var Passport_InfoText: String { return self._s[4431]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4432]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4422]!, self._r[4422]!, [_0]) + return formatWithArgumentRanges(self._s[4433]!, self._r[4433]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4423]!, self._r[4423]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4434]!, self._r[4434]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4424]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[4425]! } - public var VoiceOver_Navigation_Compose: String { return self._s[4426]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[4427]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4429]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4430]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4435]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4436]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4437]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4438]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4440]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4441]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4431]!, self._r[4431]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4442]!, self._r[4442]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4434]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4435]! } - public var Map_HomeAndWorkTitle: String { return self._s[4436]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4445]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4446]! } + public var Map_HomeAndWorkTitle: String { return self._s[4447]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4438]!, self._r[4438]!, [_0]) + return formatWithArgumentRanges(self._s[4449]!, self._r[4449]!, [_0]) } - public var DialogList_Unread: String { return self._s[4439]! } + public var DialogList_Unread: String { return self._s[4450]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4440]!, self._r[4440]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4451]!, self._r[4451]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4441]! } - public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4442]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4443]! } + public var User_DeletedAccount: String { return self._s[4452]! } + public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4453]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4454]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4444]!, self._r[4444]!, [_0]) + return formatWithArgumentRanges(self._s[4455]!, self._r[4455]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4445]! } - public var SharedMedia_CategoryMedia: String { return self._s[4446]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4447]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4448]! } - public var Watch_ChatList_Compose: String { return self._s[4449]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4450]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4451]! } - public var Watch_Microphone_Access: String { return self._s[4452]! } - public var Cache_MaximumCacheSize: String { return self._s[4453]! } - public var Group_Setup_HistoryHeader: String { return self._s[4454]! } - public var Map_SetThisLocation: String { return self._s[4455]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4456]! } - public var Activity_UploadingPhoto: String { return self._s[4457]! } - public var Conversation_Edit: String { return self._s[4459]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4460]! } - public var Login_TermsOfServiceDecline: String { return self._s[4461]! } - public var Message_PinnedContactMessage: String { return self._s[4462]! } + public var UserInfo_NotificationsDefault: String { return self._s[4456]! } + public var SharedMedia_CategoryMedia: String { return self._s[4457]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4458]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4459]! } + public var Watch_ChatList_Compose: String { return self._s[4460]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4461]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4462]! } + public var Watch_Microphone_Access: String { return self._s[4463]! } + public var Cache_MaximumCacheSize: String { return self._s[4464]! } + public var Group_Setup_HistoryHeader: String { return self._s[4465]! } + public var Map_SetThisLocation: String { return self._s[4466]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4467]! } + public var Activity_UploadingPhoto: String { return self._s[4468]! } + public var Conversation_Edit: String { return self._s[4470]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4471]! } + public var Login_TermsOfServiceDecline: String { return self._s[4472]! } + public var Message_PinnedContactMessage: String { return self._s[4473]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4463]!, self._r[4463]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4474]!, self._r[4474]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4464]!, self._r[4464]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4475]!, self._r[4475]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4465]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4467]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4468]! } + public var Appearance_LargeEmoji: String { return self._s[4476]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4478]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4479]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4469]!, self._r[4469]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4480]!, self._r[4480]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4470]! } - public var Message_PinnedPhotoMessage: String { return self._s[4471]! } - public var Passport_FieldPhone: String { return self._s[4472]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4473]! } - public var Stats_NotificationsTitle: String { return self._s[4474]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4475]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4477]! } - public var Conversation_Call: String { return self._s[4478]! } - public var Common_TakePhoto: String { return self._s[4480]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4481]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4482]! } - public var Channel_NotificationLoading: String { return self._s[4483]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4481]! } + public var Message_PinnedPhotoMessage: String { return self._s[4482]! } + public var Passport_FieldPhone: String { return self._s[4483]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4484]! } + public var Stats_NotificationsTitle: String { return self._s[4485]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4486]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4488]! } + public var Conversation_Call: String { return self._s[4489]! } + public var Common_TakePhoto: String { return self._s[4491]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4492]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4493]! } + public var Channel_NotificationLoading: String { return self._s[4494]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4484]!, self._r[4484]!, [_0]) + return formatWithArgumentRanges(self._s[4495]!, self._r[4495]!, [_0]) } public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4485]!, self._r[4485]!, [_0]) + return formatWithArgumentRanges(self._s[4496]!, self._r[4496]!, [_0]) } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4486]!, self._r[4486]!, [_1]) + return formatWithArgumentRanges(self._s[4497]!, self._r[4497]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[4487]! } + public var Permissions_SiriTitle_v0: String { return self._s[4498]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4488]!, self._r[4488]!, [_0]) + return formatWithArgumentRanges(self._s[4499]!, self._r[4499]!, [_0]) } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4489]!, self._r[4489]!, [_0]) + return formatWithArgumentRanges(self._s[4500]!, self._r[4500]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4490]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4491]! } - public var ClearCache_FreeSpace: String { return self._s[4492]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[4493]! } - public var Common_edit: String { return self._s[4494]! } - public var PrivacySettings_AuthSessions: String { return self._s[4495]! } + public var Channel_MessagePhotoRemoved: String { return self._s[4501]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4502]! } + public var ClearCache_FreeSpace: String { return self._s[4503]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[4504]! } + public var Common_edit: String { return self._s[4505]! } + public var PrivacySettings_AuthSessions: String { return self._s[4506]! } public func PUSH_VIDEO_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4496]!, self._r[4496]!, [_1]) + return formatWithArgumentRanges(self._s[4507]!, self._r[4507]!, [_1]) } - public var Month_ShortJune: String { return self._s[4497]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4498]! } - public var Call_ReportSend: String { return self._s[4499]! } - public var Watch_LastSeen_JustNow: String { return self._s[4500]! } - public var Notifications_MessageNotifications: String { return self._s[4501]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4502]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4504]! } - public var Group_Status: String { return self._s[4505]! } + public var Month_ShortJune: String { return self._s[4508]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4509]! } + public var Call_ReportSend: String { return self._s[4510]! } + public var Watch_LastSeen_JustNow: String { return self._s[4511]! } + public var Notifications_MessageNotifications: String { return self._s[4512]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4513]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4515]! } + public var Group_Status: String { return self._s[4516]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4506]!, self._r[4506]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4517]!, self._r[4517]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4507]! } - public var ShareMenu_ShareTo: String { return self._s[4508]! } - public var Conversation_Moderate_Ban: String { return self._s[4509]! } + public var TextFormat_AddLinkTitle: String { return self._s[4518]! } + public var ShareMenu_ShareTo: String { return self._s[4519]! } + public var Conversation_Moderate_Ban: String { return self._s[4520]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4510]!, self._r[4510]!, [_0]) + return formatWithArgumentRanges(self._s[4521]!, self._r[4521]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4511]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4512]! } + public var SharedMedia_ViewInChat: String { return self._s[4522]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4523]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4513]!, self._r[4513]!, [_1]) + return formatWithArgumentRanges(self._s[4524]!, self._r[4524]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4514]!, self._r[4514]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4525]!, self._r[4525]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4516]!, self._r[4516]!, [_0]) + return formatWithArgumentRanges(self._s[4527]!, self._r[4527]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4517]! } - public var Appearance_ReduceMotion: String { return self._s[4518]! } + public var Map_OpenInHereMaps: String { return self._s[4528]! } + public var Appearance_ReduceMotion: String { return self._s[4529]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4519]!, self._r[4519]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4530]!, self._r[4530]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4520]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4521]! } - public var PhotoEditor_Skip: String { return self._s[4522]! } - public func Stats_GroupShowMoreTopPosters(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4531]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4532]! } + public var PhotoEditor_Skip: String { return self._s[4533]! } + public func Notification_GameScoreExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteFor_Days(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Hours(_ value: Int32) -> String { + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func Call_ShortMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func StickerPack_AddStickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Link(_ value: Int32) -> String { + public func Notifications_Exceptions(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, _1, _2) + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func MessagePoll_QuizCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_InviteContacts(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { + public func Theme_UsersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + public func ChatList_DeletedChats(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedLocations(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func Stats_MessageForwards(_ value: Int32) -> String { + public func OldChannels_GroupFormat(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, _1, _2) + public func Stats_GroupShowMoreTopPosters(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + public func StickerPack_StickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) } - public func Stats_GroupTopAdminBans(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareVideo(_ value: Int32) -> String { + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideos(_ value: Int32) -> String { + public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func OldChannels_Leave(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedContacts(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Days(_ value: Int32) -> String { + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_SelectedChats(_ value: Int32) -> String { + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Years(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func MessageTimer_Months(_ value: Int32) -> String { + public func Passport_Scans(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } - public func Stats_GroupTopPosterChars(_ value: Int32) -> String { + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + public func UserCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func OldChannels_InactiveYear(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) } - public func Stats_GroupShowMoreTopAdmins(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + public func Contacts_ImportersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) @@ -5159,77 +5178,76 @@ public final class PresentationStrings: Equatable { let form = getPluralizationForm(self.lc, selector) return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, _1, _2) } - public func Stats_GroupShowMoreTopInviters(_ value: Int32) -> String { + public func Contacts_InviteContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_MessagePhotos(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) } - public func Invitation_Members(_ value: Int32) -> String { + public func Conversation_SelectedMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) } - public func Map_ETAHours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + public func MessageTimer_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + public func LastSeen_HoursAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_Leave(_ value: Int32) -> String { + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) } - public func Theme_UsersCount(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func Stats_MessageViews(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func Media_ShareItem(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func ChatListFilter_ShowMoreChats(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) } - public func Stats_GroupTopAdminDeletions(_ value: Int32) -> String { + public func QuickSend_Photos(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func InstantPage_Views(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) @@ -5239,467 +5257,468 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, _2, _1, _3) + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Minutes(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortHours(_ value: Int32) -> String { + public func OldChannels_InactiveMonth(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func ChatList_MessageVideos(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Hours(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func Stats_GroupTopPosterChars(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public func Stats_GroupTopAdminKicks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) } - public func Stats_GroupTopPosterMessages(_ value: Int32) -> String { + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_StickerCount(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) - } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, _1, _2) } public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_GroupTopAdminKicks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_File(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveYear(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, _1, _2) } public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_HoursAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPhotos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Video(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) - } - public func InviteText_ContactsCountText(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_MessageVideos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessagePoll_QuizCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_MessageViews(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_SelectedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Map_ETAMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeletedChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) - } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveWeek(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAudios(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatListFilter_ShowMoreChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_GroupTopInviterInvites(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, stringValue) - } - public func UserCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[114 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func SharedMedia_Photo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedGifs(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedStickers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[120 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessagePoll_VotedCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, stringValue) - } - public func InstantPage_Views(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) - } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[123 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_Exceptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[124 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[125 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Generic(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[127 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[128 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveMonth(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PollResults_ShowMore(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[130 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[131 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func OldChannels_GroupFormat(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[132 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPolls(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[133 * 6 + Int(form.rawValue)]!, stringValue) - } - public func QuickSend_Photos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[134 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[135 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) } public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[136 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedGifs(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupTopPosterMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusSubscribers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortDays(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_InactiveWeek(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Link(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_File(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_ShortSeconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteFor_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupShowMoreTopAdmins(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedLocations(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupTopInviterInvites(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupShowMoreTopInviters(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAudios(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedStickers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_MessageForwards(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) } public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[137 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func Passport_Scans(_ value: Int32) -> String { + public func ForwardedPolls(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[138 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedFiles(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessagePoll_VotedCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareVideo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[114 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ForwardedVideoMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Weeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PollResults_ShowMore(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[120 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[123 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[124 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Generic(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[125 * 6 + Int(form.rawValue)]!, stringValue) } public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[139 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[127 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[128 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupTopAdminDeletions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) + } + public func InviteText_ContactsCountText(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[130 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupTopAdminBans(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[131 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[132 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Notification_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[133 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendItem(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[134 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_MessagePhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[135 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[136 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[137 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Invitation_Members(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[138 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[139 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[140 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[141 * 6 + Int(form.rawValue)]!, _1, _2) + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[141 * 6 + Int(form.rawValue)]!, stringValue) } public init(primaryComponent: PresentationStringsComponent, secondaryComponent: PresentationStringsComponent?, groupingSeparator: String) { diff --git a/submodules/TelegramUI/BUCK b/submodules/TelegramUI/BUCK index 0689ad24b9..be53f26092 100644 --- a/submodules/TelegramUI/BUCK +++ b/submodules/TelegramUI/BUCK @@ -206,6 +206,9 @@ framework( "//submodules/ManagedAnimationNode:ManagedAnimationNode", "//submodules/TooltipUI:TooltipUI", "//submodules/AuthTransferUI:AuthTransferUI", + "//submodules/ListMessageItem:ListMessageItem", + "//submodules/FileMediaResourceStatus:FileMediaResourceStatus", + "//submodules/ChatMessageInteractiveMediaBadge:ChatMessageInteractiveMediaBadge", ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", diff --git a/submodules/TelegramUI/BUILD b/submodules/TelegramUI/BUILD index b52fe63c9b..0b843e3158 100644 --- a/submodules/TelegramUI/BUILD +++ b/submodules/TelegramUI/BUILD @@ -201,6 +201,9 @@ swift_library( "//submodules/ManagedAnimationNode:ManagedAnimationNode", "//submodules/TooltipUI:TooltipUI", "//submodules/AuthTransferUI:AuthTransferUI", + "//submodules/ListMessageItem:ListMessageItem", + "//submodules/FileMediaResourceStatus:FileMediaResourceStatus", + "//submodules/ChatMessageInteractiveMediaBadge:ChatMessageInteractiveMediaBadge", ], visibility = [ "//visibility:public", diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Arrow.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Arrow.imageset/Contents.json new file mode 100644 index 0000000000..9952bcc0b6 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Arrow.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_addresult.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Arrow.imageset/ic_addresult.pdf b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Arrow.imageset/ic_addresult.pdf new file mode 100644 index 0000000000..61096012ce Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Arrow.imageset/ic_addresult.pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Calendar.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Calendar.imageset/Contents.json new file mode 100644 index 0000000000..65cbf323d2 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Calendar.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_search_calendar (2).pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Calendar.imageset/ic_search_calendar (2).pdf b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Calendar.imageset/ic_search_calendar (2).pdf new file mode 100644 index 0000000000..278f33aad8 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Calendar.imageset/ic_search_calendar (2).pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Contents.json new file mode 100644 index 0000000000..6e965652df --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Contents.json @@ -0,0 +1,9 @@ +{ + "info" : { + "author" : "xcode", + "version" : 1 + }, + "properties" : { + "provides-namespace" : true + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Files.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Files.imageset/Contents.json new file mode 100644 index 0000000000..9c2974799f --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Files.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_search_docs.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Files.imageset/ic_search_docs.pdf b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Files.imageset/ic_search_docs.pdf new file mode 100644 index 0000000000..bd6b9cd16c Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Files.imageset/ic_search_docs.pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Links.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Links.imageset/Contents.json new file mode 100644 index 0000000000..61900b0c65 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Links.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_search_links.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Links.imageset/ic_search_links.pdf b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Links.imageset/ic_search_links.pdf new file mode 100644 index 0000000000..a87c7df112 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Links.imageset/ic_search_links.pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Media.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Media.imageset/Contents.json new file mode 100644 index 0000000000..27e7833bb7 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Media.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_search_media.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Media.imageset/ic_search_media.pdf b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Media.imageset/ic_search_media.pdf new file mode 100644 index 0000000000..c2b7eb8889 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Media.imageset/ic_search_media.pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Music.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Music.imageset/Contents.json new file mode 100644 index 0000000000..753d87e84b --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Music.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_search_music.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/Music.imageset/ic_search_music.pdf b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Music.imageset/ic_search_music.pdf new file mode 100644 index 0000000000..64d3e7cc16 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat List/Search/Music.imageset/ic_search_music.pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/User.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat List/Search/User.imageset/Contents.json new file mode 100644 index 0000000000..62bafe5364 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat List/Search/User.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_search_user.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Chat List/Search/User.imageset/ic_search_user.pdf b/submodules/TelegramUI/Images.xcassets/Chat List/Search/User.imageset/ic_search_user.pdf new file mode 100644 index 0000000000..7fef737b30 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat List/Search/User.imageset/ic_search_user.pdf differ diff --git a/submodules/TelegramUI/Resources/Animations/ChatListNoResults.tgs b/submodules/TelegramUI/Resources/Animations/ChatListNoResults.tgs new file mode 100644 index 0000000000..62a21279fb Binary files /dev/null and b/submodules/TelegramUI/Resources/Animations/ChatListNoResults.tgs differ diff --git a/submodules/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Resources/PresentationStrings.mapping index 9861c49aa2..1f36e0107c 100644 Binary files a/submodules/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TelegramUI/Sources/ChatController.swift b/submodules/TelegramUI/Sources/ChatController.swift index cff35478e5..b0c411ead9 100644 --- a/submodules/TelegramUI/Sources/ChatController.swift +++ b/submodules/TelegramUI/Sources/ChatController.swift @@ -6212,7 +6212,6 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G if let peer = strongSelf.presentationInterfaceState.renderedPeer?.chatMainPeer, let infoController = strongSelf.context.sharedContext.makePeerInfoController(context: strongSelf.context, peer: peer, mode: .generic, avatarInitiallyExpanded: false, fromChat: true) { strongSelf.effectiveNavigationController?.pushViewController(infoController) } - //strongSelf.effectiveNavigationController?.pushViewController(PeerMediaCollectionController(context: strongSelf.context, peerId: strongSelf.context.account.peerId)) } else { var expandAvatar = expandAvatar if peer.smallProfileImage == nil { @@ -7931,11 +7930,11 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G } switch search.domain { case .everything: - derivedSearchState = ChatSearchState(query: search.query, location: .peer(peerId: self.chatLocation.peerId, fromId: nil, tags: nil, topMsgId: searchTopMsgId), loadMoreState: loadMoreStateFromResultsState(search.resultsState)) + derivedSearchState = ChatSearchState(query: search.query, location: .peer(peerId: self.chatLocation.peerId, fromId: nil, tags: nil, topMsgId: searchTopMsgId, minDate: nil, maxDate: nil), loadMoreState: loadMoreStateFromResultsState(search.resultsState)) case .members: derivedSearchState = nil case let .member(peer): - derivedSearchState = ChatSearchState(query: search.query, location: .peer(peerId: self.chatLocation.peerId, fromId: peer.id, tags: nil, topMsgId: searchTopMsgId), loadMoreState: loadMoreStateFromResultsState(search.resultsState)) + derivedSearchState = ChatSearchState(query: search.query, location: .peer(peerId: self.chatLocation.peerId, fromId: peer.id, tags: nil, topMsgId: searchTopMsgId, minDate: nil, maxDate: nil), loadMoreState: loadMoreStateFromResultsState(search.resultsState)) } } @@ -7946,7 +7945,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G if previousSearchState?.query != searchState.query || previousSearchState?.location != searchState.location { var queryIsEmpty = false if searchState.query.isEmpty { - if case let .peer(_, fromId, _, _) = searchState.location { + if case let .peer(_, fromId, _, _, _, _) = searchState.location { if fromId == nil { queryIsEmpty = true } @@ -9794,115 +9793,3 @@ private final class ContextControllerContentSourceImpl: ContextControllerContent func animatedIn() { } } - -func parseUrl(url: String, wasConcealed: Bool) -> (string: String, concealed: Bool) { - var parsedUrlValue: URL? - if url.hasPrefix("tel:") { - return (url, false) - } else if let parsed = URL(string: url) { - parsedUrlValue = parsed - } else if let parsed = URL(string: "https://" + url) { - parsedUrlValue = parsed - } else if let encoded = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed), let parsed = URL(string: encoded) { - parsedUrlValue = parsed - } - let host = parsedUrlValue?.host ?? url - - let rawHost = (host as NSString).removingPercentEncoding ?? host - var latin = CharacterSet() - latin.insert(charactersIn: "A"..."Z") - latin.insert(charactersIn: "a"..."z") - latin.insert(charactersIn: "0"..."9") - var punctuation = CharacterSet() - punctuation.insert(charactersIn: ".-/+_") - var hasLatin = false - var hasNonLatin = false - for c in rawHost { - if c.unicodeScalars.allSatisfy(punctuation.contains) { - } else if c.unicodeScalars.allSatisfy(latin.contains) { - hasLatin = true - } else { - hasNonLatin = true - } - } - var concealed = wasConcealed - if hasLatin && hasNonLatin { - concealed = true - } - - var rawDisplayUrl: String - if hasNonLatin { - rawDisplayUrl = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) ?? url - } else { - rawDisplayUrl = url - } - - if let parsedUrlValue = parsedUrlValue, isConcealedUrlWhitelisted(parsedUrlValue) { - concealed = false - } - - let whitelistedSchemes: [String] = [ - "tel", - ] - if let parsedUrlValue = parsedUrlValue, let scheme = parsedUrlValue.scheme, whitelistedSchemes.contains(scheme) { - concealed = false - } - - return (rawDisplayUrl, concealed) -} - -func openUserGeneratedUrl(context: AccountContext, url: String, concealed: Bool, present: @escaping (ViewController) -> Void, openResolved: @escaping (ResolvedUrl) -> Void) { - var concealed = concealed - - let presentationData = context.sharedContext.currentPresentationData.with { $0 } - - let openImpl: () -> Void = { - let disposable = MetaDisposable() - var cancelImpl: (() -> Void)? - let progressSignal = Signal { subscriber in - let controller = OverlayStatusController(theme: presentationData.theme, type: .loading(cancelled: { - cancelImpl?() - })) - present(controller) - return ActionDisposable { [weak controller] in - Queue.mainQueue().async() { - controller?.dismiss() - } - } - } - |> runOn(Queue.mainQueue()) - |> delay(0.15, queue: Queue.mainQueue()) - let progressDisposable = progressSignal.start() - - cancelImpl = { - disposable.dispose() - } - disposable.set((context.sharedContext.resolveUrl(account: context.account, url: url) - |> afterDisposed { - Queue.mainQueue().async { - progressDisposable.dispose() - } - } - |> deliverOnMainQueue).start(next: { result in - openResolved(result) - })) - } - - let (parsedString, parsedConcealed) = parseUrl(url: url, wasConcealed: concealed) - concealed = parsedConcealed - - if concealed { - var rawDisplayUrl: String = parsedString - let maxLength = 180 - if rawDisplayUrl.count > maxLength { - rawDisplayUrl = String(rawDisplayUrl[..?, presentationData: ChatPresentationData, historyAppearsCleared: Bool, associatedData: ChatMessageItemAssociatedData, updatingMedia: [MessageId: ChatUpdatingMessageMedia]) -> [ChatHistoryEntry] { if historyAppearsCleared { diff --git a/submodules/TelegramUI/Sources/ChatHistoryEntry.swift b/submodules/TelegramUI/Sources/ChatHistoryEntry.swift index 05488d9409..61adbd48ca 100644 --- a/submodules/TelegramUI/Sources/ChatHistoryEntry.swift +++ b/submodules/TelegramUI/Sources/ChatHistoryEntry.swift @@ -4,28 +4,7 @@ import SyncCore import TelegramPresentationData import MergeLists import TemporaryCachedPeerDataManager - -public enum ChatHistoryMessageSelection: Equatable { - case none - case selectable(selected: Bool) - - public static func ==(lhs: ChatHistoryMessageSelection, rhs: ChatHistoryMessageSelection) -> Bool { - switch lhs { - case .none: - if case .none = rhs { - return true - } else { - return false - } - case let .selectable(selected): - if case .selectable(selected) = rhs { - return true - } else { - return false - } - } - } -} +import AccountContext public enum ChatMessageEntryContentType { case generic diff --git a/submodules/TelegramUI/Sources/ChatHistoryListNode.swift b/submodules/TelegramUI/Sources/ChatHistoryListNode.swift index 9095da2da9..43d031ecf3 100644 --- a/submodules/TelegramUI/Sources/ChatHistoryListNode.swift +++ b/submodules/TelegramUI/Sources/ChatHistoryListNode.swift @@ -14,6 +14,8 @@ import TemporaryCachedPeerDataManager import ChatListSearchItemNode import Emoji import AppBundle +import ListMessageItem +import AccountContext private class ChatHistoryListSelectionRecognizer: UIPanGestureRecognizer { private let selectionGestureActivationThreshold: CGFloat = 5.0 @@ -74,7 +76,7 @@ public enum ChatHistoryListDisplayHeaders { public enum ChatHistoryListMode: Equatable { case bubbles - case list(search: Bool, reversed: Bool, displayHeaders: ChatHistoryListDisplayHeaders) + case list(search: Bool, reversed: Bool, displayHeaders: ChatHistoryListDisplayHeaders, isGlobalSearch: Bool) } enum ChatHistoryViewScrollPosition { @@ -219,6 +221,26 @@ private func maxMessageIndexForEntries(_ view: ChatHistoryView, indexRange: (Int return (incoming, overall) } +extension ListMessageItemInteraction { + convenience init(controllerInteraction: ChatControllerInteraction) { + self.init(openMessage: { message, mode -> Bool in + return controllerInteraction.openMessage(message, mode) + }, openMessageContextMenu: { message, bool, node, rect, gesture in + controllerInteraction.openMessageContextMenu(message, bool, node, rect, gesture) + }, toggleMessagesSelection: { messageId, selected in + controllerInteraction.toggleMessagesSelection(messageId, selected) + }, openUrl: { url, param1, param2, message in + controllerInteraction.openUrl(url, param1, param2, message) + }, openInstantPage: { message, data in + controllerInteraction.openInstantPage(message, data) + }, longTap: { action, message in + controllerInteraction.longTap(action, message) + }, getHiddenMedia: { + return controllerInteraction.hiddenMedia + }) + } +} + private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, lastHeaderId: Int64, entries: [ChatHistoryViewTransitionInsertEntry]) -> [ListViewInsertItem] { return entries.map { entry -> ListViewInsertItem in switch entry.entry { @@ -227,7 +249,7 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) - case let .list(_, _, displayHeaders): + case let .list(_, _, displayHeaders, isGlobalSearch): let displayHeader: Bool switch displayHeaders { case .none: @@ -238,7 +260,7 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca displayHeader = listMessageDateHeaderId(timestamp: message.timestamp) != lastHeaderId } - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: displayHeader) + item = ListMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, interaction: ListMessageItemInteraction(controllerInteraction: controllerInteraction), message: message, selection: selection, displayHeader: displayHeader, isGlobalSearchResult: isGlobalSearch) } return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .MessageGroupEntry(_, messages, presentationData): @@ -246,9 +268,9 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .group(messages: messages)) - case let .list(_, _, _): + case let .list(_, _, _, _): assertionFailure() - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: false) + item = ListMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, interaction: ListMessageItemInteraction(controllerInteraction: controllerInteraction), message: messages[0].0, selection: .none, displayHeader: false) } return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .UnreadEntry(_, presentationData): @@ -271,7 +293,7 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) - case let .list(_, _, displayHeaders): + case let .list(_, _, displayHeaders, isGlobalSearch): let displayHeader: Bool switch displayHeaders { case .none: @@ -281,7 +303,7 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca case .allButLast: displayHeader = listMessageDateHeaderId(timestamp: message.timestamp) != lastHeaderId } - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: displayHeader) + item = ListMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, interaction: ListMessageItemInteraction(controllerInteraction: controllerInteraction), message: message, selection: selection, displayHeader: displayHeader, isGlobalSearchResult: isGlobalSearch) } return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .MessageGroupEntry(_, messages, presentationData): @@ -289,9 +311,9 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .group(messages: messages)) - case let .list(_, _, _): + case let .list(_, _, _, _): assertionFailure() - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: false) + item = ListMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, interaction: ListMessageItemInteraction(controllerInteraction: controllerInteraction), message: messages[0].0, selection: .none, displayHeader: false) } return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .UnreadEntry(_, presentationData): @@ -740,7 +762,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { var reverse = false var includeSearchEntry = false - if case let .list(search, reverseValue, _) = mode { + if case let .list(search, reverseValue, _, _) = mode { includeSearchEntry = search reverse = reverseValue } @@ -1716,7 +1738,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { switch self.mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: self.context, chatLocation: self.chatLocation, associatedData: associatedData, controllerInteraction: self.controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) - case let .list(_, _, displayHeaders): + case let .list(_, _, displayHeaders, isGlobalSearch): let displayHeader: Bool switch displayHeaders { case .none: @@ -1726,7 +1748,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { case .allButLast: displayHeader = listMessageDateHeaderId(timestamp: message.timestamp) != historyView.lastHeaderId } - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: self.context, chatLocation: self.chatLocation, controllerInteraction: self.controllerInteraction, message: message, selection: selection, displayHeader: displayHeader) + item = ListMessageItem(presentationData: presentationData, context: self.context, chatLocation: self.chatLocation, interaction: ListMessageItemInteraction(controllerInteraction: self.controllerInteraction), message: message, selection: selection, displayHeader: displayHeader, isGlobalSearchResult: isGlobalSearch) } let updateItem = ListViewUpdateItem(index: index, previousIndex: index, item: item, directionHint: nil) self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [updateItem], options: [.AnimateInsertion], scrollToItem: nil, additionalScrollDistance: 0.0, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) diff --git a/submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift b/submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift index 89087ad022..6d49b2ea67 100644 --- a/submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift +++ b/submodules/TelegramUI/Sources/ChatHistorySearchContainerNode.swift @@ -11,6 +11,7 @@ import MergeLists import AccountContext import SearchUI import TelegramUIPreferences +import ListMessageItem private enum ChatHistorySearchEntryStableId: Hashable { case messageId(MessageId) @@ -88,7 +89,7 @@ private enum ChatHistorySearchEntry: Comparable, Identifiable { func item(context: AccountContext, peerId: PeerId, interaction: ChatControllerInteraction) -> ListViewItem { switch self { case let .message(message, theme, strings, dateTimeFormat, fontSize): - return ListMessageItem(theme: theme, strings: strings, fontSize: fontSize, dateTimeFormat: dateTimeFormat, context: context, chatLocation: .peer(peerId), controllerInteraction: interaction, message: message, selection: .none, displayHeader: true) + return ListMessageItem(presentationData: ChatPresentationData(theme: ChatPresentationThemeData(theme: theme, wallpaper: .builtin(WallpaperSettings())), fontSize: fontSize, strings: strings, dateTimeFormat: dateTimeFormat, nameDisplayOrder: .firstLast, disableAnimations: false, largeEmoji: false, chatBubbleCorners: PresentationChatBubbleCorners(mainRadius: 0.0, auxiliaryRadius: 0.0, mergeBubbleCorners: false)), context: context, chatLocation: .peer(peerId), interaction: ListMessageItemInteraction(controllerInteraction: interaction), message: message, selection: .none, displayHeader: true) } } } @@ -185,7 +186,7 @@ final class ChatHistorySearchContainerNode: SearchDisplayControllerContentNode { if let strongSelf = self { let signal: Signal<([ChatHistorySearchEntry], [MessageId: Message])?, NoError> if let query = query, !query.isEmpty { - let foundRemoteMessages: Signal<[Message], NoError> = searchMessages(account: context.account, location: .peer(peerId: peerId, fromId: nil, tags: tagMask, topMsgId: nil), query: query, state: nil) + let foundRemoteMessages: Signal<[Message], NoError> = searchMessages(account: context.account, location: .peer(peerId: peerId, fromId: nil, tags: tagMask, topMsgId: nil, minDate: nil, maxDate: nil), query: query, state: nil) |> map { $0.0.messages } |> delay(0.2, queue: Queue.concurrentDefaultQueue()) diff --git a/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift index a7447accc9..a151bc97ac 100644 --- a/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift @@ -13,6 +13,8 @@ import TextFormat import AccountContext import UrlEscaping import PhotoResources +import WebsiteType +import ChatMessageInteractiveMediaBadge private let buttonFont = Font.semibold(13.0) diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift index 502a5a4c3b..091734ed14 100644 --- a/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift @@ -6,6 +6,7 @@ import Postbox import TelegramCore import SyncCore import TelegramUIPreferences +import TelegramPresentationData import AccountContext enum ChatMessageBubbleContentBackgroundHiding { diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift index 784a7af594..2054b91a02 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift @@ -13,6 +13,7 @@ import PhotoResources import TelegramStringFormatting import RadialStatusNode import SemanticStatusNode +import FileMediaResourceStatus private struct FetchControls { let fetch: () -> Void @@ -259,15 +260,15 @@ final class ChatMessageInteractiveFileNode: ASDisplayNode { |> map { resourceStatus, actualFetchStatus -> (FileMediaResourceStatus, MediaResourceStatus?) in return (resourceStatus, actualFetchStatus) } - updatedAudioLevelEventsSignal = messageFileMediaPlaybackAudioLevelEvents(context: context, file: file, message: message, isRecentActions: isRecentActions) + updatedAudioLevelEventsSignal = messageFileMediaPlaybackAudioLevelEvents(context: context, file: file, message: message, isRecentActions: isRecentActions, isGlobalSearch: false) } else { updatedStatusSignal = messageFileMediaResourceStatus(context: context, file: file, message: message, isRecentActions: isRecentActions) |> map { resourceStatus -> (FileMediaResourceStatus, MediaResourceStatus?) in return (resourceStatus, nil) } - updatedAudioLevelEventsSignal = messageFileMediaPlaybackAudioLevelEvents(context: context, file: file, message: message, isRecentActions: isRecentActions) + updatedAudioLevelEventsSignal = messageFileMediaPlaybackAudioLevelEvents(context: context, file: file, message: message, isRecentActions: isRecentActions, isGlobalSearch: false) } - updatedPlaybackStatusSignal = messageFileMediaPlaybackStatus(context: context, file: file, message: message, isRecentActions: isRecentActions) + updatedPlaybackStatusSignal = messageFileMediaPlaybackStatus(context: context, file: file, message: message, isRecentActions: isRecentActions, isGlobalSearch: false) } var statusSize: CGSize? diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift index 25212c7819..eafec61d64 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift @@ -12,6 +12,7 @@ import AccountContext import RadialStatusNode import PhotoResources import TelegramUniversalVideoContent +import FileMediaResourceStatus struct ChatMessageInstantVideoItemLayoutResult { let contentSize: CGSize @@ -629,7 +630,7 @@ class ChatMessageInteractiveInstantVideoNode: ASDisplayNode { } playbackStatusNode.frame = videoFrame.insetBy(dx: 1.5, dy: 1.5) - let status = messageFileMediaPlaybackStatus(context: item.context, file: file, message: item.message, isRecentActions: item.associatedData.isRecentActions) + let status = messageFileMediaPlaybackStatus(context: item.context, file: file, message: item.message, isRecentActions: item.associatedData.isRecentActions, isGlobalSearch: false) playbackStatusNode.status = status self.durationNode?.status = status |> map(Optional.init) diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift index 2b00d06405..b99d2a3502 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift @@ -21,6 +21,7 @@ import AnimatedStickerNode import TelegramAnimatedStickerNode import LocalMediaResources import WallpaperResources +import ChatMessageInteractiveMediaBadge private struct FetchControls { let fetch: (Bool) -> Void diff --git a/submodules/TelegramUI/Sources/ChatMessageItem.swift b/submodules/TelegramUI/Sources/ChatMessageItem.swift index b652decc42..f0eb92ed1a 100644 --- a/submodules/TelegramUI/Sources/ChatMessageItem.swift +++ b/submodules/TelegramUI/Sources/ChatMessageItem.swift @@ -220,51 +220,6 @@ enum ChatMessageMerge: Int32 { } } -public final class ChatMessageItemAssociatedData: Equatable { - let automaticDownloadPeerType: MediaAutoDownloadPeerType - let automaticDownloadNetworkType: MediaAutoDownloadNetworkType - let isRecentActions: Bool - let isScheduledMessages: Bool - let contactsPeerIds: Set - let animatedEmojiStickers: [String: [StickerPackItem]] - let forcedResourceStatus: FileMediaResourceStatus? - - init(automaticDownloadPeerType: MediaAutoDownloadPeerType, automaticDownloadNetworkType: MediaAutoDownloadNetworkType, isRecentActions: Bool = false, isScheduledMessages: Bool = false, contactsPeerIds: Set = Set(), animatedEmojiStickers: [String: [StickerPackItem]] = [:], forcedResourceStatus: FileMediaResourceStatus? = nil) { - self.automaticDownloadPeerType = automaticDownloadPeerType - self.automaticDownloadNetworkType = automaticDownloadNetworkType - self.isRecentActions = isRecentActions - self.isScheduledMessages = isScheduledMessages - self.contactsPeerIds = contactsPeerIds - self.animatedEmojiStickers = animatedEmojiStickers - self.forcedResourceStatus = forcedResourceStatus - } - - public static func == (lhs: ChatMessageItemAssociatedData, rhs: ChatMessageItemAssociatedData) -> Bool { - if lhs.automaticDownloadPeerType != rhs.automaticDownloadPeerType { - return false - } - if lhs.automaticDownloadNetworkType != rhs.automaticDownloadNetworkType { - return false - } - if lhs.isRecentActions != rhs.isRecentActions { - return false - } - if lhs.isScheduledMessages != rhs.isScheduledMessages { - return false - } - if lhs.contactsPeerIds != rhs.contactsPeerIds { - return false - } - if lhs.animatedEmojiStickers != rhs.animatedEmojiStickers { - return false - } - if lhs.forcedResourceStatus != rhs.forcedResourceStatus { - return false - } - return true - } -} - public final class ChatMessageItem: ListViewItem, CustomStringConvertible { let presentationData: ChatPresentationData let context: AccountContext diff --git a/submodules/TelegramUI/Sources/ChatMessageItemView.swift b/submodules/TelegramUI/Sources/ChatMessageItemView.swift index f114d2af30..d0a8422e62 100644 --- a/submodules/TelegramUI/Sources/ChatMessageItemView.swift +++ b/submodules/TelegramUI/Sources/ChatMessageItemView.swift @@ -9,6 +9,7 @@ import AccountContext import LocalizedPeerData import ContextUI import ChatListUI +import TelegramPresentationData struct ChatMessageItemWidthFill { var compactInset: CGFloat diff --git a/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift index 4ad043b1a8..c1ff8efc88 100644 --- a/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift @@ -13,24 +13,6 @@ import WebsiteType import InstantPageUI import UrlHandling -enum InstantPageType { - case generic - case album -} - -func instantPageType(of webpage: TelegramMediaWebpageLoadedContent) -> InstantPageType { - if let type = webpage.type, type == "telegram_album" { - return .album - } - - switch websiteType(of: webpage.websiteName) { - case .instagram, .twitter: - return .album - default: - return .generic - } -} - func instantPageGalleryMedia(webpageId: MediaId, page: InstantPage, galleryMedia: Media) -> [InstantPageGalleryEntry] { var result: [InstantPageGalleryEntry] = [] var counter: Int = 0 diff --git a/submodules/TelegramUI/Sources/ChatPresentationData.swift b/submodules/TelegramUI/Sources/ChatPresentationData.swift deleted file mode 100644 index 253882e904..0000000000 --- a/submodules/TelegramUI/Sources/ChatPresentationData.swift +++ /dev/null @@ -1,65 +0,0 @@ -import Foundation -import UIKit -import Display -import TelegramCore -import SyncCore -import TelegramPresentationData -import TelegramUIPreferences - -public final class ChatPresentationThemeData: Equatable { - public let theme: PresentationTheme - public let wallpaper: TelegramWallpaper - - public init(theme: PresentationTheme, wallpaper: TelegramWallpaper) { - self.theme = theme - self.wallpaper = wallpaper - } - - public static func ==(lhs: ChatPresentationThemeData, rhs: ChatPresentationThemeData) -> Bool { - return lhs.theme === rhs.theme && lhs.wallpaper == rhs.wallpaper - } -} - -public final class ChatPresentationData { - let theme: ChatPresentationThemeData - let fontSize: PresentationFontSize - let strings: PresentationStrings - let dateTimeFormat: PresentationDateTimeFormat - let nameDisplayOrder: PresentationPersonNameOrder - let disableAnimations: Bool - let largeEmoji: Bool - let chatBubbleCorners: PresentationChatBubbleCorners - let animatedEmojiScale: CGFloat - let isPreview: Bool - - let messageFont: UIFont - let messageEmojiFont: UIFont - let messageBoldFont: UIFont - let messageItalicFont: UIFont - let messageBoldItalicFont: UIFont - let messageFixedFont: UIFont - let messageBlockQuoteFont: UIFont - - init(theme: ChatPresentationThemeData, fontSize: PresentationFontSize, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, disableAnimations: Bool, largeEmoji: Bool, chatBubbleCorners: PresentationChatBubbleCorners, animatedEmojiScale: CGFloat = 1.0, isPreview: Bool = false) { - self.theme = theme - self.fontSize = fontSize - self.strings = strings - self.dateTimeFormat = dateTimeFormat - self.nameDisplayOrder = nameDisplayOrder - self.disableAnimations = disableAnimations - self.chatBubbleCorners = chatBubbleCorners - self.largeEmoji = largeEmoji - self.isPreview = isPreview - - let baseFontSize = fontSize.baseDisplaySize - self.messageFont = Font.regular(baseFontSize) - self.messageEmojiFont = Font.regular(53.0) - self.messageBoldFont = Font.bold(baseFontSize) - self.messageItalicFont = Font.italic(baseFontSize) - self.messageBoldItalicFont = Font.semiboldItalic(baseFontSize) - self.messageFixedFont = Font.monospace(baseFontSize) - self.messageBlockQuoteFont = Font.regular(baseFontSize - 1.0) - - self.animatedEmojiScale = animatedEmojiScale - } -} diff --git a/submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift b/submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift index d3b4346f7f..e9082e6f4d 100644 --- a/submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift +++ b/submodules/TelegramUI/Sources/ChatScheduleTimeControllerNode.swift @@ -8,7 +8,6 @@ import SyncCore import TelegramPresentationData import TelegramStringFormatting import AccountContext -import ShareController import SolidRoundedButtonNode import PresentationDataUtils diff --git a/submodules/TelegramUI/Sources/GridMessageItem.swift b/submodules/TelegramUI/Sources/GridMessageItem.swift index 46b058964b..9d60e67869 100644 --- a/submodules/TelegramUI/Sources/GridMessageItem.swift +++ b/submodules/TelegramUI/Sources/GridMessageItem.swift @@ -14,6 +14,7 @@ import RadialStatusNode import PhotoResources import GridMessageSelectionNode import ContextUI +import ChatMessageInteractiveMediaBadge private func mediaForMessage(_ message: Message) -> Media? { for media in message.media { diff --git a/submodules/TelegramUI/Sources/OpenChatMessage.swift b/submodules/TelegramUI/Sources/OpenChatMessage.swift index 7fc987a44b..224269a1cd 100644 --- a/submodules/TelegramUI/Sources/OpenChatMessage.swift +++ b/submodules/TelegramUI/Sources/OpenChatMessage.swift @@ -21,6 +21,7 @@ import AlertUI import PresentationDataUtils import ShareController import UndoUI +import WebsiteType private enum ChatMessageGalleryControllerData { case url(String) @@ -37,7 +38,7 @@ private enum ChatMessageGalleryControllerData { case other(Media) } -private func chatMessageGalleryControllerData(context: AccountContext, chatLocation: ChatLocation?, chatLocationContextHolder: Atomic?, message: Message, navigationController: NavigationController?, standalone: Bool, reverseMessageGalleryOrder: Bool, mode: ChatControllerInteractionOpenMessageMode, synchronousLoad: Bool, actionInteraction: GalleryControllerActionInteraction?) -> ChatMessageGalleryControllerData? { +private func chatMessageGalleryControllerData(context: AccountContext, chatLocation: ChatLocation?, chatLocationContextHolder: Atomic?, message: Message, navigationController: NavigationController?, standalone: Bool, reverseMessageGalleryOrder: Bool, mode: ChatControllerInteractionOpenMessageMode, source: GalleryControllerItemSource?, synchronousLoad: Bool, actionInteraction: GalleryControllerActionInteraction?) -> ChatMessageGalleryControllerData? { var galleryMedia: Media? var otherMedia: Media? var instantPageMedia: (TelegramMediaWebpage, [InstantPageGalleryEntry])? @@ -190,7 +191,7 @@ private func chatMessageGalleryControllerData(context: AccountContext, chatLocat return .gallery(startTimecode |> deliverOnMainQueue |> map { timecode in - let gallery = GalleryController(context: context, source: standalone ? .standaloneMessage(message) : .peerMessagesAtId(messageId: message.id, chatLocation: chatLocation ?? .peer(message.id.peerId), chatLocationContextHolder: chatLocationContextHolder ?? Atomic(value: nil)), invertItemOrder: reverseMessageGalleryOrder, streamSingleVideo: stream, fromPlayingVideo: autoplayingVideo, landscape: landscape, timecode: timecode, synchronousLoad: synchronousLoad, replaceRootController: { [weak navigationController] controller, ready in + let gallery = GalleryController(context: context, source: source ?? (standalone ? .standaloneMessage(message) : .peerMessagesAtId(messageId: message.id, chatLocation: chatLocation ?? .peer(message.id.peerId), chatLocationContextHolder: chatLocationContextHolder ?? Atomic(value: nil))), invertItemOrder: reverseMessageGalleryOrder, streamSingleVideo: stream, fromPlayingVideo: autoplayingVideo, landscape: landscape, timecode: timecode, synchronousLoad: synchronousLoad, replaceRootController: { [weak navigationController] controller, ready in navigationController?.replaceTopController(controller, animated: false, ready: ready) }, baseNavigationController: navigationController, actionInteraction: actionInteraction) gallery.temporaryDoNotWaitForReady = autoplayingVideo @@ -212,7 +213,7 @@ enum ChatMessagePreviewControllerData { } func chatMessagePreviewControllerData(context: AccountContext, chatLocation: ChatLocation?, chatLocationContextHolder: Atomic?, message: Message, standalone: Bool, reverseMessageGalleryOrder: Bool, navigationController: NavigationController?) -> ChatMessagePreviewControllerData? { - if let mediaData = chatMessageGalleryControllerData(context: context, chatLocation: chatLocation, chatLocationContextHolder: chatLocationContextHolder, message: message, navigationController: navigationController, standalone: standalone, reverseMessageGalleryOrder: reverseMessageGalleryOrder, mode: .default, synchronousLoad: true, actionInteraction: nil) { + if let mediaData = chatMessageGalleryControllerData(context: context, chatLocation: chatLocation, chatLocationContextHolder: chatLocationContextHolder, message: message, navigationController: navigationController, standalone: standalone, reverseMessageGalleryOrder: reverseMessageGalleryOrder, mode: .default, source: nil, synchronousLoad: true, actionInteraction: nil) { switch mediaData { case let .gallery(gallery): break @@ -226,7 +227,7 @@ func chatMessagePreviewControllerData(context: AccountContext, chatLocation: Cha } func chatMediaListPreviewControllerData(context: AccountContext, chatLocation: ChatLocation?, chatLocationContextHolder: Atomic?, message: Message, standalone: Bool, reverseMessageGalleryOrder: Bool, navigationController: NavigationController?) -> Signal { - if let mediaData = chatMessageGalleryControllerData(context: context, chatLocation: chatLocation, chatLocationContextHolder: chatLocationContextHolder, message: message, navigationController: navigationController, standalone: standalone, reverseMessageGalleryOrder: reverseMessageGalleryOrder, mode: .default, synchronousLoad: true, actionInteraction: nil) { + if let mediaData = chatMessageGalleryControllerData(context: context, chatLocation: chatLocation, chatLocationContextHolder: chatLocationContextHolder, message: message, navigationController: navigationController, standalone: standalone, reverseMessageGalleryOrder: reverseMessageGalleryOrder, mode: .default, source: nil, synchronousLoad: true, actionInteraction: nil) { switch mediaData { case let .gallery(gallery): return gallery @@ -243,7 +244,7 @@ func chatMediaListPreviewControllerData(context: AccountContext, chatLocation: C } func openChatMessageImpl(_ params: OpenChatMessageParams) -> Bool { - if let mediaData = chatMessageGalleryControllerData(context: params.context, chatLocation: params.chatLocation, chatLocationContextHolder: params.chatLocationContextHolder, message: params.message, navigationController: params.navigationController, standalone: params.standalone, reverseMessageGalleryOrder: params.reverseMessageGalleryOrder, mode: params.mode, synchronousLoad: false, actionInteraction: params.actionInteraction) { + if let mediaData = chatMessageGalleryControllerData(context: params.context, chatLocation: params.chatLocation, chatLocationContextHolder: params.chatLocationContextHolder, message: params.message, navigationController: params.navigationController, standalone: params.standalone, reverseMessageGalleryOrder: params.reverseMessageGalleryOrder, mode: params.mode, source: params.gallerySource, synchronousLoad: false, actionInteraction: params.actionInteraction) { switch mediaData { case let .url(url): params.openUrl(url) @@ -358,8 +359,10 @@ func openChatMessageImpl(_ params: OpenChatMessageParams) -> Bool { } playerType = .voice } else if file.isMusic && params.message.tags.contains(.music) { - if params.standalone { - location = .recentActions(params.message) + if let playlistLocation = params.playlistLocation { + location = playlistLocation + } else if params.standalone { + location = .recentActions(params.message) } else { location = .messages(peerId: params.message.id.peerId, tagMask: .music, at: params.message.id) } diff --git a/submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift b/submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift index d1f106392e..9581fbc8ff 100644 --- a/submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift +++ b/submodules/TelegramUI/Sources/OverlayAudioPlayerController.swift @@ -15,6 +15,7 @@ final class OverlayAudioPlayerControllerImpl: ViewController, OverlayAudioPlayer let type: MediaManagerPlayerType let initialMessageId: MessageId let initialOrder: MusicPlaybackSettingsOrder + let isGlobalSearch: Bool private weak var parentNavigationController: NavigationController? @@ -26,12 +27,13 @@ final class OverlayAudioPlayerControllerImpl: ViewController, OverlayAudioPlayer private var accountInUseDisposable: Disposable? - init(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, parentNavigationController: NavigationController?) { + init(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, isGlobalSearch: Bool = false, parentNavigationController: NavigationController?) { self.context = context self.peerId = peerId self.type = type self.initialMessageId = initialMessageId self.initialOrder = initialOrder + self.isGlobalSearch = isGlobalSearch self.parentNavigationController = parentNavigationController super.init(navigationBarPresentationData: nil) @@ -52,7 +54,7 @@ final class OverlayAudioPlayerControllerImpl: ViewController, OverlayAudioPlayer } override public func loadDisplayNode() { - self.displayNode = OverlayAudioPlayerControllerNode(context: self.context, peerId: self.peerId, type: self.type, initialMessageId: self.initialMessageId, initialOrder: self.initialOrder, requestDismiss: { [weak self] in + self.displayNode = OverlayAudioPlayerControllerNode(context: self.context, peerId: self.peerId, type: self.type, initialMessageId: self.initialMessageId, initialOrder: self.initialOrder, isGlobalSearch: self.isGlobalSearch, requestDismiss: { [weak self] in self?.dismiss() }, requestShare: { [weak self] messageId in if let strongSelf = self { diff --git a/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift b/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift index bdd32429f4..d5d571e8e4 100644 --- a/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift +++ b/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift @@ -20,6 +20,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu private let type: MediaManagerPlayerType private let requestDismiss: () -> Void private let requestShare: (MessageId) -> Void + private let isGlobalSearch: Bool private let controllerInteraction: ChatControllerInteraction @@ -40,13 +41,14 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu private var presentationDataDisposable: Disposable? private let replacementHistoryNodeReadyDisposable = MetaDisposable() - init(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, requestDismiss: @escaping () -> Void, requestShare: @escaping (MessageId) -> Void) { + init(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, isGlobalSearch: Bool, requestDismiss: @escaping () -> Void, requestShare: @escaping (MessageId) -> Void) { self.context = context self.peerId = peerId self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.type = type self.requestDismiss = requestDismiss self.requestShare = requestShare + self.isGlobalSearch = isGlobalSearch if case .regular = initialOrder { self.currentIsReversed = false @@ -162,7 +164,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu let chatLocationContextHolder = Atomic(value: nil) - self.historyNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), chatLocationContextHolder: chatLocationContextHolder, tagMask: tagMask, subject: .message(initialMessageId), controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: currentIsReversed, displayHeaders: .none)) + self.historyNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), chatLocationContextHolder: chatLocationContextHolder, tagMask: tagMask, subject: .message(initialMessageId), controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: currentIsReversed, displayHeaders: .none, isGlobalSearch: isGlobalSearch)) super.init() @@ -493,7 +495,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu } let chatLocationContextHolder = Atomic(value: nil) - let historyNode = ChatHistoryListNode(context: self.context, chatLocation: .peer(self.peerId), chatLocationContextHolder: chatLocationContextHolder, tagMask: tagMask, subject: .message(messageId), controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: self.currentIsReversed, displayHeaders: .none)) + let historyNode = ChatHistoryListNode(context: self.context, chatLocation: .peer(self.peerId), chatLocationContextHolder: chatLocationContextHolder, tagMask: tagMask, subject: .message(messageId), controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: self.currentIsReversed, displayHeaders: .none, isGlobalSearch: self.isGlobalSearch)) historyNode.preloadPages = true historyNode.stackFromBottom = true historyNode.updateFloatingHeaderOffset = { [weak self] offset, _ in diff --git a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift index f99b2fe66b..14780e7beb 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoListPaneNode.swift @@ -13,6 +13,7 @@ import TelegramUIPreferences import UniversalMediaPlayer import TelegramBaseController import OverlayStatusController +import ListMessageItem private final class PassthroughContainerNode: ASDisplayNode { override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { @@ -71,7 +72,7 @@ final class PeerInfoListPaneNode: ASDisplayNode, PeerInfoPaneNode { self.selectedMessagesPromise.set(.single(self.selectedMessages)) let chatLocationContextHolder = Atomic(value: nil) - self.listNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), chatLocationContextHolder: chatLocationContextHolder, tagMask: tagMask, subject: nil, controllerInteraction: chatControllerInteraction, selectedMessages: self.selectedMessagesPromise.get(), mode: .list(search: false, reversed: false, displayHeaders: .allButLast)) + self.listNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), chatLocationContextHolder: chatLocationContextHolder, tagMask: tagMask, subject: nil, controllerInteraction: chatControllerInteraction, selectedMessages: self.selectedMessagesPromise.get(), mode: .list(search: false, reversed: false, displayHeaders: .allButLast, isGlobalSearch: false)) self.listNode.defaultToSynchronousTransactionWhileScrolling = true if tagMask == .music { @@ -305,7 +306,7 @@ final class PeerInfoListPaneNode: ASDisplayNode, PeerInfoPaneNode { } else { controllerContext = strongSelf.context.sharedContext.makeTempAccountContext(account: account) } - let controller = strongSelf.context.sharedContext.makeOverlayAudioPlayerController(context: controllerContext, peerId: id.messageId.peerId, type: type, initialMessageId: id.messageId, initialOrder: order, parentNavigationController: strongSelf.chatControllerInteraction.navigationController()) + let controller = strongSelf.context.sharedContext.makeOverlayAudioPlayerController(context: controllerContext, peerId: id.messageId.peerId, type: type, initialMessageId: id.messageId, initialOrder: order, isGlobalSearch: false, parentNavigationController: strongSelf.chatControllerInteraction.navigationController()) strongSelf.view.window?.endEditing(true) strongSelf.chatControllerInteraction.presentController(controller, nil) } else if index.1 { diff --git a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift index a779b60417..5a905bda94 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift @@ -12,6 +12,8 @@ import RadialStatusNode import TelegramStringFormatting import GridMessageSelectionNode import UniversalMediaPlayer +import ListMessageItem +import ChatMessageInteractiveMediaBadge private final class FrameSequenceThumbnailNode: ASDisplayNode { private let context: AccountContext diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift index 2c10cf10fb..17cdf49101 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift @@ -49,6 +49,7 @@ import LegacyMediaPickerUI import TelegramNotices import SaveToCameraRoll import PeerInfoUI +import ListMessageItem protocol PeerInfoScreenItem: class { var id: AnyHashable { get } @@ -4869,7 +4870,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } }) } - }, exceptionsList: .single(settings.notificationExceptions), archivedStickerPacks: .single(settings.archivedStickerPacks), privacySettings: .single(settings.privacySettings), hasWallet: .single(false), activeSessionsContext: self.activeSessionsContextAndCount.get() |> map { $0?.0 }, webSessionsContext: self.activeSessionsContextAndCount.get() |> map { $0?.2 }), cancel: { [weak self] in + }, resolvedFaqUrl: self.cachedFaq.get(), exceptionsList: .single(settings.notificationExceptions), archivedStickerPacks: .single(settings.archivedStickerPacks), privacySettings: .single(settings.privacySettings), hasWallet: .single(false), activeSessionsContext: self.activeSessionsContextAndCount.get() |> map { $0?.0 }, webSessionsContext: self.activeSessionsContextAndCount.get() |> map { $0?.2 }), cancel: { [weak self] in self?.deactivateSearch() }) } diff --git a/submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift b/submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift index b8be00a33d..07c233a369 100644 --- a/submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift +++ b/submodules/TelegramUI/Sources/PeerMessagesMediaPlaylist.swift @@ -199,94 +199,6 @@ private func navigatedMessageFromView(_ view: MessageHistoryView, anchorIndex: M } } -enum PeerMessagesPlaylistLocation: Equatable, SharedMediaPlaylistLocation { - case messages(peerId: PeerId, tagMask: MessageTags, at: MessageId) - case singleMessage(MessageId) - case recentActions(Message) - - var playlistId: PeerMessagesMediaPlaylistId { - switch self { - case let .messages(peerId, _, _): - return .peer(peerId) - case let .singleMessage(id): - return .peer(id.peerId) - case let .recentActions(message): - return .recentActions(message.id.peerId) - } - } - - var messageId: MessageId? { - switch self { - case let .messages(_, _, messageId), let .singleMessage(messageId): - return messageId - default: - return nil - } - } - - func isEqual(to: SharedMediaPlaylistLocation) -> Bool { - if let to = to as? PeerMessagesPlaylistLocation { - return self == to - } else { - return false - } - } - - static func ==(lhs: PeerMessagesPlaylistLocation, rhs: PeerMessagesPlaylistLocation) -> Bool { - switch lhs { - case let .messages(peerId, tagMask, at): - if case .messages(peerId, tagMask, at) = rhs { - return true - } else { - return false - } - case let .singleMessage(messageId): - if case .singleMessage(messageId) = rhs { - return true - } else { - return false - } - case let .recentActions(lhsMessage): - if case let .recentActions(rhsMessage) = rhs, lhsMessage.id == rhsMessage.id { - return true - } else { - return false - } - } - } -} - -enum PeerMessagesMediaPlaylistId: Equatable, SharedMediaPlaylistId { - case peer(PeerId) - case recentActions(PeerId) - - func isEqual(to: SharedMediaPlaylistId) -> Bool { - if let to = to as? PeerMessagesMediaPlaylistId { - return self == to - } - return false - } -} - -func peerMessageMediaPlayerType(_ message: Message) -> MediaManagerPlayerType? { - if let file = extractFileMedia(message) { - if file.isVoice || file.isInstantVideo { - return .voice - } else if file.isMusic { - return .music - } - } - return nil -} - -func peerMessagesMediaPlaylistAndItemId(_ message: Message, isRecentActions: Bool) -> (SharedMediaPlaylistId, SharedMediaPlaylistItemId)? { - if isRecentActions { - return (PeerMessagesMediaPlaylistId.recentActions(message.id.peerId), PeerMessagesMediaPlaylistItemId(messageId: message.id)) - } else { - return (PeerMessagesMediaPlaylistId.peer(message.id.peerId), PeerMessagesMediaPlaylistItemId(messageId: message.id)) - } -} - private struct PlaybackStack { var ids: [MessageId] = [] var set: Set = [] @@ -383,6 +295,10 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { self.loadingItem = false self.currentItem = (message, []) self.updateState() + case let .searchResults(_, _, messages, messageId): + self.loadingItem = false + self.currentItem = (messages.first(where: { $0.id == messageId })!, messages) + self.updateState() } } @@ -430,7 +346,7 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { self.currentItem = nil self.updateState() } else { - self.loadItem(anchor: .index(currentItem.current.index), navigation: navigation) + self.loadItem(anchor: .index(currentItem.current.index), navigation: navigation) } } } @@ -562,6 +478,10 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { } case let .index(index): switch self.messagesLocation { + case let .searchResults(_, _, messages, _): + self.loadingItem = false + self.currentItem = (messages.first(where: { $0.id == index.id })!, messages) + self.updateState() case let .messages(peerId, tagMask, _): let inputIndex: Signal let looping = self.looping diff --git a/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift b/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift index b8cc8236fd..8ca92ecc54 100644 --- a/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift +++ b/submodules/TelegramUI/Sources/PeerSelectionControllerNode.swift @@ -223,8 +223,8 @@ final class PeerSelectionControllerNode: ASDisplayNode { if let requestOpenMessageFromSearch = self?.requestOpenMessageFromSearch { requestOpenMessageFromSearch(peer, messageId) } - }, addContact: nil, peerContextAction: nil, present: { _ in - }), cancel: { [weak self] in + }, addContact: nil, peerContextAction: nil, present: { _, _ in + }, navigationController: nil), cancel: { [weak self] in if let requestDeactivateSearch = self?.requestDeactivateSearch { requestDeactivateSearch() } diff --git a/submodules/TelegramUI/Sources/SharedAccountContext.swift b/submodules/TelegramUI/Sources/SharedAccountContext.swift index 4a3e1deaaa..682fe934b9 100644 --- a/submodules/TelegramUI/Sources/SharedAccountContext.swift +++ b/submodules/TelegramUI/Sources/SharedAccountContext.swift @@ -936,8 +936,8 @@ public final class SharedAccountContextImpl: SharedAccountContext { }) } - public func makeOverlayAudioPlayerController(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, parentNavigationController: NavigationController?) -> ViewController & OverlayAudioPlayerController { - return OverlayAudioPlayerControllerImpl(context: context, peerId: peerId, type: type, initialMessageId: initialMessageId, initialOrder: initialOrder, parentNavigationController: parentNavigationController) + public func makeOverlayAudioPlayerController(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, isGlobalSearch: Bool, parentNavigationController: NavigationController?) -> ViewController & OverlayAudioPlayerController { + return OverlayAudioPlayerControllerImpl(context: context, peerId: peerId, type: type, initialMessageId: initialMessageId, initialOrder: initialOrder, isGlobalSearch: isGlobalSearch, parentNavigationController: parentNavigationController) } public func makeTempAccountContext(account: Account) -> AccountContext { diff --git a/submodules/TelegramUI/Sources/TextLinkHandling.swift b/submodules/TelegramUI/Sources/TextLinkHandling.swift index 8a0c852220..afab3cbc48 100644 --- a/submodules/TelegramUI/Sources/TextLinkHandling.swift +++ b/submodules/TelegramUI/Sources/TextLinkHandling.swift @@ -15,6 +15,7 @@ import HashtagSearchUI import StickerPackPreviewUI import JoinLinkPreviewUI import PresentationDataUtils +import UrlWhitelist func handleTextLinkActionImpl(context: AccountContext, peerId: PeerId?, navigateDisposable: MetaDisposable, controller: ViewController, action: TextLinkItemActionType, itemLink: TextLinkItem) { let presentImpl: (ViewController, Any?) -> Void = { controllerToPresent, _ in diff --git a/submodules/UrlHandling/Sources/UrlHandling.swift b/submodules/UrlHandling/Sources/UrlHandling.swift index 7ef3e0ad6f..92d99b604a 100644 --- a/submodules/UrlHandling/Sources/UrlHandling.swift +++ b/submodules/UrlHandling/Sources/UrlHandling.swift @@ -13,6 +13,7 @@ import WalletUrl #endif private let baseTelegramMePaths = ["telegram.me", "t.me", "telegram.dog"] +private let baseTelegraPhPaths = ["telegra.ph/", "te.legra.ph/", "graph.org/", "t.me/iv?"] public enum ParsedInternalPeerUrlParameter { case botStart(String) @@ -475,7 +476,6 @@ public func resolveUrlImpl(account: Account, url: String) -> Signal Bool { } return false } + +public func parseUrl(url: String, wasConcealed: Bool) -> (string: String, concealed: Bool) { + var parsedUrlValue: URL? + if url.hasPrefix("tel:") { + return (url, false) + } else if let parsed = URL(string: url) { + parsedUrlValue = parsed + } else if let parsed = URL(string: "https://" + url) { + parsedUrlValue = parsed + } else if let encoded = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed), let parsed = URL(string: encoded) { + parsedUrlValue = parsed + } + let host = parsedUrlValue?.host ?? url + + let rawHost = (host as NSString).removingPercentEncoding ?? host + var latin = CharacterSet() + latin.insert(charactersIn: "A"..."Z") + latin.insert(charactersIn: "a"..."z") + latin.insert(charactersIn: "0"..."9") + var punctuation = CharacterSet() + punctuation.insert(charactersIn: ".-/+_") + var hasLatin = false + var hasNonLatin = false + for c in rawHost { + if c.unicodeScalars.allSatisfy(punctuation.contains) { + } else if c.unicodeScalars.allSatisfy(latin.contains) { + hasLatin = true + } else { + hasNonLatin = true + } + } + var concealed = wasConcealed + if hasLatin && hasNonLatin { + concealed = true + } + + var rawDisplayUrl: String + if hasNonLatin { + rawDisplayUrl = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) ?? url + } else { + rawDisplayUrl = url + } + + if let parsedUrlValue = parsedUrlValue, isConcealedUrlWhitelisted(parsedUrlValue) { + concealed = false + } + + let whitelistedSchemes: [String] = [ + "tel", + ] + if let parsedUrlValue = parsedUrlValue, let scheme = parsedUrlValue.scheme, whitelistedSchemes.contains(scheme) { + concealed = false + } + + return (rawDisplayUrl, concealed) +} diff --git a/submodules/WebsiteType/BUCK b/submodules/WebsiteType/BUCK index cc609e752b..7c8ecfbdd2 100644 --- a/submodules/WebsiteType/BUCK +++ b/submodules/WebsiteType/BUCK @@ -5,6 +5,9 @@ static_library( srcs = glob([ "Sources/**/*.swift", ]), + deps = [ + "//submodules/SyncCore:SyncCore#shared", + ], frameworks = [ "$SDKROOT/System/Library/Frameworks/Foundation.framework", ], diff --git a/submodules/WebsiteType/BUILD b/submodules/WebsiteType/BUILD index ba2a658eb1..dd3c2d8c69 100644 --- a/submodules/WebsiteType/BUILD +++ b/submodules/WebsiteType/BUILD @@ -7,6 +7,7 @@ swift_library( "Sources/**/*.swift", ]), deps = [ + "//submodules/SyncCore:SyncCore", ], visibility = [ "//visibility:public", diff --git a/submodules/WebsiteType/Sources/WebsiteType.swift b/submodules/WebsiteType/Sources/WebsiteType.swift index ce214994cb..53b6950108 100644 --- a/submodules/WebsiteType/Sources/WebsiteType.swift +++ b/submodules/WebsiteType/Sources/WebsiteType.swift @@ -1,4 +1,5 @@ import Foundation +import SyncCore public enum WebsiteType { case generic @@ -16,3 +17,21 @@ public func websiteType(of websiteName: String?) -> WebsiteType { } return .generic } + +public enum InstantPageType { + case generic + case album +} + +public func instantPageType(of webpage: TelegramMediaWebpageLoadedContent) -> InstantPageType { + if let type = webpage.type, type == "telegram_album" { + return .album + } + + switch websiteType(of: webpage.websiteName) { + case .instagram, .twitter: + return .album + default: + return .generic + } +}