diff --git a/Telegram/SiriIntents/IntentMessages.swift b/Telegram/SiriIntents/IntentMessages.swift index 4de0ef0384..0f1e90de05 100644 --- a/Telegram/SiriIntents/IntentMessages.swift +++ b/Telegram/SiriIntents/IntentMessages.swift @@ -156,7 +156,7 @@ private func callWithTelegramMessage(_ telegramMessage: Message, account: Accoun var duration: Int32? for media in telegramMessage.media { - if let action = media as? TelegramMediaAction, case let .phoneCall(_, _, callDuration) = action.action { + if let action = media as? TelegramMediaAction, case let .phoneCall(_, _, callDuration, _) = action.action { duration = callDuration } } diff --git a/Telegram/Telegram-iOS/en.lproj/Localizable.strings b/Telegram/Telegram-iOS/en.lproj/Localizable.strings index 909f96e1e8..4b04aea311 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -2289,7 +2289,9 @@ Unused sets are archived when you add more."; "Notification.CallTimeFormat" = "%1$@ (%2$@)"; // 1 - type, 2 - duration "Notification.CallOutgoing" = "Outgoing Call"; +"Notification.VideoCallOutgoing" = "Outgoing Video Call"; "Notification.CallIncoming" = "Incoming Call"; +"Notification.VideoCallIncoming" = "Incoming Video Call"; "Notification.CallMissed" = "Missed Call"; "Notification.CallCanceled" = "Cancelled Call"; "Notification.CallOutgoingShort" = "Outgoing"; @@ -5328,6 +5330,7 @@ Any member of this group will be able to see messages in the channel."; "PeerInfo.ButtonMessage" = "Message"; "PeerInfo.ButtonDiscuss" = "Discuss"; "PeerInfo.ButtonCall" = "Call"; +"PeerInfo.ButtonVideoCall" = "Video Call"; "PeerInfo.ButtonMute" = "Mute"; "PeerInfo.ButtonUnmute" = "Unmute"; "PeerInfo.ButtonMore" = "More"; @@ -5620,3 +5623,9 @@ Any member of this group will be able to see messages in the channel."; "Stats.GroupTopInviter.History" = "History"; "Stats.GroupTopInviter.Promote" = "Promote"; + +"PrivacySettings.AutoArchiveTitle" = "NEW CHATS FROM UNKNOWN USERS"; +"PrivacySettings.AutoArchive" = "Archive and Mute"; +"PrivacySettings.AutoArchiveInfo" = "Automatically archive and mute new chats, groups and channels from non-contacts."; + +"Call.RemoteVideoPaused" = "%@'s video paused"; diff --git a/submodules/AccountContext/Sources/OpenChatMessage.swift b/submodules/AccountContext/Sources/OpenChatMessage.swift index 39bf422b69..00f353051c 100644 --- a/submodules/AccountContext/Sources/OpenChatMessage.swift +++ b/submodules/AccountContext/Sources/OpenChatMessage.swift @@ -30,7 +30,7 @@ public final class OpenChatMessageParams { public let addToTransitionSurface: (UIView) -> Void public let openUrl: (String) -> Void public let openPeer: (Peer, ChatControllerInteractionNavigateToPeer) -> Void - public let callPeer: (PeerId) -> Void + public let callPeer: (PeerId, Bool) -> Void public let enqueueMessage: (EnqueueMessage) -> Void public let sendSticker: ((FileMediaReference, ASDisplayNode, CGRect) -> Bool)? public let setupTemporaryHiddenMedia: (Signal, Int, Media) -> Void @@ -51,7 +51,7 @@ public final class OpenChatMessageParams { addToTransitionSurface: @escaping (UIView) -> Void, openUrl: @escaping (String) -> Void, openPeer: @escaping (Peer, ChatControllerInteractionNavigateToPeer) -> Void, - callPeer: @escaping (PeerId) -> Void, + callPeer: @escaping (PeerId, Bool) -> Void, enqueueMessage: @escaping (EnqueueMessage) -> Void, sendSticker: ((FileMediaReference, ASDisplayNode, CGRect) -> Bool)?, setupTemporaryHiddenMedia: @escaping (Signal, Int, Media) -> Void, diff --git a/submodules/AccountContext/Sources/OverlayMediaManager.swift b/submodules/AccountContext/Sources/OverlayMediaManager.swift index 15edac8a7d..45d7eec061 100644 --- a/submodules/AccountContext/Sources/OverlayMediaManager.swift +++ b/submodules/AccountContext/Sources/OverlayMediaManager.swift @@ -1,7 +1,24 @@ import Foundation +import UIKit import Display +public final class OverlayMediaControllerEmbeddingItem { + public let position: CGPoint + public let itemNode: OverlayMediaItemNode + + public init( + position: CGPoint, + itemNode: OverlayMediaItemNode + ) { + self.position = position + self.itemNode = itemNode + } +} + public protocol OverlayMediaController: class { + var updatePossibleEmbeddingItem: ((OverlayMediaControllerEmbeddingItem?) -> Void)? { get set } + var embedPossibleEmbeddingItem: ((OverlayMediaControllerEmbeddingItem) -> Bool)? { get set } + var hasNodes: Bool { get } func addNode(_ node: OverlayMediaItemNode, customTransition: Bool) func removeNode(_ node: OverlayMediaItemNode, customTransition: Bool) @@ -10,10 +27,21 @@ public protocol OverlayMediaController: class { public final class OverlayMediaManager { public var controller: (OverlayMediaController & ViewController)? + public var updatePossibleEmbeddingItem: ((OverlayMediaControllerEmbeddingItem?) -> Void)? + public var embedPossibleEmbeddingItem: ((OverlayMediaControllerEmbeddingItem) -> Bool)? + public init() { } public func attachOverlayMediaController(_ controller: OverlayMediaController & ViewController) { self.controller = controller + + controller.updatePossibleEmbeddingItem = { [weak self] item in + self?.updatePossibleEmbeddingItem?(item) + } + + controller.embedPossibleEmbeddingItem = { [weak self] item in + return self?.embedPossibleEmbeddingItem?(item) ?? false + } } } diff --git a/submodules/AccountContext/Sources/PresentationCallManager.swift b/submodules/AccountContext/Sources/PresentationCallManager.swift index 0200352455..aedbdc6b8b 100644 --- a/submodules/AccountContext/Sources/PresentationCallManager.swift +++ b/submodules/AccountContext/Sources/PresentationCallManager.swift @@ -11,6 +11,27 @@ public enum RequestCallResult { case alreadyInProgress(PeerId) } +public struct CallAuxiliaryServer { + public enum Connection { + case stun + case turn(username: String, password: String) + } + + public let host: String + public let port: Int + public let connection: Connection + + public init( + host: String, + port: Int, + connection: Connection + ) { + self.host = host + self.port = port + self.connection = connection + } +} + public struct PresentationCallState: Equatable { public enum State: Equatable { case waiting @@ -27,14 +48,22 @@ public struct PresentationCallState: Equatable { case notAvailable case available(Bool) case active + case activeOutgoing + } + + public enum RemoteVideoState: Equatable { + case inactive + case active } public var state: State public var videoState: VideoState + public var remoteVideoState: RemoteVideoState - public init(state: State, videoState: VideoState) { + public init(state: State, videoState: VideoState, remoteVideoState: RemoteVideoState) { self.state = state self.videoState = videoState + self.remoteVideoState = remoteVideoState } } @@ -72,5 +101,5 @@ public protocol PresentationCall: class { public protocol PresentationCallManager: class { var currentCallSignal: Signal { get } - func requestCall(account: Account, peerId: PeerId, endCurrentIfAny: Bool) -> RequestCallResult + func requestCall(account: Account, peerId: PeerId, isVideo: Bool, endCurrentIfAny: Bool) -> RequestCallResult } diff --git a/submodules/CallListUI/Sources/CallListCallItem.swift b/submodules/CallListUI/Sources/CallListCallItem.swift index b70d8b5598..a5ef89767c 100644 --- a/submodules/CallListUI/Sources/CallListCallItem.swift +++ b/submodules/CallListUI/Sources/CallListCallItem.swift @@ -135,7 +135,16 @@ class CallListCallItem: ListViewItem { func selected(listView: ListView) { listView.clearHighlightAnimated(true) - self.interaction.call(self.topMessage.id.peerId) + var isVideo = false + for media in self.topMessage.media { + if let action = media as? TelegramMediaAction { + if case let .phoneCall(_, _, _, isVideoValue) = action.action { + break + isVideo = isVideoValue + } + } + } + self.interaction.call(self.topMessage.id.peerId, isVideo) } static func mergeType(item: CallListCallItem, previousItem: ListViewItem?, nextItem: ListViewItem?) -> (first: Bool, last: Bool, firstWithHeader: Bool) { @@ -237,7 +246,16 @@ class CallListCallItemNode: ItemListRevealOptionsItemNode { guard let item = self?.layoutParams?.0 else { return false } - item.interaction.call(item.topMessage.id.peerId) + var isVideo = false + for media in item.topMessage.media { + if let action = media as? TelegramMediaAction { + if case let .phoneCall(_, _, _, isVideoValue) = action.action { + break + isVideo = isVideoValue + } + } + } + item.interaction.call(item.topMessage.id.peerId, isVideo) return true } } @@ -357,7 +375,7 @@ class CallListCallItemNode: ItemListRevealOptionsItemNode { for message in item.messages { inner: for media in message.media { if let action = media as? TelegramMediaAction { - if case let .phoneCall(_, discardReason, duration) = action.action { + if case let .phoneCall(_, discardReason, duration, _) = action.action { if message.flags.contains(.Incoming) { hasIncoming = true diff --git a/submodules/CallListUI/Sources/CallListController.swift b/submodules/CallListUI/Sources/CallListController.swift index 573847c575..87da74d805 100644 --- a/submodules/CallListUI/Sources/CallListController.swift +++ b/submodules/CallListUI/Sources/CallListController.swift @@ -145,9 +145,9 @@ public final class CallListController: ViewController { } override public func loadDisplayNode() { - self.displayNode = CallListControllerNode(context: self.context, mode: self.mode, presentationData: self.presentationData, call: { [weak self] peerId in + self.displayNode = CallListControllerNode(context: self.context, mode: self.mode, presentationData: self.presentationData, call: { [weak self] peerId, isVideo in if let strongSelf = self { - strongSelf.call(peerId) + strongSelf.call(peerId, isVideo: isVideo) } }, openInfo: { [weak self] peerId, messages in if let strongSelf = self { @@ -201,6 +201,10 @@ public final class CallListController: ViewController { } @objc func callPressed() { + self.beginCallImpl(isVideo: false) + } + + private func beginCallImpl(isVideo: Bool) { let controller = self.context.sharedContext.makeContactSelectionController(ContactSelectionControllerParams(context: self.context, title: { $0.Calls_NewCall })) controller.navigationPresentation = .modal self.createActionDisposable.set((controller.result @@ -208,7 +212,7 @@ public final class CallListController: ViewController { |> deliverOnMainQueue).start(next: { [weak controller, weak self] peer in controller?.dismissSearch() if let strongSelf = self, let contactPeer = peer, case let .peer(peer, _, _) = contactPeer { - strongSelf.call(peer.id, began: { + strongSelf.call(peer.id, isVideo: isVideo, began: { if let strongSelf = self { let _ = (strongSelf.context.sharedContext.hasOngoingCall.get() |> filter { $0 } @@ -257,7 +261,7 @@ public final class CallListController: ViewController { } } - private func call(_ peerId: PeerId, began: (() -> Void)? = nil) { + private func call(_ peerId: PeerId, isVideo: Bool, began: (() -> Void)? = nil) { self.peerViewDisposable.set((self.context.account.viewTracker.peerView(peerId) |> take(1) |> deliverOnMainQueue).start(next: { [weak self] view in @@ -273,7 +277,7 @@ public final class CallListController: ViewController { return } - let callResult = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peerId, endCurrentIfAny: false) + let callResult = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peerId, isVideo: isVideo, endCurrentIfAny: false) if let callResult = callResult { if case let .alreadyInProgress(currentPeerId) = callResult { if currentPeerId == peerId { @@ -287,7 +291,7 @@ public final class CallListController: ViewController { if let strongSelf = self, let peer = peer, let current = current { strongSelf.present(textAlertController(context: strongSelf.context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: { if let strongSelf = self { - let _ = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peerId, endCurrentIfAny: true) + let _ = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peerId, isVideo: isVideo, endCurrentIfAny: true) began?() } })]), in: .window(.root)) diff --git a/submodules/CallListUI/Sources/CallListControllerNode.swift b/submodules/CallListUI/Sources/CallListControllerNode.swift index 96c2880606..f7d7d14dd0 100644 --- a/submodules/CallListUI/Sources/CallListControllerNode.swift +++ b/submodules/CallListUI/Sources/CallListControllerNode.swift @@ -59,12 +59,12 @@ private extension CallListViewEntry { final class CallListNodeInteraction { let setMessageIdWithRevealedOptions: (MessageId?, MessageId?) -> Void - let call: (PeerId) -> Void + let call: (PeerId, Bool) -> Void let openInfo: (PeerId, [Message]) -> Void let delete: ([MessageId]) -> Void let updateShowCallsTab: (Bool) -> Void - init(setMessageIdWithRevealedOptions: @escaping (MessageId?, MessageId?) -> Void, call: @escaping (PeerId) -> Void, openInfo: @escaping (PeerId, [Message]) -> Void, delete: @escaping ([MessageId]) -> Void, updateShowCallsTab: @escaping (Bool) -> Void) { + init(setMessageIdWithRevealedOptions: @escaping (MessageId?, MessageId?) -> Void, call: @escaping (PeerId, Bool) -> Void, openInfo: @escaping (PeerId, [Message]) -> Void, delete: @escaping ([MessageId]) -> Void, updateShowCallsTab: @escaping (Bool) -> Void) { self.setMessageIdWithRevealedOptions = setMessageIdWithRevealedOptions self.call = call self.openInfo = openInfo @@ -190,14 +190,14 @@ final class CallListControllerNode: ASDisplayNode { private let rightOverlayNode: ASDisplayNode private let emptyTextNode: ASTextNode - private let call: (PeerId) -> Void + private let call: (PeerId, Bool) -> Void private let openInfo: (PeerId, [Message]) -> Void private let emptyStateUpdated: (Bool) -> Void private let emptyStatePromise = Promise() private let emptyStateDisposable = MetaDisposable() - init(context: AccountContext, mode: CallListControllerMode, presentationData: PresentationData, call: @escaping (PeerId) -> Void, openInfo: @escaping (PeerId, [Message]) -> Void, emptyStateUpdated: @escaping (Bool) -> Void) { + init(context: AccountContext, mode: CallListControllerMode, presentationData: PresentationData, call: @escaping (PeerId, Bool) -> Void, openInfo: @escaping (PeerId, [Message]) -> Void, emptyStateUpdated: @escaping (Bool) -> Void) { self.context = context self.mode = mode self.presentationData = presentationData @@ -248,8 +248,8 @@ final class CallListControllerNode: ASDisplayNode { } } } - }, call: { [weak self] peerId in - self?.call(peerId) + }, call: { [weak self] peerId, isVideo in + self?.call(peerId, isVideo) }, openInfo: { [weak self] peerId, messages in self?.openInfo(peerId, messages) }, delete: { [weak self] messageIds in diff --git a/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift b/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift index 2bca3e7095..bb90be8f37 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift @@ -189,7 +189,7 @@ public func chatListItemStrings(strings: PresentationStrings, nameDisplayOrder: messageText = invoice.title case let action as TelegramMediaAction: switch action.action { - case let .phoneCall(_, discardReason, _): + case let .phoneCall(_, discardReason, _, isVideo): hideAuthor = !isPeerGroup let incoming = message.flags.contains(.Incoming) if let discardReason = discardReason { @@ -205,9 +205,17 @@ public func chatListItemStrings(strings: PresentationStrings, nameDisplayOrder: if messageText.isEmpty { if incoming { - messageText = strings.Notification_CallIncoming + if isVideo { + messageText = strings.Notification_VideoCallIncoming + } else { + messageText = strings.Notification_CallIncoming + } } else { - messageText = strings.Notification_CallOutgoing + if isVideo { + messageText = strings.Notification_VideoCallOutgoing + } else { + messageText = strings.Notification_CallOutgoing + } } } default: diff --git a/submodules/ContactListUI/Sources/ContactContextMenus.swift b/submodules/ContactListUI/Sources/ContactContextMenus.swift index 57a057e4a8..279c60109b 100644 --- a/submodules/ContactListUI/Sources/ContactContextMenus.swift +++ b/submodules/ContactListUI/Sources/ContactContextMenus.swift @@ -111,11 +111,17 @@ func contactContextMenuItems(context: AccountContext, peerId: PeerId, contactsCo if let user = peer as? TelegramUser, let cachedUserData = transaction.getPeerCachedData(peerId: peerId) as? CachedUserData, user.flags.contains(.isSupport) || cachedUserData.callsPrivate { canCall = false } + var canVideoCall = false + if canCall { + if context.sharedContext.immediateExperimentalUISettings.videoCalls { + canVideoCall = true + } + } if canCall { items.append(.action(ContextMenuActionItem(text: strings.ContactList_Context_Call, icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Call"), color: theme.contextMenu.primaryColor) }, action: { _, f in if let contactsController = contactsController { - let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peerId, endCurrentIfAny: false) + let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peerId, isVideo: false, endCurrentIfAny: false) if let callResult = callResult, case let .alreadyInProgress(currentPeerId) = callResult { if currentPeerId == peerId { context.sharedContext.navigateToCurrentCall() @@ -127,7 +133,33 @@ func contactContextMenuItems(context: AccountContext, peerId: PeerId, contactsCo |> deliverOnMainQueue).start(next: { [weak contactsController] peer, current in if let contactsController = contactsController, let peer = peer, let current = current { contactsController.present(textAlertController(context: context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: { - let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peerId, endCurrentIfAny: true) + let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peerId, isVideo: false, endCurrentIfAny: true) + })]), in: .window(.root)) + } + }) + } + } + } + f(.default) + }))) + } + if canVideoCall { + //TODO:localize + items.append(.action(ContextMenuActionItem(text: "Video Call", icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Call"), color: theme.contextMenu.primaryColor) }, action: { _, f in + if let contactsController = contactsController { + let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peerId, isVideo: true, endCurrentIfAny: false) + if let callResult = callResult, case let .alreadyInProgress(currentPeerId) = callResult { + if currentPeerId == peerId { + context.sharedContext.navigateToCurrentCall() + } else { + let presentationData = context.sharedContext.currentPresentationData.with { $0 } + let _ = (context.account.postbox.transaction { transaction -> (Peer?, Peer?) in + return (transaction.getPeer(peerId), transaction.getPeer(currentPeerId)) + } + |> deliverOnMainQueue).start(next: { [weak contactsController] peer, current in + if let contactsController = contactsController, let peer = peer, let current = current { + contactsController.present(textAlertController(context: context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: { + let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peerId, isVideo: true, endCurrentIfAny: true) })]), in: .window(.root)) } }) diff --git a/submodules/Display/Source/ContainedViewLayoutTransition.swift b/submodules/Display/Source/ContainedViewLayoutTransition.swift index 2fa1b6bf39..0ce89df155 100644 --- a/submodules/Display/Source/ContainedViewLayoutTransition.swift +++ b/submodules/Display/Source/ContainedViewLayoutTransition.swift @@ -544,6 +544,31 @@ public extension ContainedViewLayoutTransition { } } + func updateCornerRadius(layer: CALayer, cornerRadius: CGFloat, completion: ((Bool) -> Void)? = nil) { + if layer.cornerRadius.isEqual(to: cornerRadius) { + if let completion = completion { + completion(true) + } + return + } + + switch self { + case .immediate: + layer.cornerRadius = cornerRadius + if let completion = completion { + completion(true) + } + case let .animated(duration, curve): + let previousCornerRadius = layer.cornerRadius + layer.cornerRadius = cornerRadius + layer.animate(from: NSNumber(value: Float(previousCornerRadius)), to: NSNumber(value: Float(cornerRadius)), keyPath: "cornerRadius", timingFunction: curve.timingFunction, duration: duration, mediaTimingFunction: curve.mediaTimingFunction, completion: { result in + if let completion = completion { + completion(result) + } + }) + } + } + func animateTransformScale(node: ASDisplayNode, from fromScale: CGFloat, completion: ((Bool) -> Void)? = nil) { let t = node.layer.transform let currentScale = sqrt((t.m11 * t.m11) + (t.m12 * t.m12) + (t.m13 * t.m13)) diff --git a/submodules/Display/Source/Navigation/NavigationController.swift b/submodules/Display/Source/Navigation/NavigationController.swift index 101cdbf2d7..26a12835c0 100644 --- a/submodules/Display/Source/Navigation/NavigationController.swift +++ b/submodules/Display/Source/Navigation/NavigationController.swift @@ -102,6 +102,19 @@ private final class NavigationControllerNode: ASDisplayNode { } } +public protocol NavigationControllerDropContentItem: class { +} + +public final class NavigationControllerDropContent { + public let position: CGPoint + public let item: NavigationControllerDropContentItem + + public init(position: CGPoint, item: NavigationControllerDropContentItem) { + self.position = position + self.item = item + } +} + open class NavigationController: UINavigationController, ContainableController, UIGestureRecognizerDelegate { public var isOpaqueWhenInOverlay: Bool = true public var blocksBackgroundWhenInOverlay: Bool = true @@ -1221,6 +1234,35 @@ open class NavigationController: UINavigationController, ContainableController, } } + public func updatePossibleControllerDropContent(content: NavigationControllerDropContent?) { + if let rootContainer = self.rootContainer { + switch rootContainer { + case let .flat(container): + if let controller = container.controllers.last { + controller.updatePossibleControllerDropContent(content: content) + } + case .split: + break + } + } + } + + public func acceptPossibleControllerDropContent(content: NavigationControllerDropContent) -> Bool { + if let rootContainer = self.rootContainer { + switch rootContainer { + case let .flat(container): + if let controller = container.controllers.last { + if controller.acceptPossibleControllerDropContent(content: content) { + return true + } + } + case .split: + break + } + } + return false + } + override open func present(_ viewControllerToPresent: UIViewController, animated flag: Bool, completion: (() -> Void)? = nil) { preconditionFailure() } diff --git a/submodules/Display/Source/NavigationBarBadge.swift b/submodules/Display/Source/NavigationBarBadge.swift index 333bcfb825..e12b716ef5 100644 --- a/submodules/Display/Source/NavigationBarBadge.swift +++ b/submodules/Display/Source/NavigationBarBadge.swift @@ -45,6 +45,7 @@ public final class NavigationBarBadgeNode: ASDisplayNode { self.textColor = textColor self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 18.0, color: fillColor, strokeColor: strokeColor, strokeWidth: 1.0) self.textNode.attributedText = NSAttributedString(string: self.text, font: self.font, textColor: self.textColor) + self.textNode.redrawIfPossible() } override public func calculateSizeThatFits(_ constrainedSize: CGSize) -> CGSize { diff --git a/submodules/Display/Source/ViewController.swift b/submodules/Display/Source/ViewController.swift index 9d40581015..2fee5bd184 100644 --- a/submodules/Display/Source/ViewController.swift +++ b/submodules/Display/Source/ViewController.swift @@ -644,6 +644,13 @@ public enum TabBarItemContextActionType { open func tabBarItemSwipeAction(direction: TabBarItemSwipeDirection) { } + + open func updatePossibleControllerDropContent(content: NavigationControllerDropContent?) { + } + + open func acceptPossibleControllerDropContent(content: NavigationControllerDropContent) -> Bool { + return false + } } func traceIsOpaque(layer: CALayer, rect: CGRect) -> Bool { diff --git a/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift b/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift index 3248033daa..e988c6ee87 100644 --- a/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift +++ b/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift @@ -1287,7 +1287,7 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { mediaManager?.setOverlayVideoNode(nil) }) expandImpl = { [weak overlayNode] in - guard let contentInfo = item.contentInfo else { + guard let contentInfo = item.contentInfo, let overlayNode = overlayNode else { return } @@ -1302,7 +1302,7 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { baseNavigationController?.view.endEditing(true) - (baseNavigationController?.topViewController as? ViewController)?.present(gallery, in: .window(.root), with: GalleryControllerPresentationArguments(transitionArguments: { id, media in + (baseNavigationController?.topViewController as? ViewController)?.present(gallery, in: .window(.root), with: GalleryControllerPresentationArguments(transitionArguments: { [weak overlayNode] id, media in if let overlayNode = overlayNode, let overlaySupernode = overlayNode.supernode { return GalleryTransitionArguments(transitionNode: (overlayNode, overlayNode.bounds, { [weak overlayNode] in return (overlayNode?.view.snapshotContentTree(), nil) diff --git a/submodules/PeerInfoUI/Sources/DeviceContactInfoController.swift b/submodules/PeerInfoUI/Sources/DeviceContactInfoController.swift index 4e2d78a55b..1e07cd3a9e 100644 --- a/submodules/PeerInfoUI/Sources/DeviceContactInfoController.swift +++ b/submodules/PeerInfoUI/Sources/DeviceContactInfoController.swift @@ -877,7 +877,7 @@ public func deviceContactInfoController(context: AccountContext, subject: Device ActionSheetItemGroup(items: [ ActionSheetButtonItem(title: presentationData.strings.UserInfo_TelegramCall, action: { dismissAction() - let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: user.id, endCurrentIfAny: false) + let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: user.id, isVideo: false, endCurrentIfAny: false) if let callResult = callResult, case let .alreadyInProgress(currentPeerId) = callResult { if currentPeerId == user.id { context.sharedContext.navigateToCurrentCall() @@ -888,7 +888,7 @@ public func deviceContactInfoController(context: AccountContext, subject: Device } |> deliverOnMainQueue).start(next: { peer, current in if let peer = peer, let current = current { presentControllerImpl?(textAlertController(context: context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: { - let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, endCurrentIfAny: true) + let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, isVideo: false, endCurrentIfAny: true) })]), nil) } }) diff --git a/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift b/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift index 1364132297..efa01b0b08 100644 --- a/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift +++ b/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift @@ -68,7 +68,7 @@ private func stringForCallType(message: Message, strings: PresentationStrings) - switch media { case let action as TelegramMediaAction: switch action.action { - case let .phoneCall(_, discardReason, _): + case let .phoneCall(_, discardReason, _, _): let incoming = message.flags.contains(.Incoming) if let discardReason = discardReason { switch discardReason { diff --git a/submodules/PeerInfoUI/Sources/UserInfoController.swift b/submodules/PeerInfoUI/Sources/UserInfoController.swift index 8603e1295e..072f34c20b 100644 --- a/submodules/PeerInfoUI/Sources/UserInfoController.swift +++ b/submodules/PeerInfoUI/Sources/UserInfoController.swift @@ -859,7 +859,7 @@ public func userInfoController(context: AccountContext, peerId: PeerId, mode: Pe return .single((view, view.cachedData)) })) - let requestCallImpl: () -> Void = { + let requestCallImpl: (Bool) -> Void = { isVideo in let _ = (peerView.get() |> take(1) |> deliverOnMainQueue).start(next: { view in @@ -873,7 +873,7 @@ public func userInfoController(context: AccountContext, peerId: PeerId, mode: Pe return } - let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, endCurrentIfAny: false) + let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, isVideo: isVideo, endCurrentIfAny: false) if let callResult = callResult, case let .alreadyInProgress(currentPeerId) = callResult { if currentPeerId == peer.id { context.sharedContext.navigateToCurrentCall() @@ -884,7 +884,7 @@ public func userInfoController(context: AccountContext, peerId: PeerId, mode: Pe } |> deliverOnMainQueue).start(next: { peer, current in if let peer = peer, let current = current { presentControllerImpl?(textAlertController(context: context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: { - let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, endCurrentIfAny: true) + let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, isVideo: isVideo, endCurrentIfAny: true) })]), nil) } }) @@ -1111,7 +1111,7 @@ public func userInfoController(context: AccountContext, peerId: PeerId, mode: Pe }, displayCopyContextMenu: { tag, phone in displayCopyContextMenuImpl?(tag, phone) }, call: { - requestCallImpl() + requestCallImpl(false) }, openCallMenu: { number in let _ = (getUserPeer(postbox: context.account.postbox, peerId: peerId) |> deliverOnMainQueue).start(next: { peer, _ in @@ -1125,7 +1125,7 @@ public func userInfoController(context: AccountContext, peerId: PeerId, mode: Pe ActionSheetItemGroup(items: [ ActionSheetButtonItem(title: presentationData.strings.UserInfo_TelegramCall, action: { dismissAction() - requestCallImpl() + requestCallImpl(false) }), ActionSheetButtonItem(title: presentationData.strings.UserInfo_PhoneCall, action: { dismissAction() diff --git a/submodules/SettingsUI/Sources/DebugController.swift b/submodules/SettingsUI/Sources/DebugController.swift index 90bd1e1cbf..3351a26003 100644 --- a/submodules/SettingsUI/Sources/DebugController.swift +++ b/submodules/SettingsUI/Sources/DebugController.swift @@ -42,6 +42,7 @@ private enum DebugControllerSection: Int32 { case logs case logging case experiments + case videoExperiments case info } @@ -70,6 +71,7 @@ private enum DebugControllerEntry: ItemListNodeEntry { case knockoutWallpaper(PresentationTheme, Bool) case alternativeFolderTabs(Bool) case videoCalls(Bool) + case videoCallsInfo(PresentationTheme, String) case hostInfo(PresentationTheme, String) case versionInfo(PresentationTheme) @@ -83,8 +85,10 @@ private enum DebugControllerEntry: ItemListNodeEntry { return DebugControllerSection.logging.rawValue case .enableRaiseToSpeak, .keepChatNavigationStack, .skipReadHistory, .crashOnSlowQueries: return DebugControllerSection.experiments.rawValue - case .clearTips, .reimport, .resetData, .resetDatabase, .resetHoles, .reindexUnread, .resetBiometricsData, .optimizeDatabase, .photoPreview, .knockoutWallpaper, .alternativeFolderTabs, .videoCalls: + case .clearTips, .reimport, .resetData, .resetDatabase, .resetHoles, .reindexUnread, .resetBiometricsData, .optimizeDatabase, .photoPreview, .knockoutWallpaper, .alternativeFolderTabs: return DebugControllerSection.experiments.rawValue + case .videoCalls, .videoCallsInfo: + return DebugControllerSection.videoExperiments.rawValue case .hostInfo, .versionInfo: return DebugControllerSection.info.rawValue } @@ -140,10 +144,12 @@ private enum DebugControllerEntry: ItemListNodeEntry { return 23 case .videoCalls: return 24 - case .hostInfo: + case .videoCallsInfo: return 25 - case .versionInfo: + case .hostInfo: return 26 + case .versionInfo: + return 27 } } @@ -542,7 +548,7 @@ private enum DebugControllerEntry: ItemListNodeEntry { }).start() }) case let .videoCalls(value): - return ItemListSwitchItem(presentationData: presentationData, title: "Video", value: value, sectionId: self.section, style: .blocks, updated: { value in + return ItemListSwitchItem(presentationData: presentationData, title: "Experimental Feature", value: value, sectionId: self.section, style: .blocks, updated: { value in let _ = arguments.sharedContext.accountManager.transaction ({ transaction in transaction.updateSharedData(ApplicationSpecificSharedDataKeys.experimentalUISettings, { settings in var settings = settings as? ExperimentalUISettings ?? ExperimentalUISettings.defaultSettings @@ -551,6 +557,8 @@ private enum DebugControllerEntry: ItemListNodeEntry { }) }).start() }) + case let .videoCallsInfo(_, text): + return ItemListTextItem(presentationData: presentationData, text: .plain(text), sectionId: self.section) case let .hostInfo(theme, string): return ItemListTextItem(presentationData: presentationData, text: .plain(string), sectionId: self.section) case let .versionInfo(theme): @@ -595,6 +603,7 @@ private func debugControllerEntries(presentationData: PresentationData, loggingS entries.append(.knockoutWallpaper(presentationData.theme, experimentalSettings.knockoutWallpaper)) entries.append(.alternativeFolderTabs(experimentalSettings.foldersTabAtBottom)) entries.append(.videoCalls(experimentalSettings.videoCalls)) + entries.append(.videoCallsInfo(presentationData.theme, "Enables experimental transmission of electromagnetic radiation synchronized with pressure waves. Needs to be enabled on both sides.")) if let backupHostOverride = networkSettings?.backupHostOverride { entries.append(.hostInfo(presentationData.theme, "Host: \(backupHostOverride)")) diff --git a/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift b/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift index 6e741d6517..34960ae7c7 100644 --- a/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift +++ b/submodules/SettingsUI/Sources/Privacy and Security/PrivacyAndSecurityController.swift @@ -28,10 +28,11 @@ private final class PrivacyAndSecurityControllerArguments { let openPasscode: () -> Void let openTwoStepVerification: (TwoStepVerificationAccessConfiguration?) -> Void let openActiveSessions: () -> Void + let toggleArchiveAndMuteNonContacts: (Bool) -> Void let setupAccountAutoremove: () -> Void let openDataSettings: () -> Void - init(account: Account, openBlockedUsers: @escaping () -> Void, openLastSeenPrivacy: @escaping () -> Void, openGroupsPrivacy: @escaping () -> Void, openVoiceCallPrivacy: @escaping () -> Void, openProfilePhotoPrivacy: @escaping () -> Void, openForwardPrivacy: @escaping () -> Void, openPhoneNumberPrivacy: @escaping () -> Void, openPasscode: @escaping () -> Void, openTwoStepVerification: @escaping (TwoStepVerificationAccessConfiguration?) -> Void, openActiveSessions: @escaping () -> Void, setupAccountAutoremove: @escaping () -> Void, openDataSettings: @escaping () -> Void) { + init(account: Account, openBlockedUsers: @escaping () -> Void, openLastSeenPrivacy: @escaping () -> Void, openGroupsPrivacy: @escaping () -> Void, openVoiceCallPrivacy: @escaping () -> Void, openProfilePhotoPrivacy: @escaping () -> Void, openForwardPrivacy: @escaping () -> Void, openPhoneNumberPrivacy: @escaping () -> Void, openPasscode: @escaping () -> Void, openTwoStepVerification: @escaping (TwoStepVerificationAccessConfiguration?) -> Void, openActiveSessions: @escaping () -> Void, toggleArchiveAndMuteNonContacts: @escaping (Bool) -> Void, setupAccountAutoremove: @escaping () -> Void, openDataSettings: @escaping () -> Void) { self.account = account self.openBlockedUsers = openBlockedUsers self.openLastSeenPrivacy = openLastSeenPrivacy @@ -43,6 +44,7 @@ private final class PrivacyAndSecurityControllerArguments { self.openPasscode = openPasscode self.openTwoStepVerification = openTwoStepVerification self.openActiveSessions = openActiveSessions + self.toggleArchiveAndMuteNonContacts = toggleArchiveAndMuteNonContacts self.setupAccountAutoremove = setupAccountAutoremove self.openDataSettings = openDataSettings } @@ -51,6 +53,7 @@ private final class PrivacyAndSecurityControllerArguments { private enum PrivacyAndSecuritySection: Int32 { case general case privacy + case autoArchive case account case dataSettings } @@ -80,6 +83,9 @@ private enum PrivacyAndSecurityEntry: ItemListNodeEntry { case passcode(PresentationTheme, String, Bool, String) case twoStepVerification(PresentationTheme, String, String, TwoStepVerificationAccessConfiguration?) case activeSessions(PresentationTheme, String, String) + case autoArchiveHeader(String) + case autoArchive(String, Bool) + case autoArchiveInfo(String) case accountHeader(PresentationTheme, String) case accountTimeout(PresentationTheme, String, String) case accountInfo(PresentationTheme, String) @@ -92,6 +98,8 @@ private enum PrivacyAndSecurityEntry: ItemListNodeEntry { return PrivacyAndSecuritySection.general.rawValue case .privacyHeader, .phoneNumberPrivacy, .lastSeenPrivacy, .profilePhotoPrivacy, .forwardPrivacy, .groupPrivacy, .selectivePrivacyInfo, .voiceCallPrivacy: return PrivacyAndSecuritySection.privacy.rawValue + case .autoArchiveHeader, .autoArchive, .autoArchiveInfo: + return PrivacyAndSecuritySection.autoArchive.rawValue case .accountHeader, .accountTimeout, .accountInfo: return PrivacyAndSecuritySection.account.rawValue case .dataSettings, .dataSettingsInfo: @@ -125,16 +133,22 @@ private enum PrivacyAndSecurityEntry: ItemListNodeEntry { return 11 case .selectivePrivacyInfo: return 12 - case .accountHeader: + case .autoArchiveHeader: return 13 - case .accountTimeout: + case .autoArchive: return 14 - case .accountInfo: + case .autoArchiveInfo: return 15 - case .dataSettings: + case .accountHeader: return 16 - case .dataSettingsInfo: + case .accountTimeout: return 17 + case .accountInfo: + return 18 + case .dataSettings: + return 19 + case .dataSettingsInfo: + return 20 } } @@ -212,6 +226,24 @@ private enum PrivacyAndSecurityEntry: ItemListNodeEntry { } else { return false } + case let .autoArchiveHeader(text): + if case .autoArchiveHeader(text) = rhs { + return true + } else { + return false + } + case let .autoArchive(text, value): + if case .autoArchive(text, value) = rhs { + return true + } else { + return false + } + case let .autoArchiveInfo(text): + if case .autoArchiveInfo(text) = rhs { + return true + } else { + return false + } case let .accountHeader(lhsTheme, lhsText): if case let .accountHeader(rhsTheme, rhsText) = rhs, lhsTheme === rhsTheme, lhsText == rhsText { return true @@ -296,6 +328,14 @@ private enum PrivacyAndSecurityEntry: ItemListNodeEntry { return ItemListDisclosureItem(presentationData: presentationData, icon: UIImage(bundleImageName: "Settings/MenuIcons/Websites")?.precomposed(), title: text, label: value, sectionId: self.section, style: .blocks, action: { arguments.openActiveSessions() }) + case let .autoArchiveHeader(text): + return ItemListSectionHeaderItem(presentationData: presentationData, text: text, sectionId: self.section) + case let .autoArchive(text, value): + return ItemListSwitchItem(presentationData: presentationData, title: text, value: value, sectionId: self.section, style: .blocks, updated: { value in + arguments.toggleArchiveAndMuteNonContacts(value) + }) + case let .autoArchiveInfo(text): + return ItemListTextItem(presentationData: presentationData, text: .plain(text), sectionId: self.section) case let .accountHeader(theme, text): return ItemListSectionHeaderItem(presentationData: presentationData, text: text, sectionId: self.section) case let .accountTimeout(theme, text, value): @@ -316,6 +356,7 @@ private enum PrivacyAndSecurityEntry: ItemListNodeEntry { private struct PrivacyAndSecurityControllerState: Equatable { var updatingAccountTimeoutValue: Int32? = nil + var updatingAutomaticallyArchiveAndMuteNonContacts: Bool? = nil } private func countForSelectivePeers(_ peers: [PeerId: SelectivePrivacyPeer]) -> Int { @@ -404,6 +445,21 @@ private func privacyAndSecurityControllerEntries(presentationData: PresentationD entries.append(.selectivePrivacyInfo(presentationData.theme, presentationData.strings.PrivacyLastSeenSettings_GroupsAndChannelsHelp)) } + entries.append(.autoArchiveHeader(presentationData.strings.PrivacySettings_AutoArchiveTitle.uppercased())) + if let privacySettings = privacySettings { + let automaticallyArchiveAndMuteNonContactsValue: Bool + if let automaticallyArchiveAndMuteNonContacts = state.updatingAutomaticallyArchiveAndMuteNonContacts { + automaticallyArchiveAndMuteNonContactsValue = automaticallyArchiveAndMuteNonContacts + } else { + automaticallyArchiveAndMuteNonContactsValue = privacySettings.automaticallyArchiveAndMuteNonContacts + } + + entries.append(.autoArchive(presentationData.strings.PrivacySettings_AutoArchive, automaticallyArchiveAndMuteNonContactsValue)) + } else { + entries.append(.autoArchive(presentationData.strings.PrivacySettings_AutoArchive, false)) + } + entries.append(.autoArchiveInfo(presentationData.strings.PrivacySettings_AutoArchiveInfo)) + entries.append(.accountHeader(presentationData.theme, presentationData.strings.PrivacySettings_DeleteAccountTitle.uppercased())) if let privacySettings = privacySettings { let value: Int32 @@ -443,6 +499,9 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting let updateAccountTimeoutDisposable = MetaDisposable() actionsDisposable.add(updateAccountTimeoutDisposable) + let updateAutoArchiveDisposable = MetaDisposable() + actionsDisposable.add(updateAutoArchiveDisposable) + let privacySettingsPromise = Promise() privacySettingsPromise.set(.single(initialSettings) |> then(requestAccountPrivacySettings(account: context.account) |> map(Optional.init))) @@ -516,7 +575,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting |> deliverOnMainQueue |> mapToSignal { value -> Signal in if let value = value { - privacySettingsPromise.set(.single(AccountPrivacySettings(presence: updated, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, accountRemovalTimeout: value.accountRemovalTimeout))) + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: updated, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: value.automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: value.accountRemovalTimeout))) } return .complete() } @@ -539,7 +598,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting |> deliverOnMainQueue |> mapToSignal { value -> Signal in if let value = value { - privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: updated, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, accountRemovalTimeout: value.accountRemovalTimeout))) + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: updated, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: value.automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: value.accountRemovalTimeout))) } return .complete() } @@ -576,7 +635,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting |> deliverOnMainQueue |> mapToSignal { value -> Signal in if let value = value { - privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: updated, voiceCallsP2P: updatedCallsPrivacy, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, accountRemovalTimeout: value.accountRemovalTimeout))) + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: updated, voiceCallsP2P: updatedCallsPrivacy, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: value.automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: value.accountRemovalTimeout))) } return .complete() } @@ -599,7 +658,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting |> deliverOnMainQueue |> mapToSignal { value -> Signal in if let value = value { - privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: updated, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, accountRemovalTimeout: value.accountRemovalTimeout))) + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: updated, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: value.automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: value.accountRemovalTimeout))) } return .complete() } @@ -622,7 +681,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting |> deliverOnMainQueue |> mapToSignal { value -> Signal in if let value = value { - privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: updated, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, accountRemovalTimeout: value.accountRemovalTimeout))) + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: updated, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: value.automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: value.accountRemovalTimeout))) } return .complete() } @@ -645,7 +704,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting |> deliverOnMainQueue |> mapToSignal { value -> Signal in if let value = value { - privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: updated, phoneDiscoveryEnabled: updatedDiscoveryEnabled ?? value.phoneDiscoveryEnabled, accountRemovalTimeout: value.accountRemovalTimeout))) + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: updated, phoneDiscoveryEnabled: updatedDiscoveryEnabled ?? value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: value.automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: value.accountRemovalTimeout))) } return .complete() } @@ -700,6 +759,33 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting } }, openActiveSessions: { pushControllerImpl?(recentSessionsController(context: context, activeSessionsContext: activeSessionsContext, webSessionsContext: webSessionsContext, websitesOnly: true), true) + }, toggleArchiveAndMuteNonContacts: { archiveValue in + updateState { state in + var state = state + state.updatingAutomaticallyArchiveAndMuteNonContacts = archiveValue + return state + } + let applyTimeout: Signal = privacySettingsPromise.get() + |> filter { $0 != nil } + |> take(1) + |> deliverOnMainQueue + |> mapToSignal { value -> Signal in + if let value = value { + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: archiveValue, accountRemovalTimeout: value.accountRemovalTimeout))) + } + return .complete() + } + + updateAutoArchiveDisposable.set((updateAccountAutoArchiveChats(account: context.account, value: archiveValue) + |> mapToSignal { _ -> Signal in } + |> then(applyTimeout) + |> deliverOnMainQueue).start(completed: { + updateState { state in + var state = state + state.updatingAutomaticallyArchiveAndMuteNonContacts = nil + return state + } + })) }, setupAccountAutoremove: { let signal = privacySettingsPromise.get() |> take(1) @@ -724,7 +810,7 @@ public func privacyAndSecurityController(context: AccountContext, initialSetting |> deliverOnMainQueue |> mapToSignal { value -> Signal in if let value = value { - privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, accountRemovalTimeout: timeout))) + privacySettingsPromise.set(.single(AccountPrivacySettings(presence: value.presence, groupInvitations: value.groupInvitations, voiceCalls: value.voiceCalls, voiceCallsP2P: value.voiceCallsP2P, profilePhoto: value.profilePhoto, forwards: value.forwards, phoneNumber: value.phoneNumber, phoneDiscoveryEnabled: value.phoneDiscoveryEnabled, automaticallyArchiveAndMuteNonContacts: value.automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: timeout))) } return .complete() } diff --git a/submodules/SyncCore/Sources/CloudFileMediaResource.swift b/submodules/SyncCore/Sources/CloudFileMediaResource.swift index c1826c179b..adbc601e56 100644 --- a/submodules/SyncCore/Sources/CloudFileMediaResource.swift +++ b/submodules/SyncCore/Sources/CloudFileMediaResource.swift @@ -508,13 +508,17 @@ public class LocalFileMediaResource: TelegramMediaResource { public let fileId: Int64 public let size: Int? - public init(fileId: Int64, size: Int? = nil) { + public let isSecretRelated: Bool + + public init(fileId: Int64, size: Int? = nil, isSecretRelated: Bool = false) { self.fileId = fileId self.size = size + self.isSecretRelated = isSecretRelated } public required init(decoder: PostboxDecoder) { self.fileId = decoder.decodeInt64ForKey("f", orElse: 0) + self.isSecretRelated = decoder.decodeBoolForKey("sr", orElse: false) if let size = decoder.decodeOptionalInt32ForKey("s") { self.size = Int(size) } else { @@ -524,6 +528,7 @@ public class LocalFileMediaResource: TelegramMediaResource { public func encode(_ encoder: PostboxEncoder) { encoder.encodeInt64(self.fileId, forKey: "f") + encoder.encodeBool(self.isSecretRelated, forKey: "sr") if let size = self.size { encoder.encodeInt32(Int32(size), forKey: "s") } else { @@ -537,7 +542,7 @@ public class LocalFileMediaResource: TelegramMediaResource { public func isEqual(to: MediaResource) -> Bool { if let to = to as? LocalFileMediaResource { - return self.fileId == to.fileId && self.size == to.size + return self.fileId == to.fileId && self.size == to.size && self.isSecretRelated == to.isSecretRelated } else { return false } diff --git a/submodules/SyncCore/Sources/PeerStatusSettings.swift b/submodules/SyncCore/Sources/PeerStatusSettings.swift index 85a1ca18b2..32ae3a899a 100644 --- a/submodules/SyncCore/Sources/PeerStatusSettings.swift +++ b/submodules/SyncCore/Sources/PeerStatusSettings.swift @@ -14,6 +14,8 @@ public struct PeerStatusSettings: PostboxCoding, Equatable { public static let canAddContact = Flags(rawValue: 1 << 4) public static let addExceptionWhenAddingContact = Flags(rawValue: 1 << 5) public static let canReportIrrelevantGeoLocation = Flags(rawValue: 1 << 6) + public static let autoArchived = Flags(rawValue: 1 << 7) + } public var flags: PeerStatusSettings.Flags diff --git a/submodules/SyncCore/Sources/TelegramMediaAction.swift b/submodules/SyncCore/Sources/TelegramMediaAction.swift index c22b4ea4f9..ffd4c61755 100644 --- a/submodules/SyncCore/Sources/TelegramMediaAction.swift +++ b/submodules/SyncCore/Sources/TelegramMediaAction.swift @@ -38,7 +38,7 @@ public enum TelegramMediaActionType: PostboxCoding, Equatable { case historyScreenshot case messageAutoremoveTimeoutUpdated(Int32) case gameScore(gameId: Int64, score: Int32) - case phoneCall(callId: Int64, discardReason: PhoneCallDiscardReason?, duration: Int32?) + case phoneCall(callId: Int64, discardReason: PhoneCallDiscardReason?, duration: Int32?, isVideo: Bool) case paymentSent(currency: String, totalAmount: Int64) case customText(text: String, entities: [MessageTextEntity]) case botDomainAccessGranted(domain: String) @@ -80,7 +80,7 @@ public enum TelegramMediaActionType: PostboxCoding, Equatable { if let value = decoder.decodeOptionalInt32ForKey("dr") { discardReason = PhoneCallDiscardReason(rawValue: value) } - self = .phoneCall(callId: decoder.decodeInt64ForKey("i", orElse: 0), discardReason: discardReason, duration: decoder.decodeInt32ForKey("d", orElse: 0)) + self = .phoneCall(callId: decoder.decodeInt64ForKey("i", orElse: 0), discardReason: discardReason, duration: decoder.decodeInt32ForKey("d", orElse: 0), isVideo: decoder.decodeInt32ForKey("vc", orElse: 0) != 0) case 15: self = .paymentSent(currency: decoder.decodeStringForKey("currency", orElse: ""), totalAmount: decoder.decodeInt64ForKey("ta", orElse: 0)) case 16: @@ -152,7 +152,7 @@ public enum TelegramMediaActionType: PostboxCoding, Equatable { encoder.encodeInt32(15, forKey: "_rawValue") encoder.encodeString(currency, forKey: "currency") encoder.encodeInt64(totalAmount, forKey: "ta") - case let .phoneCall(callId, discardReason, duration): + case let .phoneCall(callId, discardReason, duration, isVideo): encoder.encodeInt32(14, forKey: "_rawValue") encoder.encodeInt64(callId, forKey: "i") if let discardReason = discardReason { @@ -165,6 +165,7 @@ public enum TelegramMediaActionType: PostboxCoding, Equatable { } else { encoder.encodeNil(forKey: "d") } + encoder.encodeInt32(isVideo ? 1 : 0, forKey: "vc") case let .customText(text, entities): encoder.encodeInt32(16, forKey: "_rawValue") encoder.encodeString(text, forKey: "text") diff --git a/submodules/TelegramApi/Sources/Api0.swift b/submodules/TelegramApi/Sources/Api0.swift index fa8ecac08b..fcf348c1c9 100644 --- a/submodules/TelegramApi/Sources/Api0.swift +++ b/submodules/TelegramApi/Sources/Api0.swift @@ -292,6 +292,7 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-525288402] = { return Api.PhotoSize.parse_photoStrippedSize($0) } dict[-244016606] = { return Api.messages.Stickers.parse_stickersNotModified($0) } dict[-463889475] = { return Api.messages.Stickers.parse_stickers($0) } + dict[-1096616924] = { return Api.GlobalPrivacySettings.parse_globalPrivacySettings($0) } dict[1008755359] = { return Api.InlineBotSwitchPM.parse_inlineBotSwitchPM($0) } dict[223655517] = { return Api.messages.FoundStickerSets.parse_foundStickerSetsNotModified($0) } dict[1359533640] = { return Api.messages.FoundStickerSets.parse_foundStickerSets($0) } @@ -1024,6 +1025,8 @@ public struct Api { _1.serialize(buffer, boxed) case let _1 as Api.messages.Stickers: _1.serialize(buffer, boxed) + case let _1 as Api.GlobalPrivacySettings: + _1.serialize(buffer, boxed) case let _1 as Api.InlineBotSwitchPM: _1.serialize(buffer, boxed) case let _1 as Api.messages.FoundStickerSets: diff --git a/submodules/TelegramApi/Sources/Api1.swift b/submodules/TelegramApi/Sources/Api1.swift index 680ac5f02d..4098c071a6 100644 --- a/submodules/TelegramApi/Sources/Api1.swift +++ b/submodules/TelegramApi/Sources/Api1.swift @@ -9210,6 +9210,46 @@ public extension Api { } } + } + public enum GlobalPrivacySettings: TypeConstructorDescription { + case globalPrivacySettings(flags: Int32, archiveAndMuteNewNoncontactPeers: Api.Bool?) + + public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { + switch self { + case .globalPrivacySettings(let flags, let archiveAndMuteNewNoncontactPeers): + if boxed { + buffer.appendInt32(-1096616924) + } + serializeInt32(flags, buffer: buffer, boxed: false) + if Int(flags) & Int(1 << 0) != 0 {archiveAndMuteNewNoncontactPeers!.serialize(buffer, true)} + break + } + } + + public func descriptionFields() -> (String, [(String, Any)]) { + switch self { + case .globalPrivacySettings(let flags, let archiveAndMuteNewNoncontactPeers): + return ("globalPrivacySettings", [("flags", flags), ("archiveAndMuteNewNoncontactPeers", archiveAndMuteNewNoncontactPeers)]) + } + } + + public static func parse_globalPrivacySettings(_ reader: BufferReader) -> GlobalPrivacySettings? { + var _1: Int32? + _1 = reader.readInt32() + var _2: Api.Bool? + if Int(_1!) & Int(1 << 0) != 0 {if let signature = reader.readInt32() { + _2 = Api.parse(reader, signature: signature) as? Api.Bool + } } + let _c1 = _1 != nil + let _c2 = (Int(_1!) & Int(1 << 0) == 0) || _2 != nil + if _c1 && _c2 { + return Api.GlobalPrivacySettings.globalPrivacySettings(flags: _1!, archiveAndMuteNewNoncontactPeers: _2) + } + else { + return nil + } + } + } public enum InlineBotSwitchPM: TypeConstructorDescription { case inlineBotSwitchPM(text: String, startParam: String) diff --git a/submodules/TelegramApi/Sources/Api3.swift b/submodules/TelegramApi/Sources/Api3.swift index 1488d7fb4d..e05b4e6c29 100644 --- a/submodules/TelegramApi/Sources/Api3.swift +++ b/submodules/TelegramApi/Sources/Api3.swift @@ -4421,12 +4421,13 @@ public extension Api { }) } - public static func getBroadcastStats(flags: Int32, channel: Api.InputChannel) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + public static func getBroadcastStats(flags: Int32, channel: Api.InputChannel, tzOffset: Int32) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { let buffer = Buffer() - buffer.appendInt32(-1421720550) + buffer.appendInt32(-433058374) serializeInt32(flags, buffer: buffer, boxed: false) channel.serialize(buffer, true) - return (FunctionDescription(name: "stats.getBroadcastStats", parameters: [("flags", flags), ("channel", channel)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.stats.BroadcastStats? in + serializeInt32(tzOffset, buffer: buffer, boxed: false) + return (FunctionDescription(name: "stats.getBroadcastStats", parameters: [("flags", flags), ("channel", channel), ("tzOffset", tzOffset)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.stats.BroadcastStats? in let reader = BufferReader(buffer) var result: Api.stats.BroadcastStats? if let signature = reader.readInt32() { @@ -6614,6 +6615,34 @@ public extension Api { return result }) } + + public static func getGlobalPrivacySettings() -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(-349483786) + + return (FunctionDescription(name: "account.getGlobalPrivacySettings", parameters: []), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.GlobalPrivacySettings? in + let reader = BufferReader(buffer) + var result: Api.GlobalPrivacySettings? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.GlobalPrivacySettings + } + return result + }) + } + + public static func setGlobalPrivacySettings(settings: Api.GlobalPrivacySettings) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(517647042) + settings.serialize(buffer, true) + return (FunctionDescription(name: "account.setGlobalPrivacySettings", parameters: [("settings", settings)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.GlobalPrivacySettings? in + let reader = BufferReader(buffer) + var result: Api.GlobalPrivacySettings? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.GlobalPrivacySettings + } + return result + }) + } } public struct wallet { public static func sendLiteRequest(body: Buffer) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { diff --git a/submodules/TelegramBaseController/Sources/TelegramBaseController.swift b/submodules/TelegramBaseController/Sources/TelegramBaseController.swift index 2b1f9776e9..b83bf9492b 100644 --- a/submodules/TelegramBaseController/Sources/TelegramBaseController.swift +++ b/submodules/TelegramBaseController/Sources/TelegramBaseController.swift @@ -37,7 +37,7 @@ private func presentLiveLocationController(context: AccountContext, peerId: Peer }, addToTransitionSurface: { _ in }, openUrl: { _ in }, openPeer: { peer, navigation in - }, callPeer: { _ in + }, callPeer: { _, _ in }, enqueueMessage: { _ in }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in diff --git a/submodules/TelegramCallsUI/Sources/CallControllerButton.swift b/submodules/TelegramCallsUI/Sources/CallControllerButton.swift index d977e4265a..7a3c6b9bc1 100644 --- a/submodules/TelegramCallsUI/Sources/CallControllerButton.swift +++ b/submodules/TelegramCallsUI/Sources/CallControllerButton.swift @@ -11,7 +11,7 @@ enum CallControllerButtonType { case accept case speaker case bluetooth - case video + case switchCamera } private let buttonSize = CGSize(width: 75.0, height: 75.0) @@ -124,8 +124,8 @@ final class CallControllerButtonNode: HighlightTrackingButtonNode { regularImage = generateEmptyButtonImage(icon: UIImage(bundleImageName: "Call/CallBluetoothButton"), strokeColor: emptyStroke, fillColor: .clear) highlightedImage = generateEmptyButtonImage(icon: UIImage(bundleImageName: "Call/CallBluetoothButton"), strokeColor: emptyStroke, fillColor: emptyHighlightedFill) filledImage = generateEmptyButtonImage(icon: UIImage(bundleImageName: "Call/CallBluetoothButton"), strokeColor: nil, fillColor: invertedFill, knockout: true) - case .video: - let patternImage = generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Text/IconVideo"), color: .white) + case .switchCamera: + let patternImage = generateTintedImage(image: UIImage(bundleImageName: "Call/CallSwitchCameraButton"), color: .white) regularImage = generateEmptyButtonImage(icon: patternImage, strokeColor: emptyStroke, fillColor: .clear) highlightedImage = generateEmptyButtonImage(icon: patternImage, strokeColor: emptyStroke, fillColor: emptyHighlightedFill) filledImage = generateEmptyButtonImage(icon: patternImage, strokeColor: nil, fillColor: invertedFill, knockout: true) @@ -215,8 +215,8 @@ final class CallControllerButtonNode: HighlightTrackingButtonNode { regularImage = generateEmptyButtonImage(icon: UIImage(bundleImageName: "Call/CallBluetoothButton"), strokeColor: emptyStroke, fillColor: .clear) highlightedImage = generateEmptyButtonImage(icon: UIImage(bundleImageName: "Call/CallBluetoothButton"), strokeColor: emptyStroke, fillColor: emptyHighlightedFill) filledImage = generateEmptyButtonImage(icon: UIImage(bundleImageName: "Call/CallBluetoothButton"), strokeColor: nil, fillColor: invertedFill, knockout: true) - case .video: - let patternImage = generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Text/IconVideo"), color: .white) + case .switchCamera: + let patternImage = generateTintedImage(image: UIImage(bundleImageName: "Call/CallSwitchCameraButton"), color: .white) regularImage = generateEmptyButtonImage(icon: patternImage, strokeColor: emptyStroke, fillColor: .clear) highlightedImage = generateEmptyButtonImage(icon: patternImage, strokeColor: emptyStroke, fillColor: emptyHighlightedFill) filledImage = generateEmptyButtonImage(icon: patternImage, strokeColor: nil, fillColor: invertedFill, knockout: true) diff --git a/submodules/TelegramCallsUI/Sources/CallControllerButtonsNode.swift b/submodules/TelegramCallsUI/Sources/CallControllerButtonsNode.swift index b6401b7fa2..7a90fd8b3f 100644 --- a/submodules/TelegramCallsUI/Sources/CallControllerButtonsNode.swift +++ b/submodules/TelegramCallsUI/Sources/CallControllerButtonsNode.swift @@ -32,8 +32,7 @@ final class CallControllerButtonsNode: ASDisplayNode { private let muteButton: CallControllerButtonNode private let endButton: CallControllerButtonNode private let speakerButton: CallControllerButtonNode - - private let videoButton: CallControllerButtonNode + private let swichCameraButton: CallControllerButtonNode private var mode: CallControllerButtonsMode? @@ -50,6 +49,7 @@ final class CallControllerButtonsNode: ASDisplayNode { var end: (() -> Void)? var speaker: (() -> Void)? var toggleVideo: (() -> Void)? + var rotateCamera: (() -> Void)? init(strings: PresentationStrings) { self.acceptButton = CallControllerButtonNode(type: .accept, label: strings.Call_Accept) @@ -63,9 +63,8 @@ final class CallControllerButtonsNode: ASDisplayNode { self.endButton.alpha = 0.0 self.speakerButton = CallControllerButtonNode(type: .speaker, label: nil) self.speakerButton.alpha = 0.0 - - self.videoButton = CallControllerButtonNode(type: .video, label: nil) - self.videoButton.alpha = 0.0 + self.swichCameraButton = CallControllerButtonNode(type: .switchCamera, label: nil) + self.swichCameraButton.alpha = 0.0 super.init() @@ -74,14 +73,14 @@ final class CallControllerButtonsNode: ASDisplayNode { self.addSubnode(self.muteButton) self.addSubnode(self.endButton) self.addSubnode(self.speakerButton) - self.addSubnode(self.videoButton) + self.addSubnode(self.swichCameraButton) self.acceptButton.addTarget(self, action: #selector(self.buttonPressed(_:)), forControlEvents: .touchUpInside) self.declineButton.addTarget(self, action: #selector(self.buttonPressed(_:)), forControlEvents: .touchUpInside) self.muteButton.addTarget(self, action: #selector(self.buttonPressed(_:)), forControlEvents: .touchUpInside) self.endButton.addTarget(self, action: #selector(self.buttonPressed(_:)), forControlEvents: .touchUpInside) self.speakerButton.addTarget(self, action: #selector(self.buttonPressed(_:)), forControlEvents: .touchUpInside) - self.videoButton.addTarget(self, action: #selector(self.buttonPressed(_:)), forControlEvents: .touchUpInside) + self.swichCameraButton.addTarget(self, action: #selector(self.buttonPressed(_:)), forControlEvents: .touchUpInside) } func updateLayout(constrainedWidth: CGFloat, transition: ContainedViewLayoutTransition) { @@ -119,11 +118,11 @@ final class CallControllerButtonsNode: ASDisplayNode { let twoButtonsWidth = 2.0 * buttonSize.width + 1.0 * twoButtonSpacing var origin = CGPoint(x: floor((width - threeButtonsWidth) / 2.0), y: 0.0) + for button in [self.muteButton, self.endButton, self.speakerButton] { transition.updateFrame(node: button, frame: CGRect(origin: origin, size: buttonSize)) - - if button === self.endButton { - transition.updateFrame(node: self.videoButton, frame: CGRect(origin: CGPoint(x: origin.x, y: origin.y - buttonSize.height - 20.0), size: buttonSize)) + if button === self.speakerButton { + transition.updateFrame(node: self.swichCameraButton, frame: CGRect(origin: origin, size: buttonSize)) } origin.x += buttonSize.width + threeButtonSpacing @@ -140,16 +139,44 @@ final class CallControllerButtonsNode: ASDisplayNode { for button in [self.declineButton, self.acceptButton] { button.alpha = 1.0 } - for button in [self.muteButton, self.endButton, self.speakerButton, self.videoButton] { + for button in [self.muteButton, self.endButton, self.speakerButton, self.swichCameraButton] { button.alpha = 0.0 } case let .active(speakerMode, videoState): - for button in [self.muteButton, self.speakerButton] { + for button in [self.muteButton] { if animated && button.alpha.isZero { button.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3) } button.alpha = 1.0 } + switch videoState { + case .active, .available: + for button in [self.speakerButton] { + if animated && !button.alpha.isZero { + button.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.3) + } + button.alpha = 0.0 + } + for button in [self.swichCameraButton] { + if animated && button.alpha.isZero { + button.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3) + } + button.alpha = 1.0 + } + case .notAvailable: + for button in [self.swichCameraButton] { + if animated && !button.alpha.isZero { + button.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.3) + } + button.alpha = 0.0 + } + for button in [self.speakerButton] { + if animated && button.alpha.isZero { + button.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3) + } + button.alpha = 1.0 + } + } var animatingAcceptButton = false if self.endButton.alpha.isZero { if animated { @@ -171,23 +198,6 @@ final class CallControllerButtonsNode: ASDisplayNode { self.endButton.alpha = 1.0 } - switch videoState { - case .notAvailable: - self.videoButton.alpha = 0.0 - case let .available(isEnabled): - self.videoButton.isUserInteractionEnabled = isEnabled - if animated { - self.videoButton.alpha = isEnabled ? 1.0 : 0.5 - self.videoButton.layer.animateAlpha(from: 0.0, to: self.videoButton.alpha, duration: 0.2) - } else { - self.videoButton.alpha = isEnabled ? 1.0 : 0.5 - } - case .active: - self.videoButton.isUserInteractionEnabled = true - self.videoButton.alpha = 0.0 - } - - if !self.declineButton.alpha.isZero { if animated { self.declineButton.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.2) @@ -223,8 +233,8 @@ final class CallControllerButtonsNode: ASDisplayNode { self.speaker?() } else if button === self.acceptButton { self.accept?() - } else if button === self.videoButton { - self.toggleVideo?() + } else if button === self.swichCameraButton { + self.rotateCamera?() } } @@ -235,9 +245,12 @@ final class CallControllerButtonsNode: ASDisplayNode { self.muteButton, self.endButton, self.speakerButton, - self.videoButton + self.swichCameraButton ] for button in buttons { + if button.isHidden || button.alpha.isZero { + continue + } if let result = button.view.hitTest(self.view.convert(point, to: button.view), with: event) { return result } diff --git a/submodules/TelegramCallsUI/Sources/CallControllerNode.swift b/submodules/TelegramCallsUI/Sources/CallControllerNode.swift index 002878e180..35a5100543 100644 --- a/submodules/TelegramCallsUI/Sources/CallControllerNode.swift +++ b/submodules/TelegramCallsUI/Sources/CallControllerNode.swift @@ -16,6 +16,8 @@ import CallsEmoji private final class IncomingVideoNode: ASDisplayNode { private let videoView: UIView + private var effectView: UIVisualEffectView? + private var isBlurred: Bool = false init(videoView: UIView) { self.videoView = videoView @@ -28,6 +30,29 @@ private final class IncomingVideoNode: ASDisplayNode { func updateLayout(size: CGSize) { self.videoView.frame = CGRect(origin: CGPoint(), size: size) } + + func updateIsBlurred(isBlurred: Bool) { + if self.isBlurred == isBlurred { + return + } + self.isBlurred = isBlurred + + if isBlurred { + if self.effectView == nil { + let effectView = UIVisualEffectView() + self.effectView = effectView + effectView.frame = self.videoView.frame + self.view.addSubview(effectView) + } + UIView.animate(withDuration: 0.3, animations: { + self.effectView?.effect = UIBlurEffect(style: .dark) + }) + } else if let effectView = self.effectView { + UIView.animate(withDuration: 0.3, animations: { + effectView.effect = nil + }) + } + } } private final class OutgoingVideoNode: ASDisplayNode { @@ -51,8 +76,9 @@ private final class OutgoingVideoNode: ASDisplayNode { self.switchCamera() } - func updateLayout(size: CGSize) { - self.videoView.frame = CGRect(origin: CGPoint(), size: size) + func updateLayout(size: CGSize, isExpanded: Bool, transition: ContainedViewLayoutTransition) { + transition.updateFrame(view: self.videoView, frame: CGRect(origin: CGPoint(), size: size)) + transition.updateCornerRadius(layer: self.videoView.layer, cornerRadius: isExpanded ? 0.0 : 16.0) self.switchCameraButton.frame = CGRect(origin: CGPoint(), size: size) } } @@ -75,11 +101,13 @@ final class CallControllerNode: ASDisplayNode { private let imageNode: TransformImageNode private let dimNode: ASDisplayNode private var incomingVideoNode: IncomingVideoNode? + private var incomingVideoViewRequested: Bool = false private var outgoingVideoNode: OutgoingVideoNode? - private var videoViewsRequested: Bool = false + private var outgoingVideoViewRequested: Bool = false private let backButtonArrowNode: ASImageNode private let backButtonNode: HighlightableButtonNode private let statusNode: CallControllerStatusNode + private let videoPausedNode: ImmediateTextNode private let buttonsNode: CallControllerButtonsNode private var keyPreviewNode: CallControllerKeyPreviewNode? @@ -140,6 +168,10 @@ final class CallControllerNode: ASDisplayNode { self.backButtonNode = HighlightableButtonNode() self.statusNode = CallControllerStatusNode() + + self.videoPausedNode = ImmediateTextNode() + self.videoPausedNode.alpha = 0.0 + self.buttonsNode = CallControllerButtonsNode(strings: self.presentationData.strings) self.keyButtonNode = HighlightableButtonNode() @@ -174,6 +206,7 @@ final class CallControllerNode: ASDisplayNode { self.containerNode.addSubnode(self.imageNode) self.containerNode.addSubnode(self.dimNode) self.containerNode.addSubnode(self.statusNode) + self.containerNode.addSubnode(self.videoPausedNode) self.containerNode.addSubnode(self.buttonsNode) self.containerNode.addSubnode(self.keyButtonNode) self.containerNode.addSubnode(self.backButtonArrowNode) @@ -199,6 +232,10 @@ final class CallControllerNode: ASDisplayNode { self?.toggleVideo?() } + self.buttonsNode.rotateCamera = { [weak self] in + self?.call.switchVideoCamera() + } + self.keyButtonNode.addTarget(self, action: #selector(self.keyPressed), forControlEvents: .touchUpInside) self.backButtonNode.addTarget(self, action: #selector(self.backPressed), forControlEvents: .touchUpInside) @@ -235,6 +272,8 @@ final class CallControllerNode: ASDisplayNode { } } + self.videoPausedNode.attributedText = NSAttributedString(string: self.presentationData.strings.Call_RemoteVideoPaused(peer.compactDisplayTitle).0, font: Font.regular(17.0), textColor: .white) + if let (layout, navigationBarHeight) = self.validLayout { self.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: .immediate) } @@ -256,8 +295,8 @@ final class CallControllerNode: ASDisplayNode { switch callState.videoState { case .active: - if !self.videoViewsRequested { - self.videoViewsRequested = true + if !self.incomingVideoViewRequested { + self.incomingVideoViewRequested = true self.call.makeIncomingVideoView(completion: { [weak self] incomingVideoView in guard let strongSelf = self else { return @@ -273,7 +312,38 @@ final class CallControllerNode: ASDisplayNode { } } }) - + } + if !self.outgoingVideoViewRequested { + self.outgoingVideoViewRequested = true + self.call.makeOutgoingVideoView(completion: { [weak self] outgoingVideoView in + guard let strongSelf = self else { + return + } + if let outgoingVideoView = outgoingVideoView { + outgoingVideoView.backgroundColor = .black + outgoingVideoView.clipsToBounds = true + strongSelf.setCurrentAudioOutput?(.speaker) + let outgoingVideoNode = OutgoingVideoNode(videoView: outgoingVideoView, switchCamera: { + guard let strongSelf = self else { + return + } + strongSelf.call.switchVideoCamera() + }) + strongSelf.outgoingVideoNode = outgoingVideoNode + if let incomingVideoNode = strongSelf.incomingVideoNode { + strongSelf.containerNode.insertSubnode(outgoingVideoNode, aboveSubnode: incomingVideoNode) + } else { + strongSelf.containerNode.insertSubnode(outgoingVideoNode, aboveSubnode: strongSelf.dimNode) + } + if let (layout, navigationBarHeight) = strongSelf.validLayout { + strongSelf.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: .immediate) + } + } + }) + } + case .activeOutgoing: + if !self.outgoingVideoViewRequested { + self.outgoingVideoViewRequested = true self.call.makeOutgoingVideoView(completion: { [weak self] outgoingVideoView in guard let strongSelf = self else { return @@ -305,6 +375,26 @@ final class CallControllerNode: ASDisplayNode { break } + if let incomingVideoNode = self.incomingVideoNode { + let isActive: Bool + switch callState.remoteVideoState { + case .inactive: + isActive = false + case .active: + isActive = true + } + incomingVideoNode.updateIsBlurred(isBlurred: !isActive) + if isActive != self.videoPausedNode.alpha.isZero { + if isActive { + self.videoPausedNode.alpha = 0.0 + self.videoPausedNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.3) + } else { + self.videoPausedNode.alpha = 1.0 + self.videoPausedNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3) + } + } + } + switch callState.state { case .waiting, .connecting: statusValue = .text(self.presentationData.strings.Call_StatusConnecting) @@ -444,6 +534,8 @@ final class CallControllerNode: ASDisplayNode { mappedVideoState = .available(true) case .active: mappedVideoState = .active + case .activeOutgoing: + mappedVideoState = .active } self.buttonsNode.updateMode(.active(speakerMode: mode, videoState: mappedVideoState)) } @@ -534,19 +626,31 @@ final class CallControllerNode: ASDisplayNode { let statusHeight = self.statusNode.updateLayout(constrainedWidth: layout.size.width, transition: transition) transition.updateFrame(node: self.statusNode, frame: CGRect(origin: CGPoint(x: 0.0, y: statusOffset), size: CGSize(width: layout.size.width, height: statusHeight))) + let videoPausedSize = self.videoPausedNode.updateLayout(CGSize(width: layout.size.width - 16.0, height: 100.0)) + transition.updateFrame(node: self.videoPausedNode, frame: CGRect(origin: CGPoint(x: floor((layout.size.width - videoPausedSize.width) / 2.0), y: floor((layout.size.height - videoPausedSize.height) / 2.0)), size: videoPausedSize)) + self.buttonsNode.updateLayout(constrainedWidth: layout.size.width, transition: transition) let buttonsOriginY: CGFloat = layout.size.height - (buttonsOffset - 40.0) - buttonsHeight - layout.intrinsicInsets.bottom transition.updateFrame(node: self.buttonsNode, frame: CGRect(origin: CGPoint(x: 0.0, y: buttonsOriginY), size: CGSize(width: layout.size.width, height: buttonsHeight))) + var outgoingVideoTransition = transition if let incomingVideoNode = self.incomingVideoNode { + if incomingVideoNode.frame.width.isZero, let outgoingVideoNode = self.outgoingVideoNode, !outgoingVideoNode.frame.width.isZero, !transition.isAnimated { + outgoingVideoTransition = .animated(duration: 0.3, curve: .easeInOut) + } incomingVideoNode.frame = CGRect(origin: CGPoint(), size: layout.size) incomingVideoNode.updateLayout(size: layout.size) } if let outgoingVideoNode = self.outgoingVideoNode { - let outgoingSize = layout.size.aspectFitted(CGSize(width: 200.0, height: 200.0)) - let outgoingFrame = CGRect(origin: CGPoint(x: layout.size.width - 16.0 - outgoingSize.width, y: buttonsOriginY - 32.0 - outgoingSize.height), size: outgoingSize) - outgoingVideoNode.frame = outgoingFrame - outgoingVideoNode.updateLayout(size: outgoingFrame.size) + if self.incomingVideoNode == nil { + outgoingVideoNode.frame = CGRect(origin: CGPoint(), size: layout.size) + outgoingVideoNode.updateLayout(size: layout.size, isExpanded: true, transition: transition) + } else { + let outgoingSize = layout.size.aspectFitted(CGSize(width: 200.0, height: 200.0)) + let outgoingFrame = CGRect(origin: CGPoint(x: layout.size.width - 16.0 - outgoingSize.width, y: buttonsOriginY - 32.0 - outgoingSize.height), size: outgoingSize) + outgoingVideoTransition.updateFrame(node: outgoingVideoNode, frame: outgoingFrame) + outgoingVideoNode.updateLayout(size: outgoingFrame.size, isExpanded: false, transition: outgoingVideoTransition) + } } let keyTextSize = self.keyButtonNode.frame.size diff --git a/submodules/TelegramCallsUI/Sources/CallKitIntegration.swift b/submodules/TelegramCallsUI/Sources/CallKitIntegration.swift index 11addb26ea..09a7f05696 100644 --- a/submodules/TelegramCallsUI/Sources/CallKitIntegration.swift +++ b/submodules/TelegramCallsUI/Sources/CallKitIntegration.swift @@ -15,13 +15,13 @@ public final class CallKitIntegration { public static var isAvailable: Bool { #if targetEnvironment(simulator) return false - #endif - + #else if #available(iOSApplicationExtension 10.0, iOS 10.0, *) { return Locale.current.regionCode?.lowercased() != "cn" } else { return false } + #endif } private let audioSessionActivePromise = ValuePromise(false, ignoreRepeated: true) @@ -29,7 +29,7 @@ public final class CallKitIntegration { return self.audioSessionActivePromise.get() } - init?(startCall: @escaping (Account, UUID, String) -> Signal, answerCall: @escaping (UUID) -> Void, endCall: @escaping (UUID) -> Signal, setCallMuted: @escaping (UUID, Bool) -> Void, audioSessionActivationChanged: @escaping (Bool) -> Void) { + init?(enableVideoCalls: Bool, startCall: @escaping (Account, UUID, String, Bool) -> Signal, answerCall: @escaping (UUID) -> Void, endCall: @escaping (UUID) -> Signal, setCallMuted: @escaping (UUID, Bool) -> Void, audioSessionActivationChanged: @escaping (Bool) -> Void) { if !CallKitIntegration.isAvailable { return nil } @@ -40,7 +40,7 @@ public final class CallKitIntegration { if #available(iOSApplicationExtension 10.0, iOS 10.0, *) { if sharedProviderDelegate == nil { - sharedProviderDelegate = CallKitProviderDelegate() + sharedProviderDelegate = CallKitProviderDelegate(enableVideoCalls: enableVideoCalls) } (sharedProviderDelegate as? CallKitProviderDelegate)?.setup(audioSessionActivePromise: self.audioSessionActivePromise, startCall: startCall, answerCall: answerCall, endCall: endCall, setCallMuted: setCallMuted, audioSessionActivationChanged: audioSessionActivationChanged) } else { @@ -49,9 +49,9 @@ public final class CallKitIntegration { #endif } - func startCall(account: Account, peerId: PeerId, displayTitle: String) { + func startCall(account: Account, peerId: PeerId, isVideo: Bool, displayTitle: String) { if #available(iOSApplicationExtension 10.0, iOS 10.0, *) { - (sharedProviderDelegate as? CallKitProviderDelegate)?.startCall(account: account, peerId: peerId, displayTitle: displayTitle) + (sharedProviderDelegate as? CallKitProviderDelegate)?.startCall(account: account, peerId: peerId, isVideo: isVideo, displayTitle: displayTitle) self.donateIntent(peerId: peerId, displayTitle: displayTitle) } } @@ -68,9 +68,9 @@ public final class CallKitIntegration { } } - func reportIncomingCall(uuid: UUID, handle: String, displayTitle: String, completion: ((NSError?) -> Void)?) { + func reportIncomingCall(uuid: UUID, handle: String, isVideo: Bool, displayTitle: String, completion: ((NSError?) -> Void)?) { if #available(iOSApplicationExtension 10.0, iOS 10.0, *) { - (sharedProviderDelegate as? CallKitProviderDelegate)?.reportIncomingCall(uuid: uuid, handle: handle, displayTitle: displayTitle, completion: completion) + (sharedProviderDelegate as? CallKitProviderDelegate)?.reportIncomingCall(uuid: uuid, handle: handle, isVideo: isVideo, displayTitle: displayTitle, completion: completion) } } @@ -102,7 +102,7 @@ class CallKitProviderDelegate: NSObject, CXProviderDelegate { private var currentStartCallAccount: (UUID, Account)? - private var startCall: ((Account, UUID, String) -> Signal)? + private var startCall: ((Account, UUID, String, Bool) -> Signal)? private var answerCall: ((UUID) -> Void)? private var endCall: ((UUID) -> Signal)? private var setCallMuted: ((UUID, Bool) -> Void)? @@ -112,15 +112,15 @@ class CallKitProviderDelegate: NSObject, CXProviderDelegate { fileprivate var audioSessionActivePromise: ValuePromise? - override init() { - self.provider = CXProvider(configuration: CallKitProviderDelegate.providerConfiguration) + init(enableVideoCalls: Bool) { + self.provider = CXProvider(configuration: CallKitProviderDelegate.providerConfiguration(enableVideoCalls: enableVideoCalls)) super.init() self.provider.setDelegate(self, queue: nil) } - func setup(audioSessionActivePromise: ValuePromise, startCall: @escaping (Account, UUID, String) -> Signal, answerCall: @escaping (UUID) -> Void, endCall: @escaping (UUID) -> Signal, setCallMuted: @escaping (UUID, Bool) -> Void, audioSessionActivationChanged: @escaping (Bool) -> Void) { + func setup(audioSessionActivePromise: ValuePromise, startCall: @escaping (Account, UUID, String, Bool) -> Signal, answerCall: @escaping (UUID) -> Void, endCall: @escaping (UUID) -> Signal, setCallMuted: @escaping (UUID, Bool) -> Void, audioSessionActivationChanged: @escaping (Bool) -> Void) { self.audioSessionActivePromise = audioSessionActivePromise self.startCall = startCall self.answerCall = answerCall @@ -129,7 +129,7 @@ class CallKitProviderDelegate: NSObject, CXProviderDelegate { self.audioSessionActivationChanged = audioSessionActivationChanged } - static var providerConfiguration: CXProviderConfiguration { + private static func providerConfiguration(enableVideoCalls: Bool) -> CXProviderConfiguration { let providerConfiguration = CXProviderConfiguration(localizedName: "Telegram") providerConfiguration.supportsVideo = false @@ -166,14 +166,14 @@ class CallKitProviderDelegate: NSObject, CXProviderDelegate { } - func startCall(account: Account, peerId: PeerId, displayTitle: String) { + func startCall(account: Account, peerId: PeerId, isVideo: Bool, displayTitle: String) { let uuid = UUID() self.currentStartCallAccount = (uuid, account) let handle = CXHandle(type: .generic, value: "\(peerId.id)") let startCallAction = CXStartCallAction(call: uuid, handle: handle) startCallAction.contactIdentifier = displayTitle - startCallAction.isVideo = false + startCallAction.isVideo = isVideo let transaction = CXTransaction(action: startCallAction) self.requestTransaction(transaction, completion: { _ in @@ -189,7 +189,7 @@ class CallKitProviderDelegate: NSObject, CXProviderDelegate { }) } - func reportIncomingCall(uuid: UUID, handle: String, displayTitle: String, completion: ((NSError?) -> Void)?) { + func reportIncomingCall(uuid: UUID, handle: String, isVideo: Bool, displayTitle: String, completion: ((NSError?) -> Void)?) { let update = CXCallUpdate() update.remoteHandle = CXHandle(type: .generic, value: handle) update.localizedCallerName = displayTitle @@ -197,6 +197,7 @@ class CallKitProviderDelegate: NSObject, CXProviderDelegate { update.supportsGrouping = false update.supportsUngrouping = false update.supportsDTMF = false + update.hasVideo = isVideo self.provider.reportNewIncomingCall(with: uuid, update: update, completion: { error in completion?(error as NSError?) @@ -222,7 +223,7 @@ class CallKitProviderDelegate: NSObject, CXProviderDelegate { self.currentStartCallAccount = nil let disposable = MetaDisposable() self.disposableSet.add(disposable) - disposable.set((startCall(account, action.callUUID, action.handle.value) + disposable.set((startCall(account, action.callUUID, action.handle.value, action.isVideo) |> deliverOnMainQueue |> afterDisposed { [weak self, weak disposable] in if let strongSelf = self, let disposable = disposable { diff --git a/submodules/TelegramCallsUI/Sources/PresentationCall.swift b/submodules/TelegramCallsUI/Sources/PresentationCall.swift index 94713dea1e..6c4da73a80 100644 --- a/submodules/TelegramCallsUI/Sources/PresentationCall.swift +++ b/submodules/TelegramCallsUI/Sources/PresentationCall.swift @@ -166,12 +166,14 @@ public final class PresentationCallImpl: PresentationCall { public let internalId: CallSessionInternalId public let peerId: PeerId public let isOutgoing: Bool + private var isVideo: Bool public let peer: Peer? private let serializedData: String? private let dataSaving: VoiceCallDataSaving private let derivedState: VoipDerivedState private let proxyServer: ProxyServerSettings? + private let auxiliaryServers: [OngoingCallContext.AuxiliaryServer] private let currentNetworkType: NetworkType private let updatedNetworkType: Signal @@ -188,7 +190,7 @@ public final class PresentationCallImpl: PresentationCall { private var sessionStateDisposable: Disposable? - private let statePromise = ValuePromise(PresentationCallState(state: .waiting, videoState: .notAvailable), ignoreRepeated: true) + private let statePromise = ValuePromise(PresentationCallState(state: .waiting, videoState: .notAvailable, remoteVideoState: .inactive), ignoreRepeated: true) public var state: Signal { return self.statePromise.get() } @@ -231,16 +233,31 @@ public final class PresentationCallImpl: PresentationCall { private var droppedCall = false private var dropCallKitCallTimer: SwiftSignalKit.Timer? - init(account: Account, audioSession: ManagedAudioSession, callSessionManager: CallSessionManager, callKitIntegration: CallKitIntegration?, serializedData: String?, dataSaving: VoiceCallDataSaving, derivedState: VoipDerivedState, getDeviceAccessData: @escaping () -> (presentationData: PresentationData, present: (ViewController, Any?) -> Void, openSettings: () -> Void), initialState: CallSession?, internalId: CallSessionInternalId, peerId: PeerId, isOutgoing: Bool, peer: Peer?, proxyServer: ProxyServerSettings?, currentNetworkType: NetworkType, updatedNetworkType: Signal) { + init(account: Account, audioSession: ManagedAudioSession, callSessionManager: CallSessionManager, callKitIntegration: CallKitIntegration?, serializedData: String?, dataSaving: VoiceCallDataSaving, derivedState: VoipDerivedState, getDeviceAccessData: @escaping () -> (presentationData: PresentationData, present: (ViewController, Any?) -> Void, openSettings: () -> Void), initialState: CallSession?, internalId: CallSessionInternalId, peerId: PeerId, isOutgoing: Bool, peer: Peer?, proxyServer: ProxyServerSettings?, auxiliaryServers: [CallAuxiliaryServer], currentNetworkType: NetworkType, updatedNetworkType: Signal) { self.account = account self.audioSession = audioSession self.callSessionManager = callSessionManager self.callKitIntegration = callKitIntegration self.getDeviceAccessData = getDeviceAccessData + self.auxiliaryServers = auxiliaryServers.map { server -> OngoingCallContext.AuxiliaryServer in + let mappedConnection: OngoingCallContext.AuxiliaryServer.Connection + switch server.connection { + case .stun: + mappedConnection = .stun + case let .turn(username, password): + mappedConnection = .turn(username: username, password: password) + } + return OngoingCallContext.AuxiliaryServer( + host: server.host, + port: server.port, + connection: mappedConnection + ) + } self.internalId = internalId self.peerId = peerId self.isOutgoing = isOutgoing + self.isVideo = initialState?.type == .video self.peer = peer self.serializedData = serializedData @@ -369,6 +386,9 @@ public final class PresentationCallImpl: PresentationCall { } private func updateSessionState(sessionState: CallSession, callContextState: OngoingCallContextState?, reception: Int32?, audioSessionControl: ManagedAudioSessionControl?) { + if case .video = sessionState.type { + self.isVideo = true + } let previous = self.sessionState let previousControl = self.audioSessionControl self.sessionState = sessionState @@ -400,13 +420,37 @@ public final class PresentationCallImpl: PresentationCall { audioSessionControl.setup(synchronous: true) } + let mappedVideoState: PresentationCallState.VideoState + let mappedRemoteVideoState: PresentationCallState.RemoteVideoState + if let callContextState = callContextState { + switch callContextState.videoState { + case .notAvailable: + mappedVideoState = .notAvailable + case let .available(enabled): + mappedVideoState = .available(enabled) + case .active: + mappedVideoState = .active + case .activeOutgoing: + mappedVideoState = .activeOutgoing + } + switch callContextState.remoteVideoState { + case .inactive: + mappedRemoteVideoState = .inactive + case .active: + mappedRemoteVideoState = .active + } + } else { + mappedVideoState = .notAvailable + mappedRemoteVideoState = .inactive + } + switch sessionState.state { case .ringing: - presentationState = PresentationCallState(state: .ringing, videoState: .notAvailable) + presentationState = PresentationCallState(state: .ringing, videoState: .notAvailable, remoteVideoState: .inactive) if previous == nil || previousControl == nil { if !self.reportedIncomingCall { self.reportedIncomingCall = true - self.callKitIntegration?.reportIncomingCall(uuid: self.internalId, handle: "\(self.peerId.id)", displayTitle: self.peer?.debugDisplayTitle ?? "Unknown", completion: { [weak self] error in + self.callKitIntegration?.reportIncomingCall(uuid: self.internalId, handle: "\(self.peerId.id)", isVideo: sessionState.type == .video, displayTitle: self.peer?.debugDisplayTitle ?? "Unknown", completion: { [weak self] error in if let error = error { if error.domain == "com.apple.CallKit.error.incomingcall" && (error.code == -3 || error.code == 3) { Logger.shared.log("PresentationCall", "reportIncomingCall device in DND mode") @@ -429,28 +473,19 @@ public final class PresentationCallImpl: PresentationCall { } case .accepting: self.callWasActive = true - presentationState = PresentationCallState(state: .connecting(nil), videoState: .notAvailable) + presentationState = PresentationCallState(state: .connecting(nil), videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState) case .dropping: - presentationState = PresentationCallState(state: .terminating, videoState: .notAvailable) + presentationState = PresentationCallState(state: .terminating, videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState) case let .terminated(id, reason, options): - presentationState = PresentationCallState(state: .terminated(id, reason, self.callWasActive && (options.contains(.reportRating) || self.shouldPresentCallRating)), videoState: .notAvailable) + presentationState = PresentationCallState(state: .terminated(id, reason, self.callWasActive && (options.contains(.reportRating) || self.shouldPresentCallRating)), videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState) case let .requesting(ringing): - presentationState = PresentationCallState(state: .requesting(ringing), videoState: .notAvailable) + presentationState = PresentationCallState(state: .requesting(ringing), videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState) case let .active(_, _, keyVisualHash, _, _, _, _): self.callWasActive = true if let callContextState = callContextState { - let mappedVideoState: PresentationCallState.VideoState - switch callContextState.videoState { - case .notAvailable: - mappedVideoState = .notAvailable - case let .available(enabled): - mappedVideoState = .available(enabled) - case .active: - mappedVideoState = .active - } switch callContextState.state { case .initializing: - presentationState = PresentationCallState(state: .connecting(keyVisualHash), videoState: mappedVideoState) + presentationState = PresentationCallState(state: .connecting(keyVisualHash), videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState) case .failed: presentationState = nil self.callSessionManager.drop(internalId: self.internalId, reason: .disconnect, debugLog: .single(nil)) @@ -462,7 +497,7 @@ public final class PresentationCallImpl: PresentationCall { timestamp = CFAbsoluteTimeGetCurrent() self.activeTimestamp = timestamp } - presentationState = PresentationCallState(state: .active(timestamp, reception, keyVisualHash), videoState: mappedVideoState) + presentationState = PresentationCallState(state: .active(timestamp, reception, keyVisualHash), videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState) case .reconnecting: let timestamp: Double if let activeTimestamp = self.activeTimestamp { @@ -471,10 +506,10 @@ public final class PresentationCallImpl: PresentationCall { timestamp = CFAbsoluteTimeGetCurrent() self.activeTimestamp = timestamp } - presentationState = PresentationCallState(state: .reconnecting(timestamp, reception, keyVisualHash), videoState: mappedVideoState) + presentationState = PresentationCallState(state: .reconnecting(timestamp, reception, keyVisualHash), videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState) } } else { - presentationState = PresentationCallState(state: .connecting(keyVisualHash), videoState: .notAvailable) + presentationState = PresentationCallState(state: .connecting(keyVisualHash), videoState: .notAvailable, remoteVideoState: .inactive) } } @@ -488,7 +523,7 @@ public final class PresentationCallImpl: PresentationCall { if let _ = audioSessionControl, !wasActive || previousControl == nil { let logName = "\(id.id)_\(id.accessHash)" - let ongoingContext = OngoingCallContext(account: account, callSessionManager: self.callSessionManager, internalId: self.internalId, proxyServer: proxyServer, initialNetworkType: self.currentNetworkType, updatedNetworkType: self.updatedNetworkType, serializedData: self.serializedData, dataSaving: dataSaving, derivedState: self.derivedState, key: key, isOutgoing: sessionState.isOutgoing, connections: connections, maxLayer: maxLayer, version: version, allowP2P: allowsP2P, audioSessionActive: self.audioSessionActive.get(), logName: logName) + let ongoingContext = OngoingCallContext(account: account, callSessionManager: self.callSessionManager, internalId: self.internalId, proxyServer: proxyServer, auxiliaryServers: auxiliaryServers, initialNetworkType: self.currentNetworkType, updatedNetworkType: self.updatedNetworkType, serializedData: self.serializedData, dataSaving: dataSaving, derivedState: self.derivedState, key: key, isOutgoing: sessionState.isOutgoing, isVideo: sessionState.type == .video, connections: connections, maxLayer: maxLayer, version: version, allowP2P: allowsP2P, audioSessionActive: self.audioSessionActive.get(), logName: logName) self.ongoingContext = ongoingContext self.debugInfoValue.set(ongoingContext.debugInfo()) @@ -629,8 +664,26 @@ public final class PresentationCallImpl: PresentationCall { return } if value { - strongSelf.callSessionManager.accept(internalId: strongSelf.internalId) - strongSelf.callKitIntegration?.answerCall(uuid: strongSelf.internalId) + if strongSelf.isVideo { + DeviceAccess.authorizeAccess(to: .camera, presentationData: presentationData, present: { c, a in + present(c, a) + }, openSettings: { + openSettings() + }, { [weak self] value in + guard let strongSelf = self else { + return + } + if value { + strongSelf.callSessionManager.accept(internalId: strongSelf.internalId) + strongSelf.callKitIntegration?.answerCall(uuid: strongSelf.internalId) + } else { + let _ = strongSelf.hangUp().start() + } + }) + } else { + strongSelf.callSessionManager.accept(internalId: strongSelf.internalId) + strongSelf.callKitIntegration?.answerCall(uuid: strongSelf.internalId) + } } else { let _ = strongSelf.hangUp().start() } diff --git a/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift b/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift index 4b7f5c4d45..d0a41bf7ff 100644 --- a/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift +++ b/submodules/TelegramCallsUI/Sources/PresentationCallManager.swift @@ -16,6 +16,47 @@ private func callKitIntegrationIfEnabled(_ integration: CallKitIntegration?, set return enabled ? integration : nil } +private func auxiliaryServers(appConfiguration: AppConfiguration) -> [CallAuxiliaryServer] { + guard let data = appConfiguration.data else { + return [] + } + guard let servers = data["rtc_servers"] as? [[String: Any]] else { + return [] + } + var result: [CallAuxiliaryServer] = [] + for server in servers { + guard let host = server["host"] as? String else { + continue + } + guard let portString = server["port"] as? String else { + continue + } + guard let username = server["username"] as? String else { + continue + } + guard let password = server["password"] as? String else { + continue + } + guard let port = Int(portString) else { + continue + } + result.append(CallAuxiliaryServer( + host: host, + port: port, + connection: .stun + )) + result.append(CallAuxiliaryServer( + host: host, + port: port, + connection: .turn( + username: username, + password: password + ) + )) + } + return result +} + private enum CurrentCall { case none case incomingRinging(CallSessionRingingState) @@ -79,7 +120,7 @@ public final class PresentationCallManagerImpl: PresentationCallManager { return OngoingCallContext.versions(includeExperimental: includeExperimental) } - public init(accountManager: AccountManager, getDeviceAccessData: @escaping () -> (presentationData: PresentationData, present: (ViewController, Any?) -> Void, openSettings: () -> Void), isMediaPlaying: @escaping () -> Bool, resumeMediaPlayback: @escaping () -> Void, audioSession: ManagedAudioSession, activeAccounts: Signal<[Account], NoError>) { + public init(accountManager: AccountManager, enableVideoCalls: Bool, getDeviceAccessData: @escaping () -> (presentationData: PresentationData, present: (ViewController, Any?) -> Void, openSettings: () -> Void), isMediaPlaying: @escaping () -> Bool, resumeMediaPlayback: @escaping () -> Void, audioSession: ManagedAudioSession, activeAccounts: Signal<[Account], NoError>) { self.getDeviceAccessData = getDeviceAccessData self.accountManager = accountManager self.audioSession = audioSession @@ -87,15 +128,15 @@ public final class PresentationCallManagerImpl: PresentationCallManager { self.isMediaPlaying = isMediaPlaying self.resumeMediaPlayback = resumeMediaPlayback - var startCallImpl: ((Account, UUID, String) -> Signal)? + var startCallImpl: ((Account, UUID, String, Bool) -> Signal)? var answerCallImpl: ((UUID) -> Void)? var endCallImpl: ((UUID) -> Signal)? var setCallMutedImpl: ((UUID, Bool) -> Void)? var audioSessionActivationChangedImpl: ((Bool) -> Void)? - self.callKitIntegration = CallKitIntegration(startCall: { account, uuid, handle in + self.callKitIntegration = CallKitIntegration(enableVideoCalls: enableVideoCalls, startCall: { account, uuid, handle, isVideo in if let startCallImpl = startCallImpl { - return startCallImpl(account, uuid, handle) + return startCallImpl(account, uuid, handle, isVideo) } else { return .single(false) } @@ -169,9 +210,9 @@ public final class PresentationCallManagerImpl: PresentationCallManager { self?.ringingStatesUpdated(ringingStates, enableCallKit: enableCallKit) }) - startCallImpl = { [weak self] account, uuid, handle in + startCallImpl = { [weak self] account, uuid, handle, isVideo in if let strongSelf = self, let userId = Int32(handle) { - return strongSelf.startCall(account: account, peerId: PeerId(namespace: Namespaces.Peer.CloudUser, id: userId), internalId: uuid) + return strongSelf.startCall(account: account, peerId: PeerId(namespace: Namespaces.Peer.CloudUser, id: userId), isVideo: isVideo, internalId: uuid) |> take(1) |> map { result -> Bool in return result @@ -245,7 +286,7 @@ public final class PresentationCallManagerImpl: PresentationCallManager { let semaphore = DispatchSemaphore(value: 0) var data: (PreferencesView, AccountSharedDataView, Peer?)? let _ = combineLatest( - account.postbox.preferencesView(keys: [PreferencesKeys.voipConfiguration, ApplicationSpecificPreferencesKeys.voipDerivedState]) + account.postbox.preferencesView(keys: [PreferencesKeys.voipConfiguration, ApplicationSpecificPreferencesKeys.voipDerivedState, PreferencesKeys.appConfiguration]) |> take(1), accountManager.sharedData(keys: [SharedDataKeys.autodownloadSettings]) |> take(1), @@ -260,12 +301,13 @@ public final class PresentationCallManagerImpl: PresentationCallManager { if let (preferences, sharedData, maybePeer) = data, let peer = maybePeer { let configuration = preferences.values[PreferencesKeys.voipConfiguration] as? VoipConfiguration ?? .defaultValue + let appConfiguration = preferences.values[PreferencesKeys.appConfiguration] as? AppConfiguration ?? AppConfiguration.defaultValue let derivedState = preferences.values[ApplicationSpecificPreferencesKeys.voipDerivedState] as? VoipDerivedState ?? .default let autodownloadSettings = sharedData.entries[SharedDataKeys.autodownloadSettings] as? AutodownloadSettings ?? .defaultSettings let enableCallKit = true - let call = PresentationCallImpl(account: account, audioSession: self.audioSession, callSessionManager: account.callSessionManager, callKitIntegration: enableCallKit ? callKitIntegrationIfEnabled(self.callKitIntegration, settings: self.callSettings) : nil, serializedData: configuration.serializedData, dataSaving: effectiveDataSaving(for: self.callSettings, autodownloadSettings: autodownloadSettings), derivedState: derivedState, getDeviceAccessData: self.getDeviceAccessData, initialState: callSession, internalId: ringingState.id, peerId: ringingState.peerId, isOutgoing: false, peer: peer, proxyServer: self.proxyServer, currentNetworkType: .none, updatedNetworkType: account.networkType) + let call = PresentationCallImpl(account: account, audioSession: self.audioSession, callSessionManager: account.callSessionManager, callKitIntegration: enableCallKit ? callKitIntegrationIfEnabled(self.callKitIntegration, settings: self.callSettings) : nil, serializedData: configuration.serializedData, dataSaving: effectiveDataSaving(for: self.callSettings, autodownloadSettings: autodownloadSettings), derivedState: derivedState, getDeviceAccessData: self.getDeviceAccessData, initialState: callSession, internalId: ringingState.id, peerId: ringingState.peerId, isOutgoing: false, peer: peer, proxyServer: self.proxyServer, auxiliaryServers: auxiliaryServers(appConfiguration: appConfiguration), currentNetworkType: .none, updatedNetworkType: account.networkType) self.updateCurrentCall(call) self.currentCallPromise.set(.single(call)) self.hasActiveCallsPromise.set(true) @@ -285,7 +327,7 @@ public final class PresentationCallManagerImpl: PresentationCallManager { private func ringingStatesUpdated(_ ringingStates: [(Account, Peer, CallSessionRingingState, Bool, NetworkType)], enableCallKit: Bool) { if let firstState = ringingStates.first { if self.currentCall == nil { - self.currentCallDisposable.set((combineLatest(firstState.0.postbox.preferencesView(keys: [PreferencesKeys.voipConfiguration, ApplicationSpecificPreferencesKeys.voipDerivedState]) |> take(1), accountManager.sharedData(keys: [SharedDataKeys.autodownloadSettings]) |> take(1)) + self.currentCallDisposable.set((combineLatest(firstState.0.postbox.preferencesView(keys: [PreferencesKeys.voipConfiguration, ApplicationSpecificPreferencesKeys.voipDerivedState, PreferencesKeys.appConfiguration]) |> take(1), accountManager.sharedData(keys: [SharedDataKeys.autodownloadSettings]) |> take(1)) |> deliverOnMainQueue).start(next: { [weak self] preferences, sharedData in guard let strongSelf = self else { return @@ -294,8 +336,9 @@ public final class PresentationCallManagerImpl: PresentationCallManager { let configuration = preferences.values[PreferencesKeys.voipConfiguration] as? VoipConfiguration ?? .defaultValue let derivedState = preferences.values[ApplicationSpecificPreferencesKeys.voipDerivedState] as? VoipDerivedState ?? .default let autodownloadSettings = sharedData.entries[SharedDataKeys.autodownloadSettings] as? AutodownloadSettings ?? .defaultSettings + let appConfiguration = preferences.values[PreferencesKeys.appConfiguration] as? AppConfiguration ?? AppConfiguration.defaultValue - let call = PresentationCallImpl(account: firstState.0, audioSession: strongSelf.audioSession, callSessionManager: firstState.0.callSessionManager, callKitIntegration: enableCallKit ? callKitIntegrationIfEnabled(strongSelf.callKitIntegration, settings: strongSelf.callSettings) : nil, serializedData: configuration.serializedData, dataSaving: effectiveDataSaving(for: strongSelf.callSettings, autodownloadSettings: autodownloadSettings), derivedState: derivedState, getDeviceAccessData: strongSelf.getDeviceAccessData, initialState: nil, internalId: firstState.2.id, peerId: firstState.2.peerId, isOutgoing: false, peer: firstState.1, proxyServer: strongSelf.proxyServer, currentNetworkType: firstState.4, updatedNetworkType: firstState.0.networkType) + let call = PresentationCallImpl(account: firstState.0, audioSession: strongSelf.audioSession, callSessionManager: firstState.0.callSessionManager, callKitIntegration: enableCallKit ? callKitIntegrationIfEnabled(strongSelf.callKitIntegration, settings: strongSelf.callSettings) : nil, serializedData: configuration.serializedData, dataSaving: effectiveDataSaving(for: strongSelf.callSettings, autodownloadSettings: autodownloadSettings), derivedState: derivedState, getDeviceAccessData: strongSelf.getDeviceAccessData, initialState: nil, internalId: firstState.2.id, peerId: firstState.2.peerId, isOutgoing: false, peer: firstState.1, proxyServer: strongSelf.proxyServer, auxiliaryServers: auxiliaryServers(appConfiguration: appConfiguration), currentNetworkType: firstState.4, updatedNetworkType: firstState.0.networkType) strongSelf.updateCurrentCall(call) strongSelf.currentCallPromise.set(.single(call)) strongSelf.hasActiveCallsPromise.set(true) @@ -320,7 +363,7 @@ public final class PresentationCallManagerImpl: PresentationCallManager { } } - public func requestCall(account: Account, peerId: PeerId, endCurrentIfAny: Bool) -> RequestCallResult { + public func requestCall(account: Account, peerId: PeerId, isVideo: Bool, endCurrentIfAny: Bool) -> RequestCallResult { if let call = self.currentCall, !endCurrentIfAny { return .alreadyInProgress(call.peerId) } @@ -337,8 +380,19 @@ public final class PresentationCallManagerImpl: PresentationCallManager { }, openSettings: { openSettings() }, { value in - subscriber.putNext(value) - subscriber.putCompletion() + if isVideo { + DeviceAccess.authorizeAccess(to: .camera, presentationData: presentationData, present: { c, a in + present(c, a) + }, openSettings: { + openSettings() + }, { value in + subscriber.putNext(value) + subscriber.putCompletion() + }) + } else { + subscriber.putNext(value) + subscriber.putCompletion() + } }) return EmptyDisposable } @@ -357,7 +411,7 @@ public final class PresentationCallManagerImpl: PresentationCallManager { guard let strongSelf = self, let peer = peer else { return } - strongSelf.callKitIntegration?.startCall(account: account, peerId: peerId, displayTitle: peer.debugDisplayTitle) + strongSelf.callKitIntegration?.startCall(account: account, peerId: peerId, isVideo: isVideo, displayTitle: peer.debugDisplayTitle) })) } if let currentCall = self.currentCall { @@ -374,7 +428,7 @@ public final class PresentationCallManagerImpl: PresentationCallManager { guard let strongSelf = self else { return } - let _ = strongSelf.startCall(account: account, peerId: peerId).start() + let _ = strongSelf.startCall(account: account, peerId: peerId, isVideo: isVideo).start() } if let currentCall = self.currentCall { self.startCallDisposable.set((currentCall.hangUp() @@ -388,7 +442,7 @@ public final class PresentationCallManagerImpl: PresentationCallManager { return .requested } - private func startCall(account: Account, peerId: PeerId, internalId: CallSessionInternalId = CallSessionInternalId()) -> Signal { + private func startCall(account: Account, peerId: PeerId, isVideo: Bool, internalId: CallSessionInternalId = CallSessionInternalId()) -> Signal { let (presentationData, present, openSettings) = self.getDeviceAccessData() let accessEnabledSignal: Signal = Signal { subscriber in @@ -397,8 +451,19 @@ public final class PresentationCallManagerImpl: PresentationCallManager { }, openSettings: { openSettings() }, { value in - subscriber.putNext(value) - subscriber.putCompletion() + if isVideo { + DeviceAccess.authorizeAccess(to: .camera, presentationData: presentationData, present: { c, a in + present(c, a) + }, openSettings: { + openSettings() + }, { value in + subscriber.putNext(value) + subscriber.putCompletion() + }) + } else { + subscriber.putNext(value) + subscriber.putCompletion() + } }) return EmptyDisposable } @@ -411,9 +476,9 @@ public final class PresentationCallManagerImpl: PresentationCallManager { if !accessEnabled { return .single(false) } - return (combineLatest(queue: .mainQueue(), account.callSessionManager.request(peerId: peerId, internalId: internalId), networkType |> take(1), account.postbox.peerView(id: peerId) |> map { peerView -> Bool in + return (combineLatest(queue: .mainQueue(), account.callSessionManager.request(peerId: peerId, isVideo: isVideo, internalId: internalId), networkType |> take(1), account.postbox.peerView(id: peerId) |> map { peerView -> Bool in return peerView.peerIsContact - } |> take(1), account.postbox.preferencesView(keys: [PreferencesKeys.voipConfiguration, ApplicationSpecificPreferencesKeys.voipDerivedState]) |> take(1), accountManager.sharedData(keys: [SharedDataKeys.autodownloadSettings]) |> take(1)) + } |> take(1), account.postbox.preferencesView(keys: [PreferencesKeys.voipConfiguration, ApplicationSpecificPreferencesKeys.voipDerivedState, PreferencesKeys.appConfiguration]) |> take(1), accountManager.sharedData(keys: [SharedDataKeys.autodownloadSettings]) |> take(1)) |> deliverOnMainQueue |> beforeNext { internalId, currentNetworkType, isContact, preferences, sharedData in if let strongSelf = self, accessEnabled { @@ -424,8 +489,9 @@ public final class PresentationCallManagerImpl: PresentationCallManager { let configuration = preferences.values[PreferencesKeys.voipConfiguration] as? VoipConfiguration ?? .defaultValue let derivedState = preferences.values[ApplicationSpecificPreferencesKeys.voipDerivedState] as? VoipDerivedState ?? .default let autodownloadSettings = sharedData.entries[SharedDataKeys.autodownloadSettings] as? AutodownloadSettings ?? .defaultSettings + let appConfiguration = preferences.values[PreferencesKeys.appConfiguration] as? AppConfiguration ?? AppConfiguration.defaultValue - let call = PresentationCallImpl(account: account, audioSession: strongSelf.audioSession, callSessionManager: account.callSessionManager, callKitIntegration: callKitIntegrationIfEnabled(strongSelf.callKitIntegration, settings: strongSelf.callSettings), serializedData: configuration.serializedData, dataSaving: effectiveDataSaving(for: strongSelf.callSettings, autodownloadSettings: autodownloadSettings), derivedState: derivedState, getDeviceAccessData: strongSelf.getDeviceAccessData, initialState: nil, internalId: internalId, peerId: peerId, isOutgoing: true, peer: nil, proxyServer: strongSelf.proxyServer, currentNetworkType: currentNetworkType, updatedNetworkType: account.networkType) + let call = PresentationCallImpl(account: account, audioSession: strongSelf.audioSession, callSessionManager: account.callSessionManager, callKitIntegration: callKitIntegrationIfEnabled(strongSelf.callKitIntegration, settings: strongSelf.callSettings), serializedData: configuration.serializedData, dataSaving: effectiveDataSaving(for: strongSelf.callSettings, autodownloadSettings: autodownloadSettings), derivedState: derivedState, getDeviceAccessData: strongSelf.getDeviceAccessData, initialState: nil, internalId: internalId, peerId: peerId, isOutgoing: true, peer: nil, proxyServer: strongSelf.proxyServer, auxiliaryServers: auxiliaryServers(appConfiguration: appConfiguration), currentNetworkType: currentNetworkType, updatedNetworkType: account.networkType) strongSelf.updateCurrentCall(call) strongSelf.currentCallPromise.set(.single(call)) strongSelf.hasActiveCallsPromise.set(true) diff --git a/submodules/TelegramCore/Sources/AccountViewTracker.swift b/submodules/TelegramCore/Sources/AccountViewTracker.swift index 33e99c4e7d..b34eaede56 100644 --- a/submodules/TelegramCore/Sources/AccountViewTracker.swift +++ b/submodules/TelegramCore/Sources/AccountViewTracker.swift @@ -1322,7 +1322,7 @@ public final class AccountViewTracker { var lhsOther = false inner: for media in lhs.media { if let action = media as? TelegramMediaAction { - if case let .phoneCall(_, discardReason, _) = action.action { + if case let .phoneCall(_, discardReason, _, _) = action.action { if lhs.flags.contains(.Incoming), let discardReason = discardReason, case .missed = discardReason { lhsMissed = true } else { @@ -1336,7 +1336,7 @@ public final class AccountViewTracker { var rhsOther = false inner: for media in rhs.media { if let action = media as? TelegramMediaAction { - if case let .phoneCall(_, discardReason, _) = action.action { + if case let .phoneCall(_, discardReason, _, _) = action.action { if rhs.flags.contains(.Incoming), let discardReason = discardReason, case .missed = discardReason { rhsMissed = true } else { diff --git a/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift b/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift index ebabf4ab90..9d09f0de6e 100644 --- a/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift +++ b/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift @@ -8,6 +8,8 @@ import SyncCore private func copyOrMoveResourceData(from fromResource: MediaResource, to toResource: MediaResource, mediaBox: MediaBox) { if fromResource is CloudFileMediaResource || fromResource is CloudDocumentMediaResource || fromResource is SecretFileMediaResource { mediaBox.copyResourceData(from: fromResource.id, to: toResource.id) + } else if let fromResource = fromResource as? LocalFileMediaResource, fromResource.isSecretRelated { + mediaBox.copyResourceData(from: fromResource.id, to: toResource.id) } else { mediaBox.moveResourceData(from: fromResource.id, to: toResource.id) } diff --git a/submodules/TelegramCore/Sources/CallSessionManager.swift b/submodules/TelegramCore/Sources/CallSessionManager.swift index 17d0cdde8f..dae749103b 100644 --- a/submodules/TelegramCore/Sources/CallSessionManager.swift +++ b/submodules/TelegramCore/Sources/CallSessionManager.swift @@ -179,8 +179,14 @@ public enum CallSessionState { } public struct CallSession { + public enum CallType { + case audio + case video + } + public let id: CallSessionInternalId public let isOutgoing: Bool + public let type: CallType public let state: CallSessionState } @@ -211,6 +217,7 @@ private func parseConnectionSet(primary: Api.PhoneConnection, alternative: [Api. private final class CallSessionContext { let peerId: PeerId let isOutgoing: Bool + let type: CallSession.CallType var state: CallSessionInternalState let subscribers = Bag<(CallSession) -> Void>() let signalingSubscribers = Bag<(Data) -> Void>() @@ -227,9 +234,10 @@ private final class CallSessionContext { } } - init(peerId: PeerId, isOutgoing: Bool, state: CallSessionInternalState) { + init(peerId: PeerId, isOutgoing: Bool, type: CallSession.CallType, state: CallSessionInternalState) { self.peerId = peerId self.isOutgoing = isOutgoing + self.type = type self.state = state } @@ -311,7 +319,7 @@ private final class CallSessionManagerContext { let index = context.subscribers.add { next in subscriber.putNext(next) } - subscriber.putNext(CallSession(id: internalId, isOutgoing: context.isOutgoing, state: CallSessionState(context))) + subscriber.putNext(CallSession(id: internalId, isOutgoing: context.isOutgoing, type: context.type, state: CallSessionState(context))) disposable.set(ActionDisposable { queue.async { if let strongSelf = self, let context = strongSelf.contexts[internalId] { @@ -372,14 +380,14 @@ private final class CallSessionManagerContext { private func contextUpdated(internalId: CallSessionInternalId) { if let context = self.contexts[internalId] { - let session = CallSession(id: internalId, isOutgoing: context.isOutgoing, state: CallSessionState(context)) + let session = CallSession(id: internalId, isOutgoing: context.isOutgoing, type: context.type, state: CallSessionState(context)) for subscriber in context.subscribers.copyItems() { subscriber(session) } } } - private func addIncoming(peerId: PeerId, stableId: CallSessionStableId, accessHash: Int64, timestamp: Int32, gAHash: Data, versions: [String]) -> CallSessionInternalId? { + private func addIncoming(peerId: PeerId, stableId: CallSessionStableId, accessHash: Int64, timestamp: Int32, gAHash: Data, versions: [String], isVideo: Bool) -> CallSessionInternalId? { if self.contextIdByStableId[stableId] != nil { return nil } @@ -390,7 +398,7 @@ private final class CallSessionManagerContext { if randomStatus == 0 { let internalId = CallSessionInternalId() - let context = CallSessionContext(peerId: peerId, isOutgoing: false, state: .ringing(id: stableId, accessHash: accessHash, gAHash: gAHash, b: b, versions: versions)) + let context = CallSessionContext(peerId: peerId, isOutgoing: false, type: isVideo ? .video : .audio, state: .ringing(id: stableId, accessHash: accessHash, gAHash: gAHash, b: b, versions: versions)) self.contexts[internalId] = context let queue = self.queue context.acknowledgeIncomingCallDisposable.set(self.network.request(Api.functions.phone.receivedCall(peer: .inputPhoneCall(id: stableId, accessHash: accessHash))).start(error: { [weak self] _ in @@ -414,6 +422,7 @@ private final class CallSessionManagerContext { if let context = self.contexts[internalId] { var dropData: (CallSessionStableId, Int64, DropCallSessionReason)? var wasRinging = false + let isVideo = context.type == .video switch context.state { case let .ringing(id, accessHash, _, _, _): wasRinging = true @@ -471,7 +480,7 @@ private final class CallSessionManagerContext { if let (id, accessHash, reason) = dropData { self.contextIdByStableId.removeValue(forKey: id) - context.state = .dropping((dropCallSession(network: self.network, addUpdates: self.addUpdates, stableId: id, accessHash: accessHash, reason: reason) + context.state = .dropping((dropCallSession(network: self.network, addUpdates: self.addUpdates, stableId: id, accessHash: accessHash, isVideo: isVideo, reason: reason) |> deliverOn(self.queue)).start(next: { [weak self] reportRating, sendDebugLogs in if let strongSelf = self { if let context = strongSelf.contexts[internalId] { @@ -722,13 +731,14 @@ private final class CallSessionManagerContext { } } case let .phoneCallRequested(flags, id, accessHash, date, adminId, _, gAHash, requestedProtocol): + let isVideo = (flags & (1 << 5)) != 0 let versions: [String] switch requestedProtocol { case let .phoneCallProtocol(_, _, _, libraryVersions): versions = libraryVersions } if self.contextIdByStableId[id] == nil { - let internalId = self.addIncoming(peerId: PeerId(namespace: Namespaces.Peer.CloudUser, id: adminId), stableId: id, accessHash: accessHash, timestamp: date, gAHash: gAHash.makeData(), versions: versions) + let internalId = self.addIncoming(peerId: PeerId(namespace: Namespaces.Peer.CloudUser, id: adminId), stableId: id, accessHash: accessHash, timestamp: date, gAHash: gAHash.makeData(), versions: versions, isVideo: isVideo) if let internalId = internalId { var resultRingingStateValue: CallSessionRingingState? for ringingState in self.ringingStatesValue() { @@ -738,7 +748,7 @@ private final class CallSessionManagerContext { } } if let context = self.contexts[internalId] { - let callSession = CallSession(id: internalId, isOutgoing: context.isOutgoing, state: CallSessionState(context)) + let callSession = CallSession(id: internalId, isOutgoing: context.isOutgoing, type: context.type, state: CallSessionState(context)) if let resultRingingStateValue = resultRingingStateValue { resultRingingState = (resultRingingStateValue, callSession) } @@ -802,12 +812,12 @@ private final class CallSessionManagerContext { return (key, keyId, keyVisualHash) } - func request(peerId: PeerId, internalId: CallSessionInternalId) -> CallSessionInternalId? { + func request(peerId: PeerId, internalId: CallSessionInternalId, isVideo: Bool) -> CallSessionInternalId? { let aBytes = malloc(256)! let randomStatus = SecRandomCopyBytes(nil, 256, aBytes.assumingMemoryBound(to: UInt8.self)) let a = Data(bytesNoCopy: aBytes, count: 256, deallocator: .free) if randomStatus == 0 { - self.contexts[internalId] = CallSessionContext(peerId: peerId, isOutgoing: true, state: .requesting(a: a, disposable: (requestCallSession(postbox: self.postbox, network: self.network, peerId: peerId, a: a, maxLayer: self.maxLayer, versions: self.versions) |> deliverOn(queue)).start(next: { [weak self] result in + self.contexts[internalId] = CallSessionContext(peerId: peerId, isOutgoing: true, type: isVideo ? .video : .audio, state: .requesting(a: a, disposable: (requestCallSession(postbox: self.postbox, network: self.network, peerId: peerId, a: a, maxLayer: self.maxLayer, versions: self.versions, isVideo: isVideo) |> deliverOn(queue)).start(next: { [weak self] result in if let strongSelf = self, let context = strongSelf.contexts[internalId] { if case .requesting = context.state { switch result { @@ -900,12 +910,12 @@ public final class CallSessionManager { } } - public func request(peerId: PeerId, internalId: CallSessionInternalId = CallSessionInternalId()) -> Signal { + public func request(peerId: PeerId, isVideo: Bool, internalId: CallSessionInternalId = CallSessionInternalId()) -> Signal { return Signal { [weak self] subscriber in let disposable = MetaDisposable() self?.withContext { context in - if let internalId = context.request(peerId: peerId, internalId: internalId) { + if let internalId = context.request(peerId: peerId, internalId: internalId, isVideo: isVideo) { subscriber.putNext(internalId) subscriber.putCompletion() } @@ -1040,7 +1050,7 @@ private enum RequestCallSessionResult { case failed(CallSessionError) } -private func requestCallSession(postbox: Postbox, network: Network, peerId: PeerId, a: Data, maxLayer: Int32, versions: [String]) -> Signal { +private func requestCallSession(postbox: Postbox, network: Network, peerId: PeerId, a: Data, maxLayer: Int32, versions: [String], isVideo: Bool) -> Signal { return validatedEncryptionConfig(postbox: postbox, network: network) |> mapToSignal { config -> Signal in return postbox.transaction { transaction -> Signal in @@ -1056,12 +1066,17 @@ private func requestCallSession(postbox: Postbox, network: Network, peerId: Peer let gAHash = MTSha256(ga)! - return network.request(Api.functions.phone.requestCall(flags: 0, userId: inputUser, randomId: Int32(bitPattern: arc4random()), gAHash: Buffer(data: gAHash), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) + var callFlags: Int32 = 0 + if isVideo { + callFlags |= 1 << 0 + } + + return network.request(Api.functions.phone.requestCall(flags: callFlags, userId: inputUser, randomId: Int32(bitPattern: arc4random()), gAHash: Buffer(data: gAHash), protocol: .phoneCallProtocol(flags: (1 << 0) | (1 << 1), minLayer: minLayer, maxLayer: maxLayer, libraryVersions: versions))) |> map { result -> RequestCallSessionResult in switch result { case let .phoneCall(phoneCall, _): switch phoneCall { - case let .phoneCallRequested(flags, id, accessHash, _, _, _, _, _): + case let .phoneCallRequested(_, id, accessHash, _, _, _, _, _): return .success(id: id, accessHash: accessHash, config: config, gA: ga, remoteConfirmationTimestamp: nil) case let .phoneCallWaiting(_, id, accessHash, _, _, _, _, receiveDate): return .success(id: id, accessHash: accessHash, config: config, gA: ga, remoteConfirmationTimestamp: receiveDate) @@ -1118,7 +1133,7 @@ private enum DropCallSessionReason { case missed } -private func dropCallSession(network: Network, addUpdates: @escaping (Api.Updates) -> Void, stableId: CallSessionStableId, accessHash: Int64, reason: DropCallSessionReason) -> Signal<(Bool, Bool), NoError> { +private func dropCallSession(network: Network, addUpdates: @escaping (Api.Updates) -> Void, stableId: CallSessionStableId, accessHash: Int64, isVideo: Bool, reason: DropCallSessionReason) -> Signal<(Bool, Bool), NoError> { var mappedReason: Api.PhoneCallDiscardReason var duration: Int32 = 0 switch reason { @@ -1134,7 +1149,13 @@ private func dropCallSession(network: Network, addUpdates: @escaping (Api.Update case .missed: mappedReason = .phoneCallDiscardReasonMissed } - return network.request(Api.functions.phone.discardCall(flags: 0, peer: Api.InputPhoneCall.inputPhoneCall(id: stableId, accessHash: accessHash), duration: duration, reason: mappedReason, connectionId: 0)) + + var callFlags: Int32 = 0 + if isVideo { + callFlags |= 1 << 0 + } + + return network.request(Api.functions.phone.discardCall(flags: callFlags, peer: Api.InputPhoneCall.inputPhoneCall(id: stableId, accessHash: accessHash), duration: duration, reason: mappedReason, connectionId: 0)) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) diff --git a/submodules/TelegramCore/Sources/EnqueueMessage.swift b/submodules/TelegramCore/Sources/EnqueueMessage.swift index 0ffa4789d9..b1fc81bf18 100644 --- a/submodules/TelegramCore/Sources/EnqueueMessage.swift +++ b/submodules/TelegramCore/Sources/EnqueueMessage.swift @@ -69,7 +69,7 @@ private func filterMessageAttributesForOutgoingMessage(_ attributes: [MessageAtt case _ as InlineBotMessageAttribute: return true case _ as OutgoingMessageInfoAttribute: - return true + return false case _ as OutgoingContentInfoMessageAttribute: return true case _ as ReplyMarkupMessageAttribute: diff --git a/submodules/TelegramCore/Sources/PeerContactSettings.swift b/submodules/TelegramCore/Sources/PeerContactSettings.swift index 172d30b92b..05f65dfbf0 100644 --- a/submodules/TelegramCore/Sources/PeerContactSettings.swift +++ b/submodules/TelegramCore/Sources/PeerContactSettings.swift @@ -27,6 +27,9 @@ extension PeerStatusSettings { if (flags & (1 << 5)) != 0 { result.insert(.canReportIrrelevantGeoLocation) } + if (flags & (1 << 7)) != 0 { + result.insert(.autoArchived) + } self = PeerStatusSettings(flags: result, geoDistance: geoDistance) } } diff --git a/submodules/TelegramCore/Sources/PeerStatistics.swift b/submodules/TelegramCore/Sources/PeerStatistics.swift index a81408a37b..5c5e427fb1 100644 --- a/submodules/TelegramCore/Sources/PeerStatistics.swift +++ b/submodules/TelegramCore/Sources/PeerStatistics.swift @@ -198,10 +198,10 @@ private func requestChannelStats(postbox: Postbox, network: Network, datacenterI signal = network.download(datacenterId: Int(datacenterId), isMedia: false, tag: nil) |> castError(MTRpcError.self) |> mapToSignal { worker in - return worker.request(Api.functions.stats.getBroadcastStats(flags: flags, channel: inputChannel)) + return worker.request(Api.functions.stats.getBroadcastStats(flags: flags, channel: inputChannel, tzOffset: 0)) } } else { - signal = network.request(Api.functions.stats.getBroadcastStats(flags: flags, channel: inputChannel)) + signal = network.request(Api.functions.stats.getBroadcastStats(flags: flags, channel: inputChannel, tzOffset: 0)) } return signal diff --git a/submodules/TelegramCore/Sources/PendingMessageUploadedContent.swift b/submodules/TelegramCore/Sources/PendingMessageUploadedContent.swift index 6d248bfa43..16b490b314 100644 --- a/submodules/TelegramCore/Sources/PendingMessageUploadedContent.swift +++ b/submodules/TelegramCore/Sources/PendingMessageUploadedContent.swift @@ -662,7 +662,7 @@ private func uploadedMediaFileContent(network: Network, postbox: Postbox, auxili return .single(.pending) case let .done(media): if let media = media as? TelegramMediaFile, let smallestThumbnail = smallestImageRepresentation(media.previewRepresentations) { - if peerId.namespace == Namespaces.Peer.SecretChat || (smallestThumbnail.resource is LocalFileMediaResource) { + if peerId.namespace == Namespaces.Peer.SecretChat { return .single(.done(media, .none)) } else { let fileReference: AnyMediaReference diff --git a/submodules/TelegramCore/Sources/PrivacySettings.swift b/submodules/TelegramCore/Sources/PrivacySettings.swift index 4bff7cb91f..0ad2eade68 100644 --- a/submodules/TelegramCore/Sources/PrivacySettings.swift +++ b/submodules/TelegramCore/Sources/PrivacySettings.swift @@ -95,9 +95,10 @@ public struct AccountPrivacySettings: Equatable { public let phoneNumber: SelectivePrivacySettings public let phoneDiscoveryEnabled: Bool + public let automaticallyArchiveAndMuteNonContacts: Bool public let accountRemovalTimeout: Int32 - public init(presence: SelectivePrivacySettings, groupInvitations: SelectivePrivacySettings, voiceCalls: SelectivePrivacySettings, voiceCallsP2P: SelectivePrivacySettings, profilePhoto: SelectivePrivacySettings, forwards: SelectivePrivacySettings, phoneNumber: SelectivePrivacySettings, phoneDiscoveryEnabled: Bool, accountRemovalTimeout: Int32) { + public init(presence: SelectivePrivacySettings, groupInvitations: SelectivePrivacySettings, voiceCalls: SelectivePrivacySettings, voiceCallsP2P: SelectivePrivacySettings, profilePhoto: SelectivePrivacySettings, forwards: SelectivePrivacySettings, phoneNumber: SelectivePrivacySettings, phoneDiscoveryEnabled: Bool, automaticallyArchiveAndMuteNonContacts: Bool, accountRemovalTimeout: Int32) { self.presence = presence self.groupInvitations = groupInvitations self.voiceCalls = voiceCalls @@ -106,6 +107,7 @@ public struct AccountPrivacySettings: Equatable { self.forwards = forwards self.phoneNumber = phoneNumber self.phoneDiscoveryEnabled = phoneDiscoveryEnabled + self.automaticallyArchiveAndMuteNonContacts = automaticallyArchiveAndMuteNonContacts self.accountRemovalTimeout = accountRemovalTimeout } @@ -134,6 +136,9 @@ public struct AccountPrivacySettings: Equatable { if lhs.phoneDiscoveryEnabled != rhs.phoneDiscoveryEnabled { return false } + if lhs.automaticallyArchiveAndMuteNonContacts != rhs.automaticallyArchiveAndMuteNonContacts { + return false + } if lhs.accountRemovalTimeout != rhs.accountRemovalTimeout { return false } diff --git a/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift b/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift index fff2ce294f..bf81ce4d04 100644 --- a/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift +++ b/submodules/TelegramCore/Sources/StoreMessage_Telegram.swift @@ -75,7 +75,7 @@ public func tagsForStoreMessage(incoming: Bool, attributes: [MessageAttribute], tags.insert(.webPage) } else if let action = attachment as? TelegramMediaAction { switch action.action { - case let .phoneCall(_, discardReason, _): + case let .phoneCall(_, discardReason, _, _): globalTags.insert(.Calls) if incoming, let discardReason = discardReason, case .missed = discardReason { globalTags.insert(.MissedCalls) diff --git a/submodules/TelegramCore/Sources/TelegramMediaAction.swift b/submodules/TelegramCore/Sources/TelegramMediaAction.swift index e089045f3a..e16fb9002d 100644 --- a/submodules/TelegramCore/Sources/TelegramMediaAction.swift +++ b/submodules/TelegramCore/Sources/TelegramMediaAction.swift @@ -32,12 +32,13 @@ func telegramMediaActionFromApiAction(_ action: Api.MessageAction) -> TelegramMe return TelegramMediaAction(action: .pinnedMessageUpdated) case let .messageActionGameScore(gameId, score): return TelegramMediaAction(action: .gameScore(gameId: gameId, score: score)) - case let .messageActionPhoneCall(_, callId, reason, duration): + case let .messageActionPhoneCall(flags, callId, reason, duration): var discardReason: PhoneCallDiscardReason? if let reason = reason { discardReason = PhoneCallDiscardReason(apiReason: reason) } - return TelegramMediaAction(action: .phoneCall(callId: callId, discardReason: discardReason, duration: duration)) + let isVideo = (flags & (1 << 2)) != 0 + return TelegramMediaAction(action: .phoneCall(callId: callId, discardReason: discardReason, duration: duration, isVideo: isVideo)) case .messageActionEmpty: return nil case let .messageActionPaymentSent(currency, totalAmount): diff --git a/submodules/TelegramCore/Sources/UpdatedAccountPrivacySettings.swift b/submodules/TelegramCore/Sources/UpdatedAccountPrivacySettings.swift index 055ca31218..0f8c5b47a6 100644 --- a/submodules/TelegramCore/Sources/UpdatedAccountPrivacySettings.swift +++ b/submodules/TelegramCore/Sources/UpdatedAccountPrivacySettings.swift @@ -15,11 +15,12 @@ public func requestAccountPrivacySettings(account: Account) -> Signal `catch` { _ in return .complete() } - |> mapToSignal { lastSeenPrivacy, groupPrivacy, voiceCallPrivacy, voiceCallP2P, profilePhotoPrivacy, forwardPrivacy, phoneNumberPrivacy, phoneDiscoveryPrivacy, autoremoveTimeout -> Signal in + |> mapToSignal { lastSeenPrivacy, groupPrivacy, voiceCallPrivacy, voiceCallP2P, profilePhotoPrivacy, forwardPrivacy, phoneNumberPrivacy, phoneDiscoveryPrivacy, autoremoveTimeout, globalPrivacySettings -> Signal in let accountTimeoutSeconds: Int32 switch autoremoveTimeout { case let .accountDaysTTL(days): @@ -119,16 +120,35 @@ public func requestAccountPrivacySettings(account: Account) -> Signal AccountPrivacySettings in updatePeers(transaction: transaction, peers: peers.map { $0.peer }, update: { _, updated in return updated }) - return AccountPrivacySettings(presence: SelectivePrivacySettings(apiRules: lastSeenRules, peers: peerMap), groupInvitations: SelectivePrivacySettings(apiRules: groupRules, peers: peerMap), voiceCalls: SelectivePrivacySettings(apiRules: voiceRules, peers: peerMap), voiceCallsP2P: SelectivePrivacySettings(apiRules: voiceP2PRules, peers: peerMap), profilePhoto: SelectivePrivacySettings(apiRules: profilePhotoRules, peers: peerMap), forwards: SelectivePrivacySettings(apiRules: forwardRules, peers: peerMap), phoneNumber: SelectivePrivacySettings(apiRules: phoneNumberRules, peers: peerMap), phoneDiscoveryEnabled: phoneDiscoveryValue, accountRemovalTimeout: accountTimeoutSeconds) + return AccountPrivacySettings(presence: SelectivePrivacySettings(apiRules: lastSeenRules, peers: peerMap), groupInvitations: SelectivePrivacySettings(apiRules: groupRules, peers: peerMap), voiceCalls: SelectivePrivacySettings(apiRules: voiceRules, peers: peerMap), voiceCallsP2P: SelectivePrivacySettings(apiRules: voiceP2PRules, peers: peerMap), profilePhoto: SelectivePrivacySettings(apiRules: profilePhotoRules, peers: peerMap), forwards: SelectivePrivacySettings(apiRules: forwardRules, peers: peerMap), phoneNumber: SelectivePrivacySettings(apiRules: phoneNumberRules, peers: peerMap), phoneDiscoveryEnabled: phoneDiscoveryValue, automaticallyArchiveAndMuteNonContacts: automaticallyArchiveAndMuteNonContacts, accountRemovalTimeout: accountTimeoutSeconds) } } } +public func updateAccountAutoArchiveChats(account: Account, value: Bool) -> Signal { + + return account.network.request(Api.functions.account.setGlobalPrivacySettings( + settings: .globalPrivacySettings(flags: 1 << 0, archiveAndMuteNewNoncontactPeers: value ? .boolTrue : .boolFalse) + )) + |> retryRequest + |> ignoreValues +} + public func updateAccountRemovalTimeout(account: Account, timeout: Int32) -> Signal { return account.network.request(Api.functions.account.setAccountTTL(ttl: .accountDaysTTL(days: timeout / (24 * 60 * 60)))) |> retryRequest diff --git a/submodules/TelegramPresentationData/Sources/ComponentsThemes.swift b/submodules/TelegramPresentationData/Sources/ComponentsThemes.swift index 075fa1a452..70e63b132c 100644 --- a/submodules/TelegramPresentationData/Sources/ComponentsThemes.swift +++ b/submodules/TelegramPresentationData/Sources/ComponentsThemes.swift @@ -45,9 +45,9 @@ public extension TabBarControllerTheme { } public extension NavigationBarTheme { - convenience init(rootControllerTheme: PresentationTheme) { + convenience init(rootControllerTheme: PresentationTheme, hideBackground: Bool = false) { let theme = rootControllerTheme.rootController.navigationBar - self.init(buttonColor: theme.buttonColor, disabledButtonColor: theme.disabledButtonColor, primaryTextColor: theme.primaryTextColor, backgroundColor: theme.backgroundColor, separatorColor: theme.separatorColor, badgeBackgroundColor: theme.badgeBackgroundColor, badgeStrokeColor: theme.badgeStrokeColor, badgeTextColor: theme.badgeTextColor) + self.init(buttonColor: theme.buttonColor, disabledButtonColor: theme.disabledButtonColor, primaryTextColor: theme.primaryTextColor, backgroundColor: hideBackground ? .clear : theme.backgroundColor, separatorColor: hideBackground ? .clear : theme.separatorColor, badgeBackgroundColor: theme.badgeBackgroundColor, badgeStrokeColor: hideBackground ? .clear : theme.badgeStrokeColor, badgeTextColor: theme.badgeTextColor) } } @@ -62,6 +62,10 @@ public extension NavigationBarPresentationData { self.init(theme: NavigationBarTheme(rootControllerTheme: presentationData.theme), strings: NavigationBarStrings(presentationStrings: presentationData.strings)) } + convenience init(presentationData: PresentationData, hideBackground: Bool) { + self.init(theme: NavigationBarTheme(rootControllerTheme: presentationData.theme, hideBackground: hideBackground), strings: NavigationBarStrings(presentationStrings: presentationData.strings)) + } + convenience init(presentationTheme: PresentationTheme, presentationStrings: PresentationStrings) { self.init(theme: NavigationBarTheme(rootControllerTheme: presentationTheme), strings: NavigationBarStrings(presentationStrings: presentationStrings)) } diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 3e5e3372f5..69e375e5ee 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -268,5332 +268,5341 @@ public final class PresentationStrings: Equatable { public var Channel_AdminLog_InfoPanelTitle: String { return self._s[82]! } public var Conversation_OpenFile: String { return self._s[84]! } public var SecretTimer_ImageDescription: String { return self._s[85]! } - public var StickerSettings_ContextInfo: String { return self._s[86]! } - public var TwoStepAuth_GenericHelp: String { return self._s[88]! } - public var AutoDownloadSettings_Unlimited: String { return self._s[89]! } - public var PrivacyLastSeenSettings_NeverShareWith_Title: String { return self._s[90]! } - public var AutoDownloadSettings_DataUsageHigh: String { return self._s[91]! } + public var PrivacySettings_AutoArchive: String { return self._s[86]! } + public var StickerSettings_ContextInfo: String { return self._s[87]! } + public var TwoStepAuth_GenericHelp: String { return self._s[89]! } + public var AutoDownloadSettings_Unlimited: String { return self._s[90]! } + public var PrivacyLastSeenSettings_NeverShareWith_Title: String { return self._s[91]! } + public var AutoDownloadSettings_DataUsageHigh: String { return self._s[92]! } public func PUSH_CHAT_MESSAGE_VIDEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[92]!, self._r[92]!, [_1, _2]) + return formatWithArgumentRanges(self._s[93]!, self._r[93]!, [_1, _2]) } - public var AuthSessions_AddDevice_ScanInfo: String { return self._s[93]! } - public var Notifications_AddExceptionTitle: String { return self._s[94]! } - public var Watch_MessageView_Reply: String { return self._s[95]! } - public var Tour_Text6: String { return self._s[96]! } - public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[97]! } + public var AuthSessions_AddDevice_ScanInfo: String { return self._s[94]! } + public var Notifications_AddExceptionTitle: String { return self._s[95]! } + public var Watch_MessageView_Reply: String { return self._s[96]! } + public var Tour_Text6: String { return self._s[97]! } + public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[98]! } public func Notification_PinnedAnimationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[98]!, self._r[98]!, [_0]) - } - public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[99]!, self._r[99]!, [_0]) } - public var Wallet_Configuration_BlockchainIdPlaceholder: String { return self._s[100]! } - public var AccessDenied_LocationDenied: String { return self._s[101]! } - public var CallSettings_RecentCalls: String { return self._s[102]! } - public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[103]! } - public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[105]! } - public var Passport_Authorize: String { return self._s[106]! } - public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[107]! } - public var AutoDownloadSettings_Videos: String { return self._s[108]! } - public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[109]! } - public var Wallet_Info_Send: String { return self._s[110]! } - public var AuthSessions_AddDevice_UrlLoginHint: String { return self._s[111]! } - public var Wallet_TransactionInfo_SendGrams: String { return self._s[112]! } - public var Tour_StartButton: String { return self._s[113]! } - public var Watch_AppName: String { return self._s[115]! } - public var StickerPack_ErrorNotFound: String { return self._s[116]! } - public var Channel_Info_Subscribers: String { return self._s[117]! } - public func Channel_AdminLog_MessageGroupPreHistoryVisible(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[118]!, self._r[118]!, [_0]) + public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[100]!, self._r[100]!, [_0]) } - public func DialogList_PinLimitError(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Wallet_Configuration_BlockchainIdPlaceholder: String { return self._s[101]! } + public var AccessDenied_LocationDenied: String { return self._s[102]! } + public var CallSettings_RecentCalls: String { return self._s[103]! } + public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[104]! } + public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[106]! } + public var Passport_Authorize: String { return self._s[107]! } + public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[108]! } + public var AutoDownloadSettings_Videos: String { return self._s[109]! } + public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[110]! } + public var Wallet_Info_Send: String { return self._s[111]! } + public var AuthSessions_AddDevice_UrlLoginHint: String { return self._s[112]! } + public var Wallet_TransactionInfo_SendGrams: String { return self._s[113]! } + public var Tour_StartButton: String { return self._s[114]! } + public var Watch_AppName: String { return self._s[116]! } + public var StickerPack_ErrorNotFound: String { return self._s[117]! } + public var Channel_Info_Subscribers: String { return self._s[118]! } + public func Channel_AdminLog_MessageGroupPreHistoryVisible(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[119]!, self._r[119]!, [_0]) } - public var Appearance_RemoveTheme: String { return self._s[120]! } + public func DialogList_PinLimitError(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[120]!, self._r[120]!, [_0]) + } + public var Appearance_RemoveTheme: String { return self._s[121]! } public func Wallet_Info_TransactionBlockchainFee(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[121]!, self._r[121]!, [_0]) + return formatWithArgumentRanges(self._s[122]!, self._r[122]!, [_0]) } - public var Conversation_StopLiveLocation: String { return self._s[124]! } - public var Channel_AdminLogFilter_EventsAll: String { return self._s[125]! } - public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[127]! } - public var Username_LinkCopied: String { return self._s[129]! } - public var GroupRemoved_Title: String { return self._s[130]! } - public var SecretVideo_Title: String { return self._s[131]! } + public var Conversation_StopLiveLocation: String { return self._s[125]! } + public var Channel_AdminLogFilter_EventsAll: String { return self._s[126]! } + public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[128]! } + public var Username_LinkCopied: String { return self._s[130]! } + public var GroupRemoved_Title: String { return self._s[131]! } + public var SecretVideo_Title: String { return self._s[132]! } public func PUSH_PINNED_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[132]!, self._r[132]!, [_1]) + return formatWithArgumentRanges(self._s[133]!, self._r[133]!, [_1]) } - public var AccessDenied_PhotosAndVideos: String { return self._s[133]! } - public var Appearance_ThemePreview_Chat_1_Text: String { return self._s[134]! } + public var AccessDenied_PhotosAndVideos: String { return self._s[134]! } + public var Appearance_ThemePreview_Chat_1_Text: String { return self._s[135]! } public func PUSH_CHANNEL_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[136]!, self._r[136]!, [_1]) + return formatWithArgumentRanges(self._s[137]!, self._r[137]!, [_1]) } - public var Map_OpenInGoogleMaps: String { return self._s[138]! } + public var Map_OpenInGoogleMaps: String { return self._s[139]! } public func Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[139]!, self._r[139]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[140]!, self._r[140]!, [_1, _2, _3]) } public func Channel_AdminLog_MessageKickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[140]!, self._r[140]!, [_1, _2]) + return formatWithArgumentRanges(self._s[141]!, self._r[141]!, [_1, _2]) } - public var Call_StatusRinging: String { return self._s[141]! } - public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[142]! } - public var Group_Username_InvalidStartsWithNumber: String { return self._s[143]! } - public var UserInfo_NotificationsEnabled: String { return self._s[144]! } - public var PeopleNearby_MakeVisibleDescription: String { return self._s[145]! } - public var ChatListFolder_CategoryRead: String { return self._s[146]! } - public var Map_Search: String { return self._s[147]! } - public var ClearCache_StorageFree: String { return self._s[149]! } - public var Login_TermsOfServiceHeader: String { return self._s[150]! } + public var Call_StatusRinging: String { return self._s[142]! } + public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[143]! } + public var Group_Username_InvalidStartsWithNumber: String { return self._s[144]! } + public var UserInfo_NotificationsEnabled: String { return self._s[145]! } + public var PeopleNearby_MakeVisibleDescription: String { return self._s[146]! } + public var ChatListFolder_CategoryRead: String { return self._s[147]! } + public var Map_Search: String { return self._s[148]! } + public var ClearCache_StorageFree: String { return self._s[150]! } + public var Login_TermsOfServiceHeader: String { return self._s[151]! } public func Notification_PinnedVideoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[151]!, self._r[151]!, [_0]) + return formatWithArgumentRanges(self._s[152]!, self._r[152]!, [_0]) } public func Channel_AdminLog_MessageToggleSignaturesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[153]!, self._r[153]!, [_0]) + return formatWithArgumentRanges(self._s[154]!, self._r[154]!, [_0]) } - public var ChatList_GenericPsaAlert: String { return self._s[154]! } - public var Wallet_Sent_Title: String { return self._s[155]! } - public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[156]! } - public var Weekday_Today: String { return self._s[157]! } - public var Stats_InstantViewInteractionsTitle: String { return self._s[158]! } + public var ChatList_GenericPsaAlert: String { return self._s[155]! } + public var Wallet_Sent_Title: String { return self._s[156]! } + public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[157]! } + public var Weekday_Today: String { return self._s[158]! } + public var Stats_InstantViewInteractionsTitle: String { return self._s[159]! } public func InstantPage_AuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[160]!, self._r[160]!, [_1, _2]) + return formatWithArgumentRanges(self._s[161]!, self._r[161]!, [_1, _2]) } public func Conversation_MessageDialogRetryAll(_ _1: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[161]!, self._r[161]!, ["\(_1)"]) + return formatWithArgumentRanges(self._s[162]!, self._r[162]!, ["\(_1)"]) } - public var Notification_PassportValuePersonalDetails: String { return self._s[163]! } - public var Channel_AdminLog_MessagePreviousLink: String { return self._s[164]! } - public var ChangePhoneNumberNumber_NewNumber: String { return self._s[165]! } - public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[166]! } - public var TwoStepAuth_ChangePasswordDescription: String { return self._s[167]! } - public var PhotoEditor_BlurToolLinear: String { return self._s[168]! } - public var Contacts_PermissionsAllowInSettings: String { return self._s[169]! } - public var Weekday_ShortMonday: String { return self._s[170]! } - public var Cache_KeepMedia: String { return self._s[171]! } - public var Passport_FieldIdentitySelfieHelp: String { return self._s[172]! } + public var Notification_PassportValuePersonalDetails: String { return self._s[164]! } + public var Channel_AdminLog_MessagePreviousLink: String { return self._s[165]! } + public var ChangePhoneNumberNumber_NewNumber: String { return self._s[166]! } + public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[167]! } + public var TwoStepAuth_ChangePasswordDescription: String { return self._s[168]! } + public var PhotoEditor_BlurToolLinear: String { return self._s[169]! } + public var Contacts_PermissionsAllowInSettings: String { return self._s[170]! } + public var Weekday_ShortMonday: String { return self._s[171]! } + public var Cache_KeepMedia: String { return self._s[172]! } + public var Passport_FieldIdentitySelfieHelp: String { return self._s[173]! } public func PUSH_PINNED_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[173]!, self._r[173]!, [_1, _2]) + return formatWithArgumentRanges(self._s[174]!, self._r[174]!, [_1, _2]) } public func Chat_SlowmodeTooltip(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[174]!, self._r[174]!, [_0]) + return formatWithArgumentRanges(self._s[175]!, self._r[175]!, [_0]) } - public var Wallet_Receive_ShareUrlInfo: String { return self._s[175]! } - public var Conversation_ClousStorageInfo_Description4: String { return self._s[176]! } - public var Wallet_RestoreFailed_Title: String { return self._s[177]! } - public var Passport_Language_ru: String { return self._s[178]! } + public var Wallet_Receive_ShareUrlInfo: String { return self._s[176]! } + public var Conversation_ClousStorageInfo_Description4: String { return self._s[177]! } + public var Wallet_RestoreFailed_Title: String { return self._s[178]! } + public var Passport_Language_ru: String { return self._s[179]! } public func Notification_CreatedChatWithTitle(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[179]!, self._r[179]!, [_0, _1]) + return formatWithArgumentRanges(self._s[180]!, self._r[180]!, [_0, _1]) } - public var WallpaperPreview_PatternIntensity: String { return self._s[180]! } - public var ChatList_EditFolder: String { return self._s[183]! } - public var WebBrowser_InAppSafari: String { return self._s[184]! } - public var TwoStepAuth_RecoveryUnavailable: String { return self._s[185]! } - public var EnterPasscode_TouchId: String { return self._s[186]! } - public var PhotoEditor_QualityVeryHigh: String { return self._s[189]! } - public var Checkout_NewCard_SaveInfo: String { return self._s[191]! } - public var Gif_NoGifsPlaceholder: String { return self._s[193]! } + public var WallpaperPreview_PatternIntensity: String { return self._s[181]! } + public var ChatList_EditFolder: String { return self._s[184]! } + public var WebBrowser_InAppSafari: String { return self._s[185]! } + public var TwoStepAuth_RecoveryUnavailable: String { return self._s[186]! } + public var EnterPasscode_TouchId: String { return self._s[187]! } + public var PhotoEditor_QualityVeryHigh: String { return self._s[190]! } + public var Checkout_NewCard_SaveInfo: String { return self._s[192]! } + public var Gif_NoGifsPlaceholder: String { return self._s[194]! } public func Notification_InvitedMultiple(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[195]!, self._r[195]!, [_0, _1]) + return formatWithArgumentRanges(self._s[196]!, self._r[196]!, [_0, _1]) } - public var ChatSettings_AutoDownloadEnabled: String { return self._s[196]! } - public var NetworkUsageSettings_BytesSent: String { return self._s[197]! } - public var Checkout_PasswordEntry_Pay: String { return self._s[198]! } - public var AuthSessions_TerminateSession: String { return self._s[199]! } - public var Message_File: String { return self._s[200]! } - public var MediaPicker_VideoMuteDescription: String { return self._s[201]! } - public var SocksProxySetup_ProxyStatusConnected: String { return self._s[202]! } - public var TwoStepAuth_RecoveryCode: String { return self._s[203]! } - public var EnterPasscode_EnterCurrentPasscode: String { return self._s[204]! } + public var ChatSettings_AutoDownloadEnabled: String { return self._s[197]! } + public var NetworkUsageSettings_BytesSent: String { return self._s[198]! } + public var Checkout_PasswordEntry_Pay: String { return self._s[199]! } + public var AuthSessions_TerminateSession: String { return self._s[200]! } + public var Message_File: String { return self._s[201]! } + public var MediaPicker_VideoMuteDescription: String { return self._s[202]! } + public var SocksProxySetup_ProxyStatusConnected: String { return self._s[203]! } + public var TwoStepAuth_RecoveryCode: String { return self._s[204]! } + public var EnterPasscode_EnterCurrentPasscode: String { return self._s[205]! } public func TwoStepAuth_EnterPasswordHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[205]!, self._r[205]!, [_0]) + return formatWithArgumentRanges(self._s[206]!, self._r[206]!, [_0]) } - public var Conversation_Moderate_Report: String { return self._s[207]! } - public var TwoStepAuth_EmailInvalid: String { return self._s[208]! } - public var Passport_Language_ms: String { return self._s[209]! } - public var Channel_Edit_AboutItem: String { return self._s[211]! } - public var DialogList_SearchSectionGlobal: String { return self._s[215]! } - public var AttachmentMenu_WebSearch: String { return self._s[216]! } - public var ChatState_WaitingForNetwork: String { return self._s[217]! } - public var Channel_BanUser_Title: String { return self._s[218]! } - public var PasscodeSettings_TurnPasscodeOn: String { return self._s[219]! } - public var WallpaperPreview_SwipeTopText: String { return self._s[220]! } - public var ChatList_DeleteSavedMessagesConfirmationText: String { return self._s[221]! } - public var ArchivedChats_IntroText2: String { return self._s[222]! } - public var ChatSearch_SearchPlaceholder: String { return self._s[224]! } - public var Conversation_OpenBotLinkTitle: String { return self._s[225]! } - public var Passport_FieldAddressTranslationHelp: String { return self._s[226]! } - public var NotificationsSound_Aurora: String { return self._s[227]! } - public var Notification_Exceptions_DeleteAll: String { return self._s[228]! } + public var Conversation_Moderate_Report: String { return self._s[208]! } + public var TwoStepAuth_EmailInvalid: String { return self._s[209]! } + public var Passport_Language_ms: String { return self._s[210]! } + public var Channel_Edit_AboutItem: String { return self._s[212]! } + public var DialogList_SearchSectionGlobal: String { return self._s[216]! } + public var AttachmentMenu_WebSearch: String { return self._s[217]! } + public var ChatState_WaitingForNetwork: String { return self._s[218]! } + public var Channel_BanUser_Title: String { return self._s[219]! } + public var PasscodeSettings_TurnPasscodeOn: String { return self._s[220]! } + public var WallpaperPreview_SwipeTopText: String { return self._s[221]! } + public var ChatList_DeleteSavedMessagesConfirmationText: String { return self._s[222]! } + public var ArchivedChats_IntroText2: String { return self._s[223]! } + public var ChatSearch_SearchPlaceholder: String { return self._s[225]! } + public var Conversation_OpenBotLinkTitle: String { return self._s[226]! } + public var Passport_FieldAddressTranslationHelp: String { return self._s[227]! } + public var NotificationsSound_Aurora: String { return self._s[228]! } + public var Notification_Exceptions_DeleteAll: String { return self._s[229]! } public func FileSize_GB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[229]!, self._r[229]!, [_0]) + return formatWithArgumentRanges(self._s[230]!, self._r[230]!, [_0]) } - public var AuthSessions_LoggedInWithTelegram: String { return self._s[232]! } + public var AuthSessions_LoggedInWithTelegram: String { return self._s[233]! } public func Privacy_GroupsAndChannels_InviteToGroupError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[233]!, self._r[233]!, [_0, _1]) + return formatWithArgumentRanges(self._s[234]!, self._r[234]!, [_0, _1]) } - public var Passport_PasswordNext: String { return self._s[234]! } - public var Bot_GroupStatusReadsHistory: String { return self._s[235]! } - public var EmptyGroupInfo_Line2: String { return self._s[236]! } + public var Passport_PasswordNext: String { return self._s[235]! } + public var Bot_GroupStatusReadsHistory: String { return self._s[236]! } + public var EmptyGroupInfo_Line2: String { return self._s[237]! } public func Channel_AdminLog_MessageTransferedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[237]!, self._r[237]!, [_1, _2]) + return formatWithArgumentRanges(self._s[238]!, self._r[238]!, [_1, _2]) } - public var VoiceOver_Chat_SeenByRecipients: String { return self._s[238]! } - public var Settings_FAQ_Intro: String { return self._s[241]! } - public var PrivacySettings_PasscodeAndTouchId: String { return self._s[243]! } - public var FeaturedStickerPacks_Title: String { return self._s[244]! } - public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[246]! } - public var Username_Title: String { return self._s[247]! } + public var VoiceOver_Chat_SeenByRecipients: String { return self._s[239]! } + public var Settings_FAQ_Intro: String { return self._s[242]! } + public var PrivacySettings_PasscodeAndTouchId: String { return self._s[244]! } + public var FeaturedStickerPacks_Title: String { return self._s[245]! } + public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[247]! } + public var Username_Title: String { return self._s[248]! } public func Message_StickerText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[248]!, self._r[248]!, [_0]) + return formatWithArgumentRanges(self._s[249]!, self._r[249]!, [_0]) } - public var PeerInfo_PaneFiles: String { return self._s[249]! } - public var PasscodeSettings_AlphanumericCode: String { return self._s[250]! } - public var Localization_LanguageOther: String { return self._s[251]! } - public var Stickers_SuggestStickers: String { return self._s[252]! } + public var PeerInfo_PaneFiles: String { return self._s[250]! } + public var PasscodeSettings_AlphanumericCode: String { return self._s[251]! } + public var Localization_LanguageOther: String { return self._s[252]! } + public var Stickers_SuggestStickers: String { return self._s[253]! } public func Channel_AdminLog_MessageRemovedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[253]!, self._r[253]!, [_0]) + return formatWithArgumentRanges(self._s[254]!, self._r[254]!, [_0]) } - public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[254]! } - public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[255]! } - public var Conversation_DefaultRestrictedStickers: String { return self._s[256]! } + public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[255]! } + public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[256]! } + public var Conversation_DefaultRestrictedStickers: String { return self._s[257]! } public func Notification_PinnedDeletedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[257]!, self._r[257]!, [_0]) + return formatWithArgumentRanges(self._s[258]!, self._r[258]!, [_0]) } - public var Wallet_TransactionInfo_CopyAddress: String { return self._s[259]! } - public var Group_UpgradeConfirmation: String { return self._s[261]! } - public var DialogList_Unpin: String { return self._s[262]! } - public var Passport_Identity_DateOfBirth: String { return self._s[264]! } - public var Month_ShortOctober: String { return self._s[265]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[266]! } - public var TwoFactorSetup_Done_Text: String { return self._s[267]! } - public var Notification_CallCanceledShort: String { return self._s[268]! } - public var Conversation_StopQuiz: String { return self._s[269]! } - public var Passport_Phone_Help: String { return self._s[270]! } - public var Passport_Language_az: String { return self._s[272]! } - public var CreatePoll_TextPlaceholder: String { return self._s[274]! } - public var VoiceOver_Chat_AnonymousPoll: String { return self._s[275]! } - public var Passport_Identity_DocumentNumber: String { return self._s[276]! } - public var PhotoEditor_CurvesRed: String { return self._s[278]! } - public var PhoneNumberHelp_Alert: String { return self._s[280]! } - public var Stats_GroupTopPostersTitle: String { return self._s[281]! } - public var SocksProxySetup_Port: String { return self._s[282]! } - public var Checkout_PayNone: String { return self._s[283]! } - public var AutoDownloadSettings_WiFi: String { return self._s[284]! } - public var GroupInfo_GroupType: String { return self._s[285]! } - public var StickerSettings_ContextHide: String { return self._s[286]! } - public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[287]! } - public var Group_Setup_HistoryTitle: String { return self._s[289]! } - public var Passport_Identity_FilesUploadNew: String { return self._s[290]! } - public var PasscodeSettings_AutoLock: String { return self._s[291]! } - public var Passport_Title: String { return self._s[292]! } - public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[293]! } - public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[294]! } - public var GroupPermission_NoSendGifs: String { return self._s[295]! } - public var PrivacySettings_PasscodeOn: String { return self._s[296]! } + public var Wallet_TransactionInfo_CopyAddress: String { return self._s[260]! } + public var Group_UpgradeConfirmation: String { return self._s[262]! } + public var DialogList_Unpin: String { return self._s[263]! } + public var Passport_Identity_DateOfBirth: String { return self._s[265]! } + public var Month_ShortOctober: String { return self._s[266]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[267]! } + public var TwoFactorSetup_Done_Text: String { return self._s[268]! } + public var Notification_CallCanceledShort: String { return self._s[269]! } + public var Conversation_StopQuiz: String { return self._s[270]! } + public var Passport_Phone_Help: String { return self._s[271]! } + public var Passport_Language_az: String { return self._s[273]! } + public var CreatePoll_TextPlaceholder: String { return self._s[275]! } + public var VoiceOver_Chat_AnonymousPoll: String { return self._s[276]! } + public var Passport_Identity_DocumentNumber: String { return self._s[277]! } + public var PhotoEditor_CurvesRed: String { return self._s[279]! } + public var PhoneNumberHelp_Alert: String { return self._s[281]! } + public var Stats_GroupTopPostersTitle: String { return self._s[282]! } + public var SocksProxySetup_Port: String { return self._s[283]! } + public var Checkout_PayNone: String { return self._s[284]! } + public var AutoDownloadSettings_WiFi: String { return self._s[285]! } + public var GroupInfo_GroupType: String { return self._s[286]! } + public var StickerSettings_ContextHide: String { return self._s[287]! } + public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[288]! } + public var Group_Setup_HistoryTitle: String { return self._s[290]! } + public var Passport_Identity_FilesUploadNew: String { return self._s[291]! } + public var PasscodeSettings_AutoLock: String { return self._s[292]! } + public var Passport_Title: String { return self._s[293]! } + public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[294]! } + public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[295]! } + public var GroupPermission_NoSendGifs: String { return self._s[296]! } + public var PrivacySettings_PasscodeOn: String { return self._s[297]! } public func Conversation_ScheduleMessage_SendTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[297]!, self._r[297]!, [_0]) + return formatWithArgumentRanges(self._s[298]!, self._r[298]!, [_0]) } - public var ChatList_PeerTypeNonContact: String { return self._s[300]! } - public var State_WaitingForNetwork: String { return self._s[301]! } + public var ChatList_PeerTypeNonContact: String { return self._s[301]! } + public var State_WaitingForNetwork: String { return self._s[302]! } public func Notification_Invited(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[302]!, self._r[302]!, [_0, _1]) + return formatWithArgumentRanges(self._s[303]!, self._r[303]!, [_0, _1]) } - public var Calls_NotNow: String { return self._s[304]! } + public var Calls_NotNow: String { return self._s[305]! } public func Channel_DiscussionGroup_HeaderSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[305]!, self._r[305]!, [_0]) + return formatWithArgumentRanges(self._s[306]!, self._r[306]!, [_0]) } - public var UserInfo_SendMessage: String { return self._s[306]! } - public var PhotoEditor_SelectCoverFrame: String { return self._s[307]! } - public var TwoStepAuth_PasswordSet: String { return self._s[308]! } - public var Passport_DeleteDocument: String { return self._s[309]! } - public var SocksProxySetup_AddProxyTitle: String { return self._s[310]! } + public var UserInfo_SendMessage: String { return self._s[307]! } + public var PhotoEditor_SelectCoverFrame: String { return self._s[308]! } + public var TwoStepAuth_PasswordSet: String { return self._s[309]! } + public var Passport_DeleteDocument: String { return self._s[310]! } + public var SocksProxySetup_AddProxyTitle: String { return self._s[311]! } public func PUSH_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[311]!, self._r[311]!, [_1]) + return formatWithArgumentRanges(self._s[312]!, self._r[312]!, [_1]) } - public var AuthSessions_AddedDeviceTitle: String { return self._s[312]! } - public var GroupRemoved_Remove: String { return self._s[313]! } - public var Passport_FieldIdentity: String { return self._s[314]! } - public var Group_Setup_TypePrivateHelp: String { return self._s[315]! } - public var Conversation_Processing: String { return self._s[318]! } - public var Wallet_Settings_BackupWallet: String { return self._s[320]! } - public var ChatListFolder_NameNonMuted: String { return self._s[321]! } - public var ChatSettings_AutoPlayAnimations: String { return self._s[322]! } - public var AuthSessions_LogOutApplicationsHelp: String { return self._s[325]! } - public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[326]! } - public var Month_GenFebruary: String { return self._s[327]! } - public var ChatListFilter_AddChatsTitle: String { return self._s[328]! } - public var Wallet_Send_NetworkErrorTitle: String { return self._s[329]! } - public var Stats_GroupTopPoster_History: String { return self._s[331]! } + public var AuthSessions_AddedDeviceTitle: String { return self._s[313]! } + public var GroupRemoved_Remove: String { return self._s[314]! } + public var Passport_FieldIdentity: String { return self._s[315]! } + public var Group_Setup_TypePrivateHelp: String { return self._s[316]! } + public var Conversation_Processing: String { return self._s[319]! } + public var Wallet_Settings_BackupWallet: String { return self._s[321]! } + public var ChatListFolder_NameNonMuted: String { return self._s[322]! } + public var ChatSettings_AutoPlayAnimations: String { return self._s[323]! } + public var AuthSessions_LogOutApplicationsHelp: String { return self._s[326]! } + public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[327]! } + public var Month_GenFebruary: String { return self._s[328]! } + public var ChatListFilter_AddChatsTitle: String { return self._s[329]! } + public var Wallet_Send_NetworkErrorTitle: String { return self._s[330]! } + public var Stats_GroupTopPoster_History: String { return self._s[332]! } public func Login_InvalidPhoneEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[332]!, self._r[332]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[333]!, self._r[333]!, [_1, _2, _3, _4, _5]) } - public var Passport_Identity_TypeIdentityCard: String { return self._s[333]! } - public var Wallet_Month_ShortJune: String { return self._s[335]! } - public var AutoDownloadSettings_DataUsageMedium: String { return self._s[336]! } - public var GroupInfo_AddParticipant: String { return self._s[337]! } - public var KeyCommand_SendMessage: String { return self._s[338]! } - public var VoiceOver_Chat_YourContact: String { return self._s[340]! } - public var Map_LiveLocationShowAll: String { return self._s[341]! } - public var WallpaperSearch_ColorOrange: String { return self._s[343]! } - public var Appearance_AppIconDefaultX: String { return self._s[344]! } - public var Checkout_Receipt_Title: String { return self._s[345]! } - public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[346]! } - public var WallpaperPreview_PreviewTopText: String { return self._s[347]! } - public var Message_Contact: String { return self._s[348]! } - public var Call_StatusIncoming: String { return self._s[349]! } - public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[350]! } + public var Passport_Identity_TypeIdentityCard: String { return self._s[334]! } + public var Wallet_Month_ShortJune: String { return self._s[336]! } + public var AutoDownloadSettings_DataUsageMedium: String { return self._s[337]! } + public var GroupInfo_AddParticipant: String { return self._s[338]! } + public var KeyCommand_SendMessage: String { return self._s[339]! } + public var VoiceOver_Chat_YourContact: String { return self._s[341]! } + public var Map_LiveLocationShowAll: String { return self._s[342]! } + public var WallpaperSearch_ColorOrange: String { return self._s[344]! } + public var Appearance_AppIconDefaultX: String { return self._s[345]! } + public var Checkout_Receipt_Title: String { return self._s[346]! } + public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[347]! } + public var WallpaperPreview_PreviewTopText: String { return self._s[348]! } + public var Message_Contact: String { return self._s[349]! } + public var Call_StatusIncoming: String { return self._s[350]! } + public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[351]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[351]!, self._r[351]!, [_1]) + return formatWithArgumentRanges(self._s[352]!, self._r[352]!, [_1]) } public func PUSH_ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[353]!, self._r[353]!, [_1]) + return formatWithArgumentRanges(self._s[354]!, self._r[354]!, [_1]) } - public var VoiceOver_Media_PlaybackRate: String { return self._s[354]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[355]! } - public var Conversation_ViewChannel: String { return self._s[356]! } + public var VoiceOver_Media_PlaybackRate: String { return self._s[355]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[356]! } + public var Conversation_ViewChannel: String { return self._s[357]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[357]!, self._r[357]!, [_0]) + return formatWithArgumentRanges(self._s[358]!, self._r[358]!, [_0]) } - public var Theme_Colors_Accent: String { return self._s[358]! } - public var Paint_Arrow: String { return self._s[359]! } - public var Passport_Language_nl: String { return self._s[361]! } - public var Camera_Retake: String { return self._s[362]! } + public var Theme_Colors_Accent: String { return self._s[359]! } + public var Paint_Arrow: String { return self._s[360]! } + public var Passport_Language_nl: String { return self._s[362]! } + public var Camera_Retake: String { return self._s[363]! } public func UserInfo_BlockActionTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[363]!, self._r[363]!, [_0]) + return formatWithArgumentRanges(self._s[364]!, self._r[364]!, [_0]) } - public var AuthSessions_LogOutApplications: String { return self._s[364]! } - public var ApplyLanguage_ApplySuccess: String { return self._s[365]! } - public var Tour_Title6: String { return self._s[366]! } - public var Map_ChooseAPlace: String { return self._s[367]! } - public var CallSettings_Never: String { return self._s[369]! } + public var AuthSessions_LogOutApplications: String { return self._s[365]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[366]! } + public var Tour_Title6: String { return self._s[367]! } + public var Map_ChooseAPlace: String { return self._s[368]! } + public var CallSettings_Never: String { return self._s[370]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[370]!, self._r[370]!, [_0]) + return formatWithArgumentRanges(self._s[371]!, self._r[371]!, [_0]) } - public var ChannelRemoved_RemoveInfo: String { return self._s[371]! } + public var ChannelRemoved_RemoveInfo: String { return self._s[372]! } public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[372]!, self._r[372]!, [_0]) + return formatWithArgumentRanges(self._s[373]!, self._r[373]!, [_0]) } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[373]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[374]! } public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[374]!, self._r[374]!, [_0]) + return formatWithArgumentRanges(self._s[375]!, self._r[375]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[375]! } + public var GroupInfo_InviteLink_Title: String { return self._s[376]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[376]!, self._r[376]!, [_1, _2]) + return formatWithArgumentRanges(self._s[377]!, self._r[377]!, [_1, _2]) } - public var KeyCommand_ScrollUp: String { return self._s[377]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[378]! } - public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[379]! } + public var KeyCommand_ScrollUp: String { return self._s[378]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[379]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[380]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[380]!, self._r[380]!, [_0]) + return formatWithArgumentRanges(self._s[381]!, self._r[381]!, [_0]) } - public var TwoFactorSetup_Done_Title: String { return self._s[381]! } + public var TwoFactorSetup_Done_Title: String { return self._s[382]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[382]!, self._r[382]!, [_0]) + return formatWithArgumentRanges(self._s[383]!, self._r[383]!, [_0]) } - public var CallFeedback_ReasonDistortedSpeech: String { return self._s[383]! } - public var Watch_LastSeen_WithinAWeek: String { return self._s[384]! } - public var ContactList_Context_SendMessage: String { return self._s[386]! } - public var Weekday_Tuesday: String { return self._s[387]! } - public var Wallet_Created_Title: String { return self._s[389]! } - public var ScheduledMessages_Delete: String { return self._s[390]! } - public var UserInfo_StartSecretChat: String { return self._s[391]! } - public var Passport_Identity_FilesTitle: String { return self._s[392]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[393]! } - public var DialogList_DeleteConversationConfirmation: String { return self._s[395]! } - public var ChatList_UndoArchiveRevealedTitle: String { return self._s[396]! } + public var CallFeedback_ReasonDistortedSpeech: String { return self._s[384]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[385]! } + public var ContactList_Context_SendMessage: String { return self._s[387]! } + public var Weekday_Tuesday: String { return self._s[388]! } + public var Wallet_Created_Title: String { return self._s[390]! } + public var ScheduledMessages_Delete: String { return self._s[391]! } + public var UserInfo_StartSecretChat: String { return self._s[392]! } + public var Passport_Identity_FilesTitle: String { return self._s[393]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[394]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[396]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[397]! } public func Wallet_Configuration_ApplyErrorTextURLUnreachable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[397]!, self._r[397]!, [_0]) + return formatWithArgumentRanges(self._s[398]!, self._r[398]!, [_0]) } - public var AuthSessions_Sessions: String { return self._s[398]! } - public var Conversation_PeerNearbyText: String { return self._s[399]! } + public var AuthSessions_Sessions: String { return self._s[399]! } + public var Conversation_PeerNearbyText: String { return self._s[400]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[402]!, self._r[402]!, [_0]) + return formatWithArgumentRanges(self._s[403]!, self._r[403]!, [_0]) } - public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[403]! } - public var Call_StatusWaiting: String { return self._s[404]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[405]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[406]! } - public var WallpaperPreview_CustomColorBottomText: String { return self._s[407]! } - public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[408]! } - public var LogoutOptions_AddAccountText: String { return self._s[409]! } - public var PasscodeSettings_6DigitCode: String { return self._s[410]! } - public var Settings_LogoutConfirmationText: String { return self._s[411]! } - public var Passport_Identity_TypePassport: String { return self._s[413]! } - public var Map_Work: String { return self._s[416]! } + public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[404]! } + public var Call_StatusWaiting: String { return self._s[405]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[406]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[407]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[408]! } + public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[409]! } + public var LogoutOptions_AddAccountText: String { return self._s[410]! } + public var PasscodeSettings_6DigitCode: String { return self._s[411]! } + public var Settings_LogoutConfirmationText: String { return self._s[412]! } + public var Passport_Identity_TypePassport: String { return self._s[414]! } + public var Map_Work: String { return self._s[417]! } public func PUSH_MESSAGE_VIDEOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[417]!, self._r[417]!, [_1, _2]) + return formatWithArgumentRanges(self._s[418]!, self._r[418]!, [_1, _2]) } - public var SocksProxySetup_SaveProxy: String { return self._s[418]! } - public var AccessDenied_SaveMedia: String { return self._s[419]! } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[421]! } - public var CreatePoll_MultipleChoice: String { return self._s[422]! } - public var Settings_Title: String { return self._s[424]! } - public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[425]! } - public var Contacts_InviteSearchLabel: String { return self._s[427]! } - public var PrivacySettings_WebSessions: String { return self._s[428]! } - public var ConvertToSupergroup_Title: String { return self._s[429]! } + public var SocksProxySetup_SaveProxy: String { return self._s[419]! } + public var AccessDenied_SaveMedia: String { return self._s[420]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[422]! } + public var CreatePoll_MultipleChoice: String { return self._s[423]! } + public var Settings_Title: String { return self._s[425]! } + public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[426]! } + public var Contacts_InviteSearchLabel: String { return self._s[428]! } + public var PrivacySettings_WebSessions: String { return self._s[429]! } + public var ConvertToSupergroup_Title: String { return self._s[430]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[430]!, self._r[430]!, [_0]) + return formatWithArgumentRanges(self._s[431]!, self._r[431]!, [_0]) } - public var TwoFactorSetup_Hint_Text: String { return self._s[431]! } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[432]! } + public var TwoFactorSetup_Hint_Text: String { return self._s[432]! } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[433]! } public func PUSH_MESSAGE_CHANNEL_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[433]!, self._r[433]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[434]!, self._r[434]!, [_1, _2, _3]) } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[434]! } - public var UserInfo_BotHelp: String { return self._s[435]! } - public var PrivacySettings_LastSeenEverybody: String { return self._s[436]! } - public var Checkout_Name: String { return self._s[437]! } - public var AutoDownloadSettings_DataUsage: String { return self._s[438]! } - public var Channel_BanUser_BlockFor: String { return self._s[439]! } - public var Checkout_ShippingAddress: String { return self._s[440]! } - public var AutoDownloadSettings_MaxVideoSize: String { return self._s[441]! } - public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[442]! } - public var Privacy_Forwards: String { return self._s[443]! } - public var Channel_BanUser_PermissionSendPolls: String { return self._s[444]! } - public var Appearance_ThemeCarouselNewNight: String { return self._s[445]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[435]! } + public var UserInfo_BotHelp: String { return self._s[436]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[437]! } + public var Checkout_Name: String { return self._s[438]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[439]! } + public var Channel_BanUser_BlockFor: String { return self._s[440]! } + public var Checkout_ShippingAddress: String { return self._s[441]! } + public var AutoDownloadSettings_MaxVideoSize: String { return self._s[442]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[443]! } + public var Privacy_Forwards: String { return self._s[444]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[445]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[446]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[448]!, self._r[448]!, [_0]) + return formatWithArgumentRanges(self._s[449]!, self._r[449]!, [_0]) } - public var Contacts_SortedByName: String { return self._s[449]! } - public var Group_OwnershipTransfer_Title: String { return self._s[450]! } - public var PeerInfo_BioExpand: String { return self._s[452]! } - public var VoiceOver_Chat_OpenHint: String { return self._s[453]! } - public var Group_LeaveGroup: String { return self._s[454]! } - public var Settings_UsernameEmpty: String { return self._s[455]! } + public var Contacts_SortedByName: String { return self._s[450]! } + public var Group_OwnershipTransfer_Title: String { return self._s[451]! } + public var PeerInfo_BioExpand: String { return self._s[453]! } + public var VoiceOver_Chat_OpenHint: String { return self._s[454]! } + public var Group_LeaveGroup: String { return self._s[455]! } + public var Settings_UsernameEmpty: String { return self._s[456]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[456]!, self._r[456]!, [_0]) + return formatWithArgumentRanges(self._s[457]!, self._r[457]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[457]!, self._r[457]!, [_1]) + return formatWithArgumentRanges(self._s[458]!, self._r[458]!, [_1]) } public func Channel_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[458]!, self._r[458]!, [_1, _2]) + return formatWithArgumentRanges(self._s[459]!, self._r[459]!, [_1, _2]) } - public var Message_ImageExpired: String { return self._s[459]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[461]! } - public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[462]! } - public var UserInfo_AddToExisting: String { return self._s[463]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[464]! } - public var Wallet_Send_SyncInProgress: String { return self._s[465]! } - public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[466]! } - public var ChatListFolder_IncludeSectionInfo: String { return self._s[467]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[468]! } + public var Message_ImageExpired: String { return self._s[460]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[462]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[463]! } + public var UserInfo_AddToExisting: String { return self._s[464]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[465]! } + public var Wallet_Send_SyncInProgress: String { return self._s[466]! } + public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[467]! } + public var ChatListFolder_IncludeSectionInfo: String { return self._s[468]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[469]! } public func PUSH_CHANNEL_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[469]!, self._r[469]!, [_1]) + return formatWithArgumentRanges(self._s[470]!, self._r[470]!, [_1]) } - public var Notifications_GroupNotificationsAlert: String { return self._s[470]! } - public var Passport_Language_km: String { return self._s[471]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[473]! } - public var VoiceOver_Media_PlaybackPlay: String { return self._s[474]! } - public var Notification_CallMissedShort: String { return self._s[475]! } - public var Wallet_Info_YourBalance: String { return self._s[476]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[478]! } - public var Watch_Compose_Send: String { return self._s[479]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[482]! } - public var TwoFactorSetup_Email_Action: String { return self._s[483]! } - public var Conversation_HoldForVideo: String { return self._s[484]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[485]! } - public var AuthSessions_OtherDevices: String { return self._s[486]! } - public var Wallet_TransactionInfo_CommentHeader: String { return self._s[487]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[489]! } - public var Appearance_AutoNightThemeDisabled: String { return self._s[491]! } - public var Channel_LinkItem: String { return self._s[492]! } + public var Notifications_GroupNotificationsAlert: String { return self._s[471]! } + public var Passport_Language_km: String { return self._s[472]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[474]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[475]! } + public var Notification_CallMissedShort: String { return self._s[476]! } + public var Wallet_Info_YourBalance: String { return self._s[477]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[479]! } + public var Watch_Compose_Send: String { return self._s[480]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[483]! } + public var TwoFactorSetup_Email_Action: String { return self._s[484]! } + public var Conversation_HoldForVideo: String { return self._s[485]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[486]! } + public var AuthSessions_OtherDevices: String { return self._s[487]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[488]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[490]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[492]! } + public var Channel_LinkItem: String { return self._s[493]! } public func PrivacySettings_LastSeenContactsMinusPlus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[493]!, self._r[493]!, [_0, _1]) + return formatWithArgumentRanges(self._s[494]!, self._r[494]!, [_0, _1]) } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[496]!, self._r[496]!, [_0]) + return formatWithArgumentRanges(self._s[497]!, self._r[497]!, [_0]) } - public var VoiceOver_Recording_StopAndPreview: String { return self._s[497]! } - public var Passport_Language_dv: String { return self._s[498]! } - public var Undo_LeftChannel: String { return self._s[499]! } - public var Notifications_ExceptionsMuted: String { return self._s[500]! } - public var ChatList_UnhideAction: String { return self._s[501]! } - public var Conversation_ContextMenuShare: String { return self._s[503]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[504]! } - public var ShareFileTip_Title: String { return self._s[505]! } - public var NotificationsSound_Chord: String { return self._s[506]! } - public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[507]! } + public var VoiceOver_Recording_StopAndPreview: String { return self._s[498]! } + public var Passport_Language_dv: String { return self._s[499]! } + public var Undo_LeftChannel: String { return self._s[500]! } + public var Notifications_ExceptionsMuted: String { return self._s[501]! } + public var ChatList_UnhideAction: String { return self._s[502]! } + public var Conversation_ContextMenuShare: String { return self._s[504]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[505]! } + public var ShareFileTip_Title: String { return self._s[506]! } + public var NotificationsSound_Chord: String { return self._s[507]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[508]! } public func PUSH_CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[508]!, self._r[508]!, [_1, _2]) + return formatWithArgumentRanges(self._s[509]!, self._r[509]!, [_1, _2]) } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[509]! } + public var PeerInfo_ButtonVideoCall: String { return self._s[510]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[511]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[510]!, self._r[510]!, [_0]) + return formatWithArgumentRanges(self._s[512]!, self._r[512]!, [_0]) } public func Wallet_Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[511]!, self._r[511]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[513]!, self._r[513]!, [_1, _2, _3]) } - public var Wallet_Settings_ConfigurationInfo: String { return self._s[512]! } - public var Wallpaper_ErrorNotFound: String { return self._s[513]! } - public var Notification_CallOutgoingShort: String { return self._s[515]! } - public var Wallet_WordImport_IncorrectText: String { return self._s[516]! } + public var Wallet_Settings_ConfigurationInfo: String { return self._s[514]! } + public var Wallpaper_ErrorNotFound: String { return self._s[515]! } + public var Notification_CallOutgoingShort: String { return self._s[517]! } + public var Wallet_WordImport_IncorrectText: String { return self._s[518]! } public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[517]!, self._r[517]!, [_1, _2]) + return formatWithArgumentRanges(self._s[519]!, self._r[519]!, [_1, _2]) } - public var Passport_Address_TypeUtilityBill: String { return self._s[518]! } - public var Privacy_Forwards_LinkIfAllowed: String { return self._s[519]! } - public var ReportPeer_Report: String { return self._s[520]! } - public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[521]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[522]! } + public var Passport_Address_TypeUtilityBill: String { return self._s[520]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[521]! } + public var ReportPeer_Report: String { return self._s[522]! } + public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[523]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[524]! } public func VoiceOver_Chat_MusicTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[523]!, self._r[523]!, [_1, _2]) + return formatWithArgumentRanges(self._s[525]!, self._r[525]!, [_1, _2]) } - public var StickerPack_Send: String { return self._s[524]! } - public var Login_CodeSentInternal: String { return self._s[525]! } - public var Wallet_Month_GenJanuary: String { return self._s[526]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[528]! } + public var StickerPack_Send: String { return self._s[526]! } + public var Login_CodeSentInternal: String { return self._s[527]! } + public var Wallet_Month_GenJanuary: String { return self._s[528]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[530]! } public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[529]!, self._r[529]!, [_0]) - } - public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[531]!, self._r[531]!, [_0]) } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[532]! } - public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[533]!, self._r[533]!, [_1]) + public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[533]!, self._r[533]!, [_0]) } - public var ReportPeer_ReasonViolence: String { return self._s[535]! } - public var Appearance_ShareThemeColor: String { return self._s[536]! } - public var Map_Locating: String { return self._s[537]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[534]! } + public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[535]!, self._r[535]!, [_1]) + } + public var ReportPeer_ReasonViolence: String { return self._s[537]! } + public var Appearance_ShareThemeColor: String { return self._s[538]! } + public var Map_Locating: String { return self._s[539]! } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[538]!, self._r[538]!, [_0]) + return formatWithArgumentRanges(self._s[540]!, self._r[540]!, [_0]) } public func PUSH_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[539]!, self._r[539]!, [_1]) + return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_1]) } - public var ChatListFolderSettings_FoldersSection: String { return self._s[540]! } - public var AutoDownloadSettings_GroupChats: String { return self._s[542]! } - public var CheckoutInfo_SaveInfo: String { return self._s[543]! } - public var ChatList_ChatTypesSection: String { return self._s[544]! } - public var SharedMedia_EmptyLinksText: String { return self._s[546]! } - public var Passport_Address_CityPlaceholder: String { return self._s[547]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[548]! } - public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[549]! } - public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[551]! } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[552]! } + public var ChatListFolderSettings_FoldersSection: String { return self._s[542]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[544]! } + public var CheckoutInfo_SaveInfo: String { return self._s[545]! } + public var ChatList_ChatTypesSection: String { return self._s[546]! } + public var SharedMedia_EmptyLinksText: String { return self._s[548]! } + public var Passport_Address_CityPlaceholder: String { return self._s[549]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[550]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[551]! } + public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[553]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[554]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[553]!, self._r[553]!, [_1]) + return formatWithArgumentRanges(self._s[555]!, self._r[555]!, [_1]) } public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[554]!, self._r[554]!, [_0]) + return formatWithArgumentRanges(self._s[556]!, self._r[556]!, [_0]) } - public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[555]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[556]! } - public var ChangePhoneNumberCode_Code: String { return self._s[557]! } - public var Appearance_CreateTheme: String { return self._s[558]! } + public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[557]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[558]! } + public var ChangePhoneNumberCode_Code: String { return self._s[559]! } + public var Appearance_CreateTheme: String { return self._s[560]! } public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[559]!, self._r[559]!, [_0]) + return formatWithArgumentRanges(self._s[561]!, self._r[561]!, [_0]) } - public var TwoStepAuth_SetupEmail: String { return self._s[560]! } - public var HashtagSearch_AllChats: String { return self._s[561]! } - public var MediaPlayer_UnknownTrack: String { return self._s[562]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[564]! } + public var TwoStepAuth_SetupEmail: String { return self._s[562]! } + public var HashtagSearch_AllChats: String { return self._s[563]! } + public var MediaPlayer_UnknownTrack: String { return self._s[564]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[566]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[565]!, self._r[565]!, [_0]) + return formatWithArgumentRanges(self._s[567]!, self._r[567]!, [_0]) } - public var Chat_Gifs_SavedSectionHeader: String { return self._s[566]! } - public var PhotoEditor_QualityHigh: String { return self._s[568]! } + public var Chat_Gifs_SavedSectionHeader: String { return self._s[568]! } + public var PhotoEditor_QualityHigh: String { return self._s[570]! } public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[569]!, self._r[569]!, [_0]) + return formatWithArgumentRanges(self._s[571]!, self._r[571]!, [_0]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[570]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[571]! } - public var Message_LiveLocation: String { return self._s[572]! } - public var Cache_LowDiskSpaceText: String { return self._s[573]! } - public var Wallet_Receive_ShareAddress: String { return self._s[574]! } - public var EditTheme_ErrorLinkTaken: String { return self._s[576]! } - public var Conversation_SendMessage: String { return self._s[577]! } - public var AuthSessions_EmptyTitle: String { return self._s[578]! } - public var Privacy_PhoneNumber: String { return self._s[579]! } - public var PeopleNearby_CreateGroup: String { return self._s[580]! } - public var Stats_SharesPerPost: String { return self._s[582]! } - public var CallSettings_UseLessData: String { return self._s[583]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[584]! } - public var Stickers_AddToFavorites: String { return self._s[585]! } - public var Wallet_WordImport_Title: String { return self._s[586]! } - public var PhotoEditor_QualityLow: String { return self._s[587]! } - public var Watch_UserInfo_Unblock: String { return self._s[588]! } - public var Settings_Logout: String { return self._s[589]! } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[572]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[573]! } + public var Message_LiveLocation: String { return self._s[574]! } + public var Cache_LowDiskSpaceText: String { return self._s[575]! } + public var Wallet_Receive_ShareAddress: String { return self._s[576]! } + public var EditTheme_ErrorLinkTaken: String { return self._s[578]! } + public var Conversation_SendMessage: String { return self._s[579]! } + public var AuthSessions_EmptyTitle: String { return self._s[580]! } + public var Privacy_PhoneNumber: String { return self._s[581]! } + public var PeopleNearby_CreateGroup: String { return self._s[582]! } + public var Stats_SharesPerPost: String { return self._s[584]! } + public var CallSettings_UseLessData: String { return self._s[585]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[586]! } + public var Stickers_AddToFavorites: String { return self._s[587]! } + public var Wallet_WordImport_Title: String { return self._s[588]! } + public var PhotoEditor_QualityLow: String { return self._s[589]! } + public var Watch_UserInfo_Unblock: String { return self._s[590]! } + public var Settings_Logout: String { return self._s[591]! } public func PUSH_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[590]!, self._r[590]!, [_1]) + return formatWithArgumentRanges(self._s[592]!, self._r[592]!, [_1]) } - public var ContactInfo_PhoneLabelWork: String { return self._s[591]! } - public var ChannelInfo_Stats: String { return self._s[592]! } - public var TextFormat_Link: String { return self._s[593]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[593]! } + public var ChannelInfo_Stats: String { return self._s[594]! } + public var TextFormat_Link: String { return self._s[595]! } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[594]!, self._r[594]!, [_1, _2]) + return formatWithArgumentRanges(self._s[596]!, self._r[596]!, [_1, _2]) } - public var Paint_Framed: String { return self._s[595]! } - public var Wallet_TransactionInfo_Title: String { return self._s[596]! } + public var Paint_Framed: String { return self._s[597]! } + public var Wallet_TransactionInfo_Title: String { return self._s[598]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[597]!, self._r[597]!, [_0]) + return formatWithArgumentRanges(self._s[599]!, self._r[599]!, [_0]) } - public var Watch_Notification_Joined: String { return self._s[598]! } - public var Group_Setup_TypePublicHelp: String { return self._s[599]! } - public var Passport_Scans_UploadNew: String { return self._s[600]! } - public var Checkout_LiabilityAlertTitle: String { return self._s[601]! } - public var DialogList_Title: String { return self._s[604]! } - public var NotificationSettings_ContactJoined: String { return self._s[605]! } - public var GroupInfo_LabelAdmin: String { return self._s[606]! } - public var KeyCommand_ChatInfo: String { return self._s[607]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[608]! } - public var Call_ReportIncludeLog: String { return self._s[609]! } + public var Watch_Notification_Joined: String { return self._s[600]! } + public var Group_Setup_TypePublicHelp: String { return self._s[601]! } + public var Passport_Scans_UploadNew: String { return self._s[602]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[603]! } + public var DialogList_Title: String { return self._s[606]! } + public var NotificationSettings_ContactJoined: String { return self._s[607]! } + public var GroupInfo_LabelAdmin: String { return self._s[608]! } + public var KeyCommand_ChatInfo: String { return self._s[609]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[610]! } + public var Call_ReportIncludeLog: String { return self._s[611]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[612]!, self._r[612]!, [_0]) + return formatWithArgumentRanges(self._s[614]!, self._r[614]!, [_0]) } - public var Stats_Followers: String { return self._s[613]! } - public var Stats_GroupLanguagesTitle: String { return self._s[614]! } - public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[615]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[616]! } - public var LocalGroup_IrrelevantWarning: String { return self._s[617]! } - public var Conversation_DefaultRestrictedInline: String { return self._s[618]! } - public var Message_Sticker: String { return self._s[619]! } - public var LastSeen_JustNow: String { return self._s[621]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[623]! } - public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[624]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[626]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[627]! } - public var TwoStepAuth_Email: String { return self._s[628]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[629]! } - public var PhotoEditor_BlurToolOff: String { return self._s[630]! } - public var Message_PinnedStickerMessage: String { return self._s[631]! } - public var ContactInfo_PhoneLabelPager: String { return self._s[632]! } - public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[633]! } - public var Passport_DiscardMessageTitle: String { return self._s[634]! } - public var Privacy_PaymentsTitle: String { return self._s[635]! } - public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[636]! } - public var ClearCache_StorageCache: String { return self._s[637]! } - public var Appearance_TextSizeSetting: String { return self._s[638]! } - public var Channel_DiscussionGroup_Header: String { return self._s[640]! } - public var VoiceOver_Chat_OptionSelected: String { return self._s[641]! } - public var Appearance_ColorTheme: String { return self._s[642]! } - public var UserInfo_ShareContact: String { return self._s[643]! } - public var Passport_Address_TypePassportRegistration: String { return self._s[644]! } - public var Common_More: String { return self._s[645]! } - public var Watch_Message_Call: String { return self._s[646]! } - public var Profile_EncryptionKey: String { return self._s[649]! } - public var Privacy_TopPeers: String { return self._s[650]! } - public var Conversation_StopPollConfirmation: String { return self._s[651]! } - public var Wallet_Words_NotDoneText: String { return self._s[653]! } - public var Privacy_TopPeersWarning: String { return self._s[655]! } - public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[656]! } - public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[657]! } - public var Media_SendWithTimer: String { return self._s[660]! } - public var Wallet_RestoreFailed_EnterWords: String { return self._s[661]! } - public var DialogList_SearchSectionMessages: String { return self._s[662]! } - public var ChatList_Context_AddToFolder: String { return self._s[663]! } - public var Notifications_ChannelNotifications: String { return self._s[664]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[665]! } - public var Passport_Language_sk: String { return self._s[666]! } - public var Notification_MessageLifetime1h: String { return self._s[667]! } - public var Wallpaper_ResetWallpapersInfo: String { return self._s[668]! } - public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[669]! } - public var PeerInfo_PaneGifs: String { return self._s[670]! } - public var Call_ReportSkip: String { return self._s[672]! } - public var Cache_ServiceFiles: String { return self._s[673]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[674]! } - public var VoiceOver_Chat_YourFile: String { return self._s[675]! } - public var Map_Hybrid: String { return self._s[676]! } - public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[678]! } + public var Stats_Followers: String { return self._s[615]! } + public var Stats_GroupLanguagesTitle: String { return self._s[616]! } + public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[617]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[618]! } + public var LocalGroup_IrrelevantWarning: String { return self._s[619]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[620]! } + public var Message_Sticker: String { return self._s[621]! } + public var LastSeen_JustNow: String { return self._s[623]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[625]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[626]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[628]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[629]! } + public var TwoStepAuth_Email: String { return self._s[630]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[631]! } + public var PhotoEditor_BlurToolOff: String { return self._s[632]! } + public var Message_PinnedStickerMessage: String { return self._s[633]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[634]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[635]! } + public var Passport_DiscardMessageTitle: String { return self._s[636]! } + public var Privacy_PaymentsTitle: String { return self._s[637]! } + public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[638]! } + public var ClearCache_StorageCache: String { return self._s[639]! } + public var Appearance_TextSizeSetting: String { return self._s[640]! } + public var Channel_DiscussionGroup_Header: String { return self._s[642]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[643]! } + public var Appearance_ColorTheme: String { return self._s[644]! } + public var UserInfo_ShareContact: String { return self._s[645]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[646]! } + public var Common_More: String { return self._s[647]! } + public var Watch_Message_Call: String { return self._s[648]! } + public var Profile_EncryptionKey: String { return self._s[651]! } + public var Privacy_TopPeers: String { return self._s[652]! } + public var Conversation_StopPollConfirmation: String { return self._s[653]! } + public var Wallet_Words_NotDoneText: String { return self._s[655]! } + public var Privacy_TopPeersWarning: String { return self._s[657]! } + public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[658]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[659]! } + public var Media_SendWithTimer: String { return self._s[662]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[663]! } + public var DialogList_SearchSectionMessages: String { return self._s[664]! } + public var ChatList_Context_AddToFolder: String { return self._s[665]! } + public var Notifications_ChannelNotifications: String { return self._s[666]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[667]! } + public var Passport_Language_sk: String { return self._s[668]! } + public var Notification_MessageLifetime1h: String { return self._s[669]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[670]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[671]! } + public var PeerInfo_PaneGifs: String { return self._s[672]! } + public var Call_ReportSkip: String { return self._s[674]! } + public var Cache_ServiceFiles: String { return self._s[675]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[676]! } + public var VoiceOver_Chat_YourFile: String { return self._s[677]! } + public var Map_Hybrid: String { return self._s[678]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[680]! } public func PUSH_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[679]!, self._r[679]!, [_1]) + return formatWithArgumentRanges(self._s[681]!, self._r[681]!, [_1]) } - public var ChatSettings_AutoDownloadVideos: String { return self._s[681]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[682]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[683]! } - public var SocksProxySetup_ProxyTelegram: String { return self._s[686]! } + public var ChatSettings_AutoDownloadVideos: String { return self._s[683]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[684]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[685]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[688]! } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[687]!, self._r[687]!, [_1]) + return formatWithArgumentRanges(self._s[689]!, self._r[689]!, [_1]) } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[689]! } - public var ScheduledMessages_ScheduledToday: String { return self._s[690]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[691]! } + public var ScheduledMessages_ScheduledToday: String { return self._s[692]! } public func PUSH_CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[691]!, self._r[691]!, [_1, _2]) + return formatWithArgumentRanges(self._s[693]!, self._r[693]!, [_1, _2]) } - public var Conversation_LiveLocationYou: String { return self._s[692]! } - public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[693]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[694]! } - public var UserInfo_ShareBot: String { return self._s[697]! } + public var Conversation_LiveLocationYou: String { return self._s[694]! } + public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[695]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[696]! } + public var UserInfo_ShareBot: String { return self._s[699]! } public func PUSH_AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[698]!, self._r[698]!, [_1, _2]) + return formatWithArgumentRanges(self._s[700]!, self._r[700]!, [_1, _2]) } - public var Conversation_ClearCache: String { return self._s[699]! } - public var PhotoEditor_ShadowsTint: String { return self._s[700]! } - public var ChatListFolderSettings_EditFoldersInfo: String { return self._s[701]! } - public var Message_Audio: String { return self._s[702]! } - public var Passport_Language_lt: String { return self._s[703]! } + public var Conversation_ClearCache: String { return self._s[701]! } + public var PhotoEditor_ShadowsTint: String { return self._s[702]! } + public var ChatListFolderSettings_EditFoldersInfo: String { return self._s[703]! } + public var Message_Audio: String { return self._s[704]! } + public var Passport_Language_lt: String { return self._s[705]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[704]!, self._r[704]!, [_0]) + return formatWithArgumentRanges(self._s[706]!, self._r[706]!, [_0]) } - public var Permissions_SiriText_v0: String { return self._s[705]! } - public var Conversation_FileICloudDrive: String { return self._s[706]! } - public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[707]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[708]! } + public var Permissions_SiriText_v0: String { return self._s[707]! } + public var Conversation_FileICloudDrive: String { return self._s[708]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[709]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[710]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[709]!, self._r[709]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[711]!, self._r[711]!, [_1, _2, _3, _4, _5, _6]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[710]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[712]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[711]!, self._r[711]!, [_0]) + return formatWithArgumentRanges(self._s[713]!, self._r[713]!, [_0]) } - public var Channel_SignMessages: String { return self._s[712]! } + public var Channel_SignMessages: String { return self._s[714]! } public func PUSH_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[713]!, self._r[713]!, [_1]) + return formatWithArgumentRanges(self._s[715]!, self._r[715]!, [_1]) } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[714]! } - public var Passport_ScanPassport: String { return self._s[715]! } - public var Watch_Suggestion_Thanks: String { return self._s[716]! } - public var BlockedUsers_AddNew: String { return self._s[717]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[716]! } + public var Passport_ScanPassport: String { return self._s[717]! } + public var Watch_Suggestion_Thanks: String { return self._s[718]! } + public var BlockedUsers_AddNew: String { return self._s[719]! } public func PUSH_CHAT_MESSAGE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[718]!, self._r[718]!, [_1, _2]) + return formatWithArgumentRanges(self._s[720]!, self._r[720]!, [_1, _2]) } - public var Watch_Message_Invoice: String { return self._s[719]! } - public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[720]! } - public var Month_GenJuly: String { return self._s[721]! } - public var CreatePoll_QuizInfo: String { return self._s[722]! } - public var UserInfo_StartSecretChatStart: String { return self._s[723]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[724]! } - public var IntentsSettings_SuggestByShare: String { return self._s[726]! } - public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[727]! } - public var Notification_ChannelInviterSelf: String { return self._s[728]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[729]! } + public var Watch_Message_Invoice: String { return self._s[721]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[722]! } + public var Month_GenJuly: String { return self._s[723]! } + public var CreatePoll_QuizInfo: String { return self._s[724]! } + public var UserInfo_StartSecretChatStart: String { return self._s[725]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[726]! } + public var IntentsSettings_SuggestByShare: String { return self._s[728]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[729]! } + public var Notification_ChannelInviterSelf: String { return self._s[730]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[731]! } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[730]!, self._r[730]!, [_1, _2]) + return formatWithArgumentRanges(self._s[732]!, self._r[732]!, [_1, _2]) } - public var Stats_FollowersTitle: String { return self._s[731]! } - public var CheckoutInfo_Title: String { return self._s[732]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[733]! } + public var Stats_FollowersTitle: String { return self._s[733]! } + public var CheckoutInfo_Title: String { return self._s[734]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[735]! } public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[734]!, self._r[734]!, [_0]) + return formatWithArgumentRanges(self._s[736]!, self._r[736]!, [_0]) } - public var Passport_Identity_MainPage: String { return self._s[735]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[736]! } - public var Passport_Language_de: String { return self._s[737]! } - public var Update_Title: String { return self._s[738]! } - public var ContactInfo_PhoneLabelWorkFax: String { return self._s[739]! } - public var Channel_AdminLog_BanEmbedLinks: String { return self._s[740]! } - public var Passport_Email_UseTelegramEmailHelp: String { return self._s[741]! } - public var Notifications_ChannelNotificationsPreview: String { return self._s[742]! } - public var NotificationsSound_Telegraph: String { return self._s[743]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[744]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[745]! } + public var Passport_Identity_MainPage: String { return self._s[737]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[738]! } + public var Passport_Language_de: String { return self._s[739]! } + public var Update_Title: String { return self._s[740]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[741]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[742]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[743]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[744]! } + public var NotificationsSound_Telegraph: String { return self._s[745]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[746]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[747]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[746]!, self._r[746]!, [_0]) + return formatWithArgumentRanges(self._s[748]!, self._r[748]!, [_0]) } - public var ClearCache_Description: String { return self._s[747]! } - public var Stickers_SuggestAll: String { return self._s[748]! } - public var Conversation_ForwardTitle: String { return self._s[749]! } - public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[750]! } + public var ClearCache_Description: String { return self._s[749]! } + public var Stickers_SuggestAll: String { return self._s[750]! } + public var Conversation_ForwardTitle: String { return self._s[751]! } + public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[752]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[751]!, self._r[751]!, [_0]) + return formatWithArgumentRanges(self._s[753]!, self._r[753]!, [_0]) } - public var Calls_NewCall: String { return self._s[752]! } - public var Call_StatusEnded: String { return self._s[753]! } - public var AutoDownloadSettings_DataUsageLow: String { return self._s[755]! } - public var Settings_ProxyConnected: String { return self._s[756]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[757]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[758]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[759]! } - public var Passport_PasswordPlaceholder: String { return self._s[760]! } - public var Message_PinnedInvoice: String { return self._s[761]! } - public var Passport_Identity_IssueDate: String { return self._s[762]! } - public var Stats_GroupTopHoursTitle: String { return self._s[763]! } - public var Passport_Language_pl: String { return self._s[764]! } + public var Calls_NewCall: String { return self._s[754]! } + public var Call_StatusEnded: String { return self._s[755]! } + public var AutoDownloadSettings_DataUsageLow: String { return self._s[757]! } + public var Settings_ProxyConnected: String { return self._s[758]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[759]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[760]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[761]! } + public var Passport_PasswordPlaceholder: String { return self._s[762]! } + public var Message_PinnedInvoice: String { return self._s[763]! } + public var Passport_Identity_IssueDate: String { return self._s[764]! } + public var Stats_GroupTopHoursTitle: String { return self._s[765]! } + public var Passport_Language_pl: String { return self._s[766]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[765]!, self._r[765]!, [_0]) + return formatWithArgumentRanges(self._s[767]!, self._r[767]!, [_0]) } - public var Call_StatusConnecting: String { return self._s[766]! } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[767]! } + public var Call_StatusConnecting: String { return self._s[768]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[769]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[768]!, self._r[768]!, [_0]) + return formatWithArgumentRanges(self._s[770]!, self._r[770]!, [_0]) } - public var ChatSettings_ConnectionType_UseProxy: String { return self._s[770]! } - public var Common_Edit: String { return self._s[771]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[772]! } + public var ChatSettings_ConnectionType_UseProxy: String { return self._s[772]! } + public var Common_Edit: String { return self._s[773]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[774]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[773]!, self._r[773]!, [_0]) + return formatWithArgumentRanges(self._s[775]!, self._r[775]!, [_0]) } - public var GroupInfo_ChatAdmins: String { return self._s[774]! } - public var PrivateDataSettings_Title: String { return self._s[775]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[776]! } - public var ChatList_Read: String { return self._s[777]! } - public var Wallet_WordImport_Text: String { return self._s[778]! } - public var Undo_ChatClearedForBothSides: String { return self._s[779]! } - public var ChatListFolder_AddChats: String { return self._s[780]! } - public var GroupPermission_SectionTitle: String { return self._s[781]! } - public var TwoFactorSetup_Intro_Title: String { return self._s[783]! } + public var GroupInfo_ChatAdmins: String { return self._s[776]! } + public var PrivateDataSettings_Title: String { return self._s[777]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[778]! } + public var ChatList_Read: String { return self._s[779]! } + public var Wallet_WordImport_Text: String { return self._s[780]! } + public var Undo_ChatClearedForBothSides: String { return self._s[781]! } + public var ChatListFolder_AddChats: String { return self._s[782]! } + public var GroupPermission_SectionTitle: String { return self._s[783]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[785]! } public func PUSH_CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[784]!, self._r[784]!, [_1, _2]) + return formatWithArgumentRanges(self._s[786]!, self._r[786]!, [_1, _2]) } - public var Checkout_ErrorPaymentFailed: String { return self._s[785]! } - public var Update_UpdateApp: String { return self._s[787]! } - public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[788]! } - public var Settings_Appearance: String { return self._s[789]! } - public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[793]! } - public var Watch_Location_Access: String { return self._s[794]! } - public var ShareMenu_CopyShareLink: String { return self._s[796]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[797]! } - public var Conversation_Theme: String { return self._s[799]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[787]! } + public var Update_UpdateApp: String { return self._s[789]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[790]! } + public var Settings_Appearance: String { return self._s[791]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[795]! } + public var Watch_Location_Access: String { return self._s[796]! } + public var ShareMenu_CopyShareLink: String { return self._s[798]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[799]! } + public var Conversation_Theme: String { return self._s[801]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[800]!, self._r[800]!, [_0]) + return formatWithArgumentRanges(self._s[802]!, self._r[802]!, [_0]) } - public var Notifications_ClassicTones: String { return self._s[801]! } - public var Weekday_ShortWednesday: String { return self._s[802]! } - public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[803]! } - public var Undo_LeftGroup: String { return self._s[806]! } - public var ChatListFolder_DiscardCancel: String { return self._s[807]! } - public var Wallet_RestoreFailed_Text: String { return self._s[808]! } - public var Conversation_LinkDialogCopy: String { return self._s[809]! } - public var Wallet_TransactionInfo_NoAddress: String { return self._s[811]! } - public var Wallet_Navigation_Back: String { return self._s[812]! } - public var KeyCommand_FocusOnInputField: String { return self._s[813]! } - public var Contacts_SelectAll: String { return self._s[814]! } - public var Preview_SaveToCameraRoll: String { return self._s[815]! } - public var PrivacySettings_PasscodeOff: String { return self._s[816]! } - public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[817]! } + public var Notifications_ClassicTones: String { return self._s[803]! } + public var Weekday_ShortWednesday: String { return self._s[804]! } + public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[805]! } + public var Undo_LeftGroup: String { return self._s[808]! } + public var ChatListFolder_DiscardCancel: String { return self._s[809]! } + public var Wallet_RestoreFailed_Text: String { return self._s[810]! } + public var Conversation_LinkDialogCopy: String { return self._s[811]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[813]! } + public var Wallet_Navigation_Back: String { return self._s[814]! } + public var KeyCommand_FocusOnInputField: String { return self._s[815]! } + public var Contacts_SelectAll: String { return self._s[816]! } + public var Preview_SaveToCameraRoll: String { return self._s[817]! } + public var PrivacySettings_PasscodeOff: String { return self._s[818]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[819]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[818]!, self._r[818]!, [_1]) + return formatWithArgumentRanges(self._s[820]!, self._r[820]!, [_1]) } - public var Wallpaper_Title: String { return self._s[819]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[820]! } - public var AccessDenied_Camera: String { return self._s[821]! } - public var Watch_Compose_CurrentLocation: String { return self._s[822]! } - public var PeerInfo_ButtonMessage: String { return self._s[824]! } - public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[825]! } + public var Wallpaper_Title: String { return self._s[821]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[822]! } + public var AccessDenied_Camera: String { return self._s[823]! } + public var Watch_Compose_CurrentLocation: String { return self._s[824]! } + public var PeerInfo_ButtonMessage: String { return self._s[826]! } + public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[827]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[826]!, self._r[826]!, [_0]) + return formatWithArgumentRanges(self._s[828]!, self._r[828]!, [_0]) } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[827]! } - public var Passport_Language_ro: String { return self._s[828]! } - public var EditTheme_UploadNewTheme: String { return self._s[829]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[830]! } - public var Wallet_Intro_Terms: String { return self._s[831]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[829]! } + public var Passport_Language_ro: String { return self._s[830]! } + public var EditTheme_UploadNewTheme: String { return self._s[831]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[832]! } + public var Wallet_Intro_Terms: String { return self._s[833]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[832]!, self._r[832]!, [_0]) + return formatWithArgumentRanges(self._s[834]!, self._r[834]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[833]! } - public var State_ConnectingToProxy: String { return self._s[834]! } - public var Calls_RatingTitle: String { return self._s[835]! } - public var Generic_ErrorMoreInfo: String { return self._s[836]! } - public var ChatList_Search_ShowMore: String { return self._s[837]! } - public var Appearance_PreviewReplyText: String { return self._s[838]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[839]! } + public var Login_CancelPhoneVerification: String { return self._s[835]! } + public var State_ConnectingToProxy: String { return self._s[836]! } + public var Calls_RatingTitle: String { return self._s[837]! } + public var Generic_ErrorMoreInfo: String { return self._s[838]! } + public var ChatList_Search_ShowMore: String { return self._s[839]! } + public var Appearance_PreviewReplyText: String { return self._s[840]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[841]! } public func Wallet_Send_Balance(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[840]!, self._r[840]!, [_0]) + return formatWithArgumentRanges(self._s[842]!, self._r[842]!, [_0]) } - public var IntentsSettings_SuggestedChatsContacts: String { return self._s[841]! } - public var SharedMedia_CategoryLinks: String { return self._s[842]! } - public var Calls_Missed: String { return self._s[843]! } - public var Cache_Photos: String { return self._s[847]! } - public var GroupPermission_NoAddMembers: String { return self._s[848]! } - public var ScheduledMessages_Title: String { return self._s[849]! } + public var IntentsSettings_SuggestedChatsContacts: String { return self._s[843]! } + public var SharedMedia_CategoryLinks: String { return self._s[844]! } + public var Calls_Missed: String { return self._s[845]! } + public var Cache_Photos: String { return self._s[849]! } + public var GroupPermission_NoAddMembers: String { return self._s[850]! } + public var ScheduledMessages_Title: String { return self._s[851]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[850]!, self._r[850]!, [_0]) + return formatWithArgumentRanges(self._s[852]!, self._r[852]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[851]! } - public var Settings_ProxyDisabled: String { return self._s[852]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[853]! } + public var Settings_ProxyDisabled: String { return self._s[854]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[853]!, self._r[853]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[855]!, self._r[855]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[854]!, self._r[854]!, [_0]) + return formatWithArgumentRanges(self._s[856]!, self._r[856]!, [_0]) } - public var Stats_ViewsPerPost: String { return self._s[856]! } - public var ChatList_Context_RemoveFromRecents: String { return self._s[857]! } - public var Appearance_Title: String { return self._s[858]! } + public var Stats_ViewsPerPost: String { return self._s[858]! } + public var ChatList_Context_RemoveFromRecents: String { return self._s[859]! } + public var Appearance_Title: String { return self._s[860]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[860]!, self._r[860]!, [_0]) + return formatWithArgumentRanges(self._s[862]!, self._r[862]!, [_0]) } - public var Conversation_WalletRequiredText: String { return self._s[861]! } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[862]! } - public var OldChannels_NoticeCreateText: String { return self._s[863]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[864]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[865]! } - public var Preview_DeletePhoto: String { return self._s[866]! } - public var Appearance_AppIconFilledX: String { return self._s[867]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[868]! } + public var Conversation_WalletRequiredText: String { return self._s[863]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[864]! } + public var OldChannels_NoticeCreateText: String { return self._s[865]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[866]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[867]! } + public var Preview_DeletePhoto: String { return self._s[868]! } + public var Appearance_AppIconFilledX: String { return self._s[869]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[870]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[869]!, self._r[869]!, [_0]) + return formatWithArgumentRanges(self._s[871]!, self._r[871]!, [_0]) } - public var ChatListFolder_TitleEdit: String { return self._s[872]! } - public var MuteFor_Forever: String { return self._s[873]! } - public var Coub_TapForSound: String { return self._s[874]! } - public var Map_LocatingError: String { return self._s[875]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[877]! } - public var Conversation_SendMessage_SendSilently: String { return self._s[878]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[879]! } + public var ChatListFolder_TitleEdit: String { return self._s[874]! } + public var MuteFor_Forever: String { return self._s[875]! } + public var Coub_TapForSound: String { return self._s[876]! } + public var Map_LocatingError: String { return self._s[877]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[879]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[880]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[881]! } public func Wallet_Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[880]!, self._r[880]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[882]!, self._r[882]!, [_1, _2, _3]) } - public var Passport_ForgottenPassword: String { return self._s[881]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[882]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[883]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[885]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[886]! } - public var Message_Location: String { return self._s[887]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[888]! } - public var Channel_Management_Title: String { return self._s[889]! } - public var DialogList_SearchSectionDialogs: String { return self._s[891]! } - public var Compose_NewChannel_Members: String { return self._s[892]! } + public var Passport_ForgottenPassword: String { return self._s[883]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[884]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[885]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[887]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[888]! } + public var Message_Location: String { return self._s[889]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[890]! } + public var Channel_Management_Title: String { return self._s[891]! } + public var DialogList_SearchSectionDialogs: String { return self._s[893]! } + public var Compose_NewChannel_Members: String { return self._s[894]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[893]!, self._r[893]!, [_0]) + return formatWithArgumentRanges(self._s[895]!, self._r[895]!, [_0]) } - public var GroupInfo_Location: String { return self._s[894]! } - public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[895]! } - public var ClearCache_Clear: String { return self._s[896]! } - public var InstantPage_FeedbackButtonShort: String { return self._s[897]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[898]! } - public var PhotoEditor_WarmthTool: String { return self._s[899]! } - public var Passport_Language_tr: String { return self._s[900]! } + public var GroupInfo_Location: String { return self._s[896]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[897]! } + public var ClearCache_Clear: String { return self._s[898]! } + public var InstantPage_FeedbackButtonShort: String { return self._s[899]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[900]! } + public var PhotoEditor_WarmthTool: String { return self._s[901]! } + public var Passport_Language_tr: String { return self._s[902]! } public func PUSH_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[901]!, self._r[901]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[903]!, self._r[903]!, [_1, _2, _3]) } - public var OldChannels_NoticeUpgradeText: String { return self._s[902]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[904]! } - public var Watch_PhotoView_Title: String { return self._s[905]! } - public var Passport_Phone_Delete: String { return self._s[906]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[907]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[908]! } - public var GroupInfo_Permissions: String { return self._s[909]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[910]! } - public var Profile_ShareContactButton: String { return self._s[911]! } - public var ChatSettings_Other: String { return self._s[912]! } - public var UserInfo_NotificationsDisabled: String { return self._s[913]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[914]! } - public var LastSeen_WithinAMonth: String { return self._s[915]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[916]! } - public var Conversation_ReportGroupLocation: String { return self._s[917]! } - public var Conversation_EncryptionCanceled: String { return self._s[918]! } - public var MediaPicker_GroupDescription: String { return self._s[919]! } - public var WebSearch_Images: String { return self._s[920]! } + public var OldChannels_NoticeUpgradeText: String { return self._s[904]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[906]! } + public var Watch_PhotoView_Title: String { return self._s[907]! } + public var Passport_Phone_Delete: String { return self._s[908]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[909]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[910]! } + public var GroupInfo_Permissions: String { return self._s[911]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[912]! } + public var Profile_ShareContactButton: String { return self._s[913]! } + public var ChatSettings_Other: String { return self._s[914]! } + public var UserInfo_NotificationsDisabled: String { return self._s[915]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[916]! } + public var LastSeen_WithinAMonth: String { return self._s[917]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[918]! } + public var Conversation_ReportGroupLocation: String { return self._s[919]! } + public var Conversation_EncryptionCanceled: String { return self._s[920]! } + public var MediaPicker_GroupDescription: String { return self._s[921]! } + public var WebSearch_Images: String { return self._s[922]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[921]!, self._r[921]!, [_0]) + return formatWithArgumentRanges(self._s[923]!, self._r[923]!, [_0]) } - public var Message_Photo: String { return self._s[922]! } - public var PasscodeSettings_HelpBottom: String { return self._s[923]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[924]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[925]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[926]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[927]! } - public var NotificationsSound_Calypso: String { return self._s[928]! } - public var Map_Map: String { return self._s[929]! } + public var Message_Photo: String { return self._s[924]! } + public var PasscodeSettings_HelpBottom: String { return self._s[925]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[926]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[927]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[928]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[929]! } + public var NotificationsSound_Calypso: String { return self._s[930]! } + public var Map_Map: String { return self._s[931]! } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[930]!, self._r[930]!, [_0]) + return formatWithArgumentRanges(self._s[932]!, self._r[932]!, [_0]) } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[932]! } - public var ChatSettings_TextSizeUnits: String { return self._s[933]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[934]! } + public var ChatSettings_TextSizeUnits: String { return self._s[935]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[934]!, self._r[934]!, [_0]) + return formatWithArgumentRanges(self._s[936]!, self._r[936]!, [_0]) } - public var Common_of: String { return self._s[935]! } - public var Conversation_ForwardContacts: String { return self._s[938]! } - public var IntentsSettings_SuggestByAll: String { return self._s[940]! } + public var Common_of: String { return self._s[937]! } + public var Conversation_ForwardContacts: String { return self._s[940]! } + public var IntentsSettings_SuggestByAll: String { return self._s[942]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[941]!, self._r[941]!, [_0]) + return formatWithArgumentRanges(self._s[943]!, self._r[943]!, [_0]) } - public var Passport_Language_hy: String { return self._s[942]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[943]! } - public var AutoDownloadSettings_Reset: String { return self._s[944]! } - public var Wallet_TransactionInfo_AddressCopied: String { return self._s[945]! } - public var Paint_ClearConfirm: String { return self._s[946]! } - public var Camera_VideoMode: String { return self._s[947]! } + public var Passport_Language_hy: String { return self._s[944]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[945]! } + public var AutoDownloadSettings_Reset: String { return self._s[946]! } + public var Wallet_TransactionInfo_AddressCopied: String { return self._s[947]! } + public var Paint_ClearConfirm: String { return self._s[948]! } + public var Camera_VideoMode: String { return self._s[949]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[948]!, self._r[948]!, [_0]) + return formatWithArgumentRanges(self._s[950]!, self._r[950]!, [_0]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[949]! } - public var Conversation_ViewBackground: String { return self._s[950]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[951]! } + public var Conversation_ViewBackground: String { return self._s[952]! } public func Wallet_Info_TransactionDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[951]!, self._r[951]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[953]!, self._r[953]!, [_1, _2, _3]) } - public var Passport_Language_el: String { return self._s[952]! } - public var PhotoEditor_Original: String { return self._s[953]! } - public var Settings_FAQ_Button: String { return self._s[956]! } - public var Channel_Setup_PublicNoLink: String { return self._s[958]! } - public var Conversation_UnsupportedMedia: String { return self._s[959]! } - public var Conversation_SlideToCancel: String { return self._s[960]! } - public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[961]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[962]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[963]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[964]! } - public var Stats_GroupViewers: String { return self._s[965]! } - public var AutoNightTheme_NotAvailable: String { return self._s[966]! } - public var Conversation_Owner: String { return self._s[967]! } - public var Common_Create: String { return self._s[968]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[969]! } - public var ContactList_Context_Call: String { return self._s[970]! } - public var Localization_ChooseLanguage: String { return self._s[972]! } - public var ChatList_Context_AddToContacts: String { return self._s[974]! } - public var OldChannels_NoticeTitle: String { return self._s[975]! } - public var Settings_Proxy: String { return self._s[977]! } - public var Privacy_TopPeersHelp: String { return self._s[978]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[979]! } - public var Chat_UnsendMyMessages: String { return self._s[980]! } + public var Passport_Language_el: String { return self._s[954]! } + public var PhotoEditor_Original: String { return self._s[955]! } + public var Settings_FAQ_Button: String { return self._s[958]! } + public var Channel_Setup_PublicNoLink: String { return self._s[960]! } + public var Conversation_UnsupportedMedia: String { return self._s[961]! } + public var Conversation_SlideToCancel: String { return self._s[962]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[963]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[964]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[965]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[966]! } + public var Stats_GroupViewers: String { return self._s[967]! } + public var AutoNightTheme_NotAvailable: String { return self._s[968]! } + public var Conversation_Owner: String { return self._s[969]! } + public var Common_Create: String { return self._s[970]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[971]! } + public var ContactList_Context_Call: String { return self._s[972]! } + public var Localization_ChooseLanguage: String { return self._s[974]! } + public var ChatList_Context_AddToContacts: String { return self._s[976]! } + public var OldChannels_NoticeTitle: String { return self._s[977]! } + public var Settings_Proxy: String { return self._s[979]! } + public var Privacy_TopPeersHelp: String { return self._s[980]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[981]! } + public var Chat_UnsendMyMessages: String { return self._s[982]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[981]!, self._r[981]!, [_0]) + return formatWithArgumentRanges(self._s[983]!, self._r[983]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[982]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[984]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[984]!, self._r[984]!, [_0]) + return formatWithArgumentRanges(self._s[986]!, self._r[986]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[985]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[986]! } - public var Cache_Title: String { return self._s[987]! } + public var Contacts_SortedByPresence: String { return self._s[987]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[988]! } + public var Cache_Title: String { return self._s[989]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[988]!, self._r[988]!, [_0]) + return formatWithArgumentRanges(self._s[990]!, self._r[990]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[989]! } - public var Channel_Moderator_Title: String { return self._s[990]! } - public var InstantPage_AutoNightTheme: String { return self._s[992]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[991]! } + public var Channel_Moderator_Title: String { return self._s[992]! } + public var InstantPage_AutoNightTheme: String { return self._s[994]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[995]!, self._r[995]!, [_1]) + return formatWithArgumentRanges(self._s[997]!, self._r[997]!, [_1]) } - public var Passport_Scans_Upload: String { return self._s[996]! } - public var Undo_Undo: String { return self._s[998]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[999]! } - public var TwoStepAuth_RemovePassword: String { return self._s[1000]! } - public var Common_Delete: String { return self._s[1001]! } - public var Contacts_AddPeopleNearby: String { return self._s[1003]! } - public var Conversation_ContextMenuDelete: String { return self._s[1004]! } - public var SocksProxySetup_Credentials: String { return self._s[1005]! } - public var Appearance_EditTheme: String { return self._s[1007]! } - public var ClearCache_StorageOtherApps: String { return self._s[1008]! } + public var Passport_Scans_Upload: String { return self._s[998]! } + public var Undo_Undo: String { return self._s[1000]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[1001]! } + public var TwoStepAuth_RemovePassword: String { return self._s[1002]! } + public var Common_Delete: String { return self._s[1003]! } + public var Contacts_AddPeopleNearby: String { return self._s[1005]! } + public var Conversation_ContextMenuDelete: String { return self._s[1006]! } + public var SocksProxySetup_Credentials: String { return self._s[1007]! } + public var Appearance_EditTheme: String { return self._s[1009]! } + public var ClearCache_StorageOtherApps: String { return self._s[1010]! } public func Conversation_PeerNearbyTitle(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1010]!, self._r[1010]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1012]!, self._r[1012]!, [_0, _1]) } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[1011]! } - public var Wallet_Send_NetworkErrorText: String { return self._s[1012]! } - public var AuthSessions_DevicesTitle: String { return self._s[1014]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[1016]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[1017]! } - public var Passport_Language_id: String { return self._s[1019]! } - public var Chat_Gifs_TrendingSectionHeader: String { return self._s[1020]! } - public var WallpaperSearch_ColorTeal: String { return self._s[1021]! } - public var ChannelIntro_Title: String { return self._s[1022]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[1013]! } + public var Wallet_Send_NetworkErrorText: String { return self._s[1014]! } + public var AuthSessions_DevicesTitle: String { return self._s[1016]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[1018]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[1019]! } + public var Passport_Language_id: String { return self._s[1021]! } + public var Chat_Gifs_TrendingSectionHeader: String { return self._s[1022]! } + public var WallpaperSearch_ColorTeal: String { return self._s[1023]! } + public var ChannelIntro_Title: String { return self._s[1024]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1023]!, self._r[1023]!, [_0]) + return formatWithArgumentRanges(self._s[1025]!, self._r[1025]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[1025]! } - public var VoiceOver_Chat_Reply: String { return self._s[1026]! } - public var ScheduledMessages_BotActionUnavailable: String { return self._s[1027]! } - public var Channel_Info_Description: String { return self._s[1028]! } - public var Stickers_FavoriteStickers: String { return self._s[1029]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[1030]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[1031]! } - public var ChatSearch_ResultsTooltip: String { return self._s[1032]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[1033]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[1034]! } - public var Group_PublicLink_Placeholder: String { return self._s[1035]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[1036]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[1027]! } + public var VoiceOver_Chat_Reply: String { return self._s[1028]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[1029]! } + public var Channel_Info_Description: String { return self._s[1030]! } + public var Stickers_FavoriteStickers: String { return self._s[1031]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[1032]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[1033]! } + public var ChatSearch_ResultsTooltip: String { return self._s[1034]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[1035]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[1036]! } + public var Group_PublicLink_Placeholder: String { return self._s[1037]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[1038]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1037]!, self._r[1037]!, [_1]) + return formatWithArgumentRanges(self._s[1039]!, self._r[1039]!, [_1]) } - public var TextFormat_Underline: String { return self._s[1038]! } + public var TextFormat_Underline: String { return self._s[1040]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1040]!, self._r[1040]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1042]!, self._r[1042]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1041]!, self._r[1041]!, [_0]) + return formatWithArgumentRanges(self._s[1043]!, self._r[1043]!, [_0]) } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1042]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1044]! } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1043]!, self._r[1043]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1045]!, self._r[1045]!, [_1, _2]) } - public var Wallet_Intro_ImportExisting: String { return self._s[1044]! } - public var GroupPermission_Delete: String { return self._s[1045]! } - public var Passport_Language_uk: String { return self._s[1046]! } - public var StickerPack_HideStickers: String { return self._s[1048]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1049]! } + public var Wallet_Intro_ImportExisting: String { return self._s[1046]! } + public var GroupPermission_Delete: String { return self._s[1047]! } + public var Passport_Language_uk: String { return self._s[1048]! } + public var StickerPack_HideStickers: String { return self._s[1050]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1051]! } public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1050]!, self._r[1050]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1052]!, self._r[1052]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[1051]! } + public var Activity_UploadingVideoMessage: String { return self._s[1053]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1052]!, self._r[1052]!, [_0]) + return formatWithArgumentRanges(self._s[1054]!, self._r[1054]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[1053]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1054]! } - public var Settings_CallSettings: String { return self._s[1055]! } - public var Camera_SquareMode: String { return self._s[1056]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1057]! } - public var GroupInfo_SharedMediaNone: String { return self._s[1058]! } + public var Channel_TitleInfo: String { return self._s[1055]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1056]! } + public var Settings_CallSettings: String { return self._s[1057]! } + public var Camera_SquareMode: String { return self._s[1058]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1059]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1060]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1059]!, self._r[1059]!, [_1]) + return formatWithArgumentRanges(self._s[1061]!, self._r[1061]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[1060]! } - public var Application_Update: String { return self._s[1062]! } - public var Month_ShortJanuary: String { return self._s[1063]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[1064]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[1065]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[1066]! } - public var Passport_Address_Street2Placeholder: String { return self._s[1067]! } + public var Bot_GenericBotStatus: String { return self._s[1062]! } + public var Application_Update: String { return self._s[1064]! } + public var Month_ShortJanuary: String { return self._s[1065]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[1066]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[1067]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1068]! } + public var Passport_Address_Street2Placeholder: String { return self._s[1069]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1068]!, self._r[1068]!, [_0]) + return formatWithArgumentRanges(self._s[1070]!, self._r[1070]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[1069]! } - public var Appearance_PreviewOutgoingText: String { return self._s[1070]! } + public var NetworkUsageSettings_Cellular: String { return self._s[1071]! } + public var Appearance_PreviewOutgoingText: String { return self._s[1072]! } public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1071]!, self._r[1071]!, [_0]) + return formatWithArgumentRanges(self._s[1073]!, self._r[1073]!, [_0]) } - public var Notifications_PermissionsAllowInSettings: String { return self._s[1072]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[1075]! } - public var Map_Directions: String { return self._s[1076]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[1078]! } - public var Appearance_ThemeDay: String { return self._s[1079]! } - public var LogoutOptions_LogOut: String { return self._s[1080]! } - public var Group_PublicLink_Title: String { return self._s[1082]! } - public var Channel_AddBotErrorNoRights: String { return self._s[1083]! } - public var ChatList_Search_ShowLess: String { return self._s[1086]! } - public var Passport_Identity_AddPassport: String { return self._s[1087]! } - public var LocalGroup_ButtonTitle: String { return self._s[1088]! } - public var Stats_InteractionsTitle: String { return self._s[1089]! } - public var Stats_GroupActionsTitle: String { return self._s[1090]! } - public var Call_Message: String { return self._s[1091]! } - public var PhotoEditor_ExposureTool: String { return self._s[1092]! } - public var Wallet_Receive_CommentInfo: String { return self._s[1094]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[1095]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[1097]! } - public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1098]! } - public var Appearance_Preview: String { return self._s[1099]! } - public var Compose_ChannelMembers: String { return self._s[1100]! } - public var Conversation_DeleteManyMessages: String { return self._s[1101]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[1102]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1103]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1104]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1107]! } - public var Conversation_UpdateTelegram: String { return self._s[1108]! } - public var EditTheme_Create_TopInfo: String { return self._s[1109]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[1074]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[1077]! } + public var Map_Directions: String { return self._s[1078]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1080]! } + public var Appearance_ThemeDay: String { return self._s[1081]! } + public var LogoutOptions_LogOut: String { return self._s[1082]! } + public var Group_PublicLink_Title: String { return self._s[1084]! } + public var Channel_AddBotErrorNoRights: String { return self._s[1085]! } + public var ChatList_Search_ShowLess: String { return self._s[1088]! } + public var Passport_Identity_AddPassport: String { return self._s[1089]! } + public var LocalGroup_ButtonTitle: String { return self._s[1090]! } + public var Stats_InteractionsTitle: String { return self._s[1091]! } + public var Stats_GroupActionsTitle: String { return self._s[1092]! } + public var Call_Message: String { return self._s[1093]! } + public var PhotoEditor_ExposureTool: String { return self._s[1094]! } + public var Wallet_Receive_CommentInfo: String { return self._s[1096]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1097]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[1099]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1100]! } + public var Appearance_Preview: String { return self._s[1101]! } + public var Compose_ChannelMembers: String { return self._s[1102]! } + public var Conversation_DeleteManyMessages: String { return self._s[1103]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1104]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1105]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1106]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1109]! } + public var Conversation_UpdateTelegram: String { return self._s[1110]! } + public var EditTheme_Create_TopInfo: String { return self._s[1111]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1110]!, self._r[1110]!, [_0]) + return formatWithArgumentRanges(self._s[1112]!, self._r[1112]!, [_0]) } - public var Wallet_WordCheck_Continue: String { return self._s[1111]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[1112]! } - public var IntentsSettings_ResetAll: String { return self._s[1113]! } + public var Wallet_WordCheck_Continue: String { return self._s[1113]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1114]! } + public var IntentsSettings_ResetAll: String { return self._s[1115]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1114]!, self._r[1114]!, [_1]) + return formatWithArgumentRanges(self._s[1116]!, self._r[1116]!, [_1]) } - public var ChatList_RemoveFolder: String { return self._s[1115]! } - public var GroupInfo_Administrators_Title: String { return self._s[1116]! } - public var Stats_GroupPosters: String { return self._s[1117]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[1118]! } + public var ChatList_RemoveFolder: String { return self._s[1117]! } + public var GroupInfo_Administrators_Title: String { return self._s[1118]! } + public var Stats_GroupPosters: String { return self._s[1119]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1120]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1119]!, self._r[1119]!, [_0]) + return formatWithArgumentRanges(self._s[1121]!, self._r[1121]!, [_0]) } - public var Tour_Title3: String { return self._s[1120]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1121]! } - public var Clipboard_SendPhoto: String { return self._s[1125]! } - public var MediaPicker_Videos: String { return self._s[1126]! } - public var Passport_Email_Title: String { return self._s[1127]! } + public var Tour_Title3: String { return self._s[1122]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1123]! } + public var Clipboard_SendPhoto: String { return self._s[1127]! } + public var MediaPicker_Videos: String { return self._s[1128]! } + public var Passport_Email_Title: String { return self._s[1129]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1128]!, self._r[1128]!, [_0]) + return formatWithArgumentRanges(self._s[1130]!, self._r[1130]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[1129]! } - public var Conversation_MessageDialogDelete: String { return self._s[1130]! } - public var Privacy_Calls_CustomHelp: String { return self._s[1132]! } - public var Message_Wallpaper: String { return self._s[1133]! } - public var MemberSearch_BotSection: String { return self._s[1134]! } - public var GroupInfo_SetSound: String { return self._s[1135]! } - public var Wallet_Send_EncryptComment: String { return self._s[1136]! } + public var StickerPacksSettings_Title: String { return self._s[1131]! } + public var Conversation_MessageDialogDelete: String { return self._s[1132]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1134]! } + public var Message_Wallpaper: String { return self._s[1135]! } + public var MemberSearch_BotSection: String { return self._s[1136]! } + public var GroupInfo_SetSound: String { return self._s[1137]! } + public var Wallet_Send_EncryptComment: String { return self._s[1138]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1137]!, self._r[1137]!, [_0]) + return formatWithArgumentRanges(self._s[1139]!, self._r[1139]!, [_0]) } - public var Core_ServiceUserStatus: String { return self._s[1138]! } - public var LiveLocationUpdated_JustNow: String { return self._s[1139]! } - public var Call_StatusFailed: String { return self._s[1140]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[1141]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1142]! } - public var TwoStepAuth_SetPassword: String { return self._s[1143]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[1144]! } + public var Core_ServiceUserStatus: String { return self._s[1140]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1141]! } + public var Call_StatusFailed: String { return self._s[1142]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1143]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1144]! } + public var TwoStepAuth_SetPassword: String { return self._s[1145]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1146]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1146]!, self._r[1146]!, [_0]) + return formatWithArgumentRanges(self._s[1148]!, self._r[1148]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[1147]! } - public var Map_NoPlacesNearby: String { return self._s[1148]! } - public var Profile_Username: String { return self._s[1149]! } - public var Bot_DescriptionTitle: String { return self._s[1150]! } - public var MaskStickerSettings_Title: String { return self._s[1151]! } - public var SharedMedia_CategoryOther: String { return self._s[1152]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1153]! } - public var Common_NotNow: String { return self._s[1154]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[1155]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[1156]! } - public var Map_Location: String { return self._s[1157]! } - public var Invitation_JoinGroup: String { return self._s[1158]! } - public var AutoDownloadSettings_Title: String { return self._s[1160]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1161]! } - public var Channel_ErrorAddBlocked: String { return self._s[1162]! } - public var ChatList_AddChatsToFolder: String { return self._s[1163]! } - public var Conversation_UnblockUser: String { return self._s[1164]! } - public var EditTheme_Edit_TopInfo: String { return self._s[1165]! } - public var Watch_Bot_Restart: String { return self._s[1166]! } - public var TwoStepAuth_Title: String { return self._s[1167]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1168]! } - public var Checkout_ShippingMethod: String { return self._s[1169]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1170]! } + public var Calls_SubmitRating: String { return self._s[1149]! } + public var Map_NoPlacesNearby: String { return self._s[1150]! } + public var Profile_Username: String { return self._s[1151]! } + public var Bot_DescriptionTitle: String { return self._s[1152]! } + public var MaskStickerSettings_Title: String { return self._s[1153]! } + public var SharedMedia_CategoryOther: String { return self._s[1154]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1155]! } + public var Common_NotNow: String { return self._s[1156]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1157]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1158]! } + public var Map_Location: String { return self._s[1159]! } + public var Invitation_JoinGroup: String { return self._s[1160]! } + public var AutoDownloadSettings_Title: String { return self._s[1162]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1163]! } + public var Channel_ErrorAddBlocked: String { return self._s[1164]! } + public var ChatList_AddChatsToFolder: String { return self._s[1165]! } + public var Conversation_UnblockUser: String { return self._s[1166]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1167]! } + public var Watch_Bot_Restart: String { return self._s[1168]! } + public var TwoStepAuth_Title: String { return self._s[1169]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1170]! } + public var Checkout_ShippingMethod: String { return self._s[1171]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1172]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1171]!, self._r[1171]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1173]!, self._r[1173]!, [_1, _2, _3]) } - public var PeerInfo_ButtonDiscuss: String { return self._s[1172]! } - public var EditTheme_ChangeColors: String { return self._s[1174]! } + public var PeerInfo_ButtonDiscuss: String { return self._s[1174]! } + public var EditTheme_ChangeColors: String { return self._s[1176]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1175]!, self._r[1175]!, [_0]) + return formatWithArgumentRanges(self._s[1177]!, self._r[1177]!, [_0]) } public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1176]!, self._r[1176]!, [_0]) + return formatWithArgumentRanges(self._s[1178]!, self._r[1178]!, [_0]) } - public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1177]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1179]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[1180]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[1181]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[1182]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1183]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1184]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[1185]! } - public var Checkout_PaymentMethod_Title: String { return self._s[1186]! } - public var SocksProxySetup_Connection: String { return self._s[1187]! } - public var Group_MessagePhotoRemoved: String { return self._s[1188]! } - public var PeopleNearby_MakeInvisible: String { return self._s[1190]! } - public var Channel_Stickers_NotFound: String { return self._s[1192]! } - public var Group_About_Help: String { return self._s[1193]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[1194]! } - public var PeopleNearby_Title: String { return self._s[1196]! } + public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1179]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1181]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1182]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1183]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1184]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1185]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1186]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1187]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1188]! } + public var SocksProxySetup_Connection: String { return self._s[1189]! } + public var Group_MessagePhotoRemoved: String { return self._s[1190]! } + public var PeopleNearby_MakeInvisible: String { return self._s[1192]! } + public var Channel_Stickers_NotFound: String { return self._s[1194]! } + public var Group_About_Help: String { return self._s[1195]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1196]! } + public var PeopleNearby_Title: String { return self._s[1198]! } public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1197]!, self._r[1197]!, [_1]) + return formatWithArgumentRanges(self._s[1199]!, self._r[1199]!, [_1]) } - public var Map_Home: String { return self._s[1198]! } - public var Stats_ZoomOut: String { return self._s[1199]! } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1201]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1202]! } - public var SocksProxySetup_Password: String { return self._s[1203]! } - public var Notifications_PermissionsEnable: String { return self._s[1204]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[1206]! } + public var Map_Home: String { return self._s[1200]! } + public var Stats_ZoomOut: String { return self._s[1201]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1203]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1204]! } + public var SocksProxySetup_Password: String { return self._s[1205]! } + public var Notifications_PermissionsEnable: String { return self._s[1206]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1208]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1207]!, self._r[1207]!, [_1]) + return formatWithArgumentRanges(self._s[1209]!, self._r[1209]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1209]!, self._r[1209]!, [_0]) + return formatWithArgumentRanges(self._s[1211]!, self._r[1211]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[1210]! } - public var ArchivedPacksAlert_Title: String { return self._s[1211]! } - public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1212]! } - public var Map_PlacesNearby: String { return self._s[1213]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[1212]! } + public var ArchivedPacksAlert_Title: String { return self._s[1213]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1214]! } + public var Map_PlacesNearby: String { return self._s[1215]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1214]!, self._r[1214]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1216]!, self._r[1216]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1215]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1218]! } - public var Conversation_StatusTyping: String { return self._s[1219]! } - public var Widget_ApplicationStartRequired: String { return self._s[1220]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[1221]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1222]! } - public var UserInfo_CreateNewContact: String { return self._s[1223]! } - public var Passport_Identity_FrontSide: String { return self._s[1224]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1225]! } - public var Calls_CallTabTitle: String { return self._s[1226]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1227]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1217]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1220]! } + public var Conversation_StatusTyping: String { return self._s[1221]! } + public var Widget_ApplicationStartRequired: String { return self._s[1222]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1223]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1224]! } + public var UserInfo_CreateNewContact: String { return self._s[1225]! } + public var Passport_Identity_FrontSide: String { return self._s[1226]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1227]! } + public var Calls_CallTabTitle: String { return self._s[1228]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1229]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1229]!, self._r[1229]!, [_0]) + return formatWithArgumentRanges(self._s[1231]!, self._r[1231]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[1230]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1231]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1232]! } - public var Wallet_Completed_Text: String { return self._s[1233]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1234]! } - public var Paint_Stickers: String { return self._s[1235]! } - public var Privacy_GroupsAndChannels: String { return self._s[1236]! } - public var ChatList_Context_Delete: String { return self._s[1238]! } - public var UserInfo_AddContact: String { return self._s[1239]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1232]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1233]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1234]! } + public var Wallet_Completed_Text: String { return self._s[1235]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1236]! } + public var Paint_Stickers: String { return self._s[1237]! } + public var Privacy_GroupsAndChannels: String { return self._s[1238]! } + public var ChatList_Context_Delete: String { return self._s[1240]! } + public var UserInfo_AddContact: String { return self._s[1241]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1240]!, self._r[1240]!, [_0]) + return formatWithArgumentRanges(self._s[1242]!, self._r[1242]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1242]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1244]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1244]!, self._r[1244]!, [_0]) + return formatWithArgumentRanges(self._s[1246]!, self._r[1246]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1245]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1246]! } - public var BlockedUsers_BlockUser: String { return self._s[1247]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1248]! } - public var MediaPicker_UngroupDescription: String { return self._s[1251]! } - public var Watch_NoConnection: String { return self._s[1252]! } - public var Month_GenSeptember: String { return self._s[1253]! } - public var Conversation_ViewGroup: String { return self._s[1255]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1258]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1259]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1260]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1261]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1262]! } - public var MediaPicker_CameraRoll: String { return self._s[1264]! } - public var Month_GenAugust: String { return self._s[1265]! } - public var Wallet_Configuration_SourceHeader: String { return self._s[1266]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1267]! } - public var SharedMedia_EmptyText: String { return self._s[1268]! } - public var Map_ShareLiveLocation: String { return self._s[1269]! } - public var Calls_All: String { return self._s[1270]! } - public var Map_SendThisPlace: String { return self._s[1272]! } - public var Appearance_ThemeNight: String { return self._s[1274]! } - public var Conversation_HoldForAudio: String { return self._s[1275]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1278]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1279]! } - public var SocksProxySetup_Secret: String { return self._s[1280]! } + public var DialogList_NoMessagesTitle: String { return self._s[1247]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1248]! } + public var BlockedUsers_BlockUser: String { return self._s[1249]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1250]! } + public var MediaPicker_UngroupDescription: String { return self._s[1253]! } + public var Watch_NoConnection: String { return self._s[1254]! } + public var Month_GenSeptember: String { return self._s[1255]! } + public var Conversation_ViewGroup: String { return self._s[1257]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1260]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1261]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1262]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1263]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1264]! } + public var MediaPicker_CameraRoll: String { return self._s[1266]! } + public var Month_GenAugust: String { return self._s[1267]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1268]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1269]! } + public var SharedMedia_EmptyText: String { return self._s[1270]! } + public var Map_ShareLiveLocation: String { return self._s[1271]! } + public var Calls_All: String { return self._s[1272]! } + public var Map_SendThisPlace: String { return self._s[1274]! } + public var Appearance_ThemeNight: String { return self._s[1276]! } + public var Conversation_HoldForAudio: String { return self._s[1277]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1280]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1281]! } + public var SocksProxySetup_Secret: String { return self._s[1282]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1281]!, self._r[1281]!, [_0]) + return formatWithArgumentRanges(self._s[1283]!, self._r[1283]!, [_0]) } - public var Channel_BanList_RestrictedTitle: String { return self._s[1283]! } - public var Conversation_Location: String { return self._s[1284]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1285]! } + public var Conversation_Location: String { return self._s[1286]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1285]!, self._r[1285]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1287]!, self._r[1287]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1287]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1288]! } - public var Notifications_PermissionsText: String { return self._s[1289]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1290]! } - public var Call_Flip: String { return self._s[1291]! } - public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1293]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1294]! } - public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1295]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1296]! } - public var Stats_GroupTopAdmin_Promote: String { return self._s[1298]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1299]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1301]! } - public var ChatList_EditFolders: String { return self._s[1303]! } - public var Channel_TooMuchBots: String { return self._s[1304]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1305]! } - public var Login_InvalidCodeError: String { return self._s[1306]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1307]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1289]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1290]! } + public var Notifications_PermissionsText: String { return self._s[1291]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1292]! } + public var Call_Flip: String { return self._s[1293]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1295]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1296]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1297]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1298]! } + public var Stats_GroupTopAdmin_Promote: String { return self._s[1300]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1301]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1303]! } + public var ChatList_EditFolders: String { return self._s[1305]! } + public var Channel_TooMuchBots: String { return self._s[1306]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1307]! } + public var Login_InvalidCodeError: String { return self._s[1308]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1309]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1308]!, self._r[1308]!, [_0]) + return formatWithArgumentRanges(self._s[1310]!, self._r[1310]!, [_0]) } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1309]!, self._r[1309]!, [_0]) + return formatWithArgumentRanges(self._s[1311]!, self._r[1311]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1310]! } - public var Call_CallInProgressTitle: String { return self._s[1311]! } - public var Month_ShortSeptember: String { return self._s[1312]! } - public var Watch_ChannelInfo_Title: String { return self._s[1313]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1316]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1317]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1318]! } - public var Wallet_Receive_Title: String { return self._s[1319]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1320]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1321]! } - public var PhotoEditor_CropReset: String { return self._s[1322]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1324]! } - public var Channel_Management_LabelEditor: String { return self._s[1325]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1327]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1328]! } - public var Wallet_Info_WalletCreated: String { return self._s[1329]! } - public var UserInfo_Title: String { return self._s[1330]! } - public var ChatList_HideAction: String { return self._s[1331]! } - public var AccessDenied_Title: String { return self._s[1332]! } - public var DialogList_SearchLabel: String { return self._s[1333]! } - public var Group_Setup_HistoryHidden: String { return self._s[1334]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1335]! } - public var State_Updating: String { return self._s[1337]! } - public var Contacts_TabTitle: String { return self._s[1338]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1340]! } - public var GroupInfo_GroupHistory: String { return self._s[1341]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1342]! } - public var Wallpaper_SetColor: String { return self._s[1343]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1344]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1345]! } - public var ChatList_ReorderTabs: String { return self._s[1346]! } - public var ChatListFolder_IncludeChatsTitle: String { return self._s[1347]! } - public var Chat_AttachmentLimitReached: String { return self._s[1348]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1349]! } - public var Contacts_NotRegisteredSection: String { return self._s[1350]! } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1312]! } + public var Call_CallInProgressTitle: String { return self._s[1313]! } + public var Month_ShortSeptember: String { return self._s[1314]! } + public var Watch_ChannelInfo_Title: String { return self._s[1315]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1318]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1319]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1320]! } + public var Wallet_Receive_Title: String { return self._s[1321]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1322]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1323]! } + public var PhotoEditor_CropReset: String { return self._s[1324]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1326]! } + public var Channel_Management_LabelEditor: String { return self._s[1327]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1329]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1330]! } + public var Wallet_Info_WalletCreated: String { return self._s[1331]! } + public var UserInfo_Title: String { return self._s[1332]! } + public var ChatList_HideAction: String { return self._s[1333]! } + public var AccessDenied_Title: String { return self._s[1334]! } + public var DialogList_SearchLabel: String { return self._s[1335]! } + public var Group_Setup_HistoryHidden: String { return self._s[1336]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1337]! } + public var State_Updating: String { return self._s[1339]! } + public var Contacts_TabTitle: String { return self._s[1340]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1342]! } + public var GroupInfo_GroupHistory: String { return self._s[1343]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1344]! } + public var Wallpaper_SetColor: String { return self._s[1345]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1346]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1347]! } + public var ChatList_ReorderTabs: String { return self._s[1348]! } + public var ChatListFolder_IncludeChatsTitle: String { return self._s[1349]! } + public var Chat_AttachmentLimitReached: String { return self._s[1350]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1351]! } + public var Contacts_NotRegisteredSection: String { return self._s[1352]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1351]!, self._r[1351]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1353]!, self._r[1353]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1352]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1353]! } - public var SocksProxySetup_Connecting: String { return self._s[1354]! } - public var ExplicitContent_AlertChannel: String { return self._s[1355]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1356]! } - public var Conversation_Contact: String { return self._s[1357]! } - public var Login_CodeExpired: String { return self._s[1358]! } - public var Passport_DiscardMessageAction: String { return self._s[1359]! } - public var ChatList_Context_Unpin: String { return self._s[1360]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1361]! } + public var Paint_Clear: String { return self._s[1354]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1355]! } + public var SocksProxySetup_Connecting: String { return self._s[1356]! } + public var ExplicitContent_AlertChannel: String { return self._s[1357]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1358]! } + public var Conversation_Contact: String { return self._s[1359]! } + public var Login_CodeExpired: String { return self._s[1360]! } + public var Passport_DiscardMessageAction: String { return self._s[1361]! } + public var ChatList_Context_Unpin: String { return self._s[1362]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1363]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1362]!, self._r[1362]!, [_0]) + return formatWithArgumentRanges(self._s[1364]!, self._r[1364]!, [_0]) } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1363]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1364]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1365]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1366]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1365]!, self._r[1365]!, [_0]) + return formatWithArgumentRanges(self._s[1367]!, self._r[1367]!, [_0]) } - public var Month_ShortApril: String { return self._s[1366]! } - public var AuthSessions_CurrentSession: String { return self._s[1367]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1370]! } - public var Wallet_Navigation_Cancel: String { return self._s[1372]! } - public var WallpaperPreview_CropTopText: String { return self._s[1373]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1374]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1376]! } + public var Month_ShortApril: String { return self._s[1368]! } + public var AuthSessions_CurrentSession: String { return self._s[1369]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1372]! } + public var Wallet_Navigation_Cancel: String { return self._s[1374]! } + public var WallpaperPreview_CropTopText: String { return self._s[1375]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1376]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1378]! } public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1377]!, self._r[1377]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1379]!, self._r[1379]!, [_0, _1]) } - public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1378]! } - public var Channel_Setup_TypePrivate: String { return self._s[1380]! } - public var Forward_ChannelReadOnly: String { return self._s[1383]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1384]! } - public var AddContact_SharedContactException: String { return self._s[1385]! } - public var UserInfo_BotPrivacy: String { return self._s[1387]! } - public var Wallet_CreateInvoice_Title: String { return self._s[1388]! } - public var Notification_PassportValueEmail: String { return self._s[1389]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1390]! } - public var GroupPermission_NewTitle: String { return self._s[1391]! } - public var CallFeedback_ReasonDropped: String { return self._s[1392]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1393]! } - public var Channel_SignMessages_Help: String { return self._s[1395]! } - public var Undo_ChatDeleted: String { return self._s[1397]! } - public var Conversation_ChatBackground: String { return self._s[1398]! } + public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1380]! } + public var Channel_Setup_TypePrivate: String { return self._s[1382]! } + public var Forward_ChannelReadOnly: String { return self._s[1385]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1386]! } + public var AddContact_SharedContactException: String { return self._s[1387]! } + public var UserInfo_BotPrivacy: String { return self._s[1389]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1390]! } + public var Notification_PassportValueEmail: String { return self._s[1391]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1392]! } + public var GroupPermission_NewTitle: String { return self._s[1393]! } + public var CallFeedback_ReasonDropped: String { return self._s[1394]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1395]! } + public var Channel_SignMessages_Help: String { return self._s[1397]! } + public var Undo_ChatDeleted: String { return self._s[1399]! } + public var Conversation_ChatBackground: String { return self._s[1400]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1399]!, self._r[1399]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1401]!, self._r[1401]!, [_1, _2, _3]) } public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1400]!, self._r[1400]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1402]!, self._r[1402]!, [_1, _2, _3]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1401]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1402]! } - public var Passport_Language_pt: String { return self._s[1403]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1404]! } - public var NotificationsSound_Popcorn: String { return self._s[1407]! } - public var AutoNightTheme_Disabled: String { return self._s[1408]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1409]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1410]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1411]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1412]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1403]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1404]! } + public var Passport_Language_pt: String { return self._s[1405]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1406]! } + public var NotificationsSound_Popcorn: String { return self._s[1409]! } + public var AutoNightTheme_Disabled: String { return self._s[1410]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1411]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1412]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1413]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1414]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1413]!, self._r[1413]!, [_0]) + return formatWithArgumentRanges(self._s[1415]!, self._r[1415]!, [_0]) } - public var ChatListFolder_TitleCreate: String { return self._s[1414]! } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1415]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1416]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1418]! } - public var PeerInfo_PaneGroups: String { return self._s[1419]! } + public var ChatListFolder_TitleCreate: String { return self._s[1416]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1417]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1418]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1420]! } + public var PeerInfo_PaneGroups: String { return self._s[1421]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1420]!, self._r[1420]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1422]!, self._r[1422]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1423]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1424]! } - public var Compose_NewEncryptedChat: String { return self._s[1425]! } - public var Login_CodeFloodError: String { return self._s[1426]! } - public var Calls_TabTitle: String { return self._s[1427]! } - public var Privacy_ProfilePhoto: String { return self._s[1428]! } - public var Passport_Language_he: String { return self._s[1429]! } + public var SocksProxySetup_Hostname: String { return self._s[1425]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1426]! } + public var Compose_NewEncryptedChat: String { return self._s[1427]! } + public var Login_CodeFloodError: String { return self._s[1428]! } + public var Calls_TabTitle: String { return self._s[1429]! } + public var Privacy_ProfilePhoto: String { return self._s[1430]! } + public var Passport_Language_he: String { return self._s[1431]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1430]!, self._r[1430]!, [_0]) + return formatWithArgumentRanges(self._s[1432]!, self._r[1432]!, [_0]) } - public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[1431]! } - public var GroupPermission_Title: String { return self._s[1432]! } + public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[1433]! } + public var GroupPermission_Title: String { return self._s[1434]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1433]!, self._r[1433]!, [_0]) + return formatWithArgumentRanges(self._s[1435]!, self._r[1435]!, [_0]) } - public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1434]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1435]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1436]! } - public var Tour_Text1: String { return self._s[1437]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1438]! } - public var Month_ShortFebruary: String { return self._s[1439]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1440]! } + public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1436]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1437]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1438]! } + public var Tour_Text1: String { return self._s[1439]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1440]! } + public var Month_ShortFebruary: String { return self._s[1441]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1442]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1441]!, self._r[1441]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1443]!, self._r[1443]!, [_1, _2, _3]) } - public var Stats_LanguagesTitle: String { return self._s[1442]! } - public var NotificationsSound_Glass: String { return self._s[1443]! } - public var Appearance_ThemeNightBlue: String { return self._s[1444]! } - public var CheckoutInfo_Pay: String { return self._s[1445]! } - public var PeerInfo_ButtonLeave: String { return self._s[1447]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1448]! } - public var Call_CallAgain: String { return self._s[1450]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1451]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1452]! } - public var Passport_InvalidPasswordError: String { return self._s[1453]! } - public var Watch_Message_Game: String { return self._s[1454]! } - public var Stickers_Install: String { return self._s[1455]! } - public var VoiceOver_Chat_Message: String { return self._s[1456]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1457]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1459]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1460]! } - public var AuthSessions_OtherSessions: String { return self._s[1461]! } - public var Channel_Username_Help: String { return self._s[1462]! } - public var Camera_Title: String { return self._s[1463]! } - public var IntentsSettings_Title: String { return self._s[1465]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1467]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1468]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1469]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1470]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1471]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1472]! } - public var ScheduledMessages_DeleteMany: String { return self._s[1473]! } - public var Conversation_RestrictedStickers: String { return self._s[1474]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1476]! } - public var UserInfo_TelegramCall: String { return self._s[1478]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1479]! } - public var CreatePoll_OptionsHeader: String { return self._s[1480]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1481]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1482]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1483]! } - public var Theme_Colors_Proceed: String { return self._s[1484]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1485]! } + public var Stats_LanguagesTitle: String { return self._s[1444]! } + public var NotificationsSound_Glass: String { return self._s[1445]! } + public var Appearance_ThemeNightBlue: String { return self._s[1446]! } + public var CheckoutInfo_Pay: String { return self._s[1447]! } + public var PeerInfo_ButtonLeave: String { return self._s[1449]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1450]! } + public var Call_CallAgain: String { return self._s[1452]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1453]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1454]! } + public var Passport_InvalidPasswordError: String { return self._s[1455]! } + public var Watch_Message_Game: String { return self._s[1456]! } + public var Stickers_Install: String { return self._s[1457]! } + public var VoiceOver_Chat_Message: String { return self._s[1458]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1459]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1461]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1462]! } + public var AuthSessions_OtherSessions: String { return self._s[1463]! } + public var Channel_Username_Help: String { return self._s[1464]! } + public var Camera_Title: String { return self._s[1465]! } + public var IntentsSettings_Title: String { return self._s[1467]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1469]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1470]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1471]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1472]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1473]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1474]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1475]! } + public var Conversation_RestrictedStickers: String { return self._s[1476]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1478]! } + public var UserInfo_TelegramCall: String { return self._s[1480]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1481]! } + public var CreatePoll_OptionsHeader: String { return self._s[1482]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1483]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1484]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1485]! } + public var Theme_Colors_Proceed: String { return self._s[1486]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1487]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1486]!, self._r[1486]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1488]!, self._r[1488]!, [_1, _2, _3]) } - public var Wallet_Month_GenAugust: String { return self._s[1487]! } - public var Settings_SaveEditedPhotos: String { return self._s[1488]! } - public var Stats_FollowersBySourceTitle: String { return self._s[1489]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1490]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1491]! } - public var Conversation_MessageDialogRetry: String { return self._s[1492]! } - public var ChatList_Context_MarkAsUnread: String { return self._s[1493]! } - public var MessagePoll_SubmitVote: String { return self._s[1494]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1495]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1496]! } - public var ChatList_Context_Back: String { return self._s[1497]! } - public var Group_Setup_TypeHeader: String { return self._s[1498]! } - public var Paint_RecentStickers: String { return self._s[1499]! } - public var PhotoEditor_GrainTool: String { return self._s[1500]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1501]! } - public var EmptyGroupInfo_Line4: String { return self._s[1502]! } - public var Watch_AuthRequired: String { return self._s[1504]! } + public var Wallet_Month_GenAugust: String { return self._s[1489]! } + public var Settings_SaveEditedPhotos: String { return self._s[1490]! } + public var Stats_FollowersBySourceTitle: String { return self._s[1491]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1492]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1493]! } + public var Conversation_MessageDialogRetry: String { return self._s[1494]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1495]! } + public var MessagePoll_SubmitVote: String { return self._s[1496]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1497]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1498]! } + public var ChatList_Context_Back: String { return self._s[1499]! } + public var Group_Setup_TypeHeader: String { return self._s[1500]! } + public var Paint_RecentStickers: String { return self._s[1501]! } + public var PhotoEditor_GrainTool: String { return self._s[1502]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1503]! } + public var EmptyGroupInfo_Line4: String { return self._s[1504]! } + public var Watch_AuthRequired: String { return self._s[1506]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1505]!, self._r[1505]!, [_0]) + return formatWithArgumentRanges(self._s[1507]!, self._r[1507]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1506]! } - public var ChannelIntro_Text: String { return self._s[1507]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1508]! } - public var GroupPermission_NoSendMedia: String { return self._s[1509]! } - public var Calls_AddTab: String { return self._s[1510]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1511]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1512]! } - public var Conversation_WalletRequiredSetup: String { return self._s[1513]! } - public var Notification_MessageLifetime1d: String { return self._s[1514]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1515]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1516]! } - public var Passport_Identity_GenderFemale: String { return self._s[1517]! } - public var BlockedUsers_BlockTitle: String { return self._s[1518]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1508]! } + public var ChannelIntro_Text: String { return self._s[1509]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1510]! } + public var GroupPermission_NoSendMedia: String { return self._s[1511]! } + public var Calls_AddTab: String { return self._s[1512]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1513]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1514]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1515]! } + public var Notification_MessageLifetime1d: String { return self._s[1516]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1517]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1518]! } + public var Passport_Identity_GenderFemale: String { return self._s[1519]! } + public var BlockedUsers_BlockTitle: String { return self._s[1520]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1519]!, self._r[1519]!, [_1]) + return formatWithArgumentRanges(self._s[1521]!, self._r[1521]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1520]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1521]! } - public var Settings_Context_Logout: String { return self._s[1522]! } - public var Wallet_Info_UnknownTransaction: String { return self._s[1523]! } - public var ChatList_ArchiveAction: String { return self._s[1524]! } - public var AutoNightTheme_Scheduled: String { return self._s[1525]! } - public var TwoFactorSetup_Email_SkipAction: String { return self._s[1526]! } - public var Settings_Devices: String { return self._s[1527]! } - public var ContactInfo_Note: String { return self._s[1528]! } + public var Weekday_Yesterday: String { return self._s[1522]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1523]! } + public var Settings_Context_Logout: String { return self._s[1524]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1525]! } + public var ChatList_ArchiveAction: String { return self._s[1526]! } + public var AutoNightTheme_Scheduled: String { return self._s[1527]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1528]! } + public var Settings_Devices: String { return self._s[1529]! } + public var ContactInfo_Note: String { return self._s[1530]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1529]!, self._r[1529]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1531]!, self._r[1531]!, [_1, _2, _3, _4, _5, _6]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1530]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[1531]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1532]! } - public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1533]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1532]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1533]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1534]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1535]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1534]!, self._r[1534]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1536]!, self._r[1536]!, [_1, _2]) } - public var CreatePoll_Create: String { return self._s[1535]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1536]! } + public var CreatePoll_Create: String { return self._s[1537]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1538]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1537]!, self._r[1537]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1539]!, self._r[1539]!, [_1, _2]) } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1538]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1539]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1541]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1540]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1541]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1543]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1542]!, self._r[1542]!, [_1]) + return formatWithArgumentRanges(self._s[1544]!, self._r[1544]!, [_1]) } - public var Preview_OpenInInstagram: String { return self._s[1543]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1544]! } + public var Preview_OpenInInstagram: String { return self._s[1545]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1546]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1545]!, self._r[1545]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1547]!, self._r[1547]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1546]!, self._r[1546]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1548]!, self._r[1548]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1547]! } - public var ArchivedChats_IntroText3: String { return self._s[1548]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1549]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1550]! } - public var Wallet_Month_GenSeptember: String { return self._s[1551]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1552]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1549]! } + public var ArchivedChats_IntroText3: String { return self._s[1550]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1551]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1552]! } + public var Wallet_Month_GenSeptember: String { return self._s[1553]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1554]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1553]!, self._r[1553]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1555]!, self._r[1555]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1555]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1556]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1557]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1558]! } - public var Gif_NoGifsFound: String { return self._s[1559]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1560]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1561]! } - public var EditTheme_Preview: String { return self._s[1562]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1557]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1558]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1559]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1560]! } + public var Gif_NoGifsFound: String { return self._s[1561]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1562]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1563]! } + public var EditTheme_Preview: String { return self._s[1564]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1563]!, self._r[1563]!, [_0]) + return formatWithArgumentRanges(self._s[1565]!, self._r[1565]!, [_0]) } - public var GroupInfo_ActionPromote: String { return self._s[1564]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1565]! } - public var GroupInfo_Permissions_Title: String { return self._s[1566]! } - public var Permissions_ContactsText_v0: String { return self._s[1567]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1568]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1569]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1572]! } - public var Passport_FieldEmailHelp: String { return self._s[1573]! } + public var GroupInfo_ActionPromote: String { return self._s[1566]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1567]! } + public var GroupInfo_Permissions_Title: String { return self._s[1568]! } + public var Permissions_ContactsText_v0: String { return self._s[1569]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1570]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1571]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1574]! } + public var Passport_FieldEmailHelp: String { return self._s[1575]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1574]!, self._r[1574]!, [_0]) + return formatWithArgumentRanges(self._s[1576]!, self._r[1576]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1575]! } - public var Weekday_ShortSaturday: String { return self._s[1576]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1577]! } - public var Watch_Conversation_UserInfo: String { return self._s[1578]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1579]! } - public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1580]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1581]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1583]! } - public var PhotoEditor_VignetteTool: String { return self._s[1584]! } - public var Conversation_ContextMenuDiscuss: String { return self._s[1585]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1586]! } - public var Passport_Language_et: String { return self._s[1587]! } - public var AppUpgrade_Running: String { return self._s[1588]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1590]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1591]! } - public var Passport_Language_bg: String { return self._s[1592]! } - public var Stickers_NoStickersFound: String { return self._s[1594]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1577]! } + public var Weekday_ShortSaturday: String { return self._s[1578]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1579]! } + public var Watch_Conversation_UserInfo: String { return self._s[1580]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1581]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1582]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1583]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1585]! } + public var PhotoEditor_VignetteTool: String { return self._s[1586]! } + public var Conversation_ContextMenuDiscuss: String { return self._s[1587]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1588]! } + public var Passport_Language_et: String { return self._s[1589]! } + public var AppUpgrade_Running: String { return self._s[1590]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1592]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1593]! } + public var Passport_Language_bg: String { return self._s[1594]! } + public var Stickers_NoStickersFound: String { return self._s[1596]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1596]!, self._r[1596]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1598]!, self._r[1598]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1597]!, self._r[1597]!, [_0]) + return formatWithArgumentRanges(self._s[1599]!, self._r[1599]!, [_0]) } - public var Wallet_Month_GenJuly: String { return self._s[1598]! } - public var Wallet_Receive_AddressHeader: String { return self._s[1600]! } - public var Wallet_Send_AmountText: String { return self._s[1601]! } - public var Settings_About: String { return self._s[1602]! } + public var Wallet_Month_GenJuly: String { return self._s[1600]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1602]! } + public var Wallet_Send_AmountText: String { return self._s[1603]! } + public var Settings_About: String { return self._s[1604]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1603]!, self._r[1603]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1605]!, self._r[1605]!, [_0, _1, _2]) } - public var ChatList_Context_MarkAsRead: String { return self._s[1605]! } - public var KeyCommand_NewMessage: String { return self._s[1606]! } - public var Group_ErrorAddBlocked: String { return self._s[1607]! } + public var ChatList_Context_MarkAsRead: String { return self._s[1607]! } + public var KeyCommand_NewMessage: String { return self._s[1608]! } + public var Group_ErrorAddBlocked: String { return self._s[1609]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1608]!, self._r[1608]!, [_0]) + return formatWithArgumentRanges(self._s[1610]!, self._r[1610]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1609]! } - public var ReportGroupLocation_Title: String { return self._s[1610]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1611]! } - public var Cache_ClearProgress: String { return self._s[1612]! } + public var Map_LocationTitle: String { return self._s[1611]! } + public var ReportGroupLocation_Title: String { return self._s[1612]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1613]! } + public var Cache_ClearProgress: String { return self._s[1614]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1613]!, self._r[1613]!, [_0]) - } - public var GroupRemoved_AddToGroup: String { return self._s[1614]! } - public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1615]!, self._r[1615]!, [_0]) } - public var Passport_UpdateRequiredError: String { return self._s[1616]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1617]! } + public var GroupRemoved_AddToGroup: String { return self._s[1616]! } + public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1617]!, self._r[1617]!, [_0]) + } + public var Passport_UpdateRequiredError: String { return self._s[1618]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1619]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1618]!, self._r[1618]!, [_1]) + return formatWithArgumentRanges(self._s[1620]!, self._r[1620]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1620]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1621]! } - public var PeerInfo_ButtonSearch: String { return self._s[1622]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1623]! } - public var Passport_Language_ka: String { return self._s[1624]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1622]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1623]! } + public var PeerInfo_ButtonSearch: String { return self._s[1624]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1625]! } + public var Passport_Language_ka: String { return self._s[1626]! } public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1625]!, self._r[1625]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1627]!, self._r[1627]!, [_1, _2, _3]) } - public var Call_Decline: String { return self._s[1626]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1627]! } - public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1630]! } + public var Call_Decline: String { return self._s[1628]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1629]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1632]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1631]!, self._r[1631]!, [_0]) + return formatWithArgumentRanges(self._s[1633]!, self._r[1633]!, [_0]) } - public var CallFeedback_Send: String { return self._s[1632]! } - public var EditTheme_EditTitle: String { return self._s[1633]! } + public var CallFeedback_Send: String { return self._s[1634]! } + public var EditTheme_EditTitle: String { return self._s[1635]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1636]!, self._r[1636]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1635]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1637]! } public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1637]!, self._r[1637]!, [_0]) + return formatWithArgumentRanges(self._s[1639]!, self._r[1639]!, [_0]) } - public var Media_SendingOptionsTooltip: String { return self._s[1638]! } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1639]! } - public var Passport_DeletePassport: String { return self._s[1640]! } - public var Appearance_AppIconFilled: String { return self._s[1641]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1642]! } - public var Month_ShortDecember: String { return self._s[1643]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1645]! } + public var Media_SendingOptionsTooltip: String { return self._s[1640]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1641]! } + public var Passport_DeletePassport: String { return self._s[1642]! } + public var Appearance_AppIconFilled: String { return self._s[1643]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1644]! } + public var Month_ShortDecember: String { return self._s[1645]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1647]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1646]!, self._r[1646]!, [_0]) + return formatWithArgumentRanges(self._s[1648]!, self._r[1648]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1647]! } - public var Conversation_EncryptedDescription1: String { return self._s[1648]! } - public var Conversation_EncryptedDescription2: String { return self._s[1649]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1650]! } - public var ChatListFolder_NameUnread: String { return self._s[1652]! } - public var Conversation_EncryptedDescription3: String { return self._s[1653]! } - public var PhotoEditor_SharpenTool: String { return self._s[1654]! } - public var Wallet_Configuration_Title: String { return self._s[1655]! } + public var Channel_Stickers_Searching: String { return self._s[1649]! } + public var Conversation_EncryptedDescription1: String { return self._s[1650]! } + public var Conversation_EncryptedDescription2: String { return self._s[1651]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1652]! } + public var ChatListFolder_NameUnread: String { return self._s[1654]! } + public var Conversation_EncryptedDescription3: String { return self._s[1655]! } + public var PhotoEditor_SharpenTool: String { return self._s[1656]! } + public var Wallet_Configuration_Title: String { return self._s[1657]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1656]!, self._r[1656]!, [_0]) + return formatWithArgumentRanges(self._s[1658]!, self._r[1658]!, [_0]) } - public var Conversation_EncryptedDescription4: String { return self._s[1659]! } - public var Channel_Members_AddMembers: String { return self._s[1660]! } - public var Wallpaper_Search: String { return self._s[1661]! } + public var Conversation_EncryptedDescription4: String { return self._s[1661]! } + public var Channel_Members_AddMembers: String { return self._s[1662]! } + public var Wallpaper_Search: String { return self._s[1663]! } public func Message_GenericForwardedPsa(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1663]!, self._r[1663]!, [_0]) + return formatWithArgumentRanges(self._s[1665]!, self._r[1665]!, [_0]) } - public var Weekday_Friday: String { return self._s[1664]! } - public var Privacy_ContactsSync: String { return self._s[1665]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1666]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1667]! } + public var Weekday_Friday: String { return self._s[1666]! } + public var Privacy_ContactsSync: String { return self._s[1667]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1668]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1669]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1668]!, self._r[1668]!, [_0]) + return formatWithArgumentRanges(self._s[1670]!, self._r[1670]!, [_0]) } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1669]! } - public var GroupInfo_Permissions_Removed: String { return self._s[1670]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[1671]! } - public var Passport_Identity_GenderMale: String { return self._s[1672]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1671]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1672]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1673]! } + public var Passport_Identity_GenderMale: String { return self._s[1674]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1673]!, self._r[1673]!, [_0]) + return formatWithArgumentRanges(self._s[1675]!, self._r[1675]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1674]! } - public var Conversation_JumpToDate: String { return self._s[1675]! } - public var Contacts_GlobalSearch: String { return self._s[1676]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1677]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1678]! } - public var ChatListFolderSettings_NewFolder: String { return self._s[1679]! } - public var Profile_MessageLifetime1d: String { return self._s[1680]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1676]! } + public var Conversation_JumpToDate: String { return self._s[1677]! } + public var Contacts_GlobalSearch: String { return self._s[1678]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1679]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1680]! } + public var ChatListFolderSettings_NewFolder: String { return self._s[1681]! } + public var Profile_MessageLifetime1d: String { return self._s[1682]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1681]!, self._r[1681]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1683]!, self._r[1683]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1684]! } + public var StickerPack_BuiltinPackName: String { return self._s[1686]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1685]!, self._r[1685]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1687]!, self._r[1687]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1686]! } - public var Passport_InfoTitle: String { return self._s[1688]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1689]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1688]! } + public var Passport_InfoTitle: String { return self._s[1690]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1691]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1693]!, self._r[1693]!, [_0]) + return formatWithArgumentRanges(self._s[1695]!, self._r[1695]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1694]!, self._r[1694]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1696]!, self._r[1696]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1695]! } - public var Profile_BotInfo: String { return self._s[1696]! } - public var Watch_Compose_CreateMessage: String { return self._s[1697]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1698]! } - public var Month_ShortNovember: String { return self._s[1699]! } - public var Conversation_ScamWarning: String { return self._s[1700]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1701]! } - public var Appearance_TextSize_Title: String { return self._s[1702]! } - public var ChatList_EmptyChatListFilterTitle: String { return self._s[1703]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1704]! } - public var NotificationsSound_Chime: String { return self._s[1705]! } - public var Passport_Language_ko: String { return self._s[1707]! } - public var InviteText_URL: String { return self._s[1708]! } - public var TextFormat_Monospace: String { return self._s[1709]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1697]! } + public var Profile_BotInfo: String { return self._s[1698]! } + public var Watch_Compose_CreateMessage: String { return self._s[1699]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1700]! } + public var Month_ShortNovember: String { return self._s[1701]! } + public var Conversation_ScamWarning: String { return self._s[1702]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1703]! } + public var Appearance_TextSize_Title: String { return self._s[1704]! } + public var ChatList_EmptyChatListFilterTitle: String { return self._s[1705]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1706]! } + public var NotificationsSound_Chime: String { return self._s[1707]! } + public var Passport_Language_ko: String { return self._s[1709]! } + public var InviteText_URL: String { return self._s[1710]! } + public var TextFormat_Monospace: String { return self._s[1711]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1710]!, self._r[1710]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1712]!, self._r[1712]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1711]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1713]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1712]!, self._r[1712]!, [_0]) + return formatWithArgumentRanges(self._s[1714]!, self._r[1714]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1713]!, self._r[1713]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1715]!, self._r[1715]!, [_1, _2]) } - public var Wallet_Words_Title: String { return self._s[1714]! } - public var Wallet_Month_ShortMay: String { return self._s[1715]! } - public var EditTheme_CreateTitle: String { return self._s[1717]! } - public var Passport_InfoLearnMore: String { return self._s[1718]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1719]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1720]! } - public var Your_card_has_expired: String { return self._s[1721]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1722]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1723]! } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1727]! } - public var Conversation_Report: String { return self._s[1729]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1730]! } - public var Notification_MessageLifetime1m: String { return self._s[1731]! } - public var Privacy_ContactsTitle: String { return self._s[1732]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1733]! } - public var Wallet_WordCheck_Title: String { return self._s[1734]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1735]! } - public var Channel_Members_Title: String { return self._s[1736]! } - public var Map_OpenInWaze: String { return self._s[1737]! } - public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1738]! } - public var Stats_GroupTopWeekdaysTitle: String { return self._s[1739]! } - public var Login_PhoneBannedError: String { return self._s[1740]! } - public var PeerInfo_GroupAboutItem: String { return self._s[1741]! } + public var Wallet_Words_Title: String { return self._s[1716]! } + public var Wallet_Month_ShortMay: String { return self._s[1717]! } + public var EditTheme_CreateTitle: String { return self._s[1719]! } + public var Passport_InfoLearnMore: String { return self._s[1720]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1721]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1722]! } + public var Your_card_has_expired: String { return self._s[1723]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1724]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1725]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1729]! } + public var Conversation_Report: String { return self._s[1731]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1732]! } + public var Notification_MessageLifetime1m: String { return self._s[1733]! } + public var Privacy_ContactsTitle: String { return self._s[1734]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1735]! } + public var Wallet_WordCheck_Title: String { return self._s[1736]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1737]! } + public var Channel_Members_Title: String { return self._s[1738]! } + public var Map_OpenInWaze: String { return self._s[1739]! } + public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1740]! } + public var Stats_GroupTopWeekdaysTitle: String { return self._s[1741]! } + public var Login_PhoneBannedError: String { return self._s[1742]! } + public var PeerInfo_GroupAboutItem: String { return self._s[1743]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1742]!, self._r[1742]!, [_0]) + return formatWithArgumentRanges(self._s[1744]!, self._r[1744]!, [_0]) } - public var IntentsSettings_MainAccount: String { return self._s[1743]! } - public var Group_Management_AddModeratorHelp: String { return self._s[1744]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1745]! } - public var Common_OK: String { return self._s[1746]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1747]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[1748]! } - public var Cache_Music: String { return self._s[1749]! } - public var Wallet_Configuration_SourceURL: String { return self._s[1750]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1751]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1754]! } - public var ChatList_EmptyChatListEditFilter: String { return self._s[1755]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1756]! } + public var IntentsSettings_MainAccount: String { return self._s[1745]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1746]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1747]! } + public var Common_OK: String { return self._s[1748]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1749]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1750]! } + public var Cache_Music: String { return self._s[1751]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1752]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1753]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1756]! } + public var ChatList_EmptyChatListEditFilter: String { return self._s[1757]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1758]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1757]!, self._r[1757]!, [_1]) + return formatWithArgumentRanges(self._s[1759]!, self._r[1759]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1758]!, self._r[1758]!, [_0]) - } - public var TwoFactorSetup_Done_Action: String { return self._s[1759]! } - public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1760]!, self._r[1760]!, [_0]) } - public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1761]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1763]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1764]! } - public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1766]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1767]! } - public var State_ConnectingToProxyInfo: String { return self._s[1768]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[1769]! } - public var Message_VideoMessage: String { return self._s[1771]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1772]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1773]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1774]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1775]! } - public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1776]!, self._r[1776]!, [_1, _2, _3]) + public var TwoFactorSetup_Done_Action: String { return self._s[1761]! } + public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1762]!, self._r[1762]!, [_0]) } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1777]! } - public var Activity_RecordingAudio: String { return self._s[1778]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1779]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1780]! } - public var Wallet_Info_Address: String { return self._s[1781]! } + public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1763]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1765]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1766]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1768]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1769]! } + public var State_ConnectingToProxyInfo: String { return self._s[1770]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1771]! } + public var Message_VideoMessage: String { return self._s[1773]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1774]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1775]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1776]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1777]! } + public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_1, _2, _3]) + } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1779]! } + public var Activity_RecordingAudio: String { return self._s[1780]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1781]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1782]! } + public var Wallet_Info_Address: String { return self._s[1783]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1783]!, self._r[1783]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1785]!, self._r[1785]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1787]!, self._r[1787]!, [_0]) + return formatWithArgumentRanges(self._s[1789]!, self._r[1789]!, [_0]) } - public var ChatList_RemoveFolderConfirmation: String { return self._s[1788]! } - public var Conversation_ApplyLocalization: String { return self._s[1789]! } + public var ChatList_RemoveFolderConfirmation: String { return self._s[1790]! } + public var Conversation_ApplyLocalization: String { return self._s[1791]! } public func Conversation_PeerNearbyDistance(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1792]!, self._r[1792]!, [_0, _1]) } - public var TwoFactorSetup_Intro_Action: String { return self._s[1791]! } - public var UserInfo_AddPhone: String { return self._s[1793]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1794]! } + public var TwoFactorSetup_Intro_Action: String { return self._s[1793]! } + public var UserInfo_AddPhone: String { return self._s[1795]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1796]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1795]!, self._r[1795]!, [_0]) + return formatWithArgumentRanges(self._s[1797]!, self._r[1797]!, [_0]) } - public var ChatListFolder_CategoryArchived: String { return self._s[1797]! } - public var Passport_Scans: String { return self._s[1798]! } - public var BlockedUsers_Unblock: String { return self._s[1799]! } + public var ChatListFolder_CategoryArchived: String { return self._s[1799]! } + public var Passport_Scans: String { return self._s[1800]! } + public var BlockedUsers_Unblock: String { return self._s[1801]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1800]!, self._r[1800]!, [_1]) + return formatWithArgumentRanges(self._s[1802]!, self._r[1802]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1801]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1802]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1803]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1804]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1805]! } + public var Channel_Management_LabelCreator: String { return self._s[1803]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1804]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1805]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1806]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1807]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1806]!, self._r[1806]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1808]!, self._r[1808]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1807]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1808]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1809]! } - public var ChannelIntro_CreateChannel: String { return self._s[1810]! } - public var Conversation_UnreadMessages: String { return self._s[1811]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1812]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1813]! } - public var Theme_Context_Apply: String { return self._s[1814]! } - public var Notification_GroupActivated: String { return self._s[1815]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1816]! } - public var Wallet_Intro_CreateWallet: String { return self._s[1817]! } + public var Login_PhoneNumberHelp: String { return self._s[1809]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1810]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1811]! } + public var ChannelIntro_CreateChannel: String { return self._s[1812]! } + public var Conversation_UnreadMessages: String { return self._s[1813]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1814]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1815]! } + public var Theme_Context_Apply: String { return self._s[1816]! } + public var Notification_GroupActivated: String { return self._s[1817]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1818]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1819]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1818]!, self._r[1818]!, [_0]) + return formatWithArgumentRanges(self._s[1820]!, self._r[1820]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1819]!, self._r[1819]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1821]!, self._r[1821]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1821]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1823]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1822]!, self._r[1822]!, [_0]) + return formatWithArgumentRanges(self._s[1824]!, self._r[1824]!, [_0]) } - public var Undo_DeletedChannel: String { return self._s[1823]! } - public var CallFeedback_AddComment: String { return self._s[1824]! } + public var Undo_DeletedChannel: String { return self._s[1825]! } + public var CallFeedback_AddComment: String { return self._s[1826]! } public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1825]!, self._r[1825]!, [_0]) - } - public var Document_TargetConfirmationFormat: String { return self._s[1826]! } - public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1827]!, self._r[1827]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1828]! } + public var Document_TargetConfirmationFormat: String { return self._s[1828]! } + public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1829]!, self._r[1829]!, [_0]) + } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1830]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1829]!, self._r[1829]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1831]!, self._r[1831]!, [_1, _2, _3, _4]) } - public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1830]! } - public var Theme_ErrorNotFound: String { return self._s[1831]! } - public var Contacts_SortByName: String { return self._s[1832]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1833]! } + public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1832]! } + public var Theme_ErrorNotFound: String { return self._s[1833]! } + public var Contacts_SortByName: String { return self._s[1834]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1835]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1835]!, self._r[1835]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1837]!, self._r[1837]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1836]! } - public var ScheduledMessages_EditTime: String { return self._s[1837]! } - public var Conversation_ClearSelfHistory: String { return self._s[1838]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1839]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1840]! } - public var Stickers_SuggestNone: String { return self._s[1841]! } - public var ChatSettings_Cache: String { return self._s[1842]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1843]! } - public var Media_ShareThisPhoto: String { return self._s[1844]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1845]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1846]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1847]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1848]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1849]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1850]! } - public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1851]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1838]! } + public var ScheduledMessages_EditTime: String { return self._s[1839]! } + public var Conversation_ClearSelfHistory: String { return self._s[1840]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1841]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1842]! } + public var Stickers_SuggestNone: String { return self._s[1843]! } + public var ChatSettings_Cache: String { return self._s[1844]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1845]! } + public var Media_ShareThisPhoto: String { return self._s[1846]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1847]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1848]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1849]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1850]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1851]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1852]! } + public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1853]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1852]!, self._r[1852]!, [_0]) + return formatWithArgumentRanges(self._s[1854]!, self._r[1854]!, [_0]) } - public var PhotoEditor_BlurToolPortrait: String { return self._s[1853]! } - public var Permissions_CellularDataTitle_v0: String { return self._s[1854]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1856]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1857]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1858]! } - public var Map_OpenIn: String { return self._s[1859]! } - public var PeerInfo_ButtonCall: String { return self._s[1860]! } + public var PhotoEditor_BlurToolPortrait: String { return self._s[1855]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1856]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1858]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1859]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1860]! } + public var Map_OpenIn: String { return self._s[1861]! } + public var PeerInfo_ButtonCall: String { return self._s[1862]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1864]!, self._r[1864]!, [_1]) + return formatWithArgumentRanges(self._s[1866]!, self._r[1866]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1865]!, self._r[1865]!, [_0]) + return formatWithArgumentRanges(self._s[1867]!, self._r[1867]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1866]! } - public var MessagePoll_LabelClosed: String { return self._s[1867]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1869]! } - public var Wallet_Send_SendAnyway: String { return self._s[1870]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1871]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1872]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1873]! } - public var Map_SetThisPlace: String { return self._s[1874]! } - public var Stats_GroupTopAdmin_Actions: String { return self._s[1875]! } - public var Login_SelectCountry_Title: String { return self._s[1876]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1877]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1868]! } + public var MessagePoll_LabelClosed: String { return self._s[1869]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1871]! } + public var Wallet_Send_SendAnyway: String { return self._s[1872]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1873]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1874]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1875]! } + public var Map_SetThisPlace: String { return self._s[1876]! } + public var Stats_GroupTopAdmin_Actions: String { return self._s[1877]! } + public var Login_SelectCountry_Title: String { return self._s[1878]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1879]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1878]!, self._r[1878]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1880]!, self._r[1880]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1879]! } - public var Watch_Suggestion_BRB: String { return self._s[1880]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1881]! } - public var Contacts_PermissionsTitle: String { return self._s[1882]! } - public var Conversation_RestrictedInline: String { return self._s[1883]! } - public var Appearance_RemoveThemeColor: String { return self._s[1885]! } - public var StickerPack_ViewPack: String { return self._s[1886]! } - public var Wallet_UnknownError: String { return self._s[1887]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1881]! } + public var Watch_Suggestion_BRB: String { return self._s[1882]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1883]! } + public var Contacts_PermissionsTitle: String { return self._s[1884]! } + public var Conversation_RestrictedInline: String { return self._s[1885]! } + public var Appearance_RemoveThemeColor: String { return self._s[1887]! } + public var StickerPack_ViewPack: String { return self._s[1888]! } + public var Wallet_UnknownError: String { return self._s[1889]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1888]!, self._r[1888]!, [_0]) + return formatWithArgumentRanges(self._s[1890]!, self._r[1890]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1890]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1894]! } - public var MessagePoll_LabelQuiz: String { return self._s[1896]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1897]! } - public var Channel_Info_Stickers: String { return self._s[1898]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1899]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1900]! } - public var Passport_DeletePersonalDetails: String { return self._s[1901]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1902]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1903]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1904]! } - public var Stats_LoadingText: String { return self._s[1907]! } - public var Conversation_SearchNoResults: String { return self._s[1908]! } - public var ChatList_AddFolder: String { return self._s[1909]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1910]! } - public var ChatListFolder_NameNonContacts: String { return self._s[1911]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1912]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1913]! } - public var Login_Code: String { return self._s[1914]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1915]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1916]! } - public var Weekday_ShortThursday: String { return self._s[1917]! } - public var Resolve_ErrorNotFound: String { return self._s[1919]! } - public var LastSeen_Offline: String { return self._s[1920]! } - public var PeopleNearby_NoMembers: String { return self._s[1921]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1922]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1923]! } - public var Conversation_Dice_u1F3AF: String { return self._s[1925]! } - public var GroupInfo_Title: String { return self._s[1926]! } - public var NotificationsSound_Note: String { return self._s[1927]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1928]! } - public var Watch_Message_Poll: String { return self._s[1929]! } - public var Privacy_Calls: String { return self._s[1930]! } + public var Compose_NewChannel: String { return self._s[1892]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1896]! } + public var MessagePoll_LabelQuiz: String { return self._s[1898]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1899]! } + public var Channel_Info_Stickers: String { return self._s[1900]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1901]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1902]! } + public var Passport_DeletePersonalDetails: String { return self._s[1903]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1904]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1905]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1906]! } + public var Stats_LoadingText: String { return self._s[1909]! } + public var Conversation_SearchNoResults: String { return self._s[1910]! } + public var ChatList_AddFolder: String { return self._s[1911]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1912]! } + public var ChatListFolder_NameNonContacts: String { return self._s[1913]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1914]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1915]! } + public var Login_Code: String { return self._s[1916]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1917]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1918]! } + public var Weekday_ShortThursday: String { return self._s[1919]! } + public var Notification_VideoCallOutgoing: String { return self._s[1920]! } + public var Resolve_ErrorNotFound: String { return self._s[1921]! } + public var LastSeen_Offline: String { return self._s[1923]! } + public var PeopleNearby_NoMembers: String { return self._s[1924]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1925]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1926]! } + public var Conversation_Dice_u1F3AF: String { return self._s[1928]! } + public var GroupInfo_Title: String { return self._s[1929]! } + public var NotificationsSound_Note: String { return self._s[1930]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1931]! } + public var Watch_Message_Poll: String { return self._s[1932]! } + public var Privacy_Calls: String { return self._s[1933]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1931]!, self._r[1931]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1934]!, self._r[1934]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1932]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1933]! } - public var Notifications_Reset: String { return self._s[1934]! } - public var Conversation_Pin: String { return self._s[1935]! } - public var Passport_Language_lv: String { return self._s[1936]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1937]! } - public var BlockedUsers_Info: String { return self._s[1938]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1940]! } - public var Watch_Conversation_Unblock: String { return self._s[1942]! } + public var Month_ShortAugust: String { return self._s[1935]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1936]! } + public var Notifications_Reset: String { return self._s[1937]! } + public var Conversation_Pin: String { return self._s[1938]! } + public var Passport_Language_lv: String { return self._s[1939]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1940]! } + public var BlockedUsers_Info: String { return self._s[1941]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1943]! } + public var Watch_Conversation_Unblock: String { return self._s[1945]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1943]!, self._r[1943]!, [_0]) - } - public var CloudStorage_Title: String { return self._s[1944]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1945]! } - public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1946]!, self._r[1946]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1947]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1948]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1949]! } - public var Passport_Address_EditBankStatement: String { return self._s[1950]! } - public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1951]!, self._r[1951]!, [_1, _2]) + public var CloudStorage_Title: String { return self._s[1947]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1948]! } + public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1949]!, self._r[1949]!, [_0]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1952]! } - public var ShareMenu_Comment: String { return self._s[1953]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1954]! } - public var Notifications_PermissionsTitle: String { return self._s[1955]! } - public var GroupPermission_NoSendLinks: String { return self._s[1956]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1957]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1958]! } - public var PeerInfo_PaneLinks: String { return self._s[1959]! } - public var Settings_Support: String { return self._s[1960]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1961]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1962]! } - public var Privacy_Forwards_Preview: String { return self._s[1963]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1964]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1965]! } - public var Common_Select: String { return self._s[1967]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1968]! } - public var WallpaperSearch_ColorGray: String { return self._s[1971]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1972]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1973]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1974]! } - public var PollResults_Title: String { return self._s[1975]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1976]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1977]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1978]! } - public var Widget_AuthRequired: String { return self._s[1979]! } - public var Camera_FlashOn: String { return self._s[1980]! } - public var Conversation_ContextMenuLookUp: String { return self._s[1981]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1982]! } - public var Watch_Suggestion_OK: String { return self._s[1983]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1950]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1951]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1952]! } + public var Passport_Address_EditBankStatement: String { return self._s[1953]! } + public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1954]!, self._r[1954]!, [_1, _2]) + } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1955]! } + public var ShareMenu_Comment: String { return self._s[1956]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1957]! } + public var Notifications_PermissionsTitle: String { return self._s[1958]! } + public var GroupPermission_NoSendLinks: String { return self._s[1959]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1960]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1961]! } + public var PeerInfo_PaneLinks: String { return self._s[1962]! } + public var Settings_Support: String { return self._s[1963]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1964]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1965]! } + public var Privacy_Forwards_Preview: String { return self._s[1966]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1967]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1968]! } + public var Common_Select: String { return self._s[1970]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1971]! } + public var WallpaperSearch_ColorGray: String { return self._s[1974]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1975]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1976]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1977]! } + public var PollResults_Title: String { return self._s[1978]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1979]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1980]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1981]! } + public var Widget_AuthRequired: String { return self._s[1982]! } + public var Camera_FlashOn: String { return self._s[1983]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1984]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1985]! } + public var Watch_Suggestion_OK: String { return self._s[1986]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1985]!, self._r[1985]!, [_0]) + return formatWithArgumentRanges(self._s[1988]!, self._r[1988]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1987]!, self._r[1987]!, [_0]) + return formatWithArgumentRanges(self._s[1990]!, self._r[1990]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1988]! } - public var DialogList_AdLabel: String { return self._s[1989]! } - public var WatchRemote_NotificationText: String { return self._s[1990]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1991]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1992]! } - public var Conversation_ReportSpam: String { return self._s[1993]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1994]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1996]! } - public var PhoneLabel_Title: String { return self._s[1997]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1998]! } - public var Settings_ChangePhoneNumber: String { return self._s[1999]! } - public var Notifications_ExceptionsTitle: String { return self._s[2000]! } - public var Notifications_AlertTones: String { return self._s[2001]! } - public var Call_ReportIncludeLogDescription: String { return self._s[2002]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[2003]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[2004]! } - public var VoiceOver_Chat_Photo: String { return self._s[2006]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[2007]! } - public var Stats_PostsTitle: String { return self._s[2008]! } - public var ReportPeer_ReasonOther: String { return self._s[2009]! } - public var ChatList_Context_JoinChannel: String { return self._s[2010]! } - public var PhotoEditor_SkinTool: String { return self._s[2011]! } - public var KeyCommand_ScrollDown: String { return self._s[2013]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[2014]! } + public var TextFormat_Strikethrough: String { return self._s[1991]! } + public var DialogList_AdLabel: String { return self._s[1992]! } + public var WatchRemote_NotificationText: String { return self._s[1993]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1994]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1995]! } + public var Conversation_ReportSpam: String { return self._s[1996]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1997]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1999]! } + public var PhoneLabel_Title: String { return self._s[2000]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[2001]! } + public var Settings_ChangePhoneNumber: String { return self._s[2002]! } + public var Notifications_ExceptionsTitle: String { return self._s[2003]! } + public var Notifications_AlertTones: String { return self._s[2004]! } + public var Call_ReportIncludeLogDescription: String { return self._s[2005]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[2006]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[2007]! } + public var VoiceOver_Chat_Photo: String { return self._s[2009]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[2010]! } + public var Stats_PostsTitle: String { return self._s[2011]! } + public var ReportPeer_ReasonOther: String { return self._s[2012]! } + public var ChatList_Context_JoinChannel: String { return self._s[2013]! } + public var PhotoEditor_SkinTool: String { return self._s[2014]! } + public var KeyCommand_ScrollDown: String { return self._s[2016]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[2017]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2015]!, self._r[2015]!, [_0]) + return formatWithArgumentRanges(self._s[2018]!, self._r[2018]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[2017]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[2018]! } - public var AuthSessions_LogOut: String { return self._s[2019]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[2020]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[2021]! } - public var Passport_Phone_Title: String { return self._s[2022]! } - public var ContactList_Context_StartSecretChat: String { return self._s[2023]! } - public var Settings_PhoneNumber: String { return self._s[2024]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[2020]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[2021]! } + public var AuthSessions_LogOut: String { return self._s[2022]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[2023]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[2024]! } + public var Passport_Phone_Title: String { return self._s[2025]! } + public var ContactList_Context_StartSecretChat: String { return self._s[2026]! } + public var Settings_PhoneNumber: String { return self._s[2027]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2025]!, self._r[2025]!, [_0]) + return formatWithArgumentRanges(self._s[2028]!, self._r[2028]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[2027]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[2028]! } - public var WebSearch_SearchNoResults: String { return self._s[2029]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[2031]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[2032]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[2033]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[2034]! } - public var PhotoEditor_CurvesTool: String { return self._s[2035]! } - public var Checkout_PaymentMethod: String { return self._s[2037]! } + public var NotificationsSound_Alert: String { return self._s[2030]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[2031]! } + public var WebSearch_SearchNoResults: String { return self._s[2032]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[2034]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[2035]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[2036]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[2037]! } + public var PhotoEditor_CurvesTool: String { return self._s[2038]! } + public var Checkout_PaymentMethod: String { return self._s[2040]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2038]!, self._r[2038]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2041]!, self._r[2041]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[2039]! } - public var Camera_PhotoMode: String { return self._s[2042]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[2043]! } - public var Appearance_TextSize_Apply: String { return self._s[2044]! } - public var Passport_Address_AddUtilityBill: String { return self._s[2046]! } - public var ChatListFolderSettings_RecommendedNewFolder: String { return self._s[2047]! } - public var CallSettings_OnMobile: String { return self._s[2048]! } - public var Tour_Text2: String { return self._s[2049]! } + public var Contacts_AccessDeniedError: String { return self._s[2042]! } + public var Camera_PhotoMode: String { return self._s[2045]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[2046]! } + public var Appearance_TextSize_Apply: String { return self._s[2047]! } + public var Passport_Address_AddUtilityBill: String { return self._s[2049]! } + public var ChatListFolderSettings_RecommendedNewFolder: String { return self._s[2050]! } + public var CallSettings_OnMobile: String { return self._s[2051]! } + public var Tour_Text2: String { return self._s[2052]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2050]!, self._r[2050]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2053]!, self._r[2053]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[2052]! } - public var Permissions_Skip: String { return self._s[2053]! } - public var Wallet_Words_NotDoneOk: String { return self._s[2054]! } - public var SecretImage_Title: String { return self._s[2055]! } - public var Watch_MessageView_Title: String { return self._s[2056]! } - public var Channel_DiscussionGroupAdd: String { return self._s[2057]! } - public var AttachmentMenu_Poll: String { return self._s[2058]! } + public var DialogList_EncryptionProcessing: String { return self._s[2055]! } + public var Permissions_Skip: String { return self._s[2056]! } + public var Wallet_Words_NotDoneOk: String { return self._s[2057]! } + public var SecretImage_Title: String { return self._s[2058]! } + public var Watch_MessageView_Title: String { return self._s[2059]! } + public var Channel_DiscussionGroupAdd: String { return self._s[2060]! } + public var AttachmentMenu_Poll: String { return self._s[2061]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2059]!, self._r[2059]!, [_0]) + return formatWithArgumentRanges(self._s[2062]!, self._r[2062]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2060]!, self._r[2060]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2063]!, self._r[2063]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[2061]! } - public var WallpaperPreview_Title: String { return self._s[2062]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[2063]! } - public var Settings_ProxyConnecting: String { return self._s[2064]! } - public var Settings_CheckPhoneNumberText: String { return self._s[2066]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[2067]! } - public var Wallet_Intro_Title: String { return self._s[2068]! } - public var TwoFactorSetup_Password_Action: String { return self._s[2069]! } - public var Profile_MessageLifetime5s: String { return self._s[2070]! } - public var Username_InvalidCharacters: String { return self._s[2071]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[2072]! } - public var ScheduledMessages_ClearAll: String { return self._s[2073]! } - public var WallpaperPreview_CropBottomText: String { return self._s[2074]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[2075]! } - public var Settings_AddAccount: String { return self._s[2076]! } - public var Notification_CreatedChannel: String { return self._s[2079]! } + public var Notification_CallCanceled: String { return self._s[2064]! } + public var WallpaperPreview_Title: String { return self._s[2065]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[2066]! } + public var Settings_ProxyConnecting: String { return self._s[2067]! } + public var Settings_CheckPhoneNumberText: String { return self._s[2069]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[2070]! } + public var Wallet_Intro_Title: String { return self._s[2071]! } + public var TwoFactorSetup_Password_Action: String { return self._s[2072]! } + public var Profile_MessageLifetime5s: String { return self._s[2073]! } + public var Username_InvalidCharacters: String { return self._s[2074]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[2075]! } + public var ScheduledMessages_ClearAll: String { return self._s[2076]! } + public var WallpaperPreview_CropBottomText: String { return self._s[2077]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[2078]! } + public var Settings_AddAccount: String { return self._s[2079]! } + public var Notification_CreatedChannel: String { return self._s[2082]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2080]!, self._r[2080]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2083]!, self._r[2083]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[2082]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[2083]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[2084]! } - public var Contacts_TopSection: String { return self._s[2085]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[2086]! } + public var Passcode_AppLockedAlert: String { return self._s[2085]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[2086]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[2087]! } + public var Contacts_TopSection: String { return self._s[2088]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[2089]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2087]!, self._r[2087]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2090]!, self._r[2090]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[2088]! } - public var Wallet_Completed_ViewWallet: String { return self._s[2089]! } + public var Wallet_Info_Receive: String { return self._s[2091]! } + public var Wallet_Completed_ViewWallet: String { return self._s[2092]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2090]!, self._r[2090]!, [_0]) + return formatWithArgumentRanges(self._s[2093]!, self._r[2093]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[2091]! } - public var UserInfo_TapToCall: String { return self._s[2092]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[2094]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[2095]! } - public var Common_Search: String { return self._s[2096]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2097]! } + public var ReportPeer_ReasonSpam: String { return self._s[2094]! } + public var UserInfo_TapToCall: String { return self._s[2095]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[2097]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[2098]! } + public var Common_Search: String { return self._s[2099]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2100]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2098]!, self._r[2098]!, [_0]) + return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_0]) } - public var Wallet_Month_ShortJuly: String { return self._s[2099]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2101]! } - public var Message_InvoiceLabel: String { return self._s[2102]! } - public var Conversation_InputTextPlaceholder: String { return self._s[2103]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2104]! } + public var Wallet_Month_ShortJuly: String { return self._s[2102]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2104]! } + public var Message_InvoiceLabel: String { return self._s[2105]! } + public var Conversation_InputTextPlaceholder: String { return self._s[2106]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2107]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2105]!, self._r[2105]!, [_0]) + return formatWithArgumentRanges(self._s[2108]!, self._r[2108]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[2106]! } - public var Conversation_Info: String { return self._s[2107]! } - public var Login_InfoDeletePhoto: String { return self._s[2108]! } - public var ChatListFolder_DiscardDiscard: String { return self._s[2110]! } - public var Passport_Language_vi: String { return self._s[2111]! } - public var UserInfo_ScamUserWarning: String { return self._s[2112]! } - public var Conversation_Search: String { return self._s[2113]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2115]! } - public var ChatListFolder_NameGroups: String { return self._s[2116]! } - public var ReportPeer_ReasonPornography: String { return self._s[2117]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[2118]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2119]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2120]! } - public var Channel_Setup_TypeHeader: String { return self._s[2121]! } - public var AuthSessions_LoggedIn: String { return self._s[2122]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2123]! } - public var Login_SmsRequestState3: String { return self._s[2124]! } - public var Passport_Address_EditUtilityBill: String { return self._s[2125]! } - public var Appearance_ReduceMotionInfo: String { return self._s[2126]! } - public var Join_ChannelsTooMuch: String { return self._s[2127]! } - public var Channel_Edit_LinkItem: String { return self._s[2128]! } - public var Privacy_Calls_P2PNever: String { return self._s[2129]! } - public var Conversation_AddToReadingList: String { return self._s[2131]! } - public var Share_MultipleMessagesDisabled: String { return self._s[2132]! } - public var Message_Animation: String { return self._s[2133]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[2134]! } - public var Map_Unknown: String { return self._s[2135]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[2136]! } + public var IntentsSettings_Reset: String { return self._s[2109]! } + public var Conversation_Info: String { return self._s[2110]! } + public var Login_InfoDeletePhoto: String { return self._s[2111]! } + public var ChatListFolder_DiscardDiscard: String { return self._s[2113]! } + public var Passport_Language_vi: String { return self._s[2114]! } + public var UserInfo_ScamUserWarning: String { return self._s[2115]! } + public var Conversation_Search: String { return self._s[2116]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2118]! } + public var ChatListFolder_NameGroups: String { return self._s[2119]! } + public var ReportPeer_ReasonPornography: String { return self._s[2120]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[2121]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2122]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2123]! } + public var Channel_Setup_TypeHeader: String { return self._s[2124]! } + public var AuthSessions_LoggedIn: String { return self._s[2125]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2126]! } + public var Login_SmsRequestState3: String { return self._s[2127]! } + public var Passport_Address_EditUtilityBill: String { return self._s[2128]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2129]! } + public var Join_ChannelsTooMuch: String { return self._s[2130]! } + public var Channel_Edit_LinkItem: String { return self._s[2131]! } + public var Privacy_Calls_P2PNever: String { return self._s[2132]! } + public var Conversation_AddToReadingList: String { return self._s[2134]! } + public var Share_MultipleMessagesDisabled: String { return self._s[2135]! } + public var Message_Animation: String { return self._s[2136]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[2137]! } + public var Map_Unknown: String { return self._s[2138]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[2139]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2137]!, self._r[2137]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2140]!, self._r[2140]!, [_1, _2]) } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2138]!, self._r[2138]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2141]!, self._r[2141]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[2139]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[2140]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2141]! } + public var Call_StatusRequesting: String { return self._s[2142]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[2143]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2144]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2142]!, self._r[2142]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2145]!, self._r[2145]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2143]!, self._r[2143]!, [_0]) + return formatWithArgumentRanges(self._s[2146]!, self._r[2146]!, [_0]) } - public var Update_Skip: String { return self._s[2144]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2145]! } - public var BlockedUsers_Title: String { return self._s[2146]! } - public var Weekday_Monday: String { return self._s[2147]! } + public var Update_Skip: String { return self._s[2147]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2148]! } + public var BlockedUsers_Title: String { return self._s[2149]! } + public var Weekday_Monday: String { return self._s[2150]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2148]!, self._r[2148]!, [_1]) + return formatWithArgumentRanges(self._s[2151]!, self._r[2151]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[2149]! } - public var NotificationsSound_Bell: String { return self._s[2150]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[2151]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2152]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2153]! } - public var ChatSettings_Groups: String { return self._s[2154]! } - public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2155]! } - public var ChatList_PeerTypeContact: String { return self._s[2156]! } + public var Username_CheckingUsername: String { return self._s[2152]! } + public var NotificationsSound_Bell: String { return self._s[2153]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[2154]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2155]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2156]! } + public var ChatSettings_Groups: String { return self._s[2157]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2158]! } + public var ChatList_PeerTypeContact: String { return self._s[2159]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2157]!, self._r[2157]!, [_0]) + return formatWithArgumentRanges(self._s[2160]!, self._r[2160]!, [_0]) } - public var Your_card_was_declined: String { return self._s[2158]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2160]! } - public var Wallet_Month_ShortApril: String { return self._s[2161]! } - public var ChatList_Unmute: String { return self._s[2162]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2163]! } - public var PhotoEditor_CurvesAll: String { return self._s[2164]! } - public var Weekday_ShortTuesday: String { return self._s[2165]! } - public var DialogList_Read: String { return self._s[2166]! } - public var Appearance_AppIconClassic: String { return self._s[2167]! } - public var Conversation_Dice_u1F3B2: String { return self._s[2168]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2169]! } - public var Passport_Identity_Gender: String { return self._s[2170]! } + public var Your_card_was_declined: String { return self._s[2161]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2163]! } + public var Wallet_Month_ShortApril: String { return self._s[2164]! } + public var ChatList_Unmute: String { return self._s[2165]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2166]! } + public var PhotoEditor_CurvesAll: String { return self._s[2167]! } + public var Weekday_ShortTuesday: String { return self._s[2168]! } + public var DialogList_Read: String { return self._s[2169]! } + public var Appearance_AppIconClassic: String { return self._s[2170]! } + public var Conversation_Dice_u1F3B2: String { return self._s[2171]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2172]! } + public var Passport_Identity_Gender: String { return self._s[2173]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2171]!, self._r[2171]!, [_0]) + return formatWithArgumentRanges(self._s[2174]!, self._r[2174]!, [_0]) } - public var Target_SelectGroup: String { return self._s[2172]! } - public var Map_HomeAndWorkInfo: String { return self._s[2174]! } + public var Target_SelectGroup: String { return self._s[2175]! } + public var Map_HomeAndWorkInfo: String { return self._s[2177]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2175]!, self._r[2175]!, [_0]) + return formatWithArgumentRanges(self._s[2178]!, self._r[2178]!, [_0]) } - public var Passport_Language_en: String { return self._s[2176]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2177]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2178]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[2179]! } - public var ScheduledMessages_SendNow: String { return self._s[2180]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[2182]! } - public var Login_InfoHelp: String { return self._s[2183]! } - public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2184]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2185]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2186]! } + public var Passport_Language_en: String { return self._s[2179]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2180]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2181]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2182]! } + public var ScheduledMessages_SendNow: String { return self._s[2183]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2185]! } + public var Login_InfoHelp: String { return self._s[2186]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2187]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2188]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2189]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2187]!, self._r[2187]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2190]!, self._r[2190]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2190]! } - public var CreatePoll_Title: String { return self._s[2191]! } - public var MessagePoll_QuizNoUsers: String { return self._s[2192]! } - public var Conversation_ViewTheme: String { return self._s[2193]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2194]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2195]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2196]! } - public var UserInfo_GroupsInCommon: String { return self._s[2197]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2198]! } - public var Stats_ViewsByHoursTitle: String { return self._s[2199]! } - public var Conversation_PrivateChannelTimeLimitedAlertTitle: String { return self._s[2200]! } - public var Call_AudioRouteHide: String { return self._s[2201]! } + public var SocksProxySetup_AddProxy: String { return self._s[2193]! } + public var CreatePoll_Title: String { return self._s[2194]! } + public var MessagePoll_QuizNoUsers: String { return self._s[2195]! } + public var Conversation_ViewTheme: String { return self._s[2196]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2197]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2198]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2199]! } + public var UserInfo_GroupsInCommon: String { return self._s[2200]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2201]! } + public var Stats_ViewsByHoursTitle: String { return self._s[2202]! } + public var Conversation_PrivateChannelTimeLimitedAlertTitle: String { return self._s[2203]! } + public var Call_AudioRouteHide: String { return self._s[2204]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2204]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2205]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[2206]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2207]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2208]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[2209]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, [_0]) + return formatWithArgumentRanges(self._s[2210]!, self._r[2210]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2208]! } - public var CreatePoll_ExplanationInfo: String { return self._s[2209]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2210]! } - public var StickerPackActionInfo_AddedTitle: String { return self._s[2211]! } - public var Notifications_Title: String { return self._s[2212]! } - public var Group_Username_InvalidTooShort: String { return self._s[2213]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2214]! } + public var TextFormat_Bold: String { return self._s[2211]! } + public var CreatePoll_ExplanationInfo: String { return self._s[2212]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2213]! } + public var StickerPackActionInfo_AddedTitle: String { return self._s[2214]! } + public var Notifications_Title: String { return self._s[2215]! } + public var Group_Username_InvalidTooShort: String { return self._s[2216]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2217]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2215]!, self._r[2215]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2218]!, self._r[2218]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2217]! } - public var Stickers_SuggestAdded: String { return self._s[2218]! } - public var Login_CountryCode: String { return self._s[2219]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2220]! } - public var Map_GetDirections: String { return self._s[2221]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2222]! } - public var Stats_GroupNewMembersBySourceTitle: String { return self._s[2223]! } - public var Login_PhoneFloodError: String { return self._s[2224]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2220]! } + public var Stickers_SuggestAdded: String { return self._s[2221]! } + public var Login_CountryCode: String { return self._s[2222]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2223]! } + public var Map_GetDirections: String { return self._s[2224]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2225]! } + public var Stats_GroupNewMembersBySourceTitle: String { return self._s[2226]! } + public var Login_PhoneFloodError: String { return self._s[2227]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2225]!, self._r[2225]!, [_0]) + return formatWithArgumentRanges(self._s[2228]!, self._r[2228]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2226]!, self._r[2226]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2229]!, self._r[2229]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2227]! } - public var Settings_SetUsername: String { return self._s[2229]! } - public var Group_Location_ChangeLocation: String { return self._s[2230]! } - public var Notification_GroupInviterSelf: String { return self._s[2231]! } - public var InstantPage_TapToOpenLink: String { return self._s[2232]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2230]! } + public var Settings_SetUsername: String { return self._s[2232]! } + public var Group_Location_ChangeLocation: String { return self._s[2233]! } + public var Notification_GroupInviterSelf: String { return self._s[2234]! } + public var InstantPage_TapToOpenLink: String { return self._s[2235]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2233]!, self._r[2233]!, [_0]) + return formatWithArgumentRanges(self._s[2236]!, self._r[2236]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2234]! } - public var SecretChat_Title: String { return self._s[2235]! } - public var Group_UpgradeNoticeText1: String { return self._s[2236]! } - public var AuthSessions_Title: String { return self._s[2237]! } + public var PrivacySettings_AutoArchiveInfo: String { return self._s[2237]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2238]! } + public var SecretChat_Title: String { return self._s[2239]! } + public var Group_UpgradeNoticeText1: String { return self._s[2240]! } + public var AuthSessions_Title: String { return self._s[2241]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2238]!, self._r[2238]!, [_0]) + return formatWithArgumentRanges(self._s[2242]!, self._r[2242]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2239]! } - public var Channel_About_Title: String { return self._s[2241]! } - public var Theme_ThemeChanged: String { return self._s[2242]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2243]! } + public var PhotoEditor_CropAuto: String { return self._s[2243]! } + public var Channel_About_Title: String { return self._s[2245]! } + public var Theme_ThemeChanged: String { return self._s[2246]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2247]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2246]!, self._r[2246]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2250]!, self._r[2250]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2247]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2249]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2250]! } + public var VoiceOver_MessageContextReport: String { return self._s[2251]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2253]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2254]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2251]!, self._r[2251]!, [_1]) + return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2253]!, self._r[2253]!, [_0]) + return formatWithArgumentRanges(self._s[2257]!, self._r[2257]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2254]!, self._r[2254]!, [_0]) + return formatWithArgumentRanges(self._s[2258]!, self._r[2258]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2255]! } - public var PeopleNearby_DiscoverDescription: String { return self._s[2257]! } - public var Presence_online: String { return self._s[2259]! } - public var PasscodeSettings_Title: String { return self._s[2260]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2261]! } - public var Web_OpenExternal: String { return self._s[2262]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2264]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2265]! } - public var LocalGroup_Title: String { return self._s[2266]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2259]! } + public var PeopleNearby_DiscoverDescription: String { return self._s[2261]! } + public var Presence_online: String { return self._s[2263]! } + public var PasscodeSettings_Title: String { return self._s[2264]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2265]! } + public var Web_OpenExternal: String { return self._s[2266]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2268]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2269]! } + public var LocalGroup_Title: String { return self._s[2270]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2267]!, self._r[2267]!, [_0]) - } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2268]! } - public var Conversation_StopQuizConfirmation: String { return self._s[2269]! } - public var Map_YouAreHere: String { return self._s[2270]! } - public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2271]!, self._r[2271]!, [_0]) } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2272]!, self._r[2272]!, [_0]) + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2272]! } + public var Conversation_StopQuizConfirmation: String { return self._s[2273]! } + public var Map_YouAreHere: String { return self._s[2274]! } + public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2275]!, self._r[2275]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[2273]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2274]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2275]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2276]!, self._r[2276]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2277]!, self._r[2277]!, [_0]) - } - public var SocksProxySetup_Username: String { return self._s[2278]! } - public var Bot_Start: String { return self._s[2279]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Theme_Context_ChangeColors: String { return self._s[2277]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2278]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2279]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2280]!, self._r[2280]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2281]!, self._r[2281]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[2282]! } - public var AccentColor_Title: String { return self._s[2285]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2286]! } + public var SocksProxySetup_Username: String { return self._s[2282]! } + public var Bot_Start: String { return self._s[2283]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2284]!, self._r[2284]!, [_0]) + } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2285]!, self._r[2285]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[2286]! } + public var AccentColor_Title: String { return self._s[2289]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2290]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2287]!, self._r[2287]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2291]!, self._r[2291]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2288]!, self._r[2288]!, [_0]) + return formatWithArgumentRanges(self._s[2292]!, self._r[2292]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2289]!, self._r[2289]!, [_1, _2]) - } - public var Stats_GroupOverview: String { return self._s[2290]! } - public var Passport_Email_EnterOtherEmail: String { return self._s[2291]! } - public var Login_InfoAvatarPhoto: String { return self._s[2292]! } - public func ChatList_RemovedFromFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_1, _2]) } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2294]! } - public var Tour_Title4: String { return self._s[2295]! } - public var Passport_Identity_Translation: String { return self._s[2296]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2297]! } - public var Login_TermsOfServiceLabel: String { return self._s[2299]! } - public var Passport_Language_it: String { return self._s[2300]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2301]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2302]! } - public var Conversation_ClearAll: String { return self._s[2304]! } - public var Wallet_Send_UninitializedText: String { return self._s[2306]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2307]! } - public var TwoStepAuth_FloodError: String { return self._s[2308]! } + public var Stats_GroupOverview: String { return self._s[2294]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[2295]! } + public var Login_InfoAvatarPhoto: String { return self._s[2296]! } + public func ChatList_RemovedFromFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2297]!, self._r[2297]!, [_1, _2]) + } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2298]! } + public var Tour_Title4: String { return self._s[2299]! } + public var Passport_Identity_Translation: String { return self._s[2300]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2301]! } + public var Login_TermsOfServiceLabel: String { return self._s[2303]! } + public var Passport_Language_it: String { return self._s[2304]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2305]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2306]! } + public var Conversation_ClearAll: String { return self._s[2308]! } + public var Wallet_Send_UninitializedText: String { return self._s[2310]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2311]! } + public var TwoStepAuth_FloodError: String { return self._s[2312]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2309]!, self._r[2309]!, [_1]) - } - public var Paint_Delete: String { return self._s[2310]! } - public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2311]!, self._r[2311]!, [_0]) - } - public var Privacy_AddNewPeer: String { return self._s[2312]! } - public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2313]!, self._r[2313]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2314]! } + public var Paint_Delete: String { return self._s[2314]! } + public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_0]) + } + public var Privacy_AddNewPeer: String { return self._s[2316]! } + public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2317]!, self._r[2317]!, [_1]) + } + public var LogoutOptions_SetPasscodeText: String { return self._s[2318]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2319]!, self._r[2319]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2316]! } + public var Message_PinnedAudioMessage: String { return self._s[2320]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2317]!, self._r[2317]!, [_0]) + return formatWithArgumentRanges(self._s[2321]!, self._r[2321]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2318]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2319]! } - public var Wallet_Month_GenNovember: String { return self._s[2320]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2322]! } - public var Conversation_MessageEditedLabel: String { return self._s[2323]! } + public var Notification_Mute1hMin: String { return self._s[2322]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2323]! } + public var Wallet_Month_GenNovember: String { return self._s[2324]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2326]! } + public var Conversation_MessageEditedLabel: String { return self._s[2327]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2328]!, self._r[2328]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2325]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2326]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2329]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2330]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2327]!, self._r[2327]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2331]!, self._r[2331]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2328]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2332]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2329]!, self._r[2329]!, [_1]) + return formatWithArgumentRanges(self._s[2333]!, self._r[2333]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2330]! } - public var Month_GenOctober: String { return self._s[2331]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2332]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2333]! } - public var MediaPicker_TimerTooltip: String { return self._s[2335]! } - public var SharedMedia_TitleAll: String { return self._s[2336]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2339]! } - public var Conversation_RestrictedMedia: String { return self._s[2340]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2341]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2343]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2344]! } + public var AccessDenied_LocationTracking: String { return self._s[2334]! } + public var Month_GenOctober: String { return self._s[2335]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2336]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2337]! } + public var MediaPicker_TimerTooltip: String { return self._s[2339]! } + public var SharedMedia_TitleAll: String { return self._s[2340]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2343]! } + public var Conversation_RestrictedMedia: String { return self._s[2344]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2345]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2347]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2348]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2345]!, self._r[2345]!, [_0]) + return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2348]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2350]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2351]! } + public var Conversation_SavedMessages: String { return self._s[2352]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2354]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2355]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_0]) + return formatWithArgumentRanges(self._s[2357]!, self._r[2357]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2354]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2358]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2355]!, self._r[2355]!, [_0]) + return formatWithArgumentRanges(self._s[2359]!, self._r[2359]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[2356]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2357]! } + public var ReportPeer_AlertSuccess: String { return self._s[2360]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2361]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2358]!, self._r[2358]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2362]!, self._r[2362]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2359]! } - public var PhotoEditor_FadeTool: String { return self._s[2360]! } - public var Privacy_ContactsReset: String { return self._s[2361]! } - public var Conversation_PrivateChannelTimeLimitedAlertText: String { return self._s[2362]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2363]! } + public var PhotoEditor_FadeTool: String { return self._s[2364]! } + public var Privacy_ContactsReset: String { return self._s[2365]! } + public var Conversation_PrivateChannelTimeLimitedAlertText: String { return self._s[2366]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2364]!, self._r[2364]!, [_0]) + return formatWithArgumentRanges(self._s[2368]!, self._r[2368]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2365]! } - public var ChatList_Mute: String { return self._s[2366]! } + public var Message_PinnedVideoMessage: String { return self._s[2369]! } + public var ChatList_Mute: String { return self._s[2370]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2367]!, self._r[2367]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2371]!, self._r[2371]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2368]! } - public var Conversation_PinnedQuiz: String { return self._s[2370]! } - public var ShareMenu_SelectChats: String { return self._s[2372]! } - public var ChatList_Context_Unarchive: String { return self._s[2373]! } - public var MusicPlayer_VoiceNote: String { return self._s[2374]! } - public var Conversation_RestrictedText: String { return self._s[2375]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2376]! } - public var Wallet_Month_GenApril: String { return self._s[2377]! } - public var Wallet_Month_ShortMarch: String { return self._s[2378]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2379]! } - public var Chat_PsaTooltip_covid: String { return self._s[2380]! } - public var Cache_Videos: String { return self._s[2381]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2382]! } - public var Wallet_Month_GenFebruary: String { return self._s[2383]! } - public var FeatureDisabled_Oops: String { return self._s[2385]! } - public var ChatList_RemoveFolderAction: String { return self._s[2386]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2387]! } + public var Permissions_CellularDataText_v0: String { return self._s[2372]! } + public var Conversation_PinnedQuiz: String { return self._s[2374]! } + public var ShareMenu_SelectChats: String { return self._s[2376]! } + public var ChatList_Context_Unarchive: String { return self._s[2377]! } + public var MusicPlayer_VoiceNote: String { return self._s[2378]! } + public var Conversation_RestrictedText: String { return self._s[2379]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2380]! } + public var Wallet_Month_GenApril: String { return self._s[2381]! } + public var Wallet_Month_ShortMarch: String { return self._s[2382]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2383]! } + public var Chat_PsaTooltip_covid: String { return self._s[2384]! } + public var Cache_Videos: String { return self._s[2385]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2386]! } + public var Wallet_Month_GenFebruary: String { return self._s[2387]! } + public var FeatureDisabled_Oops: String { return self._s[2389]! } + public var ChatList_RemoveFolderAction: String { return self._s[2390]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2391]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2388]!, self._r[2388]!, [_0]) + return formatWithArgumentRanges(self._s[2392]!, self._r[2392]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2390]! } - public var GroupPermission_NoSendPolls: String { return self._s[2391]! } - public var Wallet_Qr_ScanCode: String { return self._s[2392]! } - public var Message_VideoExpired: String { return self._s[2394]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2395]! } - public var Notifications_Badge: String { return self._s[2396]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2397]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2398]! } - public var Username_InvalidTooShort: String { return self._s[2399]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2400]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2401]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2402]! } + public var Stickers_GroupStickersHelp: String { return self._s[2394]! } + public var GroupPermission_NoSendPolls: String { return self._s[2395]! } + public var Wallet_Qr_ScanCode: String { return self._s[2396]! } + public var Message_VideoExpired: String { return self._s[2398]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2399]! } + public var Notifications_Badge: String { return self._s[2400]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2401]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2402]! } + public var Username_InvalidTooShort: String { return self._s[2403]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2404]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2405]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2406]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2403]!, self._r[2403]!, [_1]) + return formatWithArgumentRanges(self._s[2407]!, self._r[2407]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2404]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2405]! } - public var SharedMedia_CategoryDocs: String { return self._s[2408]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2408]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2409]! } + public var SharedMedia_CategoryDocs: String { return self._s[2412]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2409]!, self._r[2409]!, [_1]) + return formatWithArgumentRanges(self._s[2413]!, self._r[2413]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2410]! } - public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2411]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2413]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2414]! } + public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2415]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2417]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2414]!, self._r[2414]!, [_1]) + return formatWithArgumentRanges(self._s[2418]!, self._r[2418]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2415]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2419]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2416]!, self._r[2416]!, [_0]) + return formatWithArgumentRanges(self._s[2420]!, self._r[2420]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2417]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2418]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2419]! } - public var Channel_UpdatePhotoItem: String { return self._s[2420]! } - public var GroupInfo_LeftStatus: String { return self._s[2421]! } - public var Watch_MessageView_Forward: String { return self._s[2423]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2424]! } - public var Cache_ClearEmpty: String { return self._s[2426]! } - public var Localization_LanguageName: String { return self._s[2427]! } - public var Wallet_AccessDenied_Title: String { return self._s[2428]! } - public var WebSearch_GIFs: String { return self._s[2429]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2430]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2431]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2432]! } - public var Common_Back: String { return self._s[2433]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2434]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2435]! } - public var Wallet_Send_Send: String { return self._s[2436]! } + public var ChatSettings_PrivateChats: String { return self._s[2421]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2422]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2423]! } + public var Channel_UpdatePhotoItem: String { return self._s[2424]! } + public var GroupInfo_LeftStatus: String { return self._s[2425]! } + public var Watch_MessageView_Forward: String { return self._s[2427]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2428]! } + public var Cache_ClearEmpty: String { return self._s[2430]! } + public var Localization_LanguageName: String { return self._s[2431]! } + public var Wallet_AccessDenied_Title: String { return self._s[2432]! } + public var WebSearch_GIFs: String { return self._s[2433]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2434]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2435]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2436]! } + public var Common_Back: String { return self._s[2437]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2438]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2439]! } + public var Wallet_Send_Send: String { return self._s[2440]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2438]!, self._r[2438]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2442]!, self._r[2442]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2439]! } - public var ChatList_Tabs_All: String { return self._s[2440]! } - public var Wallet_Month_GenJune: String { return self._s[2441]! } - public var Passport_Email_Help: String { return self._s[2442]! } - public var Watch_Conversation_Reply: String { return self._s[2444]! } - public var Stats_GroupTopInvitersTitle: String { return self._s[2445]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2448]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2449]! } - public var Channel_BanUser_Unban: String { return self._s[2451]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2452]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2453]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2455]! } - public var Wallet_Send_AddressHeader: String { return self._s[2456]! } - public var Passport_Identity_Name: String { return self._s[2457]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2443]! } + public var ChatList_Tabs_All: String { return self._s[2444]! } + public var Wallet_Month_GenJune: String { return self._s[2445]! } + public var Passport_Email_Help: String { return self._s[2446]! } + public var Watch_Conversation_Reply: String { return self._s[2448]! } + public var Stats_GroupTopInvitersTitle: String { return self._s[2449]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2452]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2453]! } + public var Channel_BanUser_Unban: String { return self._s[2455]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2456]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2457]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2459]! } + public var Wallet_Send_AddressHeader: String { return self._s[2460]! } + public var Passport_Identity_Name: String { return self._s[2461]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2458]!, self._r[2458]!, [_0]) + return formatWithArgumentRanges(self._s[2462]!, self._r[2462]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2459]! } - public var Conversation_BlockUser: String { return self._s[2460]! } - public var Month_GenJanuary: String { return self._s[2461]! } - public var ChatSettings_TextSize: String { return self._s[2462]! } - public var Notification_PassportValuePhone: String { return self._s[2463]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2464]! } - public var Passport_Language_ne: String { return self._s[2465]! } - public var Notification_CallBack: String { return self._s[2466]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2467]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2468]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2463]! } + public var Conversation_BlockUser: String { return self._s[2464]! } + public var Month_GenJanuary: String { return self._s[2465]! } + public var ChatSettings_TextSize: String { return self._s[2466]! } + public var Notification_PassportValuePhone: String { return self._s[2467]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2468]! } + public var Passport_Language_ne: String { return self._s[2469]! } + public var Notification_CallBack: String { return self._s[2470]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2471]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2472]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2469]!, self._r[2469]!, [_0]) + return formatWithArgumentRanges(self._s[2473]!, self._r[2473]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2470]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2471]! } - public var Stickers_FrequentlyUsed: String { return self._s[2473]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2474]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2476]! } + public var Channel_Info_Management: String { return self._s[2474]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2475]! } + public var Stickers_FrequentlyUsed: String { return self._s[2477]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2478]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2480]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2477]!, self._r[2477]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2481]!, self._r[2481]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2478]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2479]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2480]! } - public var CreatePoll_TextHeader: String { return self._s[2481]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2482]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2483]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2484]! } + public var CreatePoll_TextHeader: String { return self._s[2485]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2482]!, self._r[2482]!, [_0]) + return formatWithArgumentRanges(self._s[2486]!, self._r[2486]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2483]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2484]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2486]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2487]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2488]! } + public var PhotoEditor_QualityMedium: String { return self._s[2487]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2488]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2490]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2491]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2492]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2489]!, self._r[2489]!, [_0]) + return formatWithArgumentRanges(self._s[2493]!, self._r[2493]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2490]!, self._r[2490]!, [_1]) + return formatWithArgumentRanges(self._s[2494]!, self._r[2494]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2491]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2492]! } - public var Conversation_LinkDialogOpen: String { return self._s[2494]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2495]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2496]! } - public var Settings_Username: String { return self._s[2498]! } - public var Conversation_Block: String { return self._s[2500]! } - public var Wallpaper_Wallpaper: String { return self._s[2501]! } - public var SocksProxySetup_UseProxy: String { return self._s[2503]! } - public var Wallet_Send_Confirmation: String { return self._s[2504]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2505]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2506]! } - public var MessageTimer_Forever: String { return self._s[2507]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2508]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2509]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2510]! } - public var Passport_Language_da: String { return self._s[2511]! } - public var Conversation_PrivateChannelTimeLimitedAlertJoin: String { return self._s[2513]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2514]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2495]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2496]! } + public var Conversation_LinkDialogOpen: String { return self._s[2498]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2499]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2500]! } + public var Settings_Username: String { return self._s[2502]! } + public var Conversation_Block: String { return self._s[2504]! } + public var Wallpaper_Wallpaper: String { return self._s[2505]! } + public var SocksProxySetup_UseProxy: String { return self._s[2507]! } + public var Wallet_Send_Confirmation: String { return self._s[2508]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2509]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2510]! } + public var MessageTimer_Forever: String { return self._s[2511]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2512]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2513]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2514]! } + public var Passport_Language_da: String { return self._s[2515]! } + public var Conversation_PrivateChannelTimeLimitedAlertJoin: String { return self._s[2517]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2518]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2515]!, self._r[2515]!, [_0]) + return formatWithArgumentRanges(self._s[2519]!, self._r[2519]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2516]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2520]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2518]!, self._r[2518]!, [_0]) + return formatWithArgumentRanges(self._s[2522]!, self._r[2522]!, [_0]) } - public var Settings_AddDevice: String { return self._s[2519]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2521]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2522]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2523]! } - public var Conversation_PinnedPoll: String { return self._s[2524]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2525]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2526]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2527]! } + public var Settings_AddDevice: String { return self._s[2523]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2525]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2526]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2527]! } + public var Conversation_PinnedPoll: String { return self._s[2528]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2529]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2530]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2531]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2528]!, self._r[2528]!, [_1]) + return formatWithArgumentRanges(self._s[2532]!, self._r[2532]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2529]! } - public var Cache_ByPeerHeader: String { return self._s[2530]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2533]! } + public var Cache_ByPeerHeader: String { return self._s[2534]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2531]!, self._r[2531]!, [_0]) + return formatWithArgumentRanges(self._s[2535]!, self._r[2535]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2532]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2535]! } - public var Wallet_Completed_Title: String { return self._s[2536]! } - public var Notification_PinnedMessage: String { return self._s[2537]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2538]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2540]! } - public var Contacts_SortBy: String { return self._s[2541]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2536]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2539]! } + public var Wallet_Completed_Title: String { return self._s[2540]! } + public var Notification_PinnedMessage: String { return self._s[2541]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2542]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2544]! } + public var Contacts_SortBy: String { return self._s[2545]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2542]!, self._r[2542]!, [_1]) + return formatWithArgumentRanges(self._s[2546]!, self._r[2546]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2544]! } + public var Appearance_ColorThemeNight: String { return self._s[2548]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2545]!, self._r[2545]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2546]! } - public var Watch_UserInfo_Service: String { return self._s[2547]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2549]! } - public var Conversation_Unpin: String { return self._s[2551]! } - public var CancelResetAccount_Title: String { return self._s[2552]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2553]! } + public var Call_EncryptionKey_Title: String { return self._s[2550]! } + public var Watch_UserInfo_Service: String { return self._s[2551]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2553]! } + public var Conversation_Unpin: String { return self._s[2555]! } + public var CancelResetAccount_Title: String { return self._s[2556]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2557]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2555]!, self._r[2555]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2559]!, self._r[2559]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2556]! } - public var Appearance_BubbleCorners_Title: String { return self._s[2557]! } - public var CallSettings_Title: String { return self._s[2558]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2559]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2561]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2562]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2560]! } + public var Appearance_BubbleCorners_Title: String { return self._s[2561]! } + public var CallSettings_Title: String { return self._s[2562]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2563]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2565]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2566]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2563]!, self._r[2563]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2567]!, self._r[2567]!, [_1, _2]) } - public var ChatList_Tabs_AllChats: String { return self._s[2564]! } - public var Passport_Identity_DocumentDetails: String { return self._s[2565]! } - public var LoginPassword_PasswordHelp: String { return self._s[2566]! } - public var ChatListFolderSettings_Info: String { return self._s[2567]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2568]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2569]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2570]! } - public var ChatListFolder_CategoryGroups: String { return self._s[2571]! } - public var Checkout_TotalPaidAmount: String { return self._s[2573]! } + public var ChatList_Tabs_AllChats: String { return self._s[2568]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2569]! } + public var LoginPassword_PasswordHelp: String { return self._s[2570]! } + public var ChatListFolderSettings_Info: String { return self._s[2571]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2572]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2573]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2574]! } + public var ChatListFolder_CategoryGroups: String { return self._s[2575]! } + public var Checkout_TotalPaidAmount: String { return self._s[2577]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2574]!, self._r[2574]!, [_0]) + return formatWithArgumentRanges(self._s[2578]!, self._r[2578]!, [_0]) } - public var ChatState_Updating: String { return self._s[2575]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[2576]! } - public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2577]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2579]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2580]! } + public var ChatState_Updating: String { return self._s[2579]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2580]! } + public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2581]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2583]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2584]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2581]!, self._r[2581]!, [_1]) + return formatWithArgumentRanges(self._s[2585]!, self._r[2585]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2582]! } - public var Contacts_InviteFriends: String { return self._s[2584]! } - public var Map_ChooseLocationTitle: String { return self._s[2585]! } - public var Conversation_StopPoll: String { return self._s[2587]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2586]! } + public var Contacts_InviteFriends: String { return self._s[2588]! } + public var Map_ChooseLocationTitle: String { return self._s[2589]! } + public var Conversation_StopPoll: String { return self._s[2591]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2588]!, self._r[2588]!, [_0]) + return formatWithArgumentRanges(self._s[2592]!, self._r[2592]!, [_0]) } - public var Call_Camera: String { return self._s[2589]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2590]! } - public var AppWallet_Intro_Text: String { return self._s[2591]! } - public var Appearance_BubbleCornersSetting: String { return self._s[2592]! } - public var Calls_RatingFeedback: String { return self._s[2593]! } + public var Call_Camera: String { return self._s[2593]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2594]! } + public var AppWallet_Intro_Text: String { return self._s[2595]! } + public var Appearance_BubbleCornersSetting: String { return self._s[2596]! } + public var Calls_RatingFeedback: String { return self._s[2597]! } public func Conversation_NoticeInvitedByInGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2595]!, self._r[2595]!, [_0]) + return formatWithArgumentRanges(self._s[2599]!, self._r[2599]!, [_0]) } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2596]! } - public var Wallet_Alert_OK: String { return self._s[2597]! } - public var NotificationsSound_Pulse: String { return self._s[2598]! } - public var Watch_LastSeen_Lately: String { return self._s[2599]! } - public var ReportGroupLocation_Report: String { return self._s[2602]! } - public var Widget_NoUsers: String { return self._s[2603]! } - public var Conversation_UnvotePoll: String { return self._s[2604]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2606]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2607]! } - public var NotificationsSound_Circles: String { return self._s[2608]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2611]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2612]! } - public var ChatListFolder_CategoryBots: String { return self._s[2613]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2614]! } - public var Proxy_TooltipUnavailable: String { return self._s[2615]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2617]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2619]! } - public var Conversation_FileDropbox: String { return self._s[2620]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2621]! } - public var Tour_Text3: String { return self._s[2623]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2626]! } - public var ChatListFolder_NamePlaceholder: String { return self._s[2627]! } - public var GroupPermission_NoSendMessages: String { return self._s[2628]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2629]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2630]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2600]! } + public var Wallet_Alert_OK: String { return self._s[2601]! } + public var NotificationsSound_Pulse: String { return self._s[2602]! } + public var Watch_LastSeen_Lately: String { return self._s[2603]! } + public var ReportGroupLocation_Report: String { return self._s[2606]! } + public var Widget_NoUsers: String { return self._s[2607]! } + public var Conversation_UnvotePoll: String { return self._s[2608]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2610]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2611]! } + public var NotificationsSound_Circles: String { return self._s[2612]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2615]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2616]! } + public var ChatListFolder_CategoryBots: String { return self._s[2617]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2618]! } + public var Proxy_TooltipUnavailable: String { return self._s[2619]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2621]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2623]! } + public var Conversation_FileDropbox: String { return self._s[2624]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2625]! } + public var Tour_Text3: String { return self._s[2627]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2630]! } + public var ChatListFolder_NamePlaceholder: String { return self._s[2631]! } + public var GroupPermission_NoSendMessages: String { return self._s[2632]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2633]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2634]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_0]) - } - public var GroupInfo_AddParticipantTitle: String { return self._s[2633]! } - public var Checkout_ShippingOption_Title: String { return self._s[2634]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2635]! } - public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2636]!, self._r[2636]!, [_0]) } + public var GroupInfo_AddParticipantTitle: String { return self._s[2637]! } + public var Checkout_ShippingOption_Title: String { return self._s[2638]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2639]! } + public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2640]!, self._r[2640]!, [_0]) + } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2637]!, self._r[2637]!, [_0]) + return formatWithArgumentRanges(self._s[2641]!, self._r[2641]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2638]! } - public var EditTheme_FileReadError: String { return self._s[2639]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2640]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2641]! } - public var AutoDownloadSettings_Photos: String { return self._s[2643]! } - public var Appearance_PreviewIncomingText: String { return self._s[2644]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2645]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2646]! } - public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2647]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2648]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2649]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2650]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2651]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2652]! } - public var Notification_SecretChatScreenshot: String { return self._s[2653]! } - public var AccessDenied_Wallpapers: String { return self._s[2654]! } - public var ChatList_Context_Mute: String { return self._s[2656]! } - public var Passport_Address_City: String { return self._s[2657]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2658]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2659]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2660]! } - public var AccessDenied_LocationDisabled: String { return self._s[2661]! } - public var Group_Location_Title: String { return self._s[2662]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2664]! } - public var GroupInfo_Sound: String { return self._s[2665]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2666]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2667]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2668]! } - public var Contacts_Title: String { return self._s[2669]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2670]! } - public var Passport_Language_fr: String { return self._s[2671]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2672]! } - public var Notifications_ResetAllNotifications: String { return self._s[2673]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2675]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2677]! } - public var Checkout_NewCard_Title: String { return self._s[2678]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2679]! } - public var Conversation_ForwardChats: String { return self._s[2680]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2682]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2683]! } - public var Settings_FAQ: String { return self._s[2685]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2686]! } - public var Conversation_ContextMenuForward: String { return self._s[2687]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2690]! } - public var PrivacyPolicy_Title: String { return self._s[2693]! } - public var Notifications_TextTone: String { return self._s[2694]! } - public var Profile_CreateNewContact: String { return self._s[2695]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2696]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2698]! } - public var Call_Speaker: String { return self._s[2699]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2700]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2702]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2703]! } + public var Channel_Management_LabelAdministrator: String { return self._s[2642]! } + public var EditTheme_FileReadError: String { return self._s[2643]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2644]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2645]! } + public var AutoDownloadSettings_Photos: String { return self._s[2647]! } + public var Appearance_PreviewIncomingText: String { return self._s[2648]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2649]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2650]! } + public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2651]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2652]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2653]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2654]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2655]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2656]! } + public var Notification_SecretChatScreenshot: String { return self._s[2657]! } + public var AccessDenied_Wallpapers: String { return self._s[2658]! } + public var ChatList_Context_Mute: String { return self._s[2660]! } + public var Passport_Address_City: String { return self._s[2661]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2662]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2663]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2664]! } + public var AccessDenied_LocationDisabled: String { return self._s[2665]! } + public var Group_Location_Title: String { return self._s[2666]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2668]! } + public var GroupInfo_Sound: String { return self._s[2669]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2670]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2671]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2672]! } + public var Contacts_Title: String { return self._s[2673]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2674]! } + public var Passport_Language_fr: String { return self._s[2675]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2676]! } + public var Notifications_ResetAllNotifications: String { return self._s[2677]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2679]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2681]! } + public var Checkout_NewCard_Title: String { return self._s[2682]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2683]! } + public var Conversation_ForwardChats: String { return self._s[2684]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2686]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2687]! } + public var Settings_FAQ: String { return self._s[2689]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2690]! } + public var Conversation_ContextMenuForward: String { return self._s[2691]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2694]! } + public var PrivacyPolicy_Title: String { return self._s[2697]! } + public var Notifications_TextTone: String { return self._s[2698]! } + public var Profile_CreateNewContact: String { return self._s[2699]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2700]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2702]! } + public var Call_Speaker: String { return self._s[2703]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2704]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2706]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2707]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2704]!, self._r[2704]!, [_0]) + return formatWithArgumentRanges(self._s[2708]!, self._r[2708]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2705]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2706]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2707]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2708]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2709]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2710]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2711]! } - public var Bot_Unblock: String { return self._s[2712]! } - public var TextFormat_Italic: String { return self._s[2713]! } - public var WallpaperSearch_ColorPink: String { return self._s[2714]! } - public var Settings_About_Help: String { return self._s[2716]! } - public var SearchImages_Title: String { return self._s[2717]! } - public var Weekday_Wednesday: String { return self._s[2718]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2719]! } - public var ExplicitContent_AlertTitle: String { return self._s[2720]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2709]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2710]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2711]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2712]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2713]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2714]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2715]! } + public var Bot_Unblock: String { return self._s[2716]! } + public var TextFormat_Italic: String { return self._s[2717]! } + public var WallpaperSearch_ColorPink: String { return self._s[2718]! } + public var Settings_About_Help: String { return self._s[2720]! } + public var SearchImages_Title: String { return self._s[2721]! } + public var Weekday_Wednesday: String { return self._s[2722]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2723]! } + public var ExplicitContent_AlertTitle: String { return self._s[2724]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2721]!, self._r[2721]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2725]!, self._r[2725]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2722]! } - public var Weekday_Thursday: String { return self._s[2723]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2724]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2725]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2726]! } + public var Weekday_Thursday: String { return self._s[2727]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2728]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2729]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2726]!, self._r[2726]!, [_0]) + return formatWithArgumentRanges(self._s[2730]!, self._r[2730]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2727]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2728]! } - public var Passport_RequestedInformation: String { return self._s[2729]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2730]! } - public var Conversation_EncryptionProcessing: String { return self._s[2732]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2733]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2735]! } - public var Channel_Setup_Title: String { return self._s[2736]! } - public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2737]! } - public var Conversation_SearchPlaceholder: String { return self._s[2738]! } - public var OldChannels_GroupEmptyFormat: String { return self._s[2739]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2740]! } - public var Checkout_ErrorGeneric: String { return self._s[2741]! } - public var Passport_Language_hu: String { return self._s[2742]! } - public var GroupPermission_EditingDisabled: String { return self._s[2743]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2745]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2731]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2732]! } + public var Passport_RequestedInformation: String { return self._s[2733]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2734]! } + public var Conversation_EncryptionProcessing: String { return self._s[2736]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2737]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2739]! } + public var Channel_Setup_Title: String { return self._s[2740]! } + public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2741]! } + public var Conversation_SearchPlaceholder: String { return self._s[2742]! } + public var OldChannels_GroupEmptyFormat: String { return self._s[2743]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2744]! } + public var Checkout_ErrorGeneric: String { return self._s[2745]! } + public var Passport_Language_hu: String { return self._s[2746]! } + public var GroupPermission_EditingDisabled: String { return self._s[2747]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2749]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2746]!, self._r[2746]!, [_0]) + return formatWithArgumentRanges(self._s[2750]!, self._r[2750]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2749]!, self._r[2749]!, [_1]) + return formatWithArgumentRanges(self._s[2753]!, self._r[2753]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2750]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2754]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_0]) + return formatWithArgumentRanges(self._s[2755]!, self._r[2755]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2752]! } - public var Group_Location_Info: String { return self._s[2753]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2754]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2755]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2756]! } + public var Group_Location_Info: String { return self._s[2757]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2758]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2759]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2757]!, self._r[2757]!, [_0]) + return formatWithArgumentRanges(self._s[2761]!, self._r[2761]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2758]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2759]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2760]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2761]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2762]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2763]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2764]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2765]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2762]!, self._r[2762]!, [_0]) + return formatWithArgumentRanges(self._s[2766]!, self._r[2766]!, [_0]) } public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2763]!, self._r[2763]!, [_0]) + return formatWithArgumentRanges(self._s[2767]!, self._r[2767]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2764]! } - public var Message_PinnedAnimationMessage: String { return self._s[2766]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2768]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2769]! } - public var Wallet_Info_TransactionTo: String { return self._s[2771]! } - public var Stats_ViewsBySourceTitle: String { return self._s[2772]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2773]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2774]! } - public var Embed_PlayingInPIP: String { return self._s[2775]! } - public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2776]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2777]! } - public var Stats_GroupMessages: String { return self._s[2778]! } + public var Passport_Language_cs: String { return self._s[2768]! } + public var Message_PinnedAnimationMessage: String { return self._s[2770]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2772]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2773]! } + public var Wallet_Info_TransactionTo: String { return self._s[2775]! } + public var Stats_ViewsBySourceTitle: String { return self._s[2776]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2777]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2778]! } + public var Embed_PlayingInPIP: String { return self._s[2779]! } + public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2780]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2781]! } + public var Stats_GroupMessages: String { return self._s[2782]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2779]!, self._r[2779]!, [_0]) + return formatWithArgumentRanges(self._s[2783]!, self._r[2783]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2780]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2784]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2781]!, self._r[2781]!, [_1]) + return formatWithArgumentRanges(self._s[2785]!, self._r[2785]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2782]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2783]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2784]! } - public var AutoNightTheme_System: String { return self._s[2785]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2786]! } - public var CreatePoll_QuizTitle: String { return self._s[2787]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2788]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2789]! } + public var Notification_PaymentSent: String { return self._s[2786]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2787]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2788]! } + public var AutoNightTheme_System: String { return self._s[2789]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2790]! } + public var CreatePoll_QuizTitle: String { return self._s[2791]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2792]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2793]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2792]!, self._r[2792]!, [_1]) + return formatWithArgumentRanges(self._s[2796]!, self._r[2796]!, [_1]) } public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2793]!, self._r[2793]!, [_1]) + return formatWithArgumentRanges(self._s[2797]!, self._r[2797]!, [_1]) } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2794]!, self._r[2794]!, [_1]) + return formatWithArgumentRanges(self._s[2798]!, self._r[2798]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2796]! } - public var PasscodeSettings_HelpTop: String { return self._s[2797]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2798]! } - public var PeerInfo_AddToContacts: String { return self._s[2799]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2800]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2801]! } - public var FeaturedStickers_OtherSection: String { return self._s[2802]! } - public var EditTheme_ShortLink: String { return self._s[2804]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2805]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2806]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2807]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2808]! } - public var Call_Accept: String { return self._s[2810]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2811]! } - public var Month_GenMarch: String { return self._s[2813]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2814]! } - public var LoginPassword_Title: String { return self._s[2815]! } - public var Call_End: String { return self._s[2816]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2817]! } - public var VoiceOver_Chat_Contact: String { return self._s[2818]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2819]! } - public var CallSettings_Always: String { return self._s[2820]! } - public var CallFeedback_Success: String { return self._s[2821]! } - public var TwoStepAuth_SetupHint: String { return self._s[2822]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2800]! } + public var PasscodeSettings_HelpTop: String { return self._s[2801]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2802]! } + public var PeerInfo_AddToContacts: String { return self._s[2803]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2804]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2805]! } + public var FeaturedStickers_OtherSection: String { return self._s[2806]! } + public var EditTheme_ShortLink: String { return self._s[2808]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2809]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2810]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2811]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2812]! } + public var Call_Accept: String { return self._s[2814]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2815]! } + public var Month_GenMarch: String { return self._s[2817]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2818]! } + public var LoginPassword_Title: String { return self._s[2819]! } + public var Call_End: String { return self._s[2820]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2821]! } + public var VoiceOver_Chat_Contact: String { return self._s[2822]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2823]! } + public var CallSettings_Always: String { return self._s[2824]! } + public var CallFeedback_Success: String { return self._s[2825]! } + public var TwoStepAuth_SetupHint: String { return self._s[2826]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_1]) + return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2824]! } - public var PeerInfo_ButtonAddMember: String { return self._s[2825]! } - public var Login_PhoneTitle: String { return self._s[2826]! } - public var Passport_FieldPhoneHelp: String { return self._s[2827]! } - public var Weekday_ShortSunday: String { return self._s[2828]! } - public var Passport_InfoFAQ_URL: String { return self._s[2829]! } - public var ContactInfo_Job: String { return self._s[2831]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2832]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2833]! } - public var CreatePoll_QuizTip: String { return self._s[2834]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2835]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2836]! } - public var Invite_ChannelsTooMuch: String { return self._s[2837]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2838]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2839]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2840]! } - public var Wallet_Receive_AmountText: String { return self._s[2841]! } - public var TwoStepAuth_Disable: String { return self._s[2842]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2843]! } - public var CallFeedback_ReasonNoise: String { return self._s[2844]! } - public var Appearance_AppIconDefault: String { return self._s[2846]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2847]! } - public var MediaPicker_AddCaption: String { return self._s[2848]! } - public var CallSettings_TabIconDescription: String { return self._s[2849]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2828]! } + public var PeerInfo_ButtonAddMember: String { return self._s[2829]! } + public var Login_PhoneTitle: String { return self._s[2830]! } + public var Passport_FieldPhoneHelp: String { return self._s[2831]! } + public var Weekday_ShortSunday: String { return self._s[2832]! } + public var Passport_InfoFAQ_URL: String { return self._s[2833]! } + public var ContactInfo_Job: String { return self._s[2835]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2836]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2837]! } + public var CreatePoll_QuizTip: String { return self._s[2838]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2839]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2840]! } + public var Invite_ChannelsTooMuch: String { return self._s[2841]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2842]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2843]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2844]! } + public var Wallet_Receive_AmountText: String { return self._s[2845]! } + public var TwoStepAuth_Disable: String { return self._s[2846]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2847]! } + public var CallFeedback_ReasonNoise: String { return self._s[2848]! } + public var Appearance_AppIconDefault: String { return self._s[2850]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2851]! } + public var MediaPicker_AddCaption: String { return self._s[2852]! } + public var CallSettings_TabIconDescription: String { return self._s[2853]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2850]!, self._r[2850]!, [_0]) + return formatWithArgumentRanges(self._s[2854]!, self._r[2854]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2851]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2855]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2852]!, self._r[2852]!, [_0]) + return formatWithArgumentRanges(self._s[2856]!, self._r[2856]!, [_0]) } - public var CreatePoll_ExplanationHeader: String { return self._s[2854]! } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2855]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2856]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2857]! } - public var DialogList_SearchSectionRecent: String { return self._s[2858]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2859]! } - public var CreatePoll_Anonymous: String { return self._s[2860]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2863]! } - public var Stats_GroupTopInviter_Promote: String { return self._s[2864]! } - public var LastSeen_WithinAWeek: String { return self._s[2865]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2866]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2868]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2869]! } + public var CreatePoll_ExplanationHeader: String { return self._s[2858]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2859]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2860]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2861]! } + public var DialogList_SearchSectionRecent: String { return self._s[2862]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2863]! } + public var CreatePoll_Anonymous: String { return self._s[2864]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2867]! } + public var Stats_GroupTopInviter_Promote: String { return self._s[2868]! } + public var LastSeen_WithinAWeek: String { return self._s[2869]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2870]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2872]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2873]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2870]!, self._r[2870]!, [_0]) + return formatWithArgumentRanges(self._s[2874]!, self._r[2874]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2871]! } - public var Conversation_StatusLeftGroup: String { return self._s[2872]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2873]! } - public var OwnershipTransfer_Transfer: String { return self._s[2875]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2876]! } - public var ProfilePhoto_MainPhoto: String { return self._s[2877]! } - public var GroupPermission_AddSuccess: String { return self._s[2879]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2881]! } - public var Conversation_ContextMenuCopy: String { return self._s[2882]! } - public var AccessDenied_CallMicrophone: String { return self._s[2883]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2875]! } + public var Conversation_StatusLeftGroup: String { return self._s[2876]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2877]! } + public var OwnershipTransfer_Transfer: String { return self._s[2879]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2880]! } + public var ProfilePhoto_MainPhoto: String { return self._s[2881]! } + public var GroupPermission_AddSuccess: String { return self._s[2883]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2885]! } + public var Conversation_ContextMenuCopy: String { return self._s[2886]! } + public var AccessDenied_CallMicrophone: String { return self._s[2887]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2884]!, self._r[2884]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2888]!, self._r[2888]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2885]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2886]! } - public var Checkout_PaymentMethod_New: String { return self._s[2887]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2888]! } - public var PhotoEditor_QualityTool: String { return self._s[2889]! } - public var Login_SendCodeViaSms: String { return self._s[2890]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2891]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2892]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2893]! } - public var Login_EmailNotConfiguredError: String { return self._s[2894]! } - public var Stats_GroupTopAdminsTitle: String { return self._s[2895]! } - public var SocksProxySetup_Status: String { return self._s[2896]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2897]! } - public var PrivacyPolicy_Accept: String { return self._s[2898]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2899]! } - public var Appearance_AppIconClassicX: String { return self._s[2900]! } + public var Login_InvalidFirstNameError: String { return self._s[2889]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2890]! } + public var Checkout_PaymentMethod_New: String { return self._s[2891]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2892]! } + public var PhotoEditor_QualityTool: String { return self._s[2893]! } + public var Login_SendCodeViaSms: String { return self._s[2894]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2895]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2896]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2897]! } + public var Login_EmailNotConfiguredError: String { return self._s[2898]! } + public var Stats_GroupTopAdminsTitle: String { return self._s[2899]! } + public var SocksProxySetup_Status: String { return self._s[2900]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2901]! } + public var PrivacyPolicy_Accept: String { return self._s[2902]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2903]! } + public var Appearance_AppIconClassicX: String { return self._s[2904]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2901]!, self._r[2901]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2905]!, self._r[2905]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2902]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2904]! } - public var AutoNightTheme_Automatic: String { return self._s[2905]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2906]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2907]! } - public var Cache_Help: String { return self._s[2908]! } - public var Group_ErrorAccessDenied: String { return self._s[2909]! } - public var Passport_Language_fa: String { return self._s[2910]! } - public var Wallet_Intro_Text: String { return self._s[2911]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2912]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2913]! } - public var PrivacySettings_LastSeen: String { return self._s[2914]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2906]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2908]! } + public var AutoNightTheme_Automatic: String { return self._s[2909]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2910]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2911]! } + public var Cache_Help: String { return self._s[2912]! } + public var Group_ErrorAccessDenied: String { return self._s[2913]! } + public var Passport_Language_fa: String { return self._s[2914]! } + public var Wallet_Intro_Text: String { return self._s[2915]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2916]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2917]! } + public var PrivacySettings_LastSeen: String { return self._s[2918]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2915]!, self._r[2915]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2919]!, self._r[2919]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2919]! } - public var Preview_SaveGif: String { return self._s[2920]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2921]! } - public var Profile_About: String { return self._s[2922]! } - public var Channel_About_Placeholder: String { return self._s[2924]! } - public var Login_InfoTitle: String { return self._s[2925]! } + public var Wallet_Configuration_Apply: String { return self._s[2923]! } + public var Preview_SaveGif: String { return self._s[2924]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2925]! } + public var Profile_About: String { return self._s[2926]! } + public var Channel_About_Placeholder: String { return self._s[2928]! } + public var Login_InfoTitle: String { return self._s[2929]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2926]!, self._r[2926]!, [_0]) + return formatWithArgumentRanges(self._s[2930]!, self._r[2930]!, [_0]) + } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2931]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2934]! } + public var ContactInfo_Title: String { return self._s[2935]! } + public var Media_ShareThisVideo: String { return self._s[2936]! } + public var Chat_GenericPsaTooltip: String { return self._s[2937]! } + public var Weekday_ShortFriday: String { return self._s[2938]! } + public var AccessDenied_Contacts: String { return self._s[2940]! } + public var Notification_CallIncomingShort: String { return self._s[2941]! } + public var Group_Setup_TypePublic: String { return self._s[2942]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2943]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2944]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2947]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2948]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2949]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2950]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2951]! } + public func Call_RemoteVideoPaused(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2952]!, self._r[2952]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2927]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2930]! } - public var ContactInfo_Title: String { return self._s[2931]! } - public var Media_ShareThisVideo: String { return self._s[2932]! } - public var Chat_GenericPsaTooltip: String { return self._s[2933]! } - public var Weekday_ShortFriday: String { return self._s[2934]! } - public var AccessDenied_Contacts: String { return self._s[2936]! } - public var Notification_CallIncomingShort: String { return self._s[2937]! } - public var Group_Setup_TypePublic: String { return self._s[2938]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2939]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2940]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2943]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2944]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2945]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2946]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2947]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2948]!, self._r[2948]!, [_0]) + return formatWithArgumentRanges(self._s[2953]!, self._r[2953]!, [_0]) } - public var DialogList_Typing: String { return self._s[2949]! } - public var CallFeedback_IncludeLogs: String { return self._s[2951]! } - public var Checkout_Phone: String { return self._s[2953]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2956]! } - public var Privacy_Calls_Integration: String { return self._s[2957]! } - public var Notifications_PermissionsAllow: String { return self._s[2958]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2964]! } - public var Settings_ChatSettings: String { return self._s[2965]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2966]! } + public var DialogList_Typing: String { return self._s[2954]! } + public var CallFeedback_IncludeLogs: String { return self._s[2956]! } + public var Checkout_Phone: String { return self._s[2958]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2961]! } + public var Privacy_Calls_Integration: String { return self._s[2962]! } + public var Notifications_PermissionsAllow: String { return self._s[2963]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2969]! } + public var Settings_ChatSettings: String { return self._s[2970]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2971]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2968]!, self._r[2968]!, [_0]) + return formatWithArgumentRanges(self._s[2973]!, self._r[2973]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2969]!, self._r[2969]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2974]!, self._r[2974]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2971]! } + public var GroupRemoved_DeleteUser: String { return self._s[2976]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2972]!, self._r[2972]!, [_0]) + return formatWithArgumentRanges(self._s[2977]!, self._r[2977]!, [_0]) } - public var ChatListFolder_CategoryMuted: String { return self._s[2973]! } + public var ChatListFolder_CategoryMuted: String { return self._s[2978]! } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2974]!, self._r[2974]!, [_1]) + return formatWithArgumentRanges(self._s[2979]!, self._r[2979]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2975]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2976]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2978]! } - public var Conversation_Unblock: String { return self._s[2979]! } - public var PrivacySettings_DataSettings: String { return self._s[2980]! } - public var WallpaperPreview_PatternPaternApply: String { return self._s[2981]! } - public var Group_PublicLink_Info: String { return self._s[2982]! } + public var Login_ContinueWithLocalization: String { return self._s[2980]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2981]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2983]! } + public var Notification_VideoCallIncoming: String { return self._s[2984]! } + public var Conversation_Unblock: String { return self._s[2985]! } + public var PrivacySettings_DataSettings: String { return self._s[2986]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[2987]! } + public var Group_PublicLink_Info: String { return self._s[2988]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2983]!, self._r[2983]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2989]!, self._r[2989]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2984]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2990]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2991]!, self._r[2991]!, [_0, _1]) } - public var ChatList_FolderAllChats: String { return self._s[2986]! } - public var OldChannels_ChannelsHeader: String { return self._s[2988]! } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2989]! } - public var PrivacySettings_Passcode: String { return self._s[2991]! } - public var Call_Mute: String { return self._s[2992]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2993]! } - public var Passport_Language_dz: String { return self._s[2994]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2995]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2996]! } - public var Passport_Language_tk: String { return self._s[2997]! } + public var ChatList_FolderAllChats: String { return self._s[2992]! } + public var OldChannels_ChannelsHeader: String { return self._s[2994]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2995]! } + public var PrivacySettings_Passcode: String { return self._s[2997]! } + public var Call_Mute: String { return self._s[2998]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2999]! } + public var Passport_Language_dz: String { return self._s[3000]! } + public var Wallet_Receive_AmountHeader: String { return self._s[3001]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[3002]! } + public var Passport_Language_tk: String { return self._s[3003]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2998]!, self._r[2998]!, [_0]) + return formatWithArgumentRanges(self._s[3004]!, self._r[3004]!, [_0]) } - public var Settings_Search: String { return self._s[2999]! } - public var Wallet_Month_ShortFebruary: String { return self._s[3000]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[3001]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[3002]! } - public var Conversation_ContextMenuReply: String { return self._s[3003]! } - public var WallpaperSearch_ColorBrown: String { return self._s[3004]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[3005]! } - public var Tour_Title1: String { return self._s[3006]! } - public var Wallet_Alert_Cancel: String { return self._s[3007]! } - public var Stats_Total: String { return self._s[3009]! } - public var Conversation_ClearGroupHistory: String { return self._s[3010]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[3011]! } - public var WallpaperPreview_Motion: String { return self._s[3012]! } + public var Settings_Search: String { return self._s[3005]! } + public var Wallet_Month_ShortFebruary: String { return self._s[3006]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[3007]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[3008]! } + public var Conversation_ContextMenuReply: String { return self._s[3009]! } + public var WallpaperSearch_ColorBrown: String { return self._s[3010]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[3011]! } + public var Tour_Title1: String { return self._s[3012]! } + public var Wallet_Alert_Cancel: String { return self._s[3013]! } + public var Stats_Total: String { return self._s[3015]! } + public var Conversation_ClearGroupHistory: String { return self._s[3016]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[3017]! } + public var WallpaperPreview_Motion: String { return self._s[3018]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3013]!, self._r[3013]!, [_0]) + return formatWithArgumentRanges(self._s[3019]!, self._r[3019]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[3014]! } - public var Call_RateCall: String { return self._s[3015]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[3016]! } - public var Passport_PasswordCompleteSetup: String { return self._s[3017]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[3018]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[3020]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[3020]! } + public var Call_RateCall: String { return self._s[3021]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[3022]! } + public var Passport_PasswordCompleteSetup: String { return self._s[3023]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[3024]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[3026]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3022]!, self._r[3022]!, [_0]) + return formatWithArgumentRanges(self._s[3028]!, self._r[3028]!, [_0]) } - public var Compose_Create: String { return self._s[3023]! } - public var Contacts_InviteToTelegram: String { return self._s[3024]! } - public var GroupInfo_Notifications: String { return self._s[3025]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[3027]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[3028]! } - public var Month_GenApril: String { return self._s[3029]! } - public var Appearance_AutoNightTheme: String { return self._s[3030]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[3032]! } - public var Login_CodeSentSms: String { return self._s[3034]! } + public var Compose_Create: String { return self._s[3029]! } + public var Contacts_InviteToTelegram: String { return self._s[3030]! } + public var GroupInfo_Notifications: String { return self._s[3031]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[3033]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[3034]! } + public var Month_GenApril: String { return self._s[3035]! } + public var Appearance_AutoNightTheme: String { return self._s[3036]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[3038]! } + public var Login_CodeSentSms: String { return self._s[3040]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3035]!, self._r[3035]!, [_0]) + return formatWithArgumentRanges(self._s[3041]!, self._r[3041]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[3036]! } - public var LogoutOptions_ContactSupportText: String { return self._s[3037]! } - public var Passport_Language_hr: String { return self._s[3038]! } - public var Common_ActionNotAllowedError: String { return self._s[3039]! } + public var EmptyGroupInfo_Line3: String { return self._s[3042]! } + public var LogoutOptions_ContactSupportText: String { return self._s[3043]! } + public var Passport_Language_hr: String { return self._s[3044]! } + public var Common_ActionNotAllowedError: String { return self._s[3045]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3040]!, self._r[3040]!, [_0]) + return formatWithArgumentRanges(self._s[3046]!, self._r[3046]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[3041]! } - public var Wallet_Info_TransactionFrom: String { return self._s[3042]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[3043]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[3044]! } - public var Privacy_SecretChatsTitle: String { return self._s[3045]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[3047]! } - public var GroupInfo_AddUserLeftError: String { return self._s[3048]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[3049]! } - public var ChatListFolder_NameSectionHeader: String { return self._s[3050]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[3051]! } - public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[3052]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[3053]! } - public var Preview_DeleteGif: String { return self._s[3054]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[3055]! } - public var Group_ErrorNotMutualContact: String { return self._s[3056]! } - public var Notification_MessageLifetime5s: String { return self._s[3057]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[3058]! } - public var OldChannels_ChannelFormat: String { return self._s[3059]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[3047]! } + public var Wallet_Info_TransactionFrom: String { return self._s[3048]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[3049]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[3050]! } + public var Privacy_SecretChatsTitle: String { return self._s[3051]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[3053]! } + public var GroupInfo_AddUserLeftError: String { return self._s[3054]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[3055]! } + public var ChatListFolder_NameSectionHeader: String { return self._s[3056]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[3057]! } + public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[3058]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[3059]! } + public var Preview_DeleteGif: String { return self._s[3060]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[3061]! } + public var Group_ErrorNotMutualContact: String { return self._s[3062]! } + public var Notification_MessageLifetime5s: String { return self._s[3063]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[3064]! } + public var OldChannels_ChannelFormat: String { return self._s[3065]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3060]!, self._r[3060]!, [_0]) + return formatWithArgumentRanges(self._s[3066]!, self._r[3066]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[3061]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3063]! } - public var ReportSpam_DeleteThisChat: String { return self._s[3064]! } - public var Passport_Address_AddBankStatement: String { return self._s[3065]! } - public var Notification_CallIncoming: String { return self._s[3066]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[3067]! } - public var Compose_NewGroupTitle: String { return self._s[3068]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3070]! } - public var Passport_Address_Postcode: String { return self._s[3072]! } + public var VoiceOver_Chat_Video: String { return self._s[3067]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3069]! } + public var ReportSpam_DeleteThisChat: String { return self._s[3070]! } + public var Passport_Address_AddBankStatement: String { return self._s[3071]! } + public var Notification_CallIncoming: String { return self._s[3072]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[3073]! } + public var Compose_NewGroupTitle: String { return self._s[3074]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3076]! } + public var Passport_Address_Postcode: String { return self._s[3078]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3073]!, self._r[3073]!, [_0]) + return formatWithArgumentRanges(self._s[3079]!, self._r[3079]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[3074]! } - public var Wallet_Month_ShortOctober: String { return self._s[3075]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[3076]! } - public var WallpaperColors_Title: String { return self._s[3077]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3078]! } - public var VoiceOver_MessageContextForward: String { return self._s[3079]! } - public var GroupPermission_Duration: String { return self._s[3080]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[3080]! } + public var Wallet_Month_ShortOctober: String { return self._s[3081]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[3082]! } + public var WallpaperColors_Title: String { return self._s[3083]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3084]! } + public var VoiceOver_MessageContextForward: String { return self._s[3085]! } + public var GroupPermission_Duration: String { return self._s[3086]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3081]!, self._r[3081]!, [_0]) + return formatWithArgumentRanges(self._s[3087]!, self._r[3087]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[3082]! } - public var Username_Placeholder: String { return self._s[3083]! } - public var CallFeedback_WhatWentWrong: String { return self._s[3084]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[3085]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3086]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[3088]! } + public var Username_Placeholder: String { return self._s[3089]! } + public var CallFeedback_WhatWentWrong: String { return self._s[3090]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[3091]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3092]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3088]!, self._r[3088]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3094]!, self._r[3094]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[3089]! } - public var Channel_MessagePhotoUpdated: String { return self._s[3090]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[3091]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3092]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[3093]! } - public var Conversation_ContextMenuMore: String { return self._s[3094]! } - public var Privacy_PaymentsClearInfo: String { return self._s[3095]! } - public var CallSettings_TabIcon: String { return self._s[3096]! } - public var KeyCommand_Find: String { return self._s[3097]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[3098]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3099]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3100]! } + public var Passport_PasswordDescription: String { return self._s[3095]! } + public var Channel_MessagePhotoUpdated: String { return self._s[3096]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[3097]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3098]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[3099]! } + public var Conversation_ContextMenuMore: String { return self._s[3100]! } + public var Privacy_PaymentsClearInfo: String { return self._s[3101]! } + public var CallSettings_TabIcon: String { return self._s[3102]! } + public var KeyCommand_Find: String { return self._s[3103]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[3104]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3105]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3106]! } public func Conversation_NoticeInvitedByInChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3101]!, self._r[3101]!, [_0]) + return formatWithArgumentRanges(self._s[3107]!, self._r[3107]!, [_0]) } - public var Message_PinnedGame: String { return self._s[3102]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3103]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3105]! } - public var Login_CallRequestState2: String { return self._s[3107]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3109]! } + public var Message_PinnedGame: String { return self._s[3108]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3109]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3111]! } + public var Login_CallRequestState2: String { return self._s[3113]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3115]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3110]!, self._r[3110]!, [_0]) + return formatWithArgumentRanges(self._s[3116]!, self._r[3116]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3112]!, self._r[3112]!, [_0]) + return formatWithArgumentRanges(self._s[3118]!, self._r[3118]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[3113]! } - public var WallpaperPreview_Blurred: String { return self._s[3114]! } - public var Conversation_InstantPagePreview: String { return self._s[3115]! } - public var PeerInfo_ButtonUnmute: String { return self._s[3116]! } + public var AuthSessions_AddDevice: String { return self._s[3119]! } + public var WallpaperPreview_Blurred: String { return self._s[3120]! } + public var Conversation_InstantPagePreview: String { return self._s[3121]! } + public var PeerInfo_ButtonUnmute: String { return self._s[3122]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3117]!, self._r[3117]!, [_0]) + return formatWithArgumentRanges(self._s[3123]!, self._r[3123]!, [_0]) } - public var ChatList_PeerTypeChannel: String { return self._s[3118]! } - public var SecretTimer_VideoDescription: String { return self._s[3121]! } - public var WallpaperSearch_ColorRed: String { return self._s[3122]! } - public var GroupPermission_NoPinMessages: String { return self._s[3123]! } - public var Passport_Language_es: String { return self._s[3124]! } - public var Permissions_ContactsAllow_v0: String { return self._s[3126]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3127]! } + public var ChatList_PeerTypeChannel: String { return self._s[3124]! } + public var SecretTimer_VideoDescription: String { return self._s[3127]! } + public var WallpaperSearch_ColorRed: String { return self._s[3128]! } + public var GroupPermission_NoPinMessages: String { return self._s[3129]! } + public var Passport_Language_es: String { return self._s[3130]! } + public var Permissions_ContactsAllow_v0: String { return self._s[3132]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3133]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3128]!, self._r[3128]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3134]!, self._r[3134]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[3129]! } - public var WebPreview_GettingLinkInfo: String { return self._s[3131]! } - public var Watch_UserInfo_Unmute: String { return self._s[3132]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3133]! } - public var AccessDenied_CameraRestricted: String { return self._s[3135]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[3135]! } + public var WebPreview_GettingLinkInfo: String { return self._s[3137]! } + public var Watch_UserInfo_Unmute: String { return self._s[3138]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3139]! } + public var AccessDenied_CameraRestricted: String { return self._s[3141]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3136]!, self._r[3136]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[3142]!, self._r[3142]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[3138]! } - public var Settings_CopyUsername: String { return self._s[3139]! } - public var Contacts_SearchLabel: String { return self._s[3140]! } - public var Map_OpenInYandexNavigator: String { return self._s[3142]! } - public var PasscodeSettings_EncryptData: String { return self._s[3143]! } - public var Settings_Wallet: String { return self._s[3144]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3145]! } - public var ChatList_PeerTypeBot: String { return self._s[3146]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[3147]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[3148]! } - public var DialogList_AdNoticeAlert: String { return self._s[3149]! } - public var Wallet_Month_GenMay: String { return self._s[3151]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3152]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3153]! } - public var Localization_LanguageCustom: String { return self._s[3154]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3155]! } - public var CallFeedback_Title: String { return self._s[3156]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3159]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3160]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[3161]! } - public var Conversation_InfoGroup: String { return self._s[3162]! } - public var Compose_NewMessage: String { return self._s[3163]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3164]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3165]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3166]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3167]! } + public var ChatList_ReadAll: String { return self._s[3144]! } + public var Settings_CopyUsername: String { return self._s[3145]! } + public var Contacts_SearchLabel: String { return self._s[3146]! } + public var Map_OpenInYandexNavigator: String { return self._s[3148]! } + public var PasscodeSettings_EncryptData: String { return self._s[3149]! } + public var Settings_Wallet: String { return self._s[3150]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3151]! } + public var ChatList_PeerTypeBot: String { return self._s[3152]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[3153]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[3154]! } + public var DialogList_AdNoticeAlert: String { return self._s[3155]! } + public var Wallet_Month_GenMay: String { return self._s[3157]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3158]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3159]! } + public var Localization_LanguageCustom: String { return self._s[3160]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3161]! } + public var CallFeedback_Title: String { return self._s[3162]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3165]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3166]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[3167]! } + public var Conversation_InfoGroup: String { return self._s[3168]! } + public var Compose_NewMessage: String { return self._s[3169]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3170]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3171]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3172]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3173]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3168]!, self._r[3168]!, [_0]) + return formatWithArgumentRanges(self._s[3174]!, self._r[3174]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3169]! } - public var Login_CancelSignUpConfirmation: String { return self._s[3170]! } - public var ChangePhoneNumberCode_Help: String { return self._s[3171]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[3172]! } - public var ChatList_Context_RemoveFromFolder: String { return self._s[3173]! } - public var Channel_BlackList_Title: String { return self._s[3174]! } - public var UserInfo_PhoneCall: String { return self._s[3175]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3177]! } - public var Wallet_Month_ShortJanuary: String { return self._s[3178]! } - public var State_connecting: String { return self._s[3179]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3180]! } - public var Wallet_Month_GenMarch: String { return self._s[3181]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[3182]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[3183]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3175]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3176]! } + public var ChangePhoneNumberCode_Help: String { return self._s[3177]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[3178]! } + public var ChatList_Context_RemoveFromFolder: String { return self._s[3179]! } + public var Channel_BlackList_Title: String { return self._s[3180]! } + public var UserInfo_PhoneCall: String { return self._s[3181]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3183]! } + public var Wallet_Month_ShortJanuary: String { return self._s[3184]! } + public var State_connecting: String { return self._s[3185]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3186]! } + public var Wallet_Month_GenMarch: String { return self._s[3187]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[3188]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[3189]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3184]!, self._r[3184]!, [_0]) + return formatWithArgumentRanges(self._s[3190]!, self._r[3190]!, [_0]) } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3185]!, self._r[3185]!, [_0]) + return formatWithArgumentRanges(self._s[3191]!, self._r[3191]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[3186]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3187]! } - public var Passport_Identity_EditPassport: String { return self._s[3188]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[3190]! } - public var Localization_EnglishLanguageName: String { return self._s[3191]! } - public var Share_AuthDescription: String { return self._s[3192]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3193]! } - public var Passport_Identity_Surname: String { return self._s[3194]! } - public var Compose_TokenListPlaceholder: String { return self._s[3195]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3196]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[3197]! } - public var Settings_AboutEmpty: String { return self._s[3198]! } - public var Conversation_Unmute: String { return self._s[3199]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[3201]! } - public var Wallet_Sending_Text: String { return self._s[3202]! } + public var Notifications_GroupNotifications: String { return self._s[3192]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3193]! } + public var Passport_Identity_EditPassport: String { return self._s[3194]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[3196]! } + public var Localization_EnglishLanguageName: String { return self._s[3197]! } + public var Share_AuthDescription: String { return self._s[3198]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3199]! } + public var Passport_Identity_Surname: String { return self._s[3200]! } + public var Compose_TokenListPlaceholder: String { return self._s[3201]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3202]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[3203]! } + public var Settings_AboutEmpty: String { return self._s[3204]! } + public var Conversation_Unmute: String { return self._s[3205]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[3207]! } + public var Wallet_Sending_Text: String { return self._s[3208]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3203]!, self._r[3203]!, [_1]) + return formatWithArgumentRanges(self._s[3209]!, self._r[3209]!, [_1]) } - public var Login_CodeSentCall: String { return self._s[3204]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3206]! } - public var ChatSettings_Appearance: String { return self._s[3207]! } - public var ClearCache_StorageUsage: String { return self._s[3208]! } - public var ChatListFolder_NameContacts: String { return self._s[3209]! } - public var Appearance_PickAccentColor: String { return self._s[3210]! } + public var Login_CodeSentCall: String { return self._s[3210]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3212]! } + public var ChatSettings_Appearance: String { return self._s[3213]! } + public var ClearCache_StorageUsage: String { return self._s[3214]! } + public var ChatListFolder_NameContacts: String { return self._s[3215]! } + public var Appearance_PickAccentColor: String { return self._s[3216]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3211]!, self._r[3211]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3217]!, self._r[3217]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3212]!, self._r[3212]!, [_1]) + return formatWithArgumentRanges(self._s[3218]!, self._r[3218]!, [_1]) } - public var Notification_CallMissed: String { return self._s[3213]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3214]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3215]! } - public var Wallet_Month_GenOctober: String { return self._s[3217]! } - public var ChatAdmins_AdminLabel: String { return self._s[3218]! } - public var KeyCommand_JumpToNextChat: String { return self._s[3219]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[3221]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3222]! } - public var Month_GenJune: String { return self._s[3223]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[3224]! } - public var Watch_Location_Current: String { return self._s[3225]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3226]! } - public var Conversation_TitleMute: String { return self._s[3227]! } - public var Map_PlacesInThisArea: String { return self._s[3228]! } + public var Notification_CallMissed: String { return self._s[3219]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3220]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3221]! } + public var Wallet_Month_GenOctober: String { return self._s[3223]! } + public var ChatAdmins_AdminLabel: String { return self._s[3224]! } + public var KeyCommand_JumpToNextChat: String { return self._s[3225]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[3227]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3228]! } + public var Month_GenJune: String { return self._s[3229]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[3230]! } + public var Watch_Location_Current: String { return self._s[3231]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3232]! } + public var Conversation_TitleMute: String { return self._s[3233]! } + public var Map_PlacesInThisArea: String { return self._s[3234]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3229]!, self._r[3229]!, [_1]) + return formatWithArgumentRanges(self._s[3235]!, self._r[3235]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3230]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3236]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3231]!, self._r[3231]!, [_0]) + return formatWithArgumentRanges(self._s[3237]!, self._r[3237]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[3232]! } - public var Chat_SlowmodeSendError: String { return self._s[3233]! } - public var MaskStickerSettings_Info: String { return self._s[3234]! } - public var EditTheme_Expand_TopInfo: String { return self._s[3235]! } + public var Call_ReportPlaceholder: String { return self._s[3238]! } + public var Chat_SlowmodeSendError: String { return self._s[3239]! } + public var MaskStickerSettings_Info: String { return self._s[3240]! } + public var EditTheme_Expand_TopInfo: String { return self._s[3241]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3236]!, self._r[3236]!, [_0]) + return formatWithArgumentRanges(self._s[3242]!, self._r[3242]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[3237]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3239]! } - public var Contacts_ShareTelegram: String { return self._s[3240]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3241]! } - public var Map_AddressOnMap: String { return self._s[3242]! } - public var Channel_ErrorAccessDenied: String { return self._s[3243]! } - public var UserInfo_ScamBotWarning: String { return self._s[3245]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[3246]! } - public var Call_ConnectionErrorTitle: String { return self._s[3247]! } - public var UserInfo_NotificationsEnable: String { return self._s[3248]! } - public var ArchivedChats_IntroText1: String { return self._s[3249]! } - public var Tour_Text4: String { return self._s[3252]! } - public var WallpaperSearch_Recent: String { return self._s[3253]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3254]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3255]! } - public var Profile_MessageLifetime2s: String { return self._s[3257]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3258]! } - public var Notification_MessageLifetime2s: String { return self._s[3259]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[3243]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3245]! } + public var Contacts_ShareTelegram: String { return self._s[3246]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3247]! } + public var Map_AddressOnMap: String { return self._s[3248]! } + public var Channel_ErrorAccessDenied: String { return self._s[3249]! } + public var UserInfo_ScamBotWarning: String { return self._s[3251]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[3252]! } + public var Call_ConnectionErrorTitle: String { return self._s[3253]! } + public var UserInfo_NotificationsEnable: String { return self._s[3254]! } + public var ArchivedChats_IntroText1: String { return self._s[3255]! } + public var Tour_Text4: String { return self._s[3258]! } + public var WallpaperSearch_Recent: String { return self._s[3259]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3260]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3261]! } + public var Profile_MessageLifetime2s: String { return self._s[3263]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3264]! } + public var Notification_MessageLifetime2s: String { return self._s[3265]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3260]!, self._r[3260]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3266]!, self._r[3266]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[3261]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3262]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3263]! } + public var Cache_ClearCache: String { return self._s[3267]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3268]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3269]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3267]!, self._r[3267]!, [_0]) + return formatWithArgumentRanges(self._s[3273]!, self._r[3273]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3269]!, self._r[3269]!, [_0]) + return formatWithArgumentRanges(self._s[3275]!, self._r[3275]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3270]! } - public var PeerInfo_PaneMembers: String { return self._s[3271]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3272]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3273]! } - public var ChatList_UnarchiveAction: String { return self._s[3274]! } - public var AutoNightTheme_Title: String { return self._s[3275]! } - public var InstantPage_FeedbackButton: String { return self._s[3276]! } - public var Passport_FieldAddress: String { return self._s[3277]! } + public var LocalGroup_Text: String { return self._s[3276]! } + public var PeerInfo_PaneMembers: String { return self._s[3277]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3278]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3279]! } + public var ChatList_UnarchiveAction: String { return self._s[3280]! } + public var AutoNightTheme_Title: String { return self._s[3281]! } + public var InstantPage_FeedbackButton: String { return self._s[3282]! } + public var Passport_FieldAddress: String { return self._s[3283]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3278]!, self._r[3278]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3284]!, self._r[3284]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3279]! } + public var Month_ShortMarch: String { return self._s[3285]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3280]!, self._r[3280]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3286]!, self._r[3286]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3281]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3282]! } - public var Passport_FloodError: String { return self._s[3283]! } - public var SecretGif_Title: String { return self._s[3284]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3285]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3286]! } - public var Passport_Language_th: String { return self._s[3288]! } - public var Passport_Address_Address: String { return self._s[3289]! } - public var Login_InvalidLastNameError: String { return self._s[3290]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3291]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3292]! } - public var ChatList_Context_Archive: String { return self._s[3293]! } - public var SettingsSearch_FAQ: String { return self._s[3294]! } - public var ShareMenu_Send: String { return self._s[3295]! } - public var ChatState_Connecting: String { return self._s[3296]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3298]! } - public var Month_GenNovember: String { return self._s[3300]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3302]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3287]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3288]! } + public var Passport_FloodError: String { return self._s[3289]! } + public var SecretGif_Title: String { return self._s[3290]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3291]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3292]! } + public var Passport_Language_th: String { return self._s[3294]! } + public var Passport_Address_Address: String { return self._s[3295]! } + public var Login_InvalidLastNameError: String { return self._s[3296]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3297]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3298]! } + public var ChatList_Context_Archive: String { return self._s[3299]! } + public var SettingsSearch_FAQ: String { return self._s[3300]! } + public var ShareMenu_Send: String { return self._s[3301]! } + public var ChatState_Connecting: String { return self._s[3302]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3304]! } + public var Month_GenNovember: String { return self._s[3306]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3308]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3303]!, self._r[3303]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3309]!, self._r[3309]!, [_1, _2]) } - public var ChatListFolder_CategoryChannels: String { return self._s[3304]! } - public var Conversation_SwipeToReplyHintText: String { return self._s[3305]! } - public var Checkout_Email: String { return self._s[3306]! } - public var NotificationsSound_Tritone: String { return self._s[3307]! } - public var Paint_Marker: String { return self._s[3309]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3311]! } - public var Wallet_ContextMenuCopy: String { return self._s[3313]! } + public var ChatListFolder_CategoryChannels: String { return self._s[3310]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3311]! } + public var Checkout_Email: String { return self._s[3312]! } + public var NotificationsSound_Tritone: String { return self._s[3313]! } + public var Paint_Marker: String { return self._s[3315]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3317]! } + public var Wallet_ContextMenuCopy: String { return self._s[3319]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3321]!, self._r[3321]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3316]! } - public var Stickers_Installed: String { return self._s[3318]! } + public var Appearance_TextSize_Automatic: String { return self._s[3322]! } + public var Stickers_Installed: String { return self._s[3324]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3319]!, self._r[3319]!, [_1]) + return formatWithArgumentRanges(self._s[3325]!, self._r[3325]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3320]!, self._r[3320]!, [_0]) + return formatWithArgumentRanges(self._s[3326]!, self._r[3326]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3321]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3327]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3322]!, self._r[3322]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3328]!, self._r[3328]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3323]! } - public var Notification_Exceptions_Add: String { return self._s[3324]! } - public var DialogList_You: String { return self._s[3325]! } - public var ChatList_PsaLabel_covid: String { return self._s[3327]! } - public var MediaPicker_Send: String { return self._s[3329]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3330]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3331]! } - public var Call_AudioRouteSpeaker: String { return self._s[3332]! } - public var Watch_UserInfo_Title: String { return self._s[3333]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3334]! } - public var Appearance_AccentColor: String { return self._s[3336]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3329]! } + public var Notification_Exceptions_Add: String { return self._s[3330]! } + public var DialogList_You: String { return self._s[3331]! } + public var ChatList_PsaLabel_covid: String { return self._s[3333]! } + public var MediaPicker_Send: String { return self._s[3335]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3336]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3337]! } + public var Call_AudioRouteSpeaker: String { return self._s[3338]! } + public var Watch_UserInfo_Title: String { return self._s[3339]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3340]! } + public var Appearance_AccentColor: String { return self._s[3342]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_0]) + return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3338]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3344]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3339]!, self._r[3339]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3345]!, self._r[3345]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3340]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3341]! } - public var Notification_CallOutgoing: String { return self._s[3342]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3343]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3344]! } - public var Call_RecordingDisabledMessage: String { return self._s[3345]! } - public var Message_Game: String { return self._s[3346]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3347]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3348]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3349]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3350]! } - public var Date_DialogDateFormat: String { return self._s[3352]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3353]! } - public var Notifications_InAppNotifications: String { return self._s[3354]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3346]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3347]! } + public var Notification_CallOutgoing: String { return self._s[3348]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3349]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3350]! } + public var Call_RecordingDisabledMessage: String { return self._s[3351]! } + public var Message_Game: String { return self._s[3352]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3353]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3354]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3355]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3356]! } + public var Date_DialogDateFormat: String { return self._s[3358]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3359]! } + public var Notifications_InAppNotifications: String { return self._s[3360]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3355]!, self._r[3355]!, [_0]) + return formatWithArgumentRanges(self._s[3361]!, self._r[3361]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3356]!, self._r[3356]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3362]!, self._r[3362]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3357]! } + public var NewContact_Title: String { return self._s[3363]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3358]!, self._r[3358]!, [_0]) + return formatWithArgumentRanges(self._s[3364]!, self._r[3364]!, [_0]) } - public var Stats_GroupTopPoster_Promote: String { return self._s[3359]! } - public var Conversation_ViewContactDetails: String { return self._s[3360]! } + public var Stats_GroupTopPoster_Promote: String { return self._s[3365]! } + public var Conversation_ViewContactDetails: String { return self._s[3366]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3362]!, self._r[3362]!, [_1]) + return formatWithArgumentRanges(self._s[3368]!, self._r[3368]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3363]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3364]! } - public var PrivacySettings_Title: String { return self._s[3365]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3368]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3369]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3370]! } - public var Contacts_PhoneNumber: String { return self._s[3371]! } - public var PeerInfo_ButtonMute: String { return self._s[3372]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3374]! } - public var Map_ShowPlaces: String { return self._s[3375]! } - public var ChatAdmins_Title: String { return self._s[3376]! } - public var InstantPage_Reference: String { return self._s[3378]! } - public var Wallet_Info_Updating: String { return self._s[3379]! } - public var ReportGroupLocation_Text: String { return self._s[3380]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3369]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3370]! } + public var PrivacySettings_Title: String { return self._s[3371]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3374]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3375]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3376]! } + public var Contacts_PhoneNumber: String { return self._s[3377]! } + public var PeerInfo_ButtonMute: String { return self._s[3378]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3380]! } + public var Map_ShowPlaces: String { return self._s[3381]! } + public var ChatAdmins_Title: String { return self._s[3382]! } + public var InstantPage_Reference: String { return self._s[3384]! } + public var Wallet_Info_Updating: String { return self._s[3385]! } + public var ReportGroupLocation_Text: String { return self._s[3386]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3381]!, self._r[3381]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3387]!, self._r[3387]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3382]! } - public var Watch_UserInfo_Block: String { return self._s[3383]! } - public var ChatSettings_Stickers: String { return self._s[3384]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3385]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3386]! } + public var Camera_FlashOff: String { return self._s[3388]! } + public var Watch_UserInfo_Block: String { return self._s[3389]! } + public var ChatSettings_Stickers: String { return self._s[3390]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3391]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3392]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3387]!, self._r[3387]!, [_0]) + return formatWithArgumentRanges(self._s[3393]!, self._r[3393]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3388]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3389]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3390]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3391]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3392]! } - public var VoiceOver_MessageContextShare: String { return self._s[3393]! } + public var Settings_ViewPhoto: String { return self._s[3394]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3395]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3396]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3397]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3398]! } + public var VoiceOver_MessageContextShare: String { return self._s[3399]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3395]!, self._r[3395]!, [_0]) + return formatWithArgumentRanges(self._s[3401]!, self._r[3401]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3396]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3397]! } + public var Privacy_DeleteDrafts: String { return self._s[3402]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3403]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3398]!, self._r[3398]!, [_0]) + return formatWithArgumentRanges(self._s[3404]!, self._r[3404]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3399]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3400]! } - public var DialogList_SavedMessages: String { return self._s[3401]! } - public var GroupInfo_UpgradeButton: String { return self._s[3402]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3404]! } - public var DialogList_Pin: String { return self._s[3405]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3405]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3406]! } + public var DialogList_SavedMessages: String { return self._s[3407]! } + public var GroupInfo_UpgradeButton: String { return self._s[3408]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3410]! } + public var DialogList_Pin: String { return self._s[3411]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3406]!, self._r[3406]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3412]!, self._r[3412]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3407]!, self._r[3407]!, [_0]) + return formatWithArgumentRanges(self._s[3413]!, self._r[3413]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3408]! } - public var UserInfo_NotificationsDisable: String { return self._s[3409]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[3410]! } - public var Paint_Outlined: String { return self._s[3411]! } - public var Activity_PlayingGame: String { return self._s[3412]! } - public var SearchImages_NoImagesFound: String { return self._s[3413]! } - public var SocksProxySetup_ProxyType: String { return self._s[3414]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3416]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3417]! } - public var Settings_AppLanguage: String { return self._s[3418]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3419]! } - public var Common_ChoosePhoto: String { return self._s[3420]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3421]! } - public var CallFeedback_ReasonEcho: String { return self._s[3422]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3414]! } + public var UserInfo_NotificationsDisable: String { return self._s[3415]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[3416]! } + public var Paint_Outlined: String { return self._s[3417]! } + public var Activity_PlayingGame: String { return self._s[3418]! } + public var SearchImages_NoImagesFound: String { return self._s[3419]! } + public var SocksProxySetup_ProxyType: String { return self._s[3420]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3422]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3423]! } + public var Settings_AppLanguage: String { return self._s[3424]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3425]! } + public var Common_ChoosePhoto: String { return self._s[3426]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3427]! } + public var CallFeedback_ReasonEcho: String { return self._s[3428]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3423]!, self._r[3423]!, [_1]) + return formatWithArgumentRanges(self._s[3429]!, self._r[3429]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3424]! } - public var PollResults_Collapse: String { return self._s[3425]! } - public var Activity_UploadingVideo: String { return self._s[3426]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3427]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3428]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3429]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3430]! } - public var PUSH_SENDER_YOU: String { return self._s[3431]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3432]! } - public var Checkout_PayWithTouchId: String { return self._s[3433]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3434]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3430]! } + public var PollResults_Collapse: String { return self._s[3431]! } + public var Activity_UploadingVideo: String { return self._s[3432]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3433]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3434]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3435]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3436]! } + public var PUSH_SENDER_YOU: String { return self._s[3437]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3438]! } + public var Checkout_PayWithTouchId: String { return self._s[3439]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3440]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1]) + return formatWithArgumentRanges(self._s[3442]!, self._r[3442]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3437]! } + public var Notifications_ExceptionsNone: String { return self._s[3443]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3438]!, self._r[3438]!, [_0]) + return formatWithArgumentRanges(self._s[3444]!, self._r[3444]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3439]!, self._r[3439]!, [_1]) + return formatWithArgumentRanges(self._s[3445]!, self._r[3445]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3441]! } - public var Passport_Address_Region: String { return self._s[3444]! } - public var ChatList_DeleteChat: String { return self._s[3445]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3446]! } - public var PhotoEditor_TiltShift: String { return self._s[3447]! } - public var Settings_FAQ_URL: String { return self._s[3448]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3449]! } - public var Passport_Language_sl: String { return self._s[3451]! } - public var Settings_PrivacySettings: String { return self._s[3453]! } - public var SharedMedia_TitleLink: String { return self._s[3454]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3455]! } - public var Settings_SetProfilePhoto: String { return self._s[3456]! } - public var Channel_About_Help: String { return self._s[3457]! } - public var Contacts_PermissionsEnable: String { return self._s[3458]! } - public var Wallet_Sending_Title: String { return self._s[3459]! } - public var PeerInfo_PaneMedia: String { return self._s[3460]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3461]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3462]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3464]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3465]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3466]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3467]! } - public var OldChannels_Title: String { return self._s[3468]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3469]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3471]! } - public var Map_OpenInYandexMaps: String { return self._s[3473]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3474]! } - public var VoiceOver_MessageContextReply: String { return self._s[3475]! } - public var ChatListFolder_DiscardConfirmation: String { return self._s[3477]! } - public var PhotoEditor_SaturationTool: String { return self._s[3478]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3447]! } + public var Passport_Address_Region: String { return self._s[3450]! } + public var ChatList_DeleteChat: String { return self._s[3451]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3452]! } + public var PhotoEditor_TiltShift: String { return self._s[3453]! } + public var Settings_FAQ_URL: String { return self._s[3454]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3455]! } + public var Passport_Language_sl: String { return self._s[3457]! } + public var Settings_PrivacySettings: String { return self._s[3459]! } + public var SharedMedia_TitleLink: String { return self._s[3460]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3461]! } + public var Settings_SetProfilePhoto: String { return self._s[3462]! } + public var Channel_About_Help: String { return self._s[3463]! } + public var Contacts_PermissionsEnable: String { return self._s[3464]! } + public var Wallet_Sending_Title: String { return self._s[3465]! } + public var PeerInfo_PaneMedia: String { return self._s[3466]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3467]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3468]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3470]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3471]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3472]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3473]! } + public var OldChannels_Title: String { return self._s[3474]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3475]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3477]! } + public var Map_OpenInYandexMaps: String { return self._s[3479]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3480]! } + public var VoiceOver_MessageContextReply: String { return self._s[3481]! } + public var ChatListFolder_DiscardConfirmation: String { return self._s[3483]! } + public var PhotoEditor_SaturationTool: String { return self._s[3484]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3485]!, self._r[3485]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3480]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3481]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3482]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3486]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3487]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3488]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3483]!, self._r[3483]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3489]!, self._r[3489]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3484]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3486]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3487]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3490]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3492]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3493]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3488]!, self._r[3488]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3494]!, self._r[3494]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3489]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3495]! } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3490]!, self._r[3490]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3496]!, self._r[3496]!, [_1, _2, _3]) } - public var WallpaperPreview_PatternTitle: String { return self._s[3491]! } - public var GroupInfo_PublicLinkAdd: String { return self._s[3492]! } - public var Passport_PassportInformation: String { return self._s[3495]! } - public var Theme_Unsupported: String { return self._s[3496]! } - public var WatchRemote_AlertTitle: String { return self._s[3497]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3498]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3500]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3497]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3498]! } + public var Passport_PassportInformation: String { return self._s[3501]! } + public var Theme_Unsupported: String { return self._s[3502]! } + public var WatchRemote_AlertTitle: String { return self._s[3503]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3504]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3506]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3501]!, self._r[3501]!, [_0]) + return formatWithArgumentRanges(self._s[3507]!, self._r[3507]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3502]!, self._r[3502]!, [_1]) + return formatWithArgumentRanges(self._s[3508]!, self._r[3508]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3503]! } - public var Wallet_Navigation_Done: String { return self._s[3505]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3506]! } - public var AccessDenied_CameraDisabled: String { return self._s[3507]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3509]! } + public var Wallet_Navigation_Done: String { return self._s[3511]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3512]! } + public var AccessDenied_CameraDisabled: String { return self._s[3513]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3508]!, self._r[3508]!, [_0]) + return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3509]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3510]! } - public var CreatePoll_Quiz: String { return self._s[3511]! } - public var PhotoEditor_ContrastTool: String { return self._s[3514]! } + public var ClearCache_Forever: String { return self._s[3515]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3516]! } + public var CreatePoll_Quiz: String { return self._s[3517]! } + public var PhotoEditor_ContrastTool: String { return self._s[3520]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3515]!, self._r[3515]!, [_1]) + return formatWithArgumentRanges(self._s[3521]!, self._r[3521]!, [_1]) } - public var DialogList_Draft: String { return self._s[3516]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3517]! } + public var DialogList_Draft: String { return self._s[3522]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3523]! } public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3518]!, self._r[3518]!, [_0]) + return formatWithArgumentRanges(self._s[3524]!, self._r[3524]!, [_0]) } - public var ChatList_PsaAlert_covid: String { return self._s[3519]! } - public var Privacy_TopPeersDelete: String { return self._s[3521]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3522]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3523]! } - public var WebSearch_RecentSectionClear: String { return self._s[3524]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3525]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3527]! } - public var PeerInfo_ButtonMore: String { return self._s[3529]! } - public var Common_Done: String { return self._s[3530]! } - public var Shortcut_SwitchAccount: String { return self._s[3531]! } - public var AuthSessions_EmptyText: String { return self._s[3532]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3533]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3534]! } - public var Tour_Title5: String { return self._s[3536]! } - public var Wallet_Settings_Title: String { return self._s[3537]! } + public var ChatList_PsaAlert_covid: String { return self._s[3525]! } + public var Privacy_TopPeersDelete: String { return self._s[3527]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3528]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3529]! } + public var WebSearch_RecentSectionClear: String { return self._s[3530]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3531]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3533]! } + public var PeerInfo_ButtonMore: String { return self._s[3535]! } + public var Common_Done: String { return self._s[3536]! } + public var Shortcut_SwitchAccount: String { return self._s[3537]! } + public var AuthSessions_EmptyText: String { return self._s[3538]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3539]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3540]! } + public var Tour_Title5: String { return self._s[3542]! } + public var Wallet_Settings_Title: String { return self._s[3543]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3538]!, self._r[3538]!, [_0]) + return formatWithArgumentRanges(self._s[3544]!, self._r[3544]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3539]! } - public var Conversation_LinkDialogSave: String { return self._s[3540]! } - public var GroupInfo_ActionRestrict: String { return self._s[3541]! } - public var Checkout_Title: String { return self._s[3543]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3545]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3547]! } - public var Notification_RenamedGroup: String { return self._s[3548]! } - public var PeopleNearby_Groups: String { return self._s[3549]! } - public var Checkout_PayWithFaceId: String { return self._s[3550]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3551]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3553]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3554]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3555]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3545]! } + public var Conversation_LinkDialogSave: String { return self._s[3546]! } + public var GroupInfo_ActionRestrict: String { return self._s[3547]! } + public var Checkout_Title: String { return self._s[3549]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3551]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3553]! } + public var Notification_RenamedGroup: String { return self._s[3554]! } + public var PeopleNearby_Groups: String { return self._s[3555]! } + public var Checkout_PayWithFaceId: String { return self._s[3556]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3557]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3559]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3560]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3561]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3556]!, self._r[3556]!, [_0]) + return formatWithArgumentRanges(self._s[3562]!, self._r[3562]!, [_0]) } - public var Stats_GroupGrowthTitle: String { return self._s[3557]! } - public var Profile_AddToExisting: String { return self._s[3559]! } + public var Stats_GroupGrowthTitle: String { return self._s[3563]! } + public var Profile_AddToExisting: String { return self._s[3565]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3560]!, self._r[3560]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3566]!, self._r[3566]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3562]! } - public var Permissions_PrivacyPolicy: String { return self._s[3563]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3564]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3565]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3567]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3569]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3570]! } + public var Cache_Files: String { return self._s[3568]! } + public var Permissions_PrivacyPolicy: String { return self._s[3569]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3570]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3571]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3573]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3575]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3576]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3571]!, self._r[3571]!, [_0]) + return formatWithArgumentRanges(self._s[3577]!, self._r[3577]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3572]! } - public var VoiceOver_AttachMedia: String { return self._s[3575]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3576]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3578]! } + public var VoiceOver_AttachMedia: String { return self._s[3581]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3582]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3577]!, self._r[3577]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3583]!, self._r[3583]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3578]! } - public var Conversation_SetReminder_Title: String { return self._s[3579]! } - public var Passport_FieldAddressHelp: String { return self._s[3580]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3581]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3582]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3584]! } + public var Conversation_SetReminder_Title: String { return self._s[3585]! } + public var Passport_FieldAddressHelp: String { return self._s[3586]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3587]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3588]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3583]!, self._r[3583]!, [_0]) + return formatWithArgumentRanges(self._s[3589]!, self._r[3589]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3584]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3585]! } - public var Login_UnknownError: String { return self._s[3586]! } - public var Group_UpgradeNoticeText2: String { return self._s[3589]! } - public var Watch_Compose_AddContact: String { return self._s[3590]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3591]! } - public var Web_Error: String { return self._s[3592]! } - public var Paint_Neon: String { return self._s[3593]! } - public var Gif_Search: String { return self._s[3594]! } - public var Profile_MessageLifetime1h: String { return self._s[3595]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3596]! } - public var Channel_Username_CheckingUsername: String { return self._s[3597]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3598]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3599]! } - public var Channel_AboutItem: String { return self._s[3600]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3603]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3604]! } - public var GroupInfo_SharedMedia: String { return self._s[3605]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3590]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3591]! } + public var Login_UnknownError: String { return self._s[3592]! } + public var Group_UpgradeNoticeText2: String { return self._s[3595]! } + public var Watch_Compose_AddContact: String { return self._s[3596]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3597]! } + public var Web_Error: String { return self._s[3598]! } + public var Paint_Neon: String { return self._s[3599]! } + public var Gif_Search: String { return self._s[3600]! } + public var Profile_MessageLifetime1h: String { return self._s[3601]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3602]! } + public var Channel_Username_CheckingUsername: String { return self._s[3603]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3604]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3605]! } + public var Channel_AboutItem: String { return self._s[3606]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3609]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3610]! } + public var GroupInfo_SharedMedia: String { return self._s[3611]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3606]!, self._r[3606]!, [_1]) + return formatWithArgumentRanges(self._s[3612]!, self._r[3612]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3607]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3613]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3608]!, self._r[3608]!, [_1]) + return formatWithArgumentRanges(self._s[3614]!, self._r[3614]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3609]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3610]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3611]! } - public var CreatePoll_AddOption: String { return self._s[3612]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3613]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3614]! } - public var Channel_Management_AddModerator: String { return self._s[3615]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3616]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3617]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3618]! } - public var Theme_Colors_Background: String { return self._s[3619]! } - public var NotificationsSound_Hello: String { return self._s[3622]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3624]! } - public var Channel_Stickers_Placeholder: String { return self._s[3626]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3615]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3616]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3617]! } + public var CreatePoll_AddOption: String { return self._s[3618]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3619]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3620]! } + public var Channel_Management_AddModerator: String { return self._s[3621]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3622]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3623]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3624]! } + public var Theme_Colors_Background: String { return self._s[3625]! } + public var NotificationsSound_Hello: String { return self._s[3628]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3630]! } + public var Channel_Stickers_Placeholder: String { return self._s[3632]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3627]!, self._r[3627]!, [_0]) + return formatWithArgumentRanges(self._s[3633]!, self._r[3633]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3628]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3629]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3630]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3631]! } - public var AutoDownloadSettings_Channels: String { return self._s[3632]! } - public var Passport_Language_mn: String { return self._s[3633]! } - public var Settings_ChatFolders: String { return self._s[3634]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3634]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3635]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3636]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3637]! } + public var AutoDownloadSettings_Channels: String { return self._s[3638]! } + public var Passport_Language_mn: String { return self._s[3639]! } + public var Settings_ChatFolders: String { return self._s[3640]! } public func ChatList_AddedToFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3635]!, self._r[3635]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3641]!, self._r[3641]!, [_1, _2]) } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3638]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3639]! } - public var Passport_Language_ja: String { return self._s[3641]! } - public var Settings_About_Title: String { return self._s[3642]! } - public var Settings_NotificationsAndSounds: String { return self._s[3643]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3644]! } - public var Settings_BlockedUsers: String { return self._s[3645]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3644]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3645]! } + public var Passport_Language_ja: String { return self._s[3647]! } + public var Settings_About_Title: String { return self._s[3648]! } + public var Settings_NotificationsAndSounds: String { return self._s[3649]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3650]! } + public var Settings_BlockedUsers: String { return self._s[3651]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3646]!, self._r[3646]!, [_0]) + return formatWithArgumentRanges(self._s[3652]!, self._r[3652]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3647]! } - public var Wallet_Weekday_Today: String { return self._s[3648]! } - public var ChatListFolderSettings_AddRecommended: String { return self._s[3649]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3650]! } - public var Widget_ApplicationLocked: String { return self._s[3651]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3652]! } - public var Channel_Username_Title: String { return self._s[3653]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3653]! } + public var Wallet_Weekday_Today: String { return self._s[3654]! } + public var ChatListFolderSettings_AddRecommended: String { return self._s[3655]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3656]! } + public var Widget_ApplicationLocked: String { return self._s[3657]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3658]! } + public var Channel_Username_Title: String { return self._s[3659]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3654]!, self._r[3654]!, [_0]) + return formatWithArgumentRanges(self._s[3660]!, self._r[3660]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3656]! } - public var AppleWatch_Title: String { return self._s[3657]! } - public var Activity_RecordingVideoMessage: String { return self._s[3658]! } + public var AttachmentMenu_File: String { return self._s[3662]! } + public var AppleWatch_Title: String { return self._s[3663]! } + public var Activity_RecordingVideoMessage: String { return self._s[3664]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3659]!, self._r[3659]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3665]!, self._r[3665]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3660]! } - public var Weekday_Saturday: String { return self._s[3661]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3662]! } - public var Conversation_Timer_Send: String { return self._s[3663]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3664]! } - public var Common_Next: String { return self._s[3666]! } - public var Channel_Stickers_YourStickers: String { return self._s[3668]! } - public var Message_Theme: String { return self._s[3669]! } - public var Call_AudioRouteHeadphones: String { return self._s[3670]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3672]! } - public var Watch_Contacts_NoResults: String { return self._s[3674]! } - public var PhotoEditor_TintTool: String { return self._s[3677]! } - public var LoginPassword_ResetAccount: String { return self._s[3679]! } - public var Settings_SavedMessages: String { return self._s[3680]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3681]! } - public var Bot_GenericSupportStatus: String { return self._s[3682]! } - public var StickerPack_Add: String { return self._s[3683]! } - public var Checkout_TotalAmount: String { return self._s[3684]! } - public var Your_cards_number_is_invalid: String { return self._s[3685]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3686]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3687]! } + public var Theme_Colors_Messages: String { return self._s[3666]! } + public var Weekday_Saturday: String { return self._s[3667]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3668]! } + public var Conversation_Timer_Send: String { return self._s[3669]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3670]! } + public var Common_Next: String { return self._s[3672]! } + public var Channel_Stickers_YourStickers: String { return self._s[3674]! } + public var Message_Theme: String { return self._s[3675]! } + public var Call_AudioRouteHeadphones: String { return self._s[3676]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3678]! } + public var Watch_Contacts_NoResults: String { return self._s[3680]! } + public var PhotoEditor_TintTool: String { return self._s[3683]! } + public var LoginPassword_ResetAccount: String { return self._s[3685]! } + public var Settings_SavedMessages: String { return self._s[3686]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3687]! } + public var Bot_GenericSupportStatus: String { return self._s[3688]! } + public var StickerPack_Add: String { return self._s[3689]! } + public var Checkout_TotalAmount: String { return self._s[3690]! } + public var Your_cards_number_is_invalid: String { return self._s[3691]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3692]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3693]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3688]!, self._r[3688]!, [_0]) + return formatWithArgumentRanges(self._s[3694]!, self._r[3694]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3689]!, self._r[3689]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3695]!, self._r[3695]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3690]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3696]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3692]!, self._r[3692]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3698]!, self._r[3698]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3693]!, self._r[3693]!, [_0]) + return formatWithArgumentRanges(self._s[3699]!, self._r[3699]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3694]! } - public var StickerPack_Share: String { return self._s[3695]! } - public var Passport_DeleteAddress: String { return self._s[3696]! } - public var Settings_Passport: String { return self._s[3697]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3698]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3699]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3700]! } - public var Contacts_PermissionsText: String { return self._s[3701]! } - public var Group_Setup_HistoryVisible: String { return self._s[3702]! } - public var Wallet_Month_ShortDecember: String { return self._s[3704]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3706]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3707]! } - public var SocksProxySetup_Title: String { return self._s[3708]! } - public var Notification_Mute1h: String { return self._s[3709]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3700]! } + public var StickerPack_Share: String { return self._s[3701]! } + public var Passport_DeleteAddress: String { return self._s[3702]! } + public var Settings_Passport: String { return self._s[3703]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3704]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3705]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3706]! } + public var Contacts_PermissionsText: String { return self._s[3707]! } + public var Group_Setup_HistoryVisible: String { return self._s[3708]! } + public var Wallet_Month_ShortDecember: String { return self._s[3710]! } + public var PrivacySettings_AutoArchiveTitle: String { return self._s[3712]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3713]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3714]! } + public var SocksProxySetup_Title: String { return self._s[3715]! } + public var Notification_Mute1h: String { return self._s[3716]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3710]!, self._r[3710]!, [_0]) + return formatWithArgumentRanges(self._s[3717]!, self._r[3717]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3711]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3718]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3712]!, self._r[3712]!, [_1]) + return formatWithArgumentRanges(self._s[3719]!, self._r[3719]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3713]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3716]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3718]! } - public var DialogList_NoMessagesText: String { return self._s[3719]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3720]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3721]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3723]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3724]! } - public var Common_TakePhotoOrVideo: String { return self._s[3725]! } - public var Wallet_Words_Text: String { return self._s[3726]! } - public var Call_StatusBusy: String { return self._s[3727]! } - public var Conversation_PinnedMessage: String { return self._s[3728]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3729]! } - public var ChatList_EmptyChatListNewMessage: String { return self._s[3730]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3731]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3732]! } - public var Undo_ChatCleared: String { return self._s[3733]! } - public var CreatePoll_Explanation: String { return self._s[3734]! } - public var AppleWatch_ReplyPresets: String { return self._s[3735]! } - public var Passport_DiscardMessageDescription: String { return self._s[3737]! } - public var Login_NetworkError: String { return self._s[3738]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3720]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3723]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3725]! } + public var DialogList_NoMessagesText: String { return self._s[3726]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3727]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3728]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3730]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3731]! } + public var Common_TakePhotoOrVideo: String { return self._s[3732]! } + public var Wallet_Words_Text: String { return self._s[3733]! } + public var Call_StatusBusy: String { return self._s[3734]! } + public var Conversation_PinnedMessage: String { return self._s[3735]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3736]! } + public var ChatList_EmptyChatListNewMessage: String { return self._s[3737]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3738]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3739]! } + public var Undo_ChatCleared: String { return self._s[3740]! } + public var CreatePoll_Explanation: String { return self._s[3741]! } + public var AppleWatch_ReplyPresets: String { return self._s[3742]! } + public var Passport_DiscardMessageDescription: String { return self._s[3744]! } + public var Login_NetworkError: String { return self._s[3745]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3739]!, self._r[3739]!, [_0]) - } - public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3740]!, self._r[3740]!, [_0]) - } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3741]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3743]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3744]! } - public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3746]!, self._r[3746]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3747]! } - public var VoiceOver_Chat_Music: String { return self._s[3748]! } - public var ChatListFolder_CategoryContacts: String { return self._s[3749]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3750]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3752]! } - public var ConversationMedia_Title: String { return self._s[3753]! } - public var EncryptionKey_Title: String { return self._s[3755]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3756]! } - public var Notification_Exceptions_AddException: String { return self._s[3757]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3758]! } - public var Profile_MessageLifetime1m: String { return self._s[3759]! } + public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3747]!, self._r[3747]!, [_0]) + } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3748]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3750]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3751]! } + public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3753]!, self._r[3753]!, [_0]) + } + public var Call_ConnectionErrorMessage: String { return self._s[3754]! } + public var VoiceOver_Chat_Music: String { return self._s[3755]! } + public var ChatListFolder_CategoryContacts: String { return self._s[3756]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3757]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3759]! } + public var ConversationMedia_Title: String { return self._s[3760]! } + public var EncryptionKey_Title: String { return self._s[3762]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3763]! } + public var Notification_Exceptions_AddException: String { return self._s[3764]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3765]! } + public var Profile_MessageLifetime1m: String { return self._s[3766]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3760]!, self._r[3760]!, [_1]) + return formatWithArgumentRanges(self._s[3767]!, self._r[3767]!, [_1]) } - public var Month_GenMay: String { return self._s[3761]! } + public var Month_GenMay: String { return self._s[3768]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3762]!, self._r[3762]!, [_0]) + return formatWithArgumentRanges(self._s[3769]!, self._r[3769]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3763]! } - public var Wallet_Send_AddressInfo: String { return self._s[3764]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3765]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3766]! } + public var PeopleNearby_Users: String { return self._s[3770]! } + public var Wallet_Send_AddressInfo: String { return self._s[3771]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3772]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3773]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3768]!, self._r[3768]!, [_0]) + return formatWithArgumentRanges(self._s[3775]!, self._r[3775]!, [_0]) } - public var Stats_LoadingTitle: String { return self._s[3769]! } - public var Conversation_EmptyPlaceholder: String { return self._s[3770]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3771]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3772]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3773]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3774]! } - public var Channel_JoinChannel: String { return self._s[3777]! } - public var Appearance_Animations: String { return self._s[3780]! } + public var Stats_LoadingTitle: String { return self._s[3776]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3777]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3778]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3779]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3780]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3781]! } + public var Channel_JoinChannel: String { return self._s[3784]! } + public var Appearance_Animations: String { return self._s[3787]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3781]!, self._r[3781]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3788]!, self._r[3788]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3783]! } - public var Appearance_ShareTheme: String { return self._s[3784]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3785]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3789]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3790]! } - public var Passport_Address_Street: String { return self._s[3791]! } - public var Conversation_AddContact: String { return self._s[3792]! } - public var Login_PhonePlaceholder: String { return self._s[3793]! } - public var Channel_Members_InviteLink: String { return self._s[3795]! } - public var Bot_Stop: String { return self._s[3796]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3798]! } - public var Notification_PassportValueAddress: String { return self._s[3799]! } - public var Month_ShortJuly: String { return self._s[3800]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3801]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3802]! } - public var Passport_Identity_ReverseSide: String { return self._s[3803]! } - public var Watch_Stickers_Recents: String { return self._s[3807]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3809]! } - public var Map_SendThisLocation: String { return self._s[3810]! } + public var Stickers_GroupStickers: String { return self._s[3790]! } + public var Appearance_ShareTheme: String { return self._s[3791]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3792]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3796]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3797]! } + public var Passport_Address_Street: String { return self._s[3798]! } + public var Conversation_AddContact: String { return self._s[3799]! } + public var Login_PhonePlaceholder: String { return self._s[3800]! } + public var Channel_Members_InviteLink: String { return self._s[3802]! } + public var Bot_Stop: String { return self._s[3803]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3805]! } + public var Notification_PassportValueAddress: String { return self._s[3806]! } + public var Month_ShortJuly: String { return self._s[3807]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3808]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3809]! } + public var Passport_Identity_ReverseSide: String { return self._s[3810]! } + public var Watch_Stickers_Recents: String { return self._s[3814]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3816]! } + public var Map_SendThisLocation: String { return self._s[3817]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3811]!, self._r[3811]!, [_0]) + return formatWithArgumentRanges(self._s[3818]!, self._r[3818]!, [_0]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3812]!, self._r[3812]!, [_0]) + return formatWithArgumentRanges(self._s[3819]!, self._r[3819]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3813]! } - public var Wallet_Intro_NotNow: String { return self._s[3814]! } - public var Stats_GroupMembers: String { return self._s[3815]! } + public var ConvertToSupergroup_Note: String { return self._s[3820]! } + public var Wallet_Intro_NotNow: String { return self._s[3821]! } + public var Stats_GroupMembers: String { return self._s[3822]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3816]!, self._r[3816]!, [_0]) + return formatWithArgumentRanges(self._s[3823]!, self._r[3823]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3817]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3824]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3818]!, self._r[3818]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3825]!, self._r[3825]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3820]! } - public var Wallpaper_SearchShort: String { return self._s[3821]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3823]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3824]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3825]! } + public var Login_CallRequestState3: String { return self._s[3827]! } + public var Wallpaper_SearchShort: String { return self._s[3828]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3830]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3831]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3832]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3826]!, self._r[3826]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3833]!, self._r[3833]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3827]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3829]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3832]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3834]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3836]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3839]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3833]!, self._r[3833]!, [_0]) + return formatWithArgumentRanges(self._s[3840]!, self._r[3840]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3834]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3835]! } + public var Passport_CorrectErrors: String { return self._s[3841]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3842]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3836]!, self._r[3836]!, [_0]) + return formatWithArgumentRanges(self._s[3843]!, self._r[3843]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3837]! } - public var Channel_DiscussionGroup: String { return self._s[3838]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3839]! } + public var Map_SendMyCurrentLocation: String { return self._s[3844]! } + public var Channel_DiscussionGroup: String { return self._s[3845]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3846]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3840]!, self._r[3840]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3847]!, self._r[3847]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3841]! } - public var Permissions_NotificationsText_v0: String { return self._s[3842]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3843]! } - public var Appearance_AppIcon: String { return self._s[3844]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3845]! } - public var LoginPassword_FloodError: String { return self._s[3846]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3848]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3849]! } + public var SharedMedia_SearchNoResults: String { return self._s[3848]! } + public var Permissions_NotificationsText_v0: String { return self._s[3849]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3850]! } + public var Appearance_AppIcon: String { return self._s[3851]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3852]! } + public var LoginPassword_FloodError: String { return self._s[3853]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3855]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3856]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3850]!, self._r[3850]!, [_0]) + return formatWithArgumentRanges(self._s[3857]!, self._r[3857]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3851]! } + public var Passport_Language_bn: String { return self._s[3858]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3852]!, self._r[3852]!, [_0]) + return formatWithArgumentRanges(self._s[3859]!, self._r[3859]!, [_0]) } - public var ChatList_Context_Pin: String { return self._s[3853]! } + public var ChatList_Context_Pin: String { return self._s[3860]! } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3854]!, self._r[3854]!, [_0]) + return formatWithArgumentRanges(self._s[3861]!, self._r[3861]!, [_0]) } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3855]!, self._r[3855]!, [_0]) + return formatWithArgumentRanges(self._s[3862]!, self._r[3862]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3856]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3860]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3862]! } - public var Wallet_Month_GenDecember: String { return self._s[3863]! } - public var Contacts_PermissionsAllow: String { return self._s[3864]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3865]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3866]! } - public var WallpaperPreview_Pattern: String { return self._s[3867]! } - public var Paint_Duplicate: String { return self._s[3868]! } - public var Passport_Address_Country: String { return self._s[3869]! } - public var Notification_RenamedChannel: String { return self._s[3871]! } - public var DialogList_UnknownPinLimitError: String { return self._s[3872]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3873]! } - public var ChatList_Context_Unmute: String { return self._s[3874]! } - public var KeyCommand_SearchInChat: String { return self._s[3875]! } - public var Group_MessagePhotoUpdated: String { return self._s[3876]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3877]! } - public var Conversation_ContextMenuBan: String { return self._s[3878]! } - public var TwoStepAuth_EmailSent: String { return self._s[3879]! } - public var MessagePoll_NoVotes: String { return self._s[3880]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3881]! } - public var Passport_Language_is: String { return self._s[3883]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3885]! } - public var Tour_Text5: String { return self._s[3886]! } + public var Wallet_Navigation_Close: String { return self._s[3863]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3867]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3869]! } + public var Wallet_Month_GenDecember: String { return self._s[3870]! } + public var Contacts_PermissionsAllow: String { return self._s[3871]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3872]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3873]! } + public var WallpaperPreview_Pattern: String { return self._s[3874]! } + public var Paint_Duplicate: String { return self._s[3875]! } + public var Passport_Address_Country: String { return self._s[3876]! } + public var Notification_RenamedChannel: String { return self._s[3878]! } + public var DialogList_UnknownPinLimitError: String { return self._s[3879]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3880]! } + public var ChatList_Context_Unmute: String { return self._s[3881]! } + public var KeyCommand_SearchInChat: String { return self._s[3882]! } + public var Group_MessagePhotoUpdated: String { return self._s[3883]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3884]! } + public var Conversation_ContextMenuBan: String { return self._s[3885]! } + public var TwoStepAuth_EmailSent: String { return self._s[3886]! } + public var MessagePoll_NoVotes: String { return self._s[3887]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3888]! } + public var Passport_Language_is: String { return self._s[3890]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3892]! } + public var Tour_Text5: String { return self._s[3893]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3889]!, self._r[3889]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3896]!, self._r[3896]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3890]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3891]! } + public var Undo_SecretChatDeleted: String { return self._s[3897]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3898]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3892]!, self._r[3892]!, [_0]) + return formatWithArgumentRanges(self._s[3899]!, self._r[3899]!, [_0]) } - public var Forward_ErrorDisabledForChat: String { return self._s[3893]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3895]! } - public var Paint_Edit: String { return self._s[3897]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3899]! } - public var Undo_DeletedGroup: String { return self._s[3901]! } - public var LoginPassword_ForgotPassword: String { return self._s[3902]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3903]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3904]! } + public var Forward_ErrorDisabledForChat: String { return self._s[3900]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3902]! } + public var Paint_Edit: String { return self._s[3904]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3906]! } + public var Undo_DeletedGroup: String { return self._s[3908]! } + public var LoginPassword_ForgotPassword: String { return self._s[3909]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3910]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3911]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3905]!, self._r[3905]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3912]!, self._r[3912]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3906]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3907]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3908]! } - public var Passport_Language_uz: String { return self._s[3909]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3910]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3911]! } - public var Map_StopLiveLocation: String { return self._s[3913]! } - public var VoiceOver_MessageContextSend: String { return self._s[3915]! } - public var PasscodeSettings_Help: String { return self._s[3916]! } - public var NotificationsSound_Input: String { return self._s[3917]! } - public var Share_Title: String { return self._s[3920]! } - public var LogoutOptions_Title: String { return self._s[3921]! } - public var Wallet_Send_AddressText: String { return self._s[3922]! } - public var Login_TermsOfServiceAgree: String { return self._s[3923]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3924]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3925]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3926]! } - public var EnterPasscode_EnterTitle: String { return self._s[3927]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3913]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3914]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3915]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3916]! } + public var Passport_Language_uz: String { return self._s[3917]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3918]! } + public var Map_StopLiveLocation: String { return self._s[3920]! } + public var VoiceOver_MessageContextSend: String { return self._s[3922]! } + public var PasscodeSettings_Help: String { return self._s[3923]! } + public var NotificationsSound_Input: String { return self._s[3924]! } + public var Share_Title: String { return self._s[3927]! } + public var LogoutOptions_Title: String { return self._s[3928]! } + public var Wallet_Send_AddressText: String { return self._s[3929]! } + public var Login_TermsOfServiceAgree: String { return self._s[3930]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3931]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3932]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3933]! } + public var EnterPasscode_EnterTitle: String { return self._s[3934]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3928]!, self._r[3928]!, [_0]) + return formatWithArgumentRanges(self._s[3935]!, self._r[3935]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3929]! } - public var Conversation_AddToContacts: String { return self._s[3930]! } + public var Settings_CopyPhoneNumber: String { return self._s[3936]! } + public var Conversation_AddToContacts: String { return self._s[3937]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3931]!, self._r[3931]!, [_0]) + return formatWithArgumentRanges(self._s[3938]!, self._r[3938]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3932]! } + public var NotificationsSound_Keys: String { return self._s[3939]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3933]!, self._r[3933]!, [_0]) + return formatWithArgumentRanges(self._s[3940]!, self._r[3940]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3934]! } - public var Message_Video: String { return self._s[3935]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3936]! } + public var Notification_MessageLifetime1w: String { return self._s[3941]! } + public var Message_Video: String { return self._s[3942]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3943]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3937]!, self._r[3937]!, [_1]) + return formatWithArgumentRanges(self._s[3944]!, self._r[3944]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3940]! } - public var Stats_Overview: String { return self._s[3941]! } + public var Wallet_Receive_AmountInfo: String { return self._s[3947]! } + public var Stats_Overview: String { return self._s[3948]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3942]!, self._r[3942]!, [_0]) + return formatWithArgumentRanges(self._s[3949]!, self._r[3949]!, [_0]) } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3943]!, self._r[3943]!, [_0]) + return formatWithArgumentRanges(self._s[3950]!, self._r[3950]!, [_0]) } - public var ChatListFolder_ExcludeChatsTitle: String { return self._s[3944]! } - public var Passport_Language_mk: String { return self._s[3945]! } - public var ChatListFolder_CategoryNonContacts: String { return self._s[3946]! } + public var ChatListFolder_ExcludeChatsTitle: String { return self._s[3951]! } + public var Passport_Language_mk: String { return self._s[3952]! } + public var ChatListFolder_CategoryNonContacts: String { return self._s[3953]! } public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3947]!, self._r[3947]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3954]!, self._r[3954]!, [_1, _2, _3]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3948]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3949]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3951]! } - public var PrivacyPolicy_Decline: String { return self._s[3952]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3953]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3954]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3955]! } - public var Permissions_SiriAllow_v0: String { return self._s[3957]! } - public var Wallet_Month_ShortAugust: String { return self._s[3958]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3959]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3955]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3956]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3958]! } + public var PrivacyPolicy_Decline: String { return self._s[3959]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3960]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3961]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3962]! } + public var Permissions_SiriAllow_v0: String { return self._s[3964]! } + public var Wallet_Month_ShortAugust: String { return self._s[3965]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3966]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3960]!, self._r[3960]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3967]!, self._r[3967]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3961]!, self._r[3961]!, [_0]) + return formatWithArgumentRanges(self._s[3968]!, self._r[3968]!, [_0]) } - public var Paint_Regular: String { return self._s[3962]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3963]! } - public var SocksProxySetup_ShareLink: String { return self._s[3964]! } - public var Wallet_Qr_Title: String { return self._s[3965]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3966]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3968]! } - public var Wallet_Settings_Configuration: String { return self._s[3969]! } - public var GroupInfo_InviteByLink: String { return self._s[3970]! } - public var MessageTimer_Custom: String { return self._s[3971]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3972]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[3973]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3975]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3976]! } - public var VoiceOver_Chat_Selected: String { return self._s[3977]! } - public var Paint_Pen: String { return self._s[3978]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3979]! } - public var Channel_Username_InvalidTaken: String { return self._s[3980]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3981]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3982]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3983]! } - public var Settings_ChatBackground: String { return self._s[3984]! } - public var Channel_Subscribers_Title: String { return self._s[3985]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3986]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3987]! } - public var Watch_ConnectionDescription: String { return self._s[3988]! } - public var OldChannels_NoticeText: String { return self._s[3991]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3992]! } - public var IntentsSettings_SuggestBy: String { return self._s[3994]! } - public var Theme_ThemeChangedText: String { return self._s[3995]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3996]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3997]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3998]! } - public var Conversation_SendDice: String { return self._s[3999]! } - public var EditProfile_Title: String { return self._s[4000]! } - public var NotificationsSound_Bamboo: String { return self._s[4002]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[4004]! } - public var Login_SmsRequestState2: String { return self._s[4005]! } - public var Passport_Language_ar: String { return self._s[4006]! } + public var Paint_Regular: String { return self._s[3969]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3970]! } + public var SocksProxySetup_ShareLink: String { return self._s[3971]! } + public var Wallet_Qr_Title: String { return self._s[3972]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3973]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3975]! } + public var Wallet_Settings_Configuration: String { return self._s[3976]! } + public var GroupInfo_InviteByLink: String { return self._s[3977]! } + public var MessageTimer_Custom: String { return self._s[3978]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3979]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[3980]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3982]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3983]! } + public var VoiceOver_Chat_Selected: String { return self._s[3984]! } + public var Paint_Pen: String { return self._s[3985]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3986]! } + public var Channel_Username_InvalidTaken: String { return self._s[3987]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3988]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3989]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3990]! } + public var Settings_ChatBackground: String { return self._s[3991]! } + public var Channel_Subscribers_Title: String { return self._s[3992]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3993]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3994]! } + public var Watch_ConnectionDescription: String { return self._s[3995]! } + public var OldChannels_NoticeText: String { return self._s[3998]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3999]! } + public var IntentsSettings_SuggestBy: String { return self._s[4001]! } + public var Theme_ThemeChangedText: String { return self._s[4002]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[4003]! } + public var Wallpaper_ResetWallpapers: String { return self._s[4004]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[4005]! } + public var Conversation_SendDice: String { return self._s[4006]! } + public var EditProfile_Title: String { return self._s[4007]! } + public var NotificationsSound_Bamboo: String { return self._s[4009]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[4011]! } + public var Login_SmsRequestState2: String { return self._s[4012]! } + public var Passport_Language_ar: String { return self._s[4013]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4007]!, self._r[4007]!, [_0]) + return formatWithArgumentRanges(self._s[4014]!, self._r[4014]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[4008]! } - public var Wallet_Created_Text: String { return self._s[4009]! } - public var Conversation_MessageDialogEdit: String { return self._s[4011]! } - public var Wallet_Created_Proceed: String { return self._s[4012]! } - public var Wallet_Words_Done: String { return self._s[4013]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[4014]! } - public var ChatListFolder_NameChannels: String { return self._s[4015]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[4015]! } + public var Wallet_Created_Text: String { return self._s[4016]! } + public var Conversation_MessageDialogEdit: String { return self._s[4018]! } + public var Wallet_Created_Proceed: String { return self._s[4019]! } + public var Wallet_Words_Done: String { return self._s[4020]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[4021]! } + public var ChatListFolder_NameChannels: String { return self._s[4022]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4016]!, self._r[4016]!, [_1]) + return formatWithArgumentRanges(self._s[4023]!, self._r[4023]!, [_1]) } - public var Common_Close: String { return self._s[4017]! } - public var GroupInfo_PublicLink: String { return self._s[4018]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[4019]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[4020]! } + public var Common_Close: String { return self._s[4024]! } + public var GroupInfo_PublicLink: String { return self._s[4025]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[4026]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[4027]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4024]!, self._r[4024]!, [_0]) + return formatWithArgumentRanges(self._s[4031]!, self._r[4031]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[4025]! } + public var UserInfo_About_Placeholder: String { return self._s[4032]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4026]!, self._r[4026]!, [_0]) + return formatWithArgumentRanges(self._s[4033]!, self._r[4033]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[4027]! } - public var Channel_Info_Banned: String { return self._s[4029]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[4034]! } + public var Channel_Info_Banned: String { return self._s[4036]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4030]!, self._r[4030]!, [_0]) + return formatWithArgumentRanges(self._s[4037]!, self._r[4037]!, [_0]) } - public var Appearance_Other: String { return self._s[4031]! } - public var Passport_Language_my: String { return self._s[4032]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[4033]! } - public var ProfilePhoto_SetMain: String { return self._s[4034]! } + public var Appearance_Other: String { return self._s[4038]! } + public var Passport_Language_my: String { return self._s[4039]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[4040]! } + public var ProfilePhoto_SetMain: String { return self._s[4041]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4035]!, self._r[4035]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4042]!, self._r[4042]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[4036]! } - public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[4037]! } - public var Preview_CopyAddress: String { return self._s[4038]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[4043]! } + public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[4044]! } + public var Preview_CopyAddress: String { return self._s[4045]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4039]!, self._r[4039]!, [_0]) + return formatWithArgumentRanges(self._s[4046]!, self._r[4046]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[4040]! } - public var UserInfo_BotSettings: String { return self._s[4041]! } - public var LiveLocation_MenuStopAll: String { return self._s[4043]! } - public var Passport_PasswordCreate: String { return self._s[4044]! } - public var StickerSettings_MaskContextInfo: String { return self._s[4045]! } - public var Message_PinnedLocationMessage: String { return self._s[4046]! } - public var Map_Satellite: String { return self._s[4047]! } - public var Watch_Message_Unsupported: String { return self._s[4048]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[4049]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[4050]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[4047]! } + public var UserInfo_BotSettings: String { return self._s[4048]! } + public var LiveLocation_MenuStopAll: String { return self._s[4050]! } + public var Passport_PasswordCreate: String { return self._s[4051]! } + public var StickerSettings_MaskContextInfo: String { return self._s[4052]! } + public var Message_PinnedLocationMessage: String { return self._s[4053]! } + public var Map_Satellite: String { return self._s[4054]! } + public var Watch_Message_Unsupported: String { return self._s[4055]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[4056]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[4057]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4058]!, self._r[4058]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4052]!, self._r[4052]!, [_0]) + return formatWithArgumentRanges(self._s[4059]!, self._r[4059]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[4053]! } + public var Wallet_WordImport_Continue: String { return self._s[4060]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4054]!, self._r[4054]!, [_0]) + return formatWithArgumentRanges(self._s[4061]!, self._r[4061]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[4055]! } - public var Privacy_Calls_P2PContacts: String { return self._s[4056]! } - public var NotificationsSound_None: String { return self._s[4057]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[4058]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[4060]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[4061]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[4062]! } + public var Privacy_Calls_P2PContacts: String { return self._s[4063]! } + public var NotificationsSound_None: String { return self._s[4064]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[4065]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[4067]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[4068]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4062]!, self._r[4062]!, [_1]) + return formatWithArgumentRanges(self._s[4069]!, self._r[4069]!, [_1]) } - public var Cache_Indexing: String { return self._s[4063]! } - public var DialogList_RecentTitlePeople: String { return self._s[4065]! } - public var DialogList_EncryptionRejected: String { return self._s[4066]! } - public var GroupInfo_Administrators: String { return self._s[4067]! } - public var Passport_ScanPassportHelp: String { return self._s[4068]! } - public var Application_Name: String { return self._s[4069]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[4070]! } - public var Conversation_Timer_Title: String { return self._s[4071]! } - public var ChatList_PeerTypeGroup: String { return self._s[4072]! } - public var PeopleNearby_MakeVisible: String { return self._s[4074]! } - public var Appearance_ThemeCarouselDay: String { return self._s[4075]! } - public var Stats_GrowthTitle: String { return self._s[4076]! } - public var Passport_Identity_TranslationHelp: String { return self._s[4077]! } + public var Cache_Indexing: String { return self._s[4070]! } + public var DialogList_RecentTitlePeople: String { return self._s[4072]! } + public var DialogList_EncryptionRejected: String { return self._s[4073]! } + public var GroupInfo_Administrators: String { return self._s[4074]! } + public var Passport_ScanPassportHelp: String { return self._s[4075]! } + public var Application_Name: String { return self._s[4076]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[4077]! } + public var Conversation_Timer_Title: String { return self._s[4078]! } + public var ChatList_PeerTypeGroup: String { return self._s[4079]! } + public var PeopleNearby_MakeVisible: String { return self._s[4081]! } + public var Appearance_ThemeCarouselDay: String { return self._s[4082]! } + public var Stats_GrowthTitle: String { return self._s[4083]! } + public var Passport_Identity_TranslationHelp: String { return self._s[4084]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4078]!, self._r[4078]!, [_0]) + return formatWithArgumentRanges(self._s[4085]!, self._r[4085]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_0]) + return formatWithArgumentRanges(self._s[4086]!, self._r[4086]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4080]!, self._r[4080]!, [_0]) + return formatWithArgumentRanges(self._s[4087]!, self._r[4087]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[4081]! } - public var Privacy_ChatsTitle: String { return self._s[4082]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[4083]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4084]! } - public var Watch_Suggestion_HoldOn: String { return self._s[4085]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[4086]! } - public var WebBrowser_Title: String { return self._s[4087]! } - public var Group_LinkedChannel: String { return self._s[4088]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4089]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[4090]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4091]! } - public var Appearance_TextSize_UseSystem: String { return self._s[4092]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[4093]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[4095]! } - public var Channel_Setup_TypePublic: String { return self._s[4097]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[4088]! } + public var Privacy_ChatsTitle: String { return self._s[4089]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[4090]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4091]! } + public var Watch_Suggestion_HoldOn: String { return self._s[4092]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[4093]! } + public var WebBrowser_Title: String { return self._s[4094]! } + public var Group_LinkedChannel: String { return self._s[4095]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4096]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[4097]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4098]! } + public var Appearance_TextSize_UseSystem: String { return self._s[4099]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[4100]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[4102]! } + public var Channel_Setup_TypePublic: String { return self._s[4104]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4098]!, self._r[4098]!, [_0]) + return formatWithArgumentRanges(self._s[4105]!, self._r[4105]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[4100]! } - public var MessagePoll_ViewResults: String { return self._s[4101]! } - public var Map_OpenInMaps: String { return self._s[4103]! } + public var Channel_TypeSetup_Title: String { return self._s[4107]! } + public var MessagePoll_ViewResults: String { return self._s[4108]! } + public var Map_OpenInMaps: String { return self._s[4110]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4104]!, self._r[4104]!, [_1]) + return formatWithArgumentRanges(self._s[4111]!, self._r[4111]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[4106]! } + public var NotificationsSound_Tremolo: String { return self._s[4113]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4107]!, self._r[4107]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4114]!, self._r[4114]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[4108]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4109]! } - public var Passport_PasswordHelp: String { return self._s[4111]! } - public var Login_CodeExpiredError: String { return self._s[4112]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4113]! } - public var Conversation_TitleUnmute: String { return self._s[4114]! } - public var Passport_Identity_ScansHelp: String { return self._s[4115]! } - public var Passport_Language_lo: String { return self._s[4116]! } - public var Camera_FlashAuto: String { return self._s[4117]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[4118]! } - public var Common_Cancel: String { return self._s[4119]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[4120]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4121]! } - public var Appearance_TintAllColors: String { return self._s[4122]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[4115]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4116]! } + public var Passport_PasswordHelp: String { return self._s[4118]! } + public var Login_CodeExpiredError: String { return self._s[4119]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4120]! } + public var Conversation_TitleUnmute: String { return self._s[4121]! } + public var Passport_Identity_ScansHelp: String { return self._s[4122]! } + public var Passport_Language_lo: String { return self._s[4123]! } + public var Camera_FlashAuto: String { return self._s[4124]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[4125]! } + public var Common_Cancel: String { return self._s[4126]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[4127]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4128]! } + public var Appearance_TintAllColors: String { return self._s[4129]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4123]!, self._r[4123]!, [_1]) + return formatWithArgumentRanges(self._s[4130]!, self._r[4130]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[4124]! } - public var ChatSettings_Title: String { return self._s[4126]! } - public var Passport_PasswordReset: String { return self._s[4127]! } - public var SocksProxySetup_TypeNone: String { return self._s[4128]! } - public var EditTheme_Title: String { return self._s[4131]! } - public var PhoneNumberHelp_Help: String { return self._s[4132]! } - public var Checkout_EnterPassword: String { return self._s[4133]! } - public var Activity_UploadingDocument: String { return self._s[4135]! } - public var Share_AuthTitle: String { return self._s[4136]! } - public var State_Connecting: String { return self._s[4137]! } - public var Profile_MessageLifetime1w: String { return self._s[4138]! } - public var Conversation_ContextMenuReport: String { return self._s[4139]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4140]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[4141]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[4131]! } + public var ChatSettings_Title: String { return self._s[4133]! } + public var Passport_PasswordReset: String { return self._s[4134]! } + public var SocksProxySetup_TypeNone: String { return self._s[4135]! } + public var EditTheme_Title: String { return self._s[4138]! } + public var PhoneNumberHelp_Help: String { return self._s[4139]! } + public var Checkout_EnterPassword: String { return self._s[4140]! } + public var Activity_UploadingDocument: String { return self._s[4142]! } + public var Share_AuthTitle: String { return self._s[4143]! } + public var State_Connecting: String { return self._s[4144]! } + public var Profile_MessageLifetime1w: String { return self._s[4145]! } + public var Conversation_ContextMenuReport: String { return self._s[4146]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4147]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[4148]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4142]!, self._r[4142]!, [_0]) + return formatWithArgumentRanges(self._s[4149]!, self._r[4149]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[4143]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[4144]! } - public var PeerInfo_PaneAudio: String { return self._s[4145]! } + public var AuthSessions_Terminate: String { return self._s[4150]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[4151]! } + public var PeerInfo_PaneAudio: String { return self._s[4152]! } public func Message_ForwardedPsa_covid(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4146]!, self._r[4146]!, [_0]) + return formatWithArgumentRanges(self._s[4153]!, self._r[4153]!, [_0]) } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[4148]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4149]! } - public var PhotoEditor_Set: String { return self._s[4150]! } - public var EmptyGroupInfo_Title: String { return self._s[4151]! } - public var Login_PadPhoneHelp: String { return self._s[4153]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4155]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4157]! } - public var NotificationsSound_Complete: String { return self._s[4158]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4159]! } - public var Group_Info_AdminLog: String { return self._s[4160]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4161]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[4155]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4156]! } + public var PhotoEditor_Set: String { return self._s[4157]! } + public var EmptyGroupInfo_Title: String { return self._s[4158]! } + public var Login_PadPhoneHelp: String { return self._s[4160]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4162]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4164]! } + public var NotificationsSound_Complete: String { return self._s[4165]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4166]! } + public var Group_Info_AdminLog: String { return self._s[4167]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4168]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4162]!, self._r[4162]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4169]!, self._r[4169]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[4163]! } - public var Group_Location_CreateInThisPlace: String { return self._s[4165]! } - public var Conversation_Admin: String { return self._s[4166]! } - public var Conversation_GifTooltip: String { return self._s[4167]! } - public var Passport_NotLoggedInMessage: String { return self._s[4168]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[4170]! } + public var Group_Location_CreateInThisPlace: String { return self._s[4172]! } + public var Conversation_Admin: String { return self._s[4173]! } + public var Conversation_GifTooltip: String { return self._s[4174]! } + public var Passport_NotLoggedInMessage: String { return self._s[4175]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4170]!, self._r[4170]!, [_0]) + return formatWithArgumentRanges(self._s[4177]!, self._r[4177]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[4171]! } - public var SharedMedia_EmptyTitle: String { return self._s[4173]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4175]! } - public var Username_Help: String { return self._s[4176]! } - public var DialogList_LanguageTooltip: String { return self._s[4178]! } - public var Map_LoadError: String { return self._s[4179]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4180]! } - public var Channel_AdminLog_AddMembers: String { return self._s[4181]! } - public var ArchivedChats_IntroTitle2: String { return self._s[4182]! } - public var Notification_Exceptions_NewException: String { return self._s[4183]! } - public var TwoStepAuth_EmailTitle: String { return self._s[4184]! } - public var WatchRemote_AlertText: String { return self._s[4185]! } + public var Profile_MessageLifetimeForever: String { return self._s[4178]! } + public var SharedMedia_EmptyTitle: String { return self._s[4180]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4182]! } + public var Username_Help: String { return self._s[4183]! } + public var DialogList_LanguageTooltip: String { return self._s[4185]! } + public var Map_LoadError: String { return self._s[4186]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4187]! } + public var Channel_AdminLog_AddMembers: String { return self._s[4188]! } + public var ArchivedChats_IntroTitle2: String { return self._s[4189]! } + public var Notification_Exceptions_NewException: String { return self._s[4190]! } + public var TwoStepAuth_EmailTitle: String { return self._s[4191]! } + public var WatchRemote_AlertText: String { return self._s[4192]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4186]!, self._r[4186]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4193]!, self._r[4193]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[4190]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[4197]! } public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4191]!, self._r[4191]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4198]!, self._r[4198]!, [_1, _2]) } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4192]!, self._r[4192]!, [_0]) + return formatWithArgumentRanges(self._s[4199]!, self._r[4199]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[4193]! } - public var WebBrowser_DefaultBrowser: String { return self._s[4194]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[4195]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[4200]! } + public var WebBrowser_DefaultBrowser: String { return self._s[4201]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[4202]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4196]!, self._r[4196]!, [_0]) + return formatWithArgumentRanges(self._s[4203]!, self._r[4203]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4197]!, self._r[4197]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4204]!, self._r[4204]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[4198]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4199]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[4201]! } - public var Wallet_Created_ExportErrorText: String { return self._s[4202]! } - public var ChatList_UndoArchiveText1: String { return self._s[4203]! } - public var ChatListFolder_IncludedSectionHeader: String { return self._s[4204]! } - public var AccessDenied_VideoMicrophone: String { return self._s[4205]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4206]! } - public var Stats_GroupTopInviter_History: String { return self._s[4207]! } - public var Cache_ClearNone: String { return self._s[4208]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[4209]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[4210]! } + public var Group_AdminLog_EmptyText: String { return self._s[4205]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4206]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[4208]! } + public var Wallet_Created_ExportErrorText: String { return self._s[4209]! } + public var ChatList_UndoArchiveText1: String { return self._s[4210]! } + public var ChatListFolder_IncludedSectionHeader: String { return self._s[4211]! } + public var AccessDenied_VideoMicrophone: String { return self._s[4212]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4213]! } + public var Stats_GroupTopInviter_History: String { return self._s[4214]! } + public var Cache_ClearNone: String { return self._s[4215]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[4216]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[4217]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4211]!, self._r[4211]!, [_0]) + return formatWithArgumentRanges(self._s[4218]!, self._r[4218]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[4212]! } + public var Passport_Identity_Country: String { return self._s[4219]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4213]!, self._r[4213]!, [_0]) + return formatWithArgumentRanges(self._s[4220]!, self._r[4220]!, [_0]) } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4214]!, self._r[4214]!, [_0]) + return formatWithArgumentRanges(self._s[4221]!, self._r[4221]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[4215]! } - public var AccessDenied_Settings: String { return self._s[4216]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4217]! } - public var Month_ShortMay: String { return self._s[4219]! } - public var Compose_NewGroup: String { return self._s[4221]! } - public var Group_Setup_TypePrivate: String { return self._s[4223]! } - public var Login_PadPhoneHelpTitle: String { return self._s[4225]! } - public var Appearance_ThemeDayClassic: String { return self._s[4226]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4227]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[4228]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4229]! } - public var Conversation_typing: String { return self._s[4231]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[4232]! } - public var Paint_Masks: String { return self._s[4233]! } - public var Contacts_DeselectAll: String { return self._s[4234]! } + public var Exceptions_AddToExceptions: String { return self._s[4222]! } + public var AccessDenied_Settings: String { return self._s[4223]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4224]! } + public var Month_ShortMay: String { return self._s[4226]! } + public var Compose_NewGroup: String { return self._s[4228]! } + public var Group_Setup_TypePrivate: String { return self._s[4230]! } + public var Login_PadPhoneHelpTitle: String { return self._s[4232]! } + public var Appearance_ThemeDayClassic: String { return self._s[4233]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4234]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[4235]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4236]! } + public var Conversation_typing: String { return self._s[4238]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[4239]! } + public var Paint_Masks: String { return self._s[4240]! } + public var Contacts_DeselectAll: String { return self._s[4241]! } public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4235]!, self._r[4235]!, [_0]) + return formatWithArgumentRanges(self._s[4242]!, self._r[4242]!, [_0]) } - public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4236]! } - public var Stats_GroupMembersTitle: String { return self._s[4237]! } - public var Username_InvalidTaken: String { return self._s[4238]! } - public var Call_StatusNoAnswer: String { return self._s[4239]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[4240]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4241]! } - public var Passport_Identity_Selfie: String { return self._s[4242]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4243]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4244]! } - public var Conversation_ClearSecretHistory: String { return self._s[4245]! } - public var PeopleNearby_Description: String { return self._s[4247]! } - public var NetworkUsageSettings_Title: String { return self._s[4248]! } - public var Your_cards_security_code_is_invalid: String { return self._s[4250]! } - public var Stats_EnabledNotifications: String { return self._s[4251]! } + public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4243]! } + public var Stats_GroupMembersTitle: String { return self._s[4244]! } + public var Username_InvalidTaken: String { return self._s[4245]! } + public var Call_StatusNoAnswer: String { return self._s[4246]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[4247]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4248]! } + public var Passport_Identity_Selfie: String { return self._s[4249]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4250]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4251]! } + public var Conversation_ClearSecretHistory: String { return self._s[4252]! } + public var PeopleNearby_Description: String { return self._s[4254]! } + public var NetworkUsageSettings_Title: String { return self._s[4255]! } + public var Your_cards_security_code_is_invalid: String { return self._s[4257]! } + public var Stats_EnabledNotifications: String { return self._s[4258]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4254]!, self._r[4254]!, [_0]) + return formatWithArgumentRanges(self._s[4261]!, self._r[4261]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4255]!, self._r[4255]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4262]!, self._r[4262]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[4257]! } - public var VoiceOver_Navigation_Search: String { return self._s[4258]! } - public var Map_LiveLocationTitle: String { return self._s[4259]! } - public var Login_InfoAvatarAdd: String { return self._s[4260]! } - public var Passport_Identity_FilesView: String { return self._s[4261]! } - public var ChatListFolderSettings_Title: String { return self._s[4262]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[4263]! } - public var Privacy_Calls_NeverAllow: String { return self._s[4264]! } - public var VoiceOver_Chat_File: String { return self._s[4265]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4266]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[4264]! } + public var VoiceOver_Navigation_Search: String { return self._s[4265]! } + public var Map_LiveLocationTitle: String { return self._s[4266]! } + public var Login_InfoAvatarAdd: String { return self._s[4267]! } + public var Passport_Identity_FilesView: String { return self._s[4268]! } + public var ChatListFolderSettings_Title: String { return self._s[4269]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[4270]! } + public var Privacy_Calls_NeverAllow: String { return self._s[4271]! } + public var VoiceOver_Chat_File: String { return self._s[4272]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4273]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4267]!, self._r[4267]!, [_0]) + return formatWithArgumentRanges(self._s[4274]!, self._r[4274]!, [_0]) } - public var ChatList_EmptyChatList: String { return self._s[4269]! } - public var ContactInfo_PhoneNumberHidden: String { return self._s[4270]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[4271]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4272]! } + public var ChatList_EmptyChatList: String { return self._s[4276]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[4277]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[4278]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4279]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4273]!, self._r[4273]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4280]!, self._r[4280]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4274]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[4275]! } - public var Tour_Title2: String { return self._s[4276]! } - public var Wallet_Sent_ViewWallet: String { return self._s[4277]! } - public var Stats_GroupMessagesTitle: String { return self._s[4278]! } - public var Conversation_FileOpenIn: String { return self._s[4279]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4280]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4281]! } - public var Wallpaper_Set: String { return self._s[4282]! } - public var Passport_Identity_Translations: String { return self._s[4284]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4281]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[4282]! } + public var Tour_Title2: String { return self._s[4283]! } + public var Wallet_Sent_ViewWallet: String { return self._s[4284]! } + public var Stats_GroupMessagesTitle: String { return self._s[4285]! } + public var Conversation_FileOpenIn: String { return self._s[4286]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4287]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4288]! } + public var Wallpaper_Set: String { return self._s[4289]! } + public var Passport_Identity_Translations: String { return self._s[4291]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4285]!, self._r[4285]!, [_0]) + return formatWithArgumentRanges(self._s[4292]!, self._r[4292]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4286]! } + public var Channel_LeaveChannel: String { return self._s[4293]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4287]!, self._r[4287]!, [_1]) + return formatWithArgumentRanges(self._s[4294]!, self._r[4294]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4289]! } - public var PhotoEditor_HighlightsTint: String { return self._s[4290]! } - public var MessagePoll_LabelPoll: String { return self._s[4291]! } - public var Passport_Email_Delete: String { return self._s[4292]! } - public var Conversation_Mute: String { return self._s[4294]! } - public var Channel_AddBotAsAdmin: String { return self._s[4295]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[4297]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4298]! } - public var ChatSettings_IntentsSettings: String { return self._s[4300]! } - public var Channel_Management_LabelOwner: String { return self._s[4301]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4296]! } + public var PhotoEditor_HighlightsTint: String { return self._s[4297]! } + public var MessagePoll_LabelPoll: String { return self._s[4298]! } + public var Passport_Email_Delete: String { return self._s[4299]! } + public var Conversation_Mute: String { return self._s[4301]! } + public var Channel_AddBotAsAdmin: String { return self._s[4302]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[4304]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4305]! } + public var ChatSettings_IntentsSettings: String { return self._s[4307]! } + public var Channel_Management_LabelOwner: String { return self._s[4308]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4302]!, self._r[4302]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4309]!, self._r[4309]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[4303]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[4304]! } - public var Common_No: String { return self._s[4305]! } - public var Weekday_Sunday: String { return self._s[4306]! } - public var Notification_Reply: String { return self._s[4307]! } - public var Conversation_ViewMessage: String { return self._s[4308]! } + public var Calls_CallTabDescription: String { return self._s[4310]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[4311]! } + public var Common_No: String { return self._s[4312]! } + public var Weekday_Sunday: String { return self._s[4313]! } + public var Notification_Reply: String { return self._s[4314]! } + public var Conversation_ViewMessage: String { return self._s[4315]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4309]!, self._r[4309]!, [_0]) + return formatWithArgumentRanges(self._s[4316]!, self._r[4316]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4310]!, self._r[4310]!, [_0]) + return formatWithArgumentRanges(self._s[4317]!, self._r[4317]!, [_0]) } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4311]!, self._r[4311]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4318]!, self._r[4318]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4312]! } - public var Wallet_Send_Title: String { return self._s[4313]! } - public var Message_PinnedDocumentMessage: String { return self._s[4314]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[4315]! } - public var DialogList_TabTitle: String { return self._s[4317]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4318]! } - public var Passport_FieldEmail: String { return self._s[4319]! } - public var Conversation_UnpinMessageAlert: String { return self._s[4320]! } - public var Passport_Address_TypeBankStatement: String { return self._s[4321]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[4322]! } - public var Passport_Identity_ExpiryDate: String { return self._s[4323]! } - public var Privacy_Calls_P2P: String { return self._s[4324]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4319]! } + public var Wallet_Send_Title: String { return self._s[4320]! } + public var Message_PinnedDocumentMessage: String { return self._s[4321]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[4322]! } + public var DialogList_TabTitle: String { return self._s[4324]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4325]! } + public var Passport_FieldEmail: String { return self._s[4326]! } + public var Conversation_UnpinMessageAlert: String { return self._s[4327]! } + public var Passport_Address_TypeBankStatement: String { return self._s[4328]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[4329]! } + public var Passport_Identity_ExpiryDate: String { return self._s[4330]! } + public var Privacy_Calls_P2P: String { return self._s[4331]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4326]!, self._r[4326]!, [_0]) + return formatWithArgumentRanges(self._s[4333]!, self._r[4333]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4327]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[4334]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4328]!, self._r[4328]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4335]!, self._r[4335]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[4329]! } - public var EnterPasscode_ChangeTitle: String { return self._s[4330]! } - public var TwoFactorSetup_Email_Title: String { return self._s[4331]! } - public var Passport_InfoText: String { return self._s[4332]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4333]! } + public var Stickers_ClearRecent: String { return self._s[4336]! } + public var EnterPasscode_ChangeTitle: String { return self._s[4337]! } + public var TwoFactorSetup_Email_Title: String { return self._s[4338]! } + public var Passport_InfoText: String { return self._s[4339]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4340]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4334]!, self._r[4334]!, [_0]) + return formatWithArgumentRanges(self._s[4341]!, self._r[4341]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4335]!, self._r[4335]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4342]!, self._r[4342]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4336]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[4337]! } - public var VoiceOver_Navigation_Compose: String { return self._s[4338]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[4339]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4341]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4342]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4343]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4344]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4345]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4346]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4348]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4349]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4343]!, self._r[4343]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4350]!, self._r[4350]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4346]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4347]! } - public var Map_HomeAndWorkTitle: String { return self._s[4348]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4353]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4354]! } + public var Map_HomeAndWorkTitle: String { return self._s[4355]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4350]!, self._r[4350]!, [_0]) + return formatWithArgumentRanges(self._s[4357]!, self._r[4357]!, [_0]) } - public var DialogList_Unread: String { return self._s[4351]! } + public var DialogList_Unread: String { return self._s[4358]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4352]!, self._r[4352]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4359]!, self._r[4359]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4353]! } - public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4354]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4355]! } + public var User_DeletedAccount: String { return self._s[4360]! } + public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4361]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4362]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4356]!, self._r[4356]!, [_0]) + return formatWithArgumentRanges(self._s[4363]!, self._r[4363]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4357]! } - public var SharedMedia_CategoryMedia: String { return self._s[4358]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4359]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4360]! } - public var Watch_ChatList_Compose: String { return self._s[4361]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4362]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4363]! } - public var Watch_Microphone_Access: String { return self._s[4364]! } - public var Group_Setup_HistoryHeader: String { return self._s[4365]! } - public var Map_SetThisLocation: String { return self._s[4366]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4367]! } - public var Activity_UploadingPhoto: String { return self._s[4368]! } - public var Conversation_Edit: String { return self._s[4370]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4371]! } - public var Login_TermsOfServiceDecline: String { return self._s[4372]! } - public var Message_PinnedContactMessage: String { return self._s[4373]! } + public var UserInfo_NotificationsDefault: String { return self._s[4364]! } + public var SharedMedia_CategoryMedia: String { return self._s[4365]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4366]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4367]! } + public var Watch_ChatList_Compose: String { return self._s[4368]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4369]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4370]! } + public var Watch_Microphone_Access: String { return self._s[4371]! } + public var Group_Setup_HistoryHeader: String { return self._s[4372]! } + public var Map_SetThisLocation: String { return self._s[4373]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4374]! } + public var Activity_UploadingPhoto: String { return self._s[4375]! } + public var Conversation_Edit: String { return self._s[4377]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4378]! } + public var Login_TermsOfServiceDecline: String { return self._s[4379]! } + public var Message_PinnedContactMessage: String { return self._s[4380]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4374]!, self._r[4374]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4381]!, self._r[4381]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4375]!, self._r[4375]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4382]!, self._r[4382]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4376]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4378]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4379]! } + public var Appearance_LargeEmoji: String { return self._s[4383]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4385]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4386]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4380]!, self._r[4380]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4387]!, self._r[4387]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4381]! } - public var Message_PinnedPhotoMessage: String { return self._s[4382]! } - public var Passport_FieldPhone: String { return self._s[4383]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4384]! } - public var Stats_NotificationsTitle: String { return self._s[4385]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4386]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4388]! } - public var Conversation_Call: String { return self._s[4389]! } - public var Common_TakePhoto: String { return self._s[4391]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4392]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4393]! } - public var Channel_NotificationLoading: String { return self._s[4394]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4388]! } + public var Message_PinnedPhotoMessage: String { return self._s[4389]! } + public var Passport_FieldPhone: String { return self._s[4390]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4391]! } + public var Stats_NotificationsTitle: String { return self._s[4392]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4393]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4395]! } + public var Conversation_Call: String { return self._s[4396]! } + public var Common_TakePhoto: String { return self._s[4398]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4399]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4400]! } + public var Channel_NotificationLoading: String { return self._s[4401]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4395]!, self._r[4395]!, [_0]) + return formatWithArgumentRanges(self._s[4402]!, self._r[4402]!, [_0]) } public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4396]!, self._r[4396]!, [_0]) + return formatWithArgumentRanges(self._s[4403]!, self._r[4403]!, [_0]) } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4397]!, self._r[4397]!, [_1]) + return formatWithArgumentRanges(self._s[4404]!, self._r[4404]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[4398]! } + public var Permissions_SiriTitle_v0: String { return self._s[4405]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4399]!, self._r[4399]!, [_0]) + return formatWithArgumentRanges(self._s[4406]!, self._r[4406]!, [_0]) } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4400]!, self._r[4400]!, [_0]) + return formatWithArgumentRanges(self._s[4407]!, self._r[4407]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4401]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4402]! } - public var ClearCache_FreeSpace: String { return self._s[4403]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[4404]! } - public var Common_edit: String { return self._s[4405]! } - public var PrivacySettings_AuthSessions: String { return self._s[4406]! } - public var Month_ShortJune: String { return self._s[4407]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4408]! } - public var Call_ReportSend: String { return self._s[4409]! } - public var Watch_LastSeen_JustNow: String { return self._s[4410]! } - public var Notifications_MessageNotifications: String { return self._s[4411]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4412]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4414]! } - public var Group_Status: String { return self._s[4415]! } + public var Channel_MessagePhotoRemoved: String { return self._s[4408]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4409]! } + public var ClearCache_FreeSpace: String { return self._s[4410]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[4411]! } + public var Common_edit: String { return self._s[4412]! } + public var PrivacySettings_AuthSessions: String { return self._s[4413]! } + public var Month_ShortJune: String { return self._s[4414]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4415]! } + public var Call_ReportSend: String { return self._s[4416]! } + public var Watch_LastSeen_JustNow: String { return self._s[4417]! } + public var Notifications_MessageNotifications: String { return self._s[4418]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4419]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4421]! } + public var Group_Status: String { return self._s[4422]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4416]!, self._r[4416]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4423]!, self._r[4423]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4417]! } - public var ShareMenu_ShareTo: String { return self._s[4418]! } - public var Conversation_Moderate_Ban: String { return self._s[4419]! } + public var TextFormat_AddLinkTitle: String { return self._s[4424]! } + public var ShareMenu_ShareTo: String { return self._s[4425]! } + public var Conversation_Moderate_Ban: String { return self._s[4426]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4420]!, self._r[4420]!, [_0]) + return formatWithArgumentRanges(self._s[4427]!, self._r[4427]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4421]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4422]! } + public var SharedMedia_ViewInChat: String { return self._s[4428]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4429]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4423]!, self._r[4423]!, [_1]) + return formatWithArgumentRanges(self._s[4430]!, self._r[4430]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4424]!, self._r[4424]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4431]!, self._r[4431]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4426]!, self._r[4426]!, [_0]) + return formatWithArgumentRanges(self._s[4433]!, self._r[4433]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4427]! } - public var Appearance_ReduceMotion: String { return self._s[4428]! } + public var Map_OpenInHereMaps: String { return self._s[4434]! } + public var Appearance_ReduceMotion: String { return self._s[4435]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4429]!, self._r[4429]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4436]!, self._r[4436]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4430]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4431]! } - public var PhotoEditor_Skip: String { return self._s[4432]! } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4437]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4438]! } + public var PhotoEditor_Skip: String { return self._s[4439]! } + public func Map_ETAMinutes(_ 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 SharedMedia_File(_ 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[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareVideo(_ value: Int32) -> String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + public func InviteText_ContactsCountText(_ 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 MessageTimer_Years(_ 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[4 * 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[5 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessageTimer_ShortWeeks(_ 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_Minutes(_ 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 Passport_Scans(_ 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 MuteFor_Days(_ 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 MessageTimer_Seconds(_ 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 Stats_GroupTopAdminBans(_ 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 Notification_GameScoreSelfSimple(_ 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 Map_ETAHours(_ 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 PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Contacts_ImportersCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[16 * 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[17 * 6 + Int(form.rawValue)]!, stringValue) - } - 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 Stats_GroupTopAdminKicks(_ 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 Notifications_Exceptions(_ 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 { - 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 MessagePoll_QuizCount(_ 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 Watch_UserInfo_Mute(_ 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 AttachmentMenu_SendVideo(_ 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) + return String(format: self._ps[5 * 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[25 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Months(_ value: Int32) -> String { + public func MuteFor_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 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[27 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Hours(_ 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 PeopleNearby_ShowMorePeople(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_MessagePhotos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func OldChannels_GroupFormat(_ 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_MessageVideos(_ 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 Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveStickerCount(_ 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 Stats_GroupTopAdminDeletions(_ 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 InviteText_ContactsCountText(_ 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 PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - 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[39 * 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[40 * 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[41 * 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[42 * 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[43 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) } public func ForwardedVideoMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareItem(_ 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[45 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Generic(_ 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[46 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[10 * 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[11 * 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[47 * 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[48 * 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[49 * 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[50 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[51 * 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[52 * 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[53 * 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[54 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 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[56 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedContacts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[57 * 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[58 * 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[59 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 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[61 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 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[63 * 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[64 * 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[65 * 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[66 * 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[67 * 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[68 * 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[69 * 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[70 * 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[71 * 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[72 * 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[73 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_GroupTopPosterChars(_ 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 StickerPack_AddStickerCount(_ 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 LastSeen_HoursAgo(_ 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 ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MuteExpires_Days(_ 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 ChatList_DeleteConfirmation(_ 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 Stats_MessageViews(_ 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 ServiceMessage_GameScoreSelfExtended(_ 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 Conversation_StatusSubscribers(_ 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 Theme_UsersCount(_ 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 Conversation_StatusOnline(_ 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 ForwardedFiles(_ 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 Media_SharePhoto(_ 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 ForwardedGifs(_ 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 Watch_LastSeen_MinutesAgo(_ 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 VoiceOver_Chat_ContactEmailCount(_ 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 Notification_GameScoreSimple(_ 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 MessageTimer_ShortDays(_ 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 Chat_DeleteMessagesConfirmation(_ 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 AttachmentMenu_SendGif(_ 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 GroupInfo_ParticipantCount(_ 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_GroupTopPosterMessages(_ 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 PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func LastSeen_MinutesAgo(_ 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 Stats_GroupTopInviterInvites(_ 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_FWDS(_ 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 Watch_LastSeen_HoursAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusMembers(_ 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[105 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Days(_ value: Int32) -> String { + public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, _0, _1) + return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, _1, _2) } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { + public func Media_ShareVideo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, _1, _2) } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + public func Stats_GroupTopPosterMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ 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[112 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[22 * 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[113 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Wallet_Updated_HoursAgo(_ 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[114 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_StickerCount(_ 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[115 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[25 * 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[26 * 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[117 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[27 * 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[28 * 6 + Int(form.rawValue)]!, _1, _2) } public func PollResults_ShowMore(_ 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) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideos(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ 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) + return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallpaper_DeleteConfirmation(_ 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[120 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MessageTimer_Years(_ 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) + return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_Seconds(_ value: Int32) -> String { + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Conversation_StatusMembers(_ 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) + return String(format: self._ps[35 * 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[36 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func Media_SharePhoto(_ 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 DialogList_LiveLocationChatsCount(_ 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 OldChannels_Leave(_ 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 ChatListFilter_ShowMoreChats(_ 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) + return String(format: self._ps[40 * 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[124 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Wallet_Updated_MinutesAgo(_ 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[125 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + public func Map_ETAHours(_ 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) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSelfExtended(_ 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[127 * 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[128 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[43 * 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[130 * 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[131 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Contacts_InviteContacts(_ 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 Stats_MessageForwards(_ 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 PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[134 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[135 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) } public func SharedMedia_Photo(_ 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[45 * 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[46 * 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[47 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedContacts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[48 * 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[49 * 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[50 * 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[51 * 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[52 * 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[53 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessagePoll_QuizCount(_ 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 Conversation_SelectedMessages(_ 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 Watch_LastSeen_MinutesAgo(_ 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 GroupInfo_ParticipantCount(_ 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 ChatList_DeleteConfirmation(_ 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 PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[59 * 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[60 * 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[61 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func AttachmentMenu_SendGif(_ 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 Call_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ 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 AttachmentMenu_SendPhoto(_ 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 Call_ShortSeconds(_ 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 ForwardedFiles(_ 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 Passport_Scans(_ 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 AttachmentMenu_SendItem(_ 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 Call_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 SharedMedia_Video(_ 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 Stats_GroupTopInviterInvites(_ 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 Contacts_InviteContacts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreExtended(_ 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 CreatePoll_AddMoreOptions(_ 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 LiveLocation_MenuChatsCount(_ 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 PrivacyLastSeenSettings_AddUsers(_ 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 ForwardedLocations(_ 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 MuteExpires_Days(_ 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 GroupInfo_ShowMoreMembers(_ 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 MessageTimer_Months(_ 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 PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ForwardedAudios(_ 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 LastSeen_MinutesAgo(_ 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 StickerPack_StickerCount(_ 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 Watch_UserInfo_Mute(_ 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 Forward_ConfirmMultipleFiles(_ 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 Notification_GameScoreSelfSimple(_ 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 ForwardedPolls(_ 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 OldChannels_InactiveWeek(_ 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 MuteExpires_Minutes(_ 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 UserCount(_ 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 Notifications_ExceptionMuteExpires_Hours(_ 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 ForwardedMessages(_ 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 MessageTimer_Seconds(_ 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 Stats_GroupTopAdminKicks(_ 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 ServiceMessage_GameScoreSelfExtended(_ 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_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_ShortDays(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Link(_ 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 Stats_MessageForwards(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Stats_GroupTopAdminBans(_ 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 SharedMedia_DeleteItemsConfirmation(_ 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_CHANNEL_MESSAGES(_ 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 Wallet_Updated_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPhotos(_ 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 Invitation_Members(_ 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 Media_ShareItem(_ 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 Call_ShortMinutes(_ 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 PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[114 * 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[115 * 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[116 * 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[117 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[118 * 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[119 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[120 * 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[121 * 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[122 * 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[123 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Contacts_ImportersCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[124 * 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[125 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupTopPosterChars(_ 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 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 Watch_LastSeen_HoursAgo(_ 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 Notification_GameScoreExtended(_ 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 MessageTimer_Days(_ 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 VoiceOver_Chat_ContactPhoneNumberCount(_ 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 OldChannels_InactiveMonth(_ 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 Conversation_StatusSubscribers(_ 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 LastSeen_HoursAgo(_ 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 LiveLocationUpdated_MinutesAgo(_ 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 ForwardedGifs(_ 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 MessageTimer_ShortHours(_ 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 OldChannels_InactiveYear(_ 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[138 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramStringFormatting/Sources/ServiceMessageStrings.swift b/submodules/TelegramStringFormatting/Sources/ServiceMessageStrings.swift index a431e8a0e7..fc80a0084f 100644 --- a/submodules/TelegramStringFormatting/Sources/ServiceMessageStrings.swift +++ b/submodules/TelegramStringFormatting/Sources/ServiceMessageStrings.swift @@ -371,7 +371,7 @@ public func universalServiceMessageString(presentationData: (PresentationTheme, } else { attributedString = NSAttributedString(string: strings.Message_PaymentSent(formatCurrencyAmount(totalAmount, currency: currency)).0, font: titleFont, textColor: primaryTextColor) } - case let .phoneCall(_, discardReason, _): + case let .phoneCall(_, discardReason, _, _): var titleString: String let incoming: Bool if message.flags.contains(.Incoming) { diff --git a/submodules/TelegramUI/Images.xcassets/Call/CallSwitchCameraButton.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Call/CallSwitchCameraButton.imageset/Contents.json new file mode 100644 index 0000000000..0dd1dc8086 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Call/CallSwitchCameraButton.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "Video.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Call/CallSwitchCameraButton.imageset/Video.pdf b/submodules/TelegramUI/Images.xcassets/Call/CallSwitchCameraButton.imageset/Video.pdf new file mode 100644 index 0000000000..71f35844b3 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Call/CallSwitchCameraButton.imageset/Video.pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonVideo.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonVideo.imageset/Contents.json new file mode 100644 index 0000000000..0dd1dc8086 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonVideo.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "Video.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonVideo.imageset/Video.pdf b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonVideo.imageset/Video.pdf new file mode 100644 index 0000000000..40cb0010b4 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonVideo.imageset/Video.pdf differ diff --git a/submodules/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Resources/PresentationStrings.mapping index 24a06afd5c..b2f247d978 100644 Binary files a/submodules/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TelegramUI/Sources/AppDelegate.swift b/submodules/TelegramUI/Sources/AppDelegate.swift index 2f84234a5a..46a7105a54 100644 --- a/submodules/TelegramUI/Sources/AppDelegate.swift +++ b/submodules/TelegramUI/Sources/AppDelegate.swift @@ -141,6 +141,14 @@ protocol SupportedStartCallIntent { @available(iOS 10.0, *) extension INStartAudioCallIntent: SupportedStartCallIntent {} +protocol SupportedStartVideoCallIntent { + @available(iOS 10.0, *) + var contacts: [INPerson]? { get } +} + +@available(iOS 10.0, *) +extension INStartVideoCallIntent: SupportedStartVideoCallIntent {} + private enum QueuedWakeup: Int32 { case call case backgroundLocation @@ -1725,9 +1733,19 @@ final class SharedApplicationContext { func application(_ application: UIApplication, continue userActivity: NSUserActivity, restorationHandler: @escaping ([UIUserActivityRestoring]?) -> Void) -> Bool { if #available(iOS 10.0, *) { + var startCallContacts: [INPerson]? + var startCallIsVideo = false if let startCallIntent = userActivity.interaction?.intent as? SupportedStartCallIntent { + startCallContacts = startCallIntent.contacts + startCallIsVideo = false + } else if let startCallIntent = userActivity.interaction?.intent as? SupportedStartVideoCallIntent { + startCallContacts = startCallIntent.contacts + startCallIsVideo = true + } + + if let startCallContacts = startCallContacts { let startCall: (Int32) -> Void = { userId in - self.startCallWhenReady(accountId: nil, peerId: PeerId(namespace: Namespaces.Peer.CloudUser, id: userId)) + self.startCallWhenReady(accountId: nil, peerId: PeerId(namespace: Namespaces.Peer.CloudUser, id: userId), isVideo: startCallIsVideo) } func cleanPhoneNumber(_ text: String) -> String { @@ -1754,7 +1772,7 @@ final class SharedApplicationContext { } } - if let contact = startCallIntent.contacts?.first { + if let contact = startCallContacts.first { var processed = false if let handle = contact.customIdentifier, handle.hasPrefix("tg") { let string = handle.suffix(from: handle.index(handle.startIndex, offsetBy: 2)) @@ -1914,7 +1932,7 @@ final class SharedApplicationContext { }) } - private func startCallWhenReady(accountId: AccountRecordId?, peerId: PeerId) { + private func startCallWhenReady(accountId: AccountRecordId?, peerId: PeerId, isVideo: Bool) { let signal = self.sharedContextPromise.get() |> take(1) |> mapToSignal { sharedApplicationContext -> Signal in @@ -1932,7 +1950,7 @@ final class SharedApplicationContext { } self.openChatWhenReadyDisposable.set((signal |> deliverOnMainQueue).start(next: { context in - context.startCall(peerId: peerId) + context.startCall(peerId: peerId, isVideo: isVideo) })) } diff --git a/submodules/TelegramUI/Sources/ApplicationContext.swift b/submodules/TelegramUI/Sources/ApplicationContext.swift index fb1b768054..c48ac38f20 100644 --- a/submodules/TelegramUI/Sources/ApplicationContext.swift +++ b/submodules/TelegramUI/Sources/ApplicationContext.swift @@ -750,7 +750,7 @@ final class AuthorizedApplicationContext { } } - func startCall(peerId: PeerId) { + func startCall(peerId: PeerId, isVideo: Bool) { guard let appLockContext = self.context.sharedContext.appLockContext as? AppLockContextImpl else { return } @@ -763,7 +763,7 @@ final class AuthorizedApplicationContext { guard let strongSelf = self else { return } - let _ = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peerId, endCurrentIfAny: false) + let _ = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peerId, isVideo: isVideo, endCurrentIfAny: false) })) } diff --git a/submodules/TelegramUI/Sources/ChatController.swift b/submodules/TelegramUI/Sources/ChatController.swift index 94ca4540d0..79713d4e9d 100644 --- a/submodules/TelegramUI/Sources/ChatController.swift +++ b/submodules/TelegramUI/Sources/ChatController.swift @@ -320,6 +320,8 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G private let peekData: ChatPeekTimeout? private let peekTimerDisposable = MetaDisposable() + + private var hasEmbeddedTitleContent = false public override var customData: Any? { return self.chatLocation @@ -373,7 +375,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G case .inline: navigationBarPresentationData = nil default: - navigationBarPresentationData = NavigationBarPresentationData(presentationData: self.presentationData) + navigationBarPresentationData = NavigationBarPresentationData(presentationData: self.presentationData, hideBackground: true) } super.init(context: context, navigationBarPresentationData: navigationBarPresentationData, mediaAccessoryPanelVisibility: mediaAccessoryPanelVisibility, locationBroadcastPanelSource: locationBroadcastPanelSource) @@ -469,8 +471,8 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self?.openUrl(url, concealed: false, message: nil) }, openPeer: { peer, navigation in self?.openPeer(peerId: peer.id, navigation: navigation, fromMessage: nil) - }, callPeer: { peerId in - self?.controllerInteraction?.callPeer(peerId) + }, callPeer: { peerId, isVideo in + self?.controllerInteraction?.callPeer(peerId, isVideo) }, enqueueMessage: { message in self?.sendMessages([message]) }, sendSticker: canSendMessagesToChat(strongSelf.presentationInterfaceState) ? { fileReference, sourceNode, sourceRect in @@ -1178,7 +1180,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G return self?.chatDisplayNode.reactionContainerNode }, presentGlobalOverlayController: { [weak self] controller, arguments in self?.presentInGlobalOverlay(controller, with: arguments) - }, callPeer: { [weak self] peerId in + }, callPeer: { [weak self] peerId, isVideo in if let strongSelf = self { strongSelf.commitPurposefulAction() @@ -1199,7 +1201,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G return } - let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, endCurrentIfAny: false) + let callResult = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, isVideo: isVideo, endCurrentIfAny: false) if let callResult = callResult, case let .alreadyInProgress(currentPeerId) = callResult { if currentPeerId == peer.id { context.sharedContext.navigateToCurrentCall() @@ -1211,7 +1213,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G |> deliverOnMainQueue).start(next: { peer, current in if let peer = peer, let current = current { strongSelf.present(textAlertController(context: strongSelf.context, title: presentationData.strings.Call_CallInProgressTitle, text: presentationData.strings.Call_CallInProgressMessage(current.compactDisplayTitle, peer.compactDisplayTitle).0, actions: [TextAlertAction(type: .defaultAction, title: presentationData.strings.Common_Cancel, action: {}), TextAlertAction(type: .genericAction, title: presentationData.strings.Common_OK, action: { - let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, endCurrentIfAny: true) + let _ = context.sharedContext.callManager?.requestCall(account: context.account, peerId: peer.id, isVideo: isVideo, endCurrentIfAny: true) })]), in: .window(.root)) } }) @@ -2779,8 +2781,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G case .inline: self.statusBar.statusBarStyle = .Ignore } - self.navigationBar?.updatePresentationData(NavigationBarPresentationData(presentationData: self.presentationData)) - self.chatTitleView?.updateThemeAndStrings(theme: self.presentationData.theme, strings: self.presentationData.strings) + self.updateNavigationBarPresentation() self.updateChatPresentationInterfaceState(animated: false, interactive: false, { state in var state = state state = state.updatedTheme(self.presentationData.theme) @@ -2794,6 +2795,20 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self.currentContextController?.updateTheme(presentationData: self.presentationData) } + private func updateNavigationBarPresentation() { + let navigationBarTheme: NavigationBarTheme + + if self.hasEmbeddedTitleContent { + navigationBarTheme = NavigationBarTheme(rootControllerTheme: defaultDarkPresentationTheme, hideBackground: true) + } else { + navigationBarTheme = NavigationBarTheme(rootControllerTheme: self.presentationData.theme, hideBackground: true) + } + + self.navigationBar?.updatePresentationData(NavigationBarPresentationData(theme: navigationBarTheme, strings: NavigationBarStrings(presentationStrings: self.presentationData.strings))) + + self.chatTitleView?.updateThemeAndStrings(theme: self.presentationData.theme, strings: self.presentationData.strings, hasEmbeddedTitleContent: self.hasEmbeddedTitleContent) + } + override public func loadDisplayNode() { self.displayNode = ChatControllerNode(context: self.context, chatLocation: self.chatLocation, subject: self.subject, controllerInteraction: self.controllerInteraction!, chatPresentationInterfaceState: self.presentationInterfaceState, automaticMediaDownloadSettings: self.automaticMediaDownloadSettings, navigationBar: self.navigationBar, controller: self) @@ -4254,9 +4269,9 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self?.dismissPeerContactOptions() }, deleteChat: { [weak self] in self?.deleteChat(reportChatSpam: false) - }, beginCall: { [weak self] in + }, beginCall: { [weak self] isVideo in if let strongSelf = self, case let .peer(peerId) = strongSelf.chatLocation { - strongSelf.controllerInteraction?.callPeer(peerId) + strongSelf.controllerInteraction?.callPeer(peerId, isVideo) } }, toggleMessageStickerStarred: { [weak self] messageId in if let strongSelf = self, let message = strongSelf.chatDisplayNode.historyNode.messageInCurrentHistoryView(messageId) { @@ -4735,6 +4750,32 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G })) } + self.chatDisplayNode.updateHasEmbeddedTitleContent = { [weak self] hasEmbeddedTitleContent in + guard let strongSelf = self else { + return + } + if strongSelf.hasEmbeddedTitleContent != hasEmbeddedTitleContent { + strongSelf.hasEmbeddedTitleContent = hasEmbeddedTitleContent + + if strongSelf.hasEmbeddedTitleContent { + strongSelf.statusBar.statusBarStyle = .White + } else { + strongSelf.statusBar.statusBarStyle = strongSelf.presentationData.theme.rootController.statusBarStyle.style + } + + if let navigationBar = strongSelf.navigationBar { + if let navigationBarCopy = navigationBar.view.snapshotContentTree() { + navigationBar.view.superview?.insertSubview(navigationBarCopy, aboveSubview: navigationBar.view) + navigationBarCopy.alpha = 0.0 + navigationBarCopy.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring, completion: { [weak navigationBarCopy] _ in + navigationBarCopy?.removeFromSuperview() + }) + } + } + strongSelf.updateNavigationBarPresentation() + } + } + self.interfaceInteraction = interfaceInteraction if let search = self.focusOnSearchAfterAppearance { @@ -5143,7 +5184,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G switch self.presentationInterfaceState.mode { case .standard, .inline: - break + break case .overlay: if case .Ignore = self.statusBar.statusBarStyle { } else if layout.safeInsets.top.isZero { @@ -5503,7 +5544,11 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G switch updatedChatPresentationInterfaceState.mode { case .standard: - self.statusBar.statusBarStyle = self.presentationData.theme.rootController.statusBarStyle.style + if self.hasEmbeddedTitleContent { + self.statusBar.statusBarStyle = .White + } else { + self.statusBar.statusBarStyle = self.presentationData.theme.rootController.statusBarStyle.style + } self.deferScreenEdgeGestures = [] case .overlay: self.deferScreenEdgeGestures = [.top] @@ -9256,6 +9301,14 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self.focusOnSearchAfterAppearance = (domain, query) self.interfaceInteraction?.beginMessageSearch(domain, query) } + + override public func updatePossibleControllerDropContent(content: NavigationControllerDropContent?) { + self.chatDisplayNode.updateEmbeddedTitlePeekContent(content: content) + } + + override public func acceptPossibleControllerDropContent(content: NavigationControllerDropContent) -> Bool { + return self.chatDisplayNode.acceptEmbeddedTitlePeekContent(content: content) + } } private final class ContextControllerContentSourceImpl: ContextControllerContentSource { diff --git a/submodules/TelegramUI/Sources/ChatControllerInteraction.swift b/submodules/TelegramUI/Sources/ChatControllerInteraction.swift index 05d5e4ba79..978c17bd9e 100644 --- a/submodules/TelegramUI/Sources/ChatControllerInteraction.swift +++ b/submodules/TelegramUI/Sources/ChatControllerInteraction.swift @@ -90,7 +90,7 @@ public final class ChatControllerInteraction { let chatControllerNode: () -> ASDisplayNode? let reactionContainerNode: () -> ReactionSelectionParentNode? let presentGlobalOverlayController: (ViewController, Any?) -> Void - let callPeer: (PeerId) -> Void + let callPeer: (PeerId, Bool) -> Void let longTap: (ChatControllerInteractionLongTapAction, Message?) -> Void let openCheckoutOrReceipt: (MessageId) -> Void let openSearch: () -> Void @@ -136,7 +136,7 @@ public final class ChatControllerInteraction { var searchTextHighightState: (String, [MessageIndex])? var seenOneTimeAnimatedMedia = Set() - init(openMessage: @escaping (Message, ChatControllerInteractionOpenMessageMode) -> Bool, openPeer: @escaping (PeerId?, ChatControllerInteractionNavigateToPeer, Message?) -> Void, openPeerMention: @escaping (String) -> Void, openMessageContextMenu: @escaping (Message, Bool, ASDisplayNode, CGRect, UIGestureRecognizer?) -> Void, openMessageContextActions: @escaping (Message, ASDisplayNode, CGRect, ContextGesture?) -> Void, navigateToMessage: @escaping (MessageId, MessageId) -> Void, tapMessage: ((Message) -> Void)?, clickThroughMessage: @escaping () -> Void, toggleMessagesSelection: @escaping ([MessageId], Bool) -> Void, sendCurrentMessage: @escaping (Bool) -> Void, sendMessage: @escaping (String) -> Void, sendSticker: @escaping (FileMediaReference, Bool, ASDisplayNode, CGRect) -> Bool, sendGif: @escaping (FileMediaReference, ASDisplayNode, CGRect) -> Bool, sendBotContextResultAsGif: @escaping (ChatContextResultCollection, ChatContextResult, ASDisplayNode, CGRect) -> Bool, requestMessageActionCallback: @escaping (MessageId, MemoryBuffer?, Bool) -> Void, requestMessageActionUrlAuth: @escaping (String, MessageId, Int32) -> Void, activateSwitchInline: @escaping (PeerId?, String) -> Void, openUrl: @escaping (String, Bool, Bool?, Message?) -> Void, shareCurrentLocation: @escaping () -> Void, shareAccountContact: @escaping () -> Void, sendBotCommand: @escaping (MessageId?, String) -> Void, openInstantPage: @escaping (Message, ChatMessageItemAssociatedData?) -> Void, openWallpaper: @escaping (Message) -> Void, openTheme: @escaping (Message) -> Void, openHashtag: @escaping (String?, String) -> Void, updateInputState: @escaping ((ChatTextInputState) -> ChatTextInputState) -> Void, updateInputMode: @escaping ((ChatInputMode) -> ChatInputMode) -> Void, openMessageShareMenu: @escaping (MessageId) -> Void, presentController: @escaping (ViewController, Any?) -> Void, navigationController: @escaping () -> NavigationController?, chatControllerNode: @escaping () -> ASDisplayNode?, reactionContainerNode: @escaping () -> ReactionSelectionParentNode?, presentGlobalOverlayController: @escaping (ViewController, Any?) -> Void, callPeer: @escaping (PeerId) -> Void, longTap: @escaping (ChatControllerInteractionLongTapAction, Message?) -> Void, openCheckoutOrReceipt: @escaping (MessageId) -> Void, openSearch: @escaping () -> Void, setupReply: @escaping (MessageId) -> Void, canSetupReply: @escaping (Message) -> ChatControllerInteractionSwipeAction, navigateToFirstDateMessage: @escaping(Int32) ->Void, requestRedeliveryOfFailedMessages: @escaping (MessageId) -> Void, addContact: @escaping (String) -> Void, rateCall: @escaping (Message, CallId) -> Void, requestSelectMessagePollOptions: @escaping (MessageId, [Data]) -> Void, requestOpenMessagePollResults: @escaping (MessageId, MediaId) -> Void, openAppStorePage: @escaping () -> Void, displayMessageTooltip: @escaping (MessageId, String, ASDisplayNode?, CGRect?) -> Void, seekToTimecode: @escaping (Message, Double, Bool) -> Void, scheduleCurrentMessage: @escaping () -> Void, sendScheduledMessagesNow: @escaping ([MessageId]) -> Void, editScheduledMessagesTime: @escaping ([MessageId]) -> Void, performTextSelectionAction: @escaping (UInt32, NSAttributedString, TextSelectionAction) -> Void, updateMessageLike: @escaping (MessageId, Bool) -> Void, openMessageReactions: @escaping (MessageId) -> Void, displaySwipeToReplyHint: @escaping () -> Void, dismissReplyMarkupMessage: @escaping (Message) -> Void, openMessagePollResults: @escaping (MessageId, Data) -> Void, openPollCreation: @escaping (Bool?) -> Void, displayPollSolution: @escaping (TelegramMediaPollResults.Solution, ASDisplayNode) -> Void, displayPsa: @escaping (String, ASDisplayNode) -> Void, displayDiceTooltip: @escaping (TelegramMediaDice) -> Void, animateDiceSuccess: @escaping () -> Void, requestMessageUpdate: @escaping (MessageId) -> Void, cancelInteractiveKeyboardGestures: @escaping () -> Void, automaticMediaDownloadSettings: MediaAutoDownloadSettings, pollActionState: ChatInterfacePollActionState, stickerSettings: ChatInterfaceStickerSettings) { + init(openMessage: @escaping (Message, ChatControllerInteractionOpenMessageMode) -> Bool, openPeer: @escaping (PeerId?, ChatControllerInteractionNavigateToPeer, Message?) -> Void, openPeerMention: @escaping (String) -> Void, openMessageContextMenu: @escaping (Message, Bool, ASDisplayNode, CGRect, UIGestureRecognizer?) -> Void, openMessageContextActions: @escaping (Message, ASDisplayNode, CGRect, ContextGesture?) -> Void, navigateToMessage: @escaping (MessageId, MessageId) -> Void, tapMessage: ((Message) -> Void)?, clickThroughMessage: @escaping () -> Void, toggleMessagesSelection: @escaping ([MessageId], Bool) -> Void, sendCurrentMessage: @escaping (Bool) -> Void, sendMessage: @escaping (String) -> Void, sendSticker: @escaping (FileMediaReference, Bool, ASDisplayNode, CGRect) -> Bool, sendGif: @escaping (FileMediaReference, ASDisplayNode, CGRect) -> Bool, sendBotContextResultAsGif: @escaping (ChatContextResultCollection, ChatContextResult, ASDisplayNode, CGRect) -> Bool, requestMessageActionCallback: @escaping (MessageId, MemoryBuffer?, Bool) -> Void, requestMessageActionUrlAuth: @escaping (String, MessageId, Int32) -> Void, activateSwitchInline: @escaping (PeerId?, String) -> Void, openUrl: @escaping (String, Bool, Bool?, Message?) -> Void, shareCurrentLocation: @escaping () -> Void, shareAccountContact: @escaping () -> Void, sendBotCommand: @escaping (MessageId?, String) -> Void, openInstantPage: @escaping (Message, ChatMessageItemAssociatedData?) -> Void, openWallpaper: @escaping (Message) -> Void, openTheme: @escaping (Message) -> Void, openHashtag: @escaping (String?, String) -> Void, updateInputState: @escaping ((ChatTextInputState) -> ChatTextInputState) -> Void, updateInputMode: @escaping ((ChatInputMode) -> ChatInputMode) -> Void, openMessageShareMenu: @escaping (MessageId) -> Void, presentController: @escaping (ViewController, Any?) -> Void, navigationController: @escaping () -> NavigationController?, chatControllerNode: @escaping () -> ASDisplayNode?, reactionContainerNode: @escaping () -> ReactionSelectionParentNode?, presentGlobalOverlayController: @escaping (ViewController, Any?) -> Void, callPeer: @escaping (PeerId, Bool) -> Void, longTap: @escaping (ChatControllerInteractionLongTapAction, Message?) -> Void, openCheckoutOrReceipt: @escaping (MessageId) -> Void, openSearch: @escaping () -> Void, setupReply: @escaping (MessageId) -> Void, canSetupReply: @escaping (Message) -> ChatControllerInteractionSwipeAction, navigateToFirstDateMessage: @escaping(Int32) ->Void, requestRedeliveryOfFailedMessages: @escaping (MessageId) -> Void, addContact: @escaping (String) -> Void, rateCall: @escaping (Message, CallId) -> Void, requestSelectMessagePollOptions: @escaping (MessageId, [Data]) -> Void, requestOpenMessagePollResults: @escaping (MessageId, MediaId) -> Void, openAppStorePage: @escaping () -> Void, displayMessageTooltip: @escaping (MessageId, String, ASDisplayNode?, CGRect?) -> Void, seekToTimecode: @escaping (Message, Double, Bool) -> Void, scheduleCurrentMessage: @escaping () -> Void, sendScheduledMessagesNow: @escaping ([MessageId]) -> Void, editScheduledMessagesTime: @escaping ([MessageId]) -> Void, performTextSelectionAction: @escaping (UInt32, NSAttributedString, TextSelectionAction) -> Void, updateMessageLike: @escaping (MessageId, Bool) -> Void, openMessageReactions: @escaping (MessageId) -> Void, displaySwipeToReplyHint: @escaping () -> Void, dismissReplyMarkupMessage: @escaping (Message) -> Void, openMessagePollResults: @escaping (MessageId, Data) -> Void, openPollCreation: @escaping (Bool?) -> Void, displayPollSolution: @escaping (TelegramMediaPollResults.Solution, ASDisplayNode) -> Void, displayPsa: @escaping (String, ASDisplayNode) -> Void, displayDiceTooltip: @escaping (TelegramMediaDice) -> Void, animateDiceSuccess: @escaping () -> Void, requestMessageUpdate: @escaping (MessageId) -> Void, cancelInteractiveKeyboardGestures: @escaping () -> Void, automaticMediaDownloadSettings: MediaAutoDownloadSettings, pollActionState: ChatInterfacePollActionState, stickerSettings: ChatInterfaceStickerSettings) { self.openMessage = openMessage self.openPeer = openPeer self.openPeerMention = openPeerMention @@ -218,7 +218,7 @@ public final class ChatControllerInteraction { return nil }, reactionContainerNode: { return nil - }, presentGlobalOverlayController: { _, _ in }, callPeer: { _ in }, longTap: { _, _ in }, openCheckoutOrReceipt: { _ in }, openSearch: { }, setupReply: { _ in + }, presentGlobalOverlayController: { _, _ in }, callPeer: { _, _ in }, longTap: { _, _ in }, openCheckoutOrReceipt: { _ in }, openSearch: { }, setupReply: { _ in }, canSetupReply: { _ in return .none }, navigateToFirstDateMessage: { _ in diff --git a/submodules/TelegramUI/Sources/ChatControllerNode.swift b/submodules/TelegramUI/Sources/ChatControllerNode.swift index 46f74fa9db..b4abb27535 100644 --- a/submodules/TelegramUI/Sources/ChatControllerNode.swift +++ b/submodules/TelegramUI/Sources/ChatControllerNode.swift @@ -12,6 +12,15 @@ import TextFormat import AccountContext import TelegramNotices import ReactionSelectionNode +import TelegramUniversalVideoContent + +final class VideoNavigationControllerDropContentItem: NavigationControllerDropContentItem { + let itemNode: OverlayMediaItemNode + + init(itemNode: OverlayMediaItemNode) { + self.itemNode = itemNode + } +} private final class ChatControllerNodeView: UITracingLayerView, WindowInputAccessoryHeightProvider, PreviewingHostView { var inputAccessoryHeight: (() -> CGFloat)? @@ -56,6 +65,175 @@ private struct ChatControllerNodeDerivedLayoutState { var upperInputPositionBound: CGFloat? } +private final class ChatEmbeddedTitleContentNode: ASDisplayNode { + private let context: AccountContext + private let backgroundNode: ASDisplayNode + private let videoNode: OverlayUniversalVideoNode + + private var validLayout: (CGSize, CGFloat, CGFloat)? + + private let dismissed: () -> Void + private let interactiveExtensionUpdated: (ContainedViewLayoutTransition) -> Void + + private(set) var interactiveExtension: CGFloat = 0.0 + private var freezeInteractiveExtension = false + + init(context: AccountContext, videoNode: OverlayUniversalVideoNode, interactiveExtensionUpdated: @escaping (ContainedViewLayoutTransition) -> Void, dismissed: @escaping () -> Void) { + self.dismissed = dismissed + self.interactiveExtensionUpdated = interactiveExtensionUpdated + + self.context = context + + self.backgroundNode = ASDisplayNode() + self.backgroundNode.backgroundColor = .black + + self.videoNode = videoNode + + super.init() + + self.clipsToBounds = true + + self.addSubnode(self.backgroundNode) + + self.view.addGestureRecognizer(UIPanGestureRecognizer(target: self, action: #selector(self.panGesture(_:)))) + } + + @objc private func panGesture(_ recognizer: UIPanGestureRecognizer) { + switch recognizer.state { + case .began: + break + case .changed: + let translation = recognizer.translation(in: self.view) + + func rubberBandingOffset(offset: CGFloat, bandingStart: CGFloat) -> CGFloat { + let bandedOffset = offset - bandingStart + let range: CGFloat = 600.0 + let coefficient: CGFloat = 0.4 + return bandingStart + (1.0 - (1.0 / ((bandedOffset * coefficient / range) + 1.0))) * range + } + + let offset = rubberBandingOffset(offset: translation.y, bandingStart: 0.0) + + if translation.y > 80.0 { + self.freezeInteractiveExtension = true + self.videoNode.customExpand?() + } else { + self.interactiveExtension = max(0.0, offset) + self.interactiveExtensionUpdated(.immediate) + } + case .cancelled, .ended: + if !freezeInteractiveExtension { + self.interactiveExtension = 0.0 + self.interactiveExtensionUpdated(.animated(duration: 0.3, curve: .spring)) + } + default: + break + } + } + + func calculateHeight(width: CGFloat) -> CGFloat { + return self.videoNode.content.dimensions.aspectFilled(CGSize(width: width, height: 16.0)).height + } + + func updateLayout(size: CGSize, topInset: CGFloat, interactiveExtension: CGFloat, transition: ContainedViewLayoutTransition, transitionSurface: ASDisplayNode?, navigationBar: NavigationBar?) { + let isFirstTime = self.validLayout == nil + + self.validLayout = (size, topInset, interactiveExtension) + + let videoFrame = CGRect(origin: CGPoint(x: 0.0, y: topInset + interactiveExtension), size: CGSize(width: size.width, height: size.height - topInset - interactiveExtension)) + + if isFirstTime, let transitionSurface = transitionSurface { + let sourceFrame = self.videoNode.view.convert(self.videoNode.bounds, to: transitionSurface.view) + let targetFrame = self.view.convert(videoFrame, to: transitionSurface.view) + + self.context.sharedContext.mediaManager.setOverlayVideoNode(nil) + transitionSurface.addSubnode(self.videoNode) + + let navigationBarCopy = navigationBar?.view.snapshotView(afterScreenUpdates: true) + let navigationBarContainer = UIView() + navigationBarContainer.frame = targetFrame + navigationBarContainer.clipsToBounds = true + transitionSurface.view.addSubview(navigationBarContainer) + + navigationBarContainer.layer.animateFrame(from: sourceFrame, to: targetFrame, duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring) + + if let navigationBar = navigationBar, let navigationBarCopy = navigationBarCopy { + let navigationFrame = navigationBar.view.convert(navigationBar.bounds, to: transitionSurface.view) + let navigationSourceFrame = navigationFrame.offsetBy(dx: -sourceFrame.minX, dy: -sourceFrame.minY) + let navigationTargetFrame = navigationFrame.offsetBy(dx: -targetFrame.minX, dy: -targetFrame.minY) + navigationBarCopy.frame = navigationTargetFrame + navigationBarContainer.addSubview(navigationBarCopy) + + navigationBarCopy.layer.animateFrame(from: navigationSourceFrame, to: navigationTargetFrame, duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring) + navigationBarCopy.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring) + } + + self.videoNode.updateRoundCorners(false, transition: .animated(duration: 0.25, curve: .spring)) + self.videoNode.showControls() + + self.videoNode.updateLayout(targetFrame.size, transition: .animated(duration: 0.25, curve: .spring)) + self.videoNode.frame = targetFrame + self.videoNode.layer.animateFrame(from: sourceFrame, to: targetFrame, duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring, completion: { [weak self] _ in + guard let strongSelf = self else { + return + } + navigationBarContainer.removeFromSuperview() + strongSelf.addSubnode(strongSelf.videoNode) + if let (size, topInset, interactiveExtension) = strongSelf.validLayout { + strongSelf.updateLayout(size: size, topInset: topInset, interactiveExtension: interactiveExtension, transition: .immediate, transitionSurface: nil, navigationBar: nil) + } + }) + self.backgroundNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) + + self.videoNode.customExpand = { [weak self] in + guard let strongSelf = self else { + return + } + + let transition: ContainedViewLayoutTransition = .animated(duration: 0.25, curve: .spring) + + strongSelf.videoNode.customExpand = nil + strongSelf.videoNode.customClose = nil + + let previousFrame = strongSelf.videoNode.frame + strongSelf.context.sharedContext.mediaManager.setOverlayVideoNode(strongSelf.videoNode) + strongSelf.videoNode.updateRoundCorners(true, transition: transition) + + if let targetSuperview = strongSelf.videoNode.view.superview { + let sourceFrame = strongSelf.view.convert(previousFrame, to: targetSuperview) + let targetFrame = strongSelf.videoNode.frame + strongSelf.videoNode.frame = sourceFrame + strongSelf.videoNode.updateLayout(sourceFrame.size, transition: .immediate) + + transition.updateFrame(node: strongSelf.videoNode, frame: targetFrame) + strongSelf.videoNode.updateLayout(targetFrame.size, transition: transition) + } + + strongSelf.dismissed() + } + + self.videoNode.customClose = { [weak self] in + guard let strongSelf = self else { + return + } + strongSelf.videoNode.customClose = nil + strongSelf.dismissed() + } + } + transition.updateFrame(node: self.backgroundNode, frame: CGRect(origin: CGPoint(), size: size)) + + if self.videoNode.supernode == self { + self.videoNode.layer.transform = CATransform3DIdentity + transition.updateFrame(node: self.videoNode, frame: videoFrame) + } + } +} + +enum ChatEmbeddedTitlePeekContent: Equatable { + case none + case peek +} + class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { let context: AccountContext let chatLocation: ChatLocation @@ -63,6 +241,8 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { private weak var controller: ChatControllerImpl? let navigationBar: NavigationBar? + private let navigationBarBackroundNode: ASDisplayNode + private let navigationBarSeparatorNode: ASDisplayNode private var backgroundEffectNode: ASDisplayNode? private var containerBackgroundNode: ASImageNode? @@ -204,6 +384,10 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { private var onLayoutCompletions: [(ContainedViewLayoutTransition) -> Void] = [] + private var embeddedTitlePeekContent: ChatEmbeddedTitlePeekContent = .none + private var embeddedTitleContentNode: ChatEmbeddedTitleContentNode? + private var dismissedEmbeddedTitleContentNode: ChatEmbeddedTitleContentNode? + init(context: AccountContext, chatLocation: ChatLocation, subject: ChatControllerSubject?, controllerInteraction: ChatControllerInteraction, chatPresentationInterfaceState: ChatPresentationInterfaceState, automaticMediaDownloadSettings: MediaAutoDownloadSettings, navigationBar: NavigationBar?, controller: ChatControllerImpl?) { self.context = context self.chatLocation = chatLocation @@ -248,6 +432,12 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { self.navigateButtons = ChatHistoryNavigationButtons(theme: self.chatPresentationInterfaceState.theme) self.navigateButtons.accessibilityElementsHidden = true + self.navigationBarBackroundNode = ASDisplayNode() + self.navigationBarBackroundNode.backgroundColor = chatPresentationInterfaceState.theme.rootController.navigationBar.backgroundColor + + self.navigationBarSeparatorNode = ASDisplayNode() + self.navigationBarSeparatorNode.backgroundColor = chatPresentationInterfaceState.theme.rootController.navigationBar.separatorColor + super.init() self.controller?.presentationContext.topLevelSubview = { [weak self] in @@ -329,6 +519,9 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { self.addSubnode(self.navigateButtons) + self.addSubnode(self.navigationBarBackroundNode) + self.addSubnode(self.navigationBarSeparatorNode) + self.historyNode.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.tapGesture(_:)))) self.textInputPanelNode = ChatTextInputPanelNode(presentationInterfaceState: chatPresentationInterfaceState, presentController: { [weak self] controller in @@ -696,12 +889,63 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { } else { insets = layout.insets(options: [.input]) } - if case .overlay = self.chatPresentationInterfaceState.mode { - insets.top = 44.0 + + let statusBarHeight = layout.insets(options: [.statusBar]).top + + if let embeddedTitleContentNode = self.embeddedTitleContentNode { + let embeddedSize = CGSize(width: layout.size.width, height: min(400.0, embeddedTitleContentNode.calculateHeight(width: layout.size.width)) + statusBarHeight + embeddedTitleContentNode.interactiveExtension) + if embeddedTitleContentNode.supernode == nil { + self.insertSubnode(embeddedTitleContentNode, aboveSubnode: self.navigationBarBackroundNode) + + var previousTopInset = insets.top + if case .overlay = self.chatPresentationInterfaceState.mode { + previousTopInset = 44.0 + } else { + previousTopInset += navigationBarHeight + } + + if case .peek = self.embeddedTitlePeekContent { + previousTopInset += 32.0 + } + + embeddedTitleContentNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: layout.size.width, height: previousTopInset)) + transition.updateFrame(node: embeddedTitleContentNode, frame: CGRect(origin: CGPoint(), size: embeddedSize)) + embeddedTitleContentNode.updateLayout(size: embeddedSize, topInset: statusBarHeight, interactiveExtension: embeddedTitleContentNode.interactiveExtension, transition: .immediate, transitionSurface: self, navigationBar: self.navigationBar) + } else { + transition.updateFrame(node: embeddedTitleContentNode, frame: CGRect(origin: CGPoint(), size: embeddedSize)) + embeddedTitleContentNode.updateLayout(size: embeddedSize, topInset: statusBarHeight, interactiveExtension: embeddedTitleContentNode.interactiveExtension, transition: transition, transitionSurface: self, navigationBar: self.navigationBar) + } + + insets.top += embeddedSize.height } else { - insets.top += navigationBarHeight + if case .overlay = self.chatPresentationInterfaceState.mode { + insets.top = 44.0 + } else { + insets.top += navigationBarHeight + } + + if case .peek = self.embeddedTitlePeekContent { + insets.top += 32.0 + } } + if let dismissedEmbeddedTitleContentNode = self.dismissedEmbeddedTitleContentNode { + self.dismissedEmbeddedTitleContentNode = nil + if transition.isAnimated { + dismissedEmbeddedTitleContentNode.alpha = 0.0 + dismissedEmbeddedTitleContentNode.layer.allowsGroupOpacity = true + dismissedEmbeddedTitleContentNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15, completion: { [weak dismissedEmbeddedTitleContentNode] _ in + dismissedEmbeddedTitleContentNode?.removeFromSupernode() + }) + transition.updateFrame(node: dismissedEmbeddedTitleContentNode, frame: CGRect(origin: CGPoint(), size: CGSize(width: layout.size.width, height: insets.top))) + } else { + dismissedEmbeddedTitleContentNode.removeFromSupernode() + } + } + + transition.updateFrame(node: self.navigationBarBackroundNode, frame: CGRect(origin: CGPoint(), size: CGSize(width: layout.size.width, height: insets.top))) + transition.updateFrame(node: self.navigationBarSeparatorNode, frame: CGRect(origin: CGPoint(x: 0.0, y: insets.top), size: CGSize(width: layout.size.width, height: UIScreenPixel))) + var wrappingInsets = UIEdgeInsets() if case .overlay = self.chatPresentationInterfaceState.mode { let containerWidth = horizontalContainerFillingSizeForLayout(layout: layout, sideInset: 8.0 + layout.safeInsets.left) @@ -1518,6 +1762,9 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { } self.updatePlainInputSeparator(transition: .immediate) self.inputPanelBackgroundSeparatorNode.backgroundColor = self.chatPresentationInterfaceState.theme.chat.inputPanel.panelSeparatorColor + + self.navigationBarBackroundNode.backgroundColor = chatPresentationInterfaceState.theme.rootController.navigationBar.backgroundColor + self.navigationBarSeparatorNode.backgroundColor = chatPresentationInterfaceState.theme.rootController.navigationBar.separatorColor } let keepSendButtonEnabled = chatPresentationInterfaceState.interfaceState.forwardMessageIds != nil || chatPresentationInterfaceState.interfaceState.editMessage != nil @@ -2384,4 +2631,58 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { func animateQuizCorrectOptionSelected() { self.view.insertSubview(ConfettiView(frame: self.view.bounds), aboveSubview: self.historyNode.view) } + + func updateEmbeddedTitlePeekContent(content: NavigationControllerDropContent?) { + guard let (_, navigationHeight) = self.validLayout else { + return + } + var peekContent: ChatEmbeddedTitlePeekContent = .none + if let content = content, let item = content.item as? VideoNavigationControllerDropContentItem, let _ = item.itemNode as? OverlayUniversalVideoNode { + if content.position.y < navigationHeight + 32.0 { + peekContent = .peek + } + } + if self.embeddedTitlePeekContent != peekContent { + self.embeddedTitlePeekContent = peekContent + self.requestLayout(.animated(duration: 0.3, curve: .spring)) + } + } + + var updateHasEmbeddedTitleContent: ((Bool) -> Void)? + + func acceptEmbeddedTitlePeekContent(content: NavigationControllerDropContent) -> Bool { + guard let (_, navigationHeight) = self.validLayout else { + return false + } + if content.position.y >= navigationHeight + 32.0 { + return false + } + if let item = content.item as? VideoNavigationControllerDropContentItem, let itemNode = item.itemNode as? OverlayUniversalVideoNode { + let embeddedTitleContentNode = ChatEmbeddedTitleContentNode(context: self.context, videoNode: itemNode, interactiveExtensionUpdated: { [weak self] transition in + guard let strongSelf = self else { + return + } + strongSelf.requestLayout(transition) + }, dismissed: { [weak self] in + guard let strongSelf = self else { + return + } + if let embeddedTitleContentNode = strongSelf.embeddedTitleContentNode { + strongSelf.embeddedTitleContentNode = nil + strongSelf.dismissedEmbeddedTitleContentNode = embeddedTitleContentNode + strongSelf.requestLayout(.animated(duration: 0.25, curve: .spring)) + strongSelf.updateHasEmbeddedTitleContent?(false) + } + }) + self.embeddedTitleContentNode = embeddedTitleContentNode + self.embeddedTitlePeekContent = .none + self.updateHasEmbeddedTitleContent?(true) + DispatchQueue.main.async { + self.requestLayout(.animated(duration: 0.25, curve: .spring)) + } + + return true + } + return false + } } diff --git a/submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift b/submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift index c104d0e09c..9f8775fe8b 100644 --- a/submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift +++ b/submodules/TelegramUI/Sources/ChatInfoTitlePanelNode.swift @@ -223,7 +223,7 @@ final class ChatInfoTitlePanelNode: ChatTitleAccessoryPanelNode { case .search: self.interfaceInteraction?.beginMessageSearch(.everything, "") case .call: - self.interfaceInteraction?.beginCall() + self.interfaceInteraction?.beginCall(false) case .report: self.interfaceInteraction?.reportPeer() case .unarchive: diff --git a/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift b/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift index 5166202b89..ceaa5643f0 100644 --- a/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift +++ b/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift @@ -406,7 +406,7 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: if data.messageActions.options.contains(.rateCall) { var callId: CallId? for media in message.media { - if let action = media as? TelegramMediaAction, case let .phoneCall(id, discardReason, _) = action.action { + if let action = media as? TelegramMediaAction, case let .phoneCall(id, discardReason, _, _) = action.action { if discardReason != .busy && discardReason != .missed { if let logName = callLogNameForId(id: id, account: context.account) { let logsPath = callLogsPath(account: context.account) diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift index ebb771f944..03517922e4 100644 --- a/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageBubbleContentNode.swift @@ -78,7 +78,7 @@ enum ChatMessageBubbleContentTapAction { case instantPage case wallpaper case theme - case call(PeerId) + case call(peerId: PeerId, isVideo: Bool) case openMessage case timecode(Double, String) case tooltip(String, ASDisplayNode?, CGRect?) diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift index 93e995919d..fe6f8da8f9 100644 --- a/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift @@ -480,8 +480,7 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode return false } else if let media = media as? TelegramMediaAction { - if case .phoneCall(_, _, _) = media.action { - + if case .phoneCall(_, _, _, _) = media.action { } else { return false } @@ -2547,9 +2546,9 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode item.controllerInteraction.openTheme(item.message) }) } - case let .call(peerId): + case let .call(peerId, isVideo): return .optionalAction({ - self.item?.controllerInteraction.callPeer(peerId) + self.item?.controllerInteraction.callPeer(peerId, isVideo) }) case .openMessage: if let item = self.item { diff --git a/submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift index 6b6fd15e7b..ceb34cd31b 100644 --- a/submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageCallBubbleContentNode.swift @@ -76,8 +76,10 @@ class ChatMessageCallBubbleContentNode: ChatMessageBubbleContentNode { var titleString: String? var callDuration: Int32? var callSuccessful = true + var isVideo = false for media in item.message.media { - if let action = media as? TelegramMediaAction, case let .phoneCall(_, discardReason, duration) = action.action { + if let action = media as? TelegramMediaAction, case let .phoneCall(_, discardReason, duration, isVideoValue) = action.action { + isVideo = isVideoValue callDuration = duration if let discardReason = discardReason { switch discardReason { @@ -98,9 +100,17 @@ class ChatMessageCallBubbleContentNode: ChatMessageBubbleContentNode { if titleString == nil { let baseString: String if message.flags.contains(.Incoming) { - baseString = item.presentationData.strings.Notification_CallIncoming + if isVideo { + baseString = item.presentationData.strings.Notification_VideoCallIncoming + } else { + baseString = item.presentationData.strings.Notification_CallIncoming + } } else { - baseString = item.presentationData.strings.Notification_CallOutgoing + if isVideo { + baseString = item.presentationData.strings.Notification_VideoCallOutgoing + } else { + baseString = item.presentationData.strings.Notification_CallOutgoing + } } titleString = baseString @@ -203,7 +213,13 @@ class ChatMessageCallBubbleContentNode: ChatMessageBubbleContentNode { @objc func callButtonPressed() { if let item = self.item { - item.controllerInteraction.callPeer(item.message.id.peerId) + var isVideo = false + for media in item.message.media { + if let action = media as? TelegramMediaAction, case let .phoneCall(_, _, _, isVideoValue) = action.action { + isVideo = isVideoValue + } + } + item.controllerInteraction.callPeer(item.message.id.peerId, isVideo) } } @@ -211,7 +227,13 @@ class ChatMessageCallBubbleContentNode: ChatMessageBubbleContentNode { if self.buttonNode.frame.contains(point) { return .ignore } else if self.bounds.contains(point), let item = self.item { - return .call(item.message.id.peerId) + var isVideo = false + for media in item.message.media { + if let action = media as? TelegramMediaAction, case let .phoneCall(_, _, _, isVideoValue) = action.action { + isVideo = isVideoValue + } + } + return .call(peerId: item.message.id.peerId, isVideo: isVideo) } else { return .none } diff --git a/submodules/TelegramUI/Sources/ChatMessageItemView.swift b/submodules/TelegramUI/Sources/ChatMessageItemView.swift index b17d83ce58..e4bab4067d 100644 --- a/submodules/TelegramUI/Sources/ChatMessageItemView.swift +++ b/submodules/TelegramUI/Sources/ChatMessageItemView.swift @@ -616,7 +616,7 @@ final class ChatMessageAccessibilityData { canReply = false } else if let media = media as? TelegramMediaAction { - if case .phoneCall(_, _, _) = media.action { + if case .phoneCall = media.action { } else { canReply = false } diff --git a/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift b/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift index 1fb9cbf8f6..3c030f9617 100644 --- a/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift +++ b/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift @@ -100,7 +100,7 @@ final class ChatPanelInterfaceInteraction { let presentPeerContact: () -> Void let dismissReportPeer: () -> Void let deleteChat: () -> Void - let beginCall: () -> Void + let beginCall: (Bool) -> Void let toggleMessageStickerStarred: (MessageId) -> Void let presentController: (ViewController, Any?) -> Void let getNavigationController: () -> NavigationController? @@ -120,7 +120,7 @@ final class ChatPanelInterfaceInteraction { let displaySearchResultsTooltip: (ASDisplayNode, CGRect) -> Void let statuses: ChatPanelInterfaceInteractionStatuses? - init(setupReplyMessage: @escaping (MessageId, @escaping (ContainedViewLayoutTransition) -> Void) -> Void, setupEditMessage: @escaping (MessageId?, @escaping (ContainedViewLayoutTransition) -> Void) -> Void, beginMessageSelection: @escaping ([MessageId], @escaping (ContainedViewLayoutTransition) -> Void) -> Void, deleteSelectedMessages: @escaping () -> Void, reportSelectedMessages: @escaping () -> Void, reportMessages: @escaping ([Message], ContextController?) -> Void, deleteMessages: @escaping ([Message], ContextController?, @escaping (ContextMenuActionResult) -> Void) -> Void, forwardSelectedMessages: @escaping () -> Void, forwardCurrentForwardMessages: @escaping () -> Void, forwardMessages: @escaping ([Message]) -> Void, shareSelectedMessages: @escaping () -> Void, updateTextInputStateAndMode: @escaping ((ChatTextInputState, ChatInputMode) -> (ChatTextInputState, ChatInputMode)) -> Void, updateInputModeAndDismissedButtonKeyboardMessageId: @escaping ((ChatPresentationInterfaceState) -> (ChatInputMode, MessageId?)) -> Void, openStickers: @escaping () -> Void, editMessage: @escaping () -> Void, beginMessageSearch: @escaping (ChatSearchDomain, String) -> Void, dismissMessageSearch: @escaping () -> Void, updateMessageSearch: @escaping (String) -> Void, openSearchResults: @escaping () -> Void, navigateMessageSearch: @escaping (ChatPanelSearchNavigationAction) -> Void, openCalendarSearch: @escaping () -> Void, toggleMembersSearch: @escaping (Bool) -> Void, navigateToMessage: @escaping (MessageId) -> Void, navigateToChat: @escaping (PeerId) -> Void, navigateToProfile: @escaping (PeerId) -> Void, openPeerInfo: @escaping () -> Void, togglePeerNotifications: @escaping () -> Void, sendContextResult: @escaping (ChatContextResultCollection, ChatContextResult, ASDisplayNode, CGRect) -> Bool, sendBotCommand: @escaping (Peer, String) -> Void, sendBotStart: @escaping (String?) -> Void, botSwitchChatWithPayload: @escaping (PeerId, String) -> Void, beginMediaRecording: @escaping (Bool) -> Void, finishMediaRecording: @escaping (ChatFinishMediaRecordingAction) -> Void, stopMediaRecording: @escaping () -> Void, lockMediaRecording: @escaping () -> Void, deleteRecordedMedia: @escaping () -> Void, sendRecordedMedia: @escaping () -> Void, displayRestrictedInfo: @escaping (ChatPanelRestrictionInfoSubject, ChatPanelRestrictionInfoDisplayType) -> Void, displayVideoUnmuteTip: @escaping (CGPoint?) -> Void, switchMediaRecordingMode: @escaping () -> Void, setupMessageAutoremoveTimeout: @escaping () -> Void, sendSticker: @escaping (FileMediaReference, ASDisplayNode, CGRect) -> Bool, unblockPeer: @escaping () -> Void, pinMessage: @escaping (MessageId) -> Void, unpinMessage: @escaping () -> Void, shareAccountContact: @escaping () -> Void, reportPeer: @escaping () -> Void, presentPeerContact: @escaping () -> Void, dismissReportPeer: @escaping () -> Void, deleteChat: @escaping () -> Void, beginCall: @escaping () -> Void, toggleMessageStickerStarred: @escaping (MessageId) -> Void, presentController: @escaping (ViewController, Any?) -> Void, getNavigationController: @escaping () -> NavigationController?, presentGlobalOverlayController: @escaping (ViewController, Any?) -> Void, navigateFeed: @escaping () -> Void, openGrouping: @escaping () -> Void, toggleSilentPost: @escaping () -> Void, requestUnvoteInMessage: @escaping (MessageId) -> Void, requestStopPollInMessage: @escaping (MessageId) -> Void, updateInputLanguage: @escaping ((String?) -> String?) -> Void, unarchiveChat: @escaping () -> Void, openLinkEditing: @escaping () -> Void, reportPeerIrrelevantGeoLocation: @escaping () -> Void, displaySlowmodeTooltip: @escaping (ASDisplayNode, CGRect) -> Void, displaySendMessageOptions: @escaping (ASDisplayNode, ContextGesture) -> Void, openScheduledMessages: @escaping () -> Void, displaySearchResultsTooltip: @escaping (ASDisplayNode, CGRect) -> Void, statuses: ChatPanelInterfaceInteractionStatuses?) { + init(setupReplyMessage: @escaping (MessageId, @escaping (ContainedViewLayoutTransition) -> Void) -> Void, setupEditMessage: @escaping (MessageId?, @escaping (ContainedViewLayoutTransition) -> Void) -> Void, beginMessageSelection: @escaping ([MessageId], @escaping (ContainedViewLayoutTransition) -> Void) -> Void, deleteSelectedMessages: @escaping () -> Void, reportSelectedMessages: @escaping () -> Void, reportMessages: @escaping ([Message], ContextController?) -> Void, deleteMessages: @escaping ([Message], ContextController?, @escaping (ContextMenuActionResult) -> Void) -> Void, forwardSelectedMessages: @escaping () -> Void, forwardCurrentForwardMessages: @escaping () -> Void, forwardMessages: @escaping ([Message]) -> Void, shareSelectedMessages: @escaping () -> Void, updateTextInputStateAndMode: @escaping ((ChatTextInputState, ChatInputMode) -> (ChatTextInputState, ChatInputMode)) -> Void, updateInputModeAndDismissedButtonKeyboardMessageId: @escaping ((ChatPresentationInterfaceState) -> (ChatInputMode, MessageId?)) -> Void, openStickers: @escaping () -> Void, editMessage: @escaping () -> Void, beginMessageSearch: @escaping (ChatSearchDomain, String) -> Void, dismissMessageSearch: @escaping () -> Void, updateMessageSearch: @escaping (String) -> Void, openSearchResults: @escaping () -> Void, navigateMessageSearch: @escaping (ChatPanelSearchNavigationAction) -> Void, openCalendarSearch: @escaping () -> Void, toggleMembersSearch: @escaping (Bool) -> Void, navigateToMessage: @escaping (MessageId) -> Void, navigateToChat: @escaping (PeerId) -> Void, navigateToProfile: @escaping (PeerId) -> Void, openPeerInfo: @escaping () -> Void, togglePeerNotifications: @escaping () -> Void, sendContextResult: @escaping (ChatContextResultCollection, ChatContextResult, ASDisplayNode, CGRect) -> Bool, sendBotCommand: @escaping (Peer, String) -> Void, sendBotStart: @escaping (String?) -> Void, botSwitchChatWithPayload: @escaping (PeerId, String) -> Void, beginMediaRecording: @escaping (Bool) -> Void, finishMediaRecording: @escaping (ChatFinishMediaRecordingAction) -> Void, stopMediaRecording: @escaping () -> Void, lockMediaRecording: @escaping () -> Void, deleteRecordedMedia: @escaping () -> Void, sendRecordedMedia: @escaping () -> Void, displayRestrictedInfo: @escaping (ChatPanelRestrictionInfoSubject, ChatPanelRestrictionInfoDisplayType) -> Void, displayVideoUnmuteTip: @escaping (CGPoint?) -> Void, switchMediaRecordingMode: @escaping () -> Void, setupMessageAutoremoveTimeout: @escaping () -> Void, sendSticker: @escaping (FileMediaReference, ASDisplayNode, CGRect) -> Bool, unblockPeer: @escaping () -> Void, pinMessage: @escaping (MessageId) -> Void, unpinMessage: @escaping () -> Void, shareAccountContact: @escaping () -> Void, reportPeer: @escaping () -> Void, presentPeerContact: @escaping () -> Void, dismissReportPeer: @escaping () -> Void, deleteChat: @escaping () -> Void, beginCall: @escaping (Bool) -> Void, toggleMessageStickerStarred: @escaping (MessageId) -> Void, presentController: @escaping (ViewController, Any?) -> Void, getNavigationController: @escaping () -> NavigationController?, presentGlobalOverlayController: @escaping (ViewController, Any?) -> Void, navigateFeed: @escaping () -> Void, openGrouping: @escaping () -> Void, toggleSilentPost: @escaping () -> Void, requestUnvoteInMessage: @escaping (MessageId) -> Void, requestStopPollInMessage: @escaping (MessageId) -> Void, updateInputLanguage: @escaping ((String?) -> String?) -> Void, unarchiveChat: @escaping () -> Void, openLinkEditing: @escaping () -> Void, reportPeerIrrelevantGeoLocation: @escaping () -> Void, displaySlowmodeTooltip: @escaping (ASDisplayNode, CGRect) -> Void, displaySendMessageOptions: @escaping (ASDisplayNode, ContextGesture) -> Void, openScheduledMessages: @escaping () -> Void, displaySearchResultsTooltip: @escaping (ASDisplayNode, CGRect) -> Void, statuses: ChatPanelInterfaceInteractionStatuses?) { self.setupReplyMessage = setupReplyMessage self.setupEditMessage = setupEditMessage self.beginMessageSelection = beginMessageSelection diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsController.swift b/submodules/TelegramUI/Sources/ChatRecentActionsController.swift index d38f18ae3d..f25e25b6d7 100644 --- a/submodules/TelegramUI/Sources/ChatRecentActionsController.swift +++ b/submodules/TelegramUI/Sources/ChatRecentActionsController.swift @@ -103,7 +103,7 @@ final class ChatRecentActionsController: TelegramBaseController { }, presentPeerContact: { }, dismissReportPeer: { }, deleteChat: { - }, beginCall: { + }, beginCall: { _ in }, toggleMessageStickerStarred: { _ in }, presentController: { _, _ in }, getNavigationController: { diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift b/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift index a40d43ab10..40c9bc0fc3 100644 --- a/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift +++ b/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift @@ -180,8 +180,8 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { self?.openUrl(url) }, openPeer: { peer, navigation in self?.openPeer(peerId: peer.id, peer: peer) - }, callPeer: { peerId in - self?.controllerInteraction?.callPeer(peerId) + }, callPeer: { peerId, isVideo in + self?.controllerInteraction?.callPeer(peerId, isVideo) }, enqueueMessage: { _ in }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in }, chatAvatarHiddenMedia: { _, _ in })) } @@ -242,7 +242,7 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { return self }, reactionContainerNode: { return nil - }, presentGlobalOverlayController: { _, _ in }, callPeer: { _ in }, longTap: { [weak self] action, message in + }, presentGlobalOverlayController: { _, _ in }, callPeer: { _, _ in }, longTap: { [weak self] action, message in if let strongSelf = self { switch action { case let .url(url): diff --git a/submodules/TelegramUI/Sources/ChatTitleView.swift b/submodules/TelegramUI/Sources/ChatTitleView.swift index 924258fb13..8228544ff7 100644 --- a/submodules/TelegramUI/Sources/ChatTitleView.swift +++ b/submodules/TelegramUI/Sources/ChatTitleView.swift @@ -23,61 +23,6 @@ enum ChatTitleContent { case custom(String) } -private final class ChatTitleNetworkStatusNode: ASDisplayNode { - private var theme: PresentationTheme - - private let titleNode: ImmediateTextNode - private let activityIndicator: ActivityIndicator - - var title: String = "" { - didSet { - if self.title != oldValue { - self.titleNode.attributedText = NSAttributedString(string: title, font: Font.bold(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) - } - } - } - - init(theme: PresentationTheme) { - self.theme = theme - - self.titleNode = ImmediateTextNode() - self.titleNode.isUserInteractionEnabled = false - self.titleNode.displaysAsynchronously = false - self.titleNode.maximumNumberOfLines = 1 - self.titleNode.isOpaque = false - self.titleNode.isUserInteractionEnabled = false - - self.activityIndicator = ActivityIndicator(type: .custom(theme.rootController.navigationBar.primaryTextColor, 22.0, 1.5, false), speed: .slow) - let activityIndicatorSize = self.activityIndicator.measure(CGSize(width: 100.0, height: 100.0)) - self.activityIndicator.frame = CGRect(origin: CGPoint(), size: activityIndicatorSize) - - super.init() - - self.addSubnode(self.titleNode) - self.addSubnode(self.activityIndicator) - } - - func updateTheme(theme: PresentationTheme) { - self.theme = theme - - self.titleNode.attributedText = NSAttributedString(string: self.title, font: Font.medium(24.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) - self.activityIndicator.type = .custom(self.theme.rootController.navigationBar.primaryTextColor, 22.0, 1.5, false) - } - - func updateLayout(size: CGSize, transition: ContainedViewLayoutTransition) { - let indicatorSize = self.activityIndicator.bounds.size - let indicatorPadding = indicatorSize.width + 6.0 - - let titleSize = self.titleNode.updateLayout(CGSize(width: max(1.0, size.width - indicatorPadding), height: size.height)) - let combinedHeight = titleSize.height - - let titleFrame = CGRect(origin: CGPoint(x: indicatorPadding + floor((size.width - titleSize.width - indicatorPadding) / 2.0), y: floor((size.height - combinedHeight) / 2.0)), size: titleSize) - transition.updateFrame(node: self.titleNode, frame: titleFrame) - - transition.updateFrame(node: self.activityIndicator, frame: CGRect(origin: CGPoint(x: titleFrame.minX - indicatorSize.width - 4.0, y: titleFrame.minY - 1.0), size: indicatorSize)) - } -} - private enum ChatTitleIcon { case none case lock @@ -88,6 +33,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { private let account: Account private var theme: PresentationTheme + private var hasEmbeddedTitleContent: Bool = false private var strings: PresentationStrings private var dateTimeFormat: PresentationDateTimeFormat private var nameDisplayOrder: PresentationPersonNameOrder @@ -120,43 +66,6 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } private func updateNetworkStatusNode(networkState: AccountNetworkState, layout: ContainerViewLayout?) { - var isOnline = false - if case .online = networkState { - isOnline = true - } - - /*if isOnline || layout?.metrics.widthClass == .regular { - self.contentContainer.isHidden = false - if let networkStatusNode = self.networkStatusNode { - self.networkStatusNode = nil - networkStatusNode.removeFromSupernode() - } - } else { - self.contentContainer.isHidden = true - let statusNode: ChatTitleNetworkStatusNode - if let current = self.networkStatusNode { - statusNode = current - } else { - statusNode = ChatTitleNetworkStatusNode(theme: self.theme) - self.networkStatusNode = statusNode - self.insertSubview(statusNode.view, aboveSubview: self.contentContainer.view) - } - switch self.networkState { - case .waitingForNetwork: - statusNode.title = self.strings.State_WaitingForNetwork - case let .connecting(proxy): - if let layout = layout, proxy != nil && layout.size.width > 320.0 { - statusNode.title = self.strings.State_ConnectingToProxy - } else { - statusNode.title = self.strings.State_Connecting - } - case .updating: - statusNode.title = self.strings.State_Updating - case .online: - break - } - }*/ - self.setNeedsLayout() } @@ -183,6 +92,8 @@ final class ChatTitleView: UIView, NavigationBarTitleView { var titleContent: ChatTitleContent? { didSet { if let titleContent = self.titleContent { + let titleTheme = self.hasEmbeddedTitleContent ? defaultDarkPresentationTheme : self.theme + var string: NSAttributedString? var titleLeftIcon: ChatTitleIcon = .none var titleRightIcon: ChatTitleIcon = .none @@ -192,20 +103,20 @@ final class ChatTitleView: UIView, NavigationBarTitleView { case let .peer(peerView, _, isScheduledMessages): if isScheduledMessages { if peerView.peerId == self.account.peerId { - string = NSAttributedString(string: self.strings.ScheduledMessages_RemindersTitle, font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + string = NSAttributedString(string: self.strings.ScheduledMessages_RemindersTitle, font: Font.medium(17.0), textColor: titleTheme.rootController.navigationBar.primaryTextColor) } else { - string = NSAttributedString(string: self.strings.ScheduledMessages_Title, font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + string = NSAttributedString(string: self.strings.ScheduledMessages_Title, font: Font.medium(17.0), textColor: titleTheme.rootController.navigationBar.primaryTextColor) } isEnabled = false } else { if let peer = peerViewMainPeer(peerView) { if peerView.peerId == self.account.peerId { - string = NSAttributedString(string: self.strings.Conversation_SavedMessages, font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + string = NSAttributedString(string: self.strings.Conversation_SavedMessages, font: Font.medium(17.0), textColor: titleTheme.rootController.navigationBar.primaryTextColor) } else { if !peerView.peerIsContact, let user = peer as? TelegramUser, !user.flags.contains(.isSupport), user.botInfo == nil, let phone = user.phone, !phone.isEmpty { - string = NSAttributedString(string: formatPhoneNumber(phone), font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + string = NSAttributedString(string: formatPhoneNumber(phone), font: Font.medium(17.0), textColor: titleTheme.rootController.navigationBar.primaryTextColor) } else { - string = NSAttributedString(string: peer.displayTitle(strings: self.strings, displayOrder: self.nameDisplayOrder), font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + string = NSAttributedString(string: peer.displayTitle(strings: self.strings, displayOrder: self.nameDisplayOrder), font: Font.medium(17.0), textColor: titleTheme.rootController.navigationBar.primaryTextColor) } } titleScamIcon = peer.isScam @@ -220,9 +131,9 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } } case .group: - string = NSAttributedString(string: "Feed", font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + string = NSAttributedString(string: "Feed", font: Font.medium(17.0), textColor: titleTheme.rootController.navigationBar.primaryTextColor) case let .custom(text): - string = NSAttributedString(string: text, font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + string = NSAttributedString(string: text, font: Font.medium(17.0), textColor: titleTheme.rootController.navigationBar.primaryTextColor) } if let string = string, self.titleNode.attributedText == nil || !self.titleNode.attributedText!.isEqual(to: string) { @@ -234,7 +145,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { self.titleLeftIcon = titleLeftIcon switch titleLeftIcon { case .lock: - self.titleLeftIconNode.image = PresentationResourcesChat.chatTitleLockIcon(self.theme) + self.titleLeftIconNode.image = PresentationResourcesChat.chatTitleLockIcon(titleTheme) default: self.titleLeftIconNode.image = nil } @@ -243,7 +154,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { if titleScamIcon != self.titleScamIcon { self.titleScamIcon = titleScamIcon - self.titleCredibilityIconNode.image = titleScamIcon ? PresentationResourcesChatList.scamIcon(self.theme, type: .regular) : nil + self.titleCredibilityIconNode.image = titleScamIcon ? PresentationResourcesChatList.scamIcon(titleTheme, type: .regular) : nil self.setNeedsLayout() } @@ -251,7 +162,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { self.titleRightIcon = titleRightIcon switch titleRightIcon { case .mute: - self.titleRightIconNode.image = PresentationResourcesChat.chatTitleMuteIcon(self.theme) + self.titleRightIconNode.image = PresentationResourcesChat.chatTitleMuteIcon(titleTheme) default: self.titleRightIconNode.image = nil } @@ -278,6 +189,8 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } } + let titleTheme = self.hasEmbeddedTitleContent ? defaultDarkPresentationTheme : self.theme + var state = ChatTitleActivityNodeState.none switch self.networkState { case .waitingForNetwork, .connecting, .updating: @@ -285,14 +198,14 @@ final class ChatTitleView: UIView, NavigationBarTitleView { switch self.networkState { case .waitingForNetwork: infoText = self.strings.ChatState_WaitingForNetwork - case let .connecting(proxy): + case .connecting: infoText = self.strings.ChatState_Connecting case .updating: infoText = self.strings.ChatState_Updating case .online: infoText = "" } - state = .info(NSAttributedString(string: infoText, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor), .generic) + state = .info(NSAttributedString(string: infoText, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor), .generic) case .online: if let (peerId, inputActivities) = self.inputActivities, !inputActivities.isEmpty, inputActivitiesAllowed { var stringValue = "" @@ -336,7 +249,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } } } - let color = self.theme.rootController.navigationBar.accentTextColor + let color = titleTheme.rootController.navigationBar.accentTextColor let string = NSAttributedString(string: stringValue, font: Font.regular(13.0), textColor: color) switch mergedActivity { case .typingText: @@ -357,21 +270,21 @@ final class ChatTitleView: UIView, NavigationBarTitleView { if let peer = peerViewMainPeer(peerView) { let servicePeer = isServicePeer(peer) if peer.id == self.account.peerId || isScheduledMessages { - let string = NSAttributedString(string: "", font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: "", font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } else if let user = peer as? TelegramUser { if servicePeer { - let string = NSAttributedString(string: "", font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: "", font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } else if user.flags.contains(.isSupport) { let statusText = self.strings.Bot_GenericSupportStatus - let string = NSAttributedString(string: statusText, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: statusText, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } else if let _ = user.botInfo { let statusText = self.strings.Bot_GenericBotStatus - let string = NSAttributedString(string: statusText, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: statusText, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } else if let peer = peerViewMainPeer(peerView) { let timestamp = CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 @@ -383,10 +296,10 @@ final class ChatTitleView: UIView, NavigationBarTitleView { userPresence = TelegramUserPresence(status: .none, lastActivity: 0) } let (string, activity) = stringAndActivityForUserPresence(strings: self.strings, dateTimeFormat: self.dateTimeFormat, presence: userPresence, relativeTo: Int32(timestamp)) - let attributedString = NSAttributedString(string: string, font: Font.regular(13.0), textColor: activity ? self.theme.rootController.navigationBar.accentTextColor : self.theme.rootController.navigationBar.secondaryTextColor) + let attributedString = NSAttributedString(string: string, font: Font.regular(13.0), textColor: activity ? titleTheme.rootController.navigationBar.accentTextColor : titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(attributedString, activity ? .online : .lastSeenTime) } else { - let string = NSAttributedString(string: "", font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: "", font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } } else if let group = peer as? TelegramGroup { @@ -408,11 +321,11 @@ final class ChatTitleView: UIView, NavigationBarTitleView { if onlineCount > 1 { let string = NSMutableAttributedString() - string.append(NSAttributedString(string: "\(strings.Conversation_StatusMembers(Int32(group.participantCount))), ", font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor)) - string.append(NSAttributedString(string: strings.Conversation_StatusOnline(Int32(onlineCount)), font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor)) + string.append(NSAttributedString(string: "\(strings.Conversation_StatusMembers(Int32(group.participantCount))), ", font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor)) + string.append(NSAttributedString(string: strings.Conversation_StatusOnline(Int32(onlineCount)), font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor)) state = .info(string, .generic) } else { - let string = NSAttributedString(string: strings.Conversation_StatusMembers(Int32(group.participantCount)), font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: strings.Conversation_StatusMembers(Int32(group.participantCount)), font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } } else if let channel = peer as? TelegramChannel { @@ -420,17 +333,17 @@ final class ChatTitleView: UIView, NavigationBarTitleView { if memberCount == 0 { let string: NSAttributedString if case .group = channel.info { - string = NSAttributedString(string: strings.Group_Status, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + string = NSAttributedString(string: strings.Group_Status, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) } else { - string = NSAttributedString(string: strings.Channel_Status, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + string = NSAttributedString(string: strings.Channel_Status, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) } state = .info(string, .generic) } else { if case .group = channel.info, let onlineMemberCount = onlineMemberCount, onlineMemberCount > 1 { let string = NSMutableAttributedString() - string.append(NSAttributedString(string: "\(strings.Conversation_StatusMembers(Int32(memberCount))), ", font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor)) - string.append(NSAttributedString(string: strings.Conversation_StatusOnline(Int32(onlineMemberCount)), font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor)) + string.append(NSAttributedString(string: "\(strings.Conversation_StatusMembers(Int32(memberCount))), ", font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor)) + string.append(NSAttributedString(string: strings.Conversation_StatusOnline(Int32(onlineMemberCount)), font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor)) state = .info(string, .generic) } else { let membersString: String @@ -439,17 +352,17 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } else { membersString = strings.Conversation_StatusSubscribers(memberCount) } - let string = NSAttributedString(string: membersString, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: membersString, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } } } else { switch channel.info { case .group: - let string = NSAttributedString(string: strings.Group_Status, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: strings.Group_Status, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) case .broadcast: - let string = NSAttributedString(string: strings.Channel_Status, font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) + let string = NSAttributedString(string: strings.Channel_Status, font: Font.regular(13.0), textColor: titleTheme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } } @@ -551,11 +464,11 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } } - func updateThemeAndStrings(theme: PresentationTheme, strings: PresentationStrings) { + func updateThemeAndStrings(theme: PresentationTheme, strings: PresentationStrings, hasEmbeddedTitleContent: Bool) { self.theme = theme + self.hasEmbeddedTitleContent = hasEmbeddedTitleContent self.strings = strings - //self.networkStatusNode?.updateTheme(theme: theme) let titleContent = self.titleContent self.titleContent = titleContent self.updateStatus() @@ -568,8 +481,6 @@ final class ChatTitleView: UIView, NavigationBarTitleView { func updateLayout(size: CGSize, clearBounds: CGRect, transition: ContainedViewLayoutTransition) { self.validLayout = (size, clearBounds) - let transition: ContainedViewLayoutTransition = .immediate - self.button.frame = clearBounds self.contentContainer.frame = clearBounds diff --git a/submodules/TelegramUI/Sources/DrawingStickersScreen.swift b/submodules/TelegramUI/Sources/DrawingStickersScreen.swift index 5d08105c80..0c0b5e5d40 100644 --- a/submodules/TelegramUI/Sources/DrawingStickersScreen.swift +++ b/submodules/TelegramUI/Sources/DrawingStickersScreen.swift @@ -115,7 +115,7 @@ private final class DrawingStickersScreenNode: ViewControllerTracingNode { return nil }, reactionContainerNode: { return nil - }, presentGlobalOverlayController: { _, _ in }, callPeer: { _ in }, longTap: { _, _ in }, openCheckoutOrReceipt: { _ in }, openSearch: { }, setupReply: { _ in + }, presentGlobalOverlayController: { _, _ in }, callPeer: { _, _ in }, longTap: { _, _ in }, openCheckoutOrReceipt: { _ in }, openSearch: { }, setupReply: { _ in }, canSetupReply: { _ in return .none }, navigateToFirstDateMessage: { _ in diff --git a/submodules/TelegramUI/Sources/OverlayMediaController.swift b/submodules/TelegramUI/Sources/OverlayMediaController.swift index 08a36a3450..7c7e93baef 100644 --- a/submodules/TelegramUI/Sources/OverlayMediaController.swift +++ b/submodules/TelegramUI/Sources/OverlayMediaController.swift @@ -11,6 +11,9 @@ public final class OverlayMediaControllerImpl: ViewController, OverlayMediaContr return self.displayNode as! OverlayMediaControllerNode } + public var updatePossibleEmbeddingItem: ((OverlayMediaControllerEmbeddingItem?) -> Void)? + public var embedPossibleEmbeddingItem: ((OverlayMediaControllerEmbeddingItem) -> Bool)? + public init() { super.init(navigationBarPresentationData: nil) @@ -22,7 +25,11 @@ public final class OverlayMediaControllerImpl: ViewController, OverlayMediaContr } override public func loadDisplayNode() { - self.displayNode = OverlayMediaControllerNode() + self.displayNode = OverlayMediaControllerNode(updatePossibleEmbeddingItem: { [weak self] item in + self?.updatePossibleEmbeddingItem?(item) + }, embedPossibleEmbeddingItem: { [weak self] item in + return self?.embedPossibleEmbeddingItem?(item) ?? false + }) self.displayNodeDidLoad() } diff --git a/submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift b/submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift index 511fa97937..52cc221d47 100644 --- a/submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift +++ b/submodules/TelegramUI/Sources/OverlayMediaControllerNode.swift @@ -28,7 +28,12 @@ private final class OverlayMediaVideoNodeData { } } + + final class OverlayMediaControllerNode: ASDisplayNode, UIGestureRecognizerDelegate { + private let updatePossibleEmbeddingItem: (OverlayMediaControllerEmbeddingItem?) -> Void + private let embedPossibleEmbeddingItem: (OverlayMediaControllerEmbeddingItem) -> Bool + private var videoNodes: [OverlayMediaVideoNodeData] = [] private var validLayout: ContainerViewLayout? @@ -40,7 +45,10 @@ final class OverlayMediaControllerNode: ASDisplayNode, UIGestureRecognizerDelega private var pinchingNode: OverlayMediaItemNode? private var pinchingNodeInitialSize: CGSize? - override init() { + init(updatePossibleEmbeddingItem: @escaping (OverlayMediaControllerEmbeddingItem?) -> Void, embedPossibleEmbeddingItem: @escaping (OverlayMediaControllerEmbeddingItem) -> Bool) { + self.updatePossibleEmbeddingItem = updatePossibleEmbeddingItem + self.embedPossibleEmbeddingItem = embedPossibleEmbeddingItem + super.init() self.setViewBlock({ @@ -329,34 +337,46 @@ final class OverlayMediaControllerNode: ASDisplayNode, UIGestureRecognizerDelega draggingNode.updateMinimizedEdge(nil, adjusting: true) } draggingNode.frame = nodeFrame + self.updatePossibleEmbeddingItem(OverlayMediaControllerEmbeddingItem( + position: nodeFrame.center, + itemNode: draggingNode + )) } case .ended, .cancelled: if let draggingNode = self.draggingNode, let validLayout = self.validLayout, let index = self.videoNodes.firstIndex(where: { $0.node === draggingNode }){ let nodeSize = self.videoNodes[index].currentSize let previousFrame = draggingNode.frame - let (updatedLocation, shouldDismiss) = self.nodeLocationForPosition(layout: validLayout, position: CGPoint(x: previousFrame.midX, y: previousFrame.midY), velocity: recognizer.velocity(in: self.view), size: nodeSize, tempExtendedTopInset: draggingNode.tempExtendedTopInset) - - if shouldDismiss && draggingNode.isMinimizeable { - draggingNode.updateMinimizedEdge(updatedLocation.x.isZero ? .left : .right, adjusting: false) - self.videoNodes[index].isMinimized = true + if self.embedPossibleEmbeddingItem(OverlayMediaControllerEmbeddingItem( + position: previousFrame.center, + itemNode: draggingNode + )) { + self.draggingNode = nil } else { - draggingNode.updateMinimizedEdge(nil, adjusting: true) - self.videoNodes[index].isMinimized = false - } - - if let group = draggingNode.group { - self.locationByGroup[group] = updatedLocation - } - self.videoNodes[index].location = updatedLocation - - draggingNode.frame = CGRect(origin: self.nodePosition(layout: validLayout, size: nodeSize, location: updatedLocation, hidden: !draggingNode.hasAttachedContext, isMinimized: self.videoNodes[index].isMinimized, tempExtendedTopInset: draggingNode.tempExtendedTopInset), size: nodeSize) - draggingNode.layer.animateFrame(from: previousFrame, to: draggingNode.frame, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) - self.draggingNode = nil - - if shouldDismiss && !draggingNode.isMinimizeable { - draggingNode.dismiss() + let (updatedLocation, shouldDismiss) = self.nodeLocationForPosition(layout: validLayout, position: CGPoint(x: previousFrame.midX, y: previousFrame.midY), velocity: recognizer.velocity(in: self.view), size: nodeSize, tempExtendedTopInset: draggingNode.tempExtendedTopInset) + + if shouldDismiss && draggingNode.isMinimizeable { + draggingNode.updateMinimizedEdge(updatedLocation.x.isZero ? .left : .right, adjusting: false) + self.videoNodes[index].isMinimized = true + } else { + draggingNode.updateMinimizedEdge(nil, adjusting: true) + self.videoNodes[index].isMinimized = false + } + + if let group = draggingNode.group { + self.locationByGroup[group] = updatedLocation + } + self.videoNodes[index].location = updatedLocation + + draggingNode.frame = CGRect(origin: self.nodePosition(layout: validLayout, size: nodeSize, location: updatedLocation, hidden: !draggingNode.hasAttachedContext, isMinimized: self.videoNodes[index].isMinimized, tempExtendedTopInset: draggingNode.tempExtendedTopInset), size: nodeSize) + draggingNode.layer.animateFrame(from: previousFrame, to: draggingNode.frame, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) + self.draggingNode = nil + + if shouldDismiss && !draggingNode.isMinimizeable { + draggingNode.dismiss() + } } + self.updatePossibleEmbeddingItem(nil) } default: break diff --git a/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift b/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift index 25954ab938..2d7a00ba96 100644 --- a/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift +++ b/submodules/TelegramUI/Sources/OverlayPlayerControllerNode.swift @@ -98,7 +98,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu }, reactionContainerNode: { return nil }, presentGlobalOverlayController: { _, _ in - }, callPeer: { _ in + }, callPeer: { _, _ in }, longTap: { _, _ in }, openCheckoutOrReceipt: { _ in }, openSearch: { @@ -234,7 +234,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu openMessageImpl = { [weak self] id in if let strongSelf = self, strongSelf.isNodeLoaded, let message = strongSelf.historyNode.messageInCurrentHistoryView(id) { - return strongSelf.context.sharedContext.openChatMessage(OpenChatMessageParams(context: strongSelf.context, message: message, standalone: false, reverseMessageGalleryOrder: false, navigationController: nil, dismissInput: { }, present: { _, _ in }, transitionNode: { _, _ in return nil }, addToTransitionSurface: { _ in }, openUrl: { _ in }, openPeer: { _, _ in }, callPeer: { _ in }, enqueueMessage: { _ in }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in }, chatAvatarHiddenMedia: { _, _ in })) + return strongSelf.context.sharedContext.openChatMessage(OpenChatMessageParams(context: strongSelf.context, message: message, standalone: false, reverseMessageGalleryOrder: false, navigationController: nil, dismissInput: { }, present: { _, _ in }, transitionNode: { _, _ in return nil }, addToTransitionSurface: { _ in }, openUrl: { _ in }, openPeer: { _, _ in }, callPeer: { _, _ in }, enqueueMessage: { _ in }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in }, chatAvatarHiddenMedia: { _, _ in })) } return false } diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift index 4995d5039b..162499ccd8 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoData.swift @@ -704,7 +704,7 @@ func availableActionsForMemberOfPeer(accountPeerId: PeerId, peer: Peer, member: return result } -func peerInfoHeaderButtons(peer: Peer?, cachedData: CachedPeerData?, isOpenedFromChat: Bool) -> [PeerInfoHeaderButtonKey] { +func peerInfoHeaderButtons(peer: Peer?, cachedData: CachedPeerData?, isOpenedFromChat: Bool, videoCallsEnabled: Bool) -> [PeerInfoHeaderButtonKey] { var result: [PeerInfoHeaderButtonKey] = [] if let user = peer as? TelegramUser { if !isOpenedFromChat { @@ -719,6 +719,9 @@ func peerInfoHeaderButtons(peer: Peer?, cachedData: CachedPeerData?, isOpenedFro } if callsAvailable { result.append(.call) + if videoCallsEnabled { + result.append(.videoCall) + } } result.append(.mute) if isOpenedFromChat { diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift index b0fb0fda15..ed2b1e634c 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift @@ -21,6 +21,7 @@ enum PeerInfoHeaderButtonKey: Hashable { case message case discussion case call + case videoCall case mute case more case addMember @@ -31,6 +32,7 @@ enum PeerInfoHeaderButtonKey: Hashable { enum PeerInfoHeaderButtonIcon { case message case call + case videoCall case mute case unmute case more @@ -103,6 +105,8 @@ final class PeerInfoHeaderButtonNode: HighlightableButtonNode { imageName = "Peer Info/ButtonMessage" case .call: imageName = "Peer Info/ButtonCall" + case .videoCall: + imageName = "Peer Info/ButtonVideo" case .mute: imageName = "Peer Info/ButtonMute" case .unmute: @@ -116,7 +120,7 @@ final class PeerInfoHeaderButtonNode: HighlightableButtonNode { case .leave: imageName = "Peer Info/ButtonLeave" } - if let image = UIImage(bundleImageName: imageName) { + if let image = generateTintedImage(image: UIImage(bundleImageName: imageName), color: .white) { let imageRect = CGRect(origin: CGPoint(x: floor((size.width - image.size.width) / 2.0), y: floor((size.height - image.size.height) / 2.0)), size: image.size) context.clip(to: imageRect, mask: image.cgImage!) context.fill(imageRect) @@ -1657,6 +1661,7 @@ final class PeerInfoHeaderNode: ASDisplayNode { private var presentationData: PresentationData? private let isOpenedFromChat: Bool + private let videoCallsEnabled: Bool private(set) var isAvatarExpanded: Bool @@ -1689,6 +1694,7 @@ final class PeerInfoHeaderNode: ASDisplayNode { self.context = context self.isAvatarExpanded = avatarInitiallyExpanded self.isOpenedFromChat = isOpenedFromChat + self.videoCallsEnabled = context.sharedContext.immediateExperimentalUISettings.videoCalls self.avatarListNode = PeerInfoAvatarListNode(context: context, readyWhenGalleryLoads: avatarInitiallyExpanded) @@ -1875,7 +1881,7 @@ final class PeerInfoHeaderNode: ASDisplayNode { let expandedAvatarListHeight = min(width, containerHeight - expandedAvatarControlsHeight) let expandedAvatarListSize = CGSize(width: width, height: expandedAvatarListHeight) - let buttonKeys: [PeerInfoHeaderButtonKey] = peerInfoHeaderButtons(peer: peer, cachedData: cachedData, isOpenedFromChat: self.isOpenedFromChat) + let buttonKeys: [PeerInfoHeaderButtonKey] = peerInfoHeaderButtons(peer: peer, cachedData: cachedData, isOpenedFromChat: self.isOpenedFromChat, videoCallsEnabled: self.videoCallsEnabled) var isVerified = false let titleString: NSAttributedString @@ -2246,6 +2252,9 @@ final class PeerInfoHeaderNode: ASDisplayNode { case .call: buttonText = presentationData.strings.PeerInfo_ButtonCall buttonIcon = .call + case .videoCall: + buttonText = presentationData.strings.PeerInfo_ButtonVideoCall + buttonIcon = .videoCall case .mute: if let notificationSettings = notificationSettings, case .muted = notificationSettings.muteState { buttonText = presentationData.strings.PeerInfo_ButtonUnmute @@ -2279,14 +2288,14 @@ final class PeerInfoHeaderNode: ASDisplayNode { if buttonKeys.count > 3 { if self.isOpenedFromChat { switch buttonKey { - case .message, .search: + case .message, .search, .videoCall: hiddenWhileExpanded = true default: hiddenWhileExpanded = false } } else { switch buttonKey { - case .mute, .search: + case .mute, .search, .videoCall: hiddenWhileExpanded = true default: hiddenWhileExpanded = false diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift index 4b13e047b7..05a01f763d 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift @@ -395,7 +395,7 @@ final class PeerInfoSelectionPanelNode: ASDisplayNode { }, presentPeerContact: { }, dismissReportPeer: { }, deleteChat: { - }, beginCall: { + }, beginCall: { _ in }, toggleMessageStickerStarred: { _ in }, presentController: { _, _ in }, getNavigationController: { @@ -1035,6 +1035,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD private let context: AccountContext private let peerId: PeerId private let isOpenedFromChat: Bool + private let videoCallsEnabled: Bool private let callMessages: [Message] private let isMediaOnly: Bool @@ -1096,6 +1097,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self.context = context self.peerId = peerId self.isOpenedFromChat = isOpenedFromChat + self.videoCallsEnabled = context.sharedContext.immediateExperimentalUISettings.videoCalls self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.nearbyPeerDistance = nearbyPeerDistance self.callMessages = callMessages @@ -1529,7 +1531,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD return nil }, reactionContainerNode: { return nil - }, presentGlobalOverlayController: { _, _ in }, callPeer: { _ in + }, presentGlobalOverlayController: { _, _ in }, callPeer: { _, _ in }, longTap: { [weak self] content, _ in guard let strongSelf = self else { return @@ -2133,7 +2135,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self?.openUrl(url: url, concealed: false, external: false) }, openPeer: { [weak self] peer, navigation in self?.openPeer(peerId: peer.id, navigation: navigation) - }, callPeer: { peerId in + }, callPeer: { peerId, isVideo in //self?.controllerInteraction?.callPeer(peerId) }, enqueueMessage: { _ in }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in }, chatAvatarHiddenMedia: { _, _ in })) @@ -2213,7 +2215,9 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } } case .call: - self.requestCall() + self.requestCall(isVideo: false) + case .videoCall: + self.requestCall(isVideo: true) case .mute: if let notificationSettings = self.data?.notificationSettings, case .muted = notificationSettings.muteState { let _ = updatePeerMuteSetting(account: self.context.account, peerId: self.peerId, muteInterval: nil).start() @@ -2259,7 +2263,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD actionSheet?.dismissAnimated() } var items: [ActionSheetItem] = [] - if !peerInfoHeaderButtons(peer: peer, cachedData: data.cachedData, isOpenedFromChat: self.isOpenedFromChat).contains(.search) || self.headerNode.isAvatarExpanded { + if !peerInfoHeaderButtons(peer: peer, cachedData: data.cachedData, isOpenedFromChat: self.isOpenedFromChat, videoCallsEnabled: self.videoCallsEnabled).contains(.search) || self.headerNode.isAvatarExpanded { items.append(ActionSheetButtonItem(title: presentationData.strings.ChatSearch_SearchPlaceholder, color: .accent, action: { [weak self] in dismissAction() self?.openChatWithMessageSearch() @@ -2361,7 +2365,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self?.openDeletePeer() })) } else { - if !peerInfoHeaderButtons(peer: peer, cachedData: data.cachedData, isOpenedFromChat: self.isOpenedFromChat).contains(.leave) { + if !peerInfoHeaderButtons(peer: peer, cachedData: data.cachedData, isOpenedFromChat: self.isOpenedFromChat, videoCallsEnabled: self.videoCallsEnabled).contains(.leave) { if case .member = channel.participationStatus { items.append(ActionSheetButtonItem(title: presentationData.strings.Channel_LeaveChannel, color: .destructive, action: { [weak self] in dismissAction() @@ -2510,7 +2514,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self.controller?.present(shareController, in: .window(.root)) } - private func requestCall() { + private func requestCall(isVideo: Bool) { guard let peer = self.data?.peer as? TelegramUser, let cachedUserData = self.data?.cachedData as? CachedUserData else { return } @@ -2519,7 +2523,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD return } - let callResult = self.context.sharedContext.callManager?.requestCall(account: self.context.account, peerId: peer.id, endCurrentIfAny: false) + let callResult = self.context.sharedContext.callManager?.requestCall(account: self.context.account, peerId: peer.id, isVideo: isVideo, endCurrentIfAny: false) if let callResult = callResult, case let .alreadyInProgress(currentPeerId) = callResult { if currentPeerId == peer.id { self.context.sharedContext.navigateToCurrentCall() @@ -2536,7 +2540,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD guard let strongSelf = self else { return } - let _ = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peer.id, endCurrentIfAny: true) + let _ = strongSelf.context.sharedContext.callManager?.requestCall(account: strongSelf.context.account, peerId: peer.id, isVideo: isVideo, endCurrentIfAny: true) })]), in: .window(.root)) } }) @@ -2559,7 +2563,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD ActionSheetItemGroup(items: [ ActionSheetButtonItem(title: strongSelf.presentationData.strings.UserInfo_TelegramCall, action: { dismissAction() - self?.requestCall() + self?.requestCall(isVideo: false) }), ActionSheetButtonItem(title: strongSelf.presentationData.strings.UserInfo_PhoneCall, action: { dismissAction() diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift index da403a4763..ea4d753878 100644 --- a/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift +++ b/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift @@ -127,8 +127,8 @@ public class PeerMediaCollectionController: TelegramBaseController { self?.openUrl(url) }, openPeer: { peer, navigation in self?.controllerInteraction?.openPeer(peer.id, navigation, nil) - }, callPeer: { peerId in - self?.controllerInteraction?.callPeer(peerId) + }, callPeer: { peerId, isVideo in + self?.controllerInteraction?.callPeer(peerId, isVideo) }, enqueueMessage: { _ in }, sendSticker: nil, setupTemporaryHiddenMedia: { _, _, _ in }, chatAvatarHiddenMedia: { _, _ in })) } @@ -357,7 +357,7 @@ public class PeerMediaCollectionController: TelegramBaseController { return nil }, reactionContainerNode: { return nil - }, presentGlobalOverlayController: { _, _ in }, callPeer: { _ in + }, presentGlobalOverlayController: { _, _ in }, callPeer: { _, _ in }, longTap: { [weak self] content, _ in if let strongSelf = self { strongSelf.view.endEditing(true) @@ -530,7 +530,7 @@ public class PeerMediaCollectionController: TelegramBaseController { }, presentPeerContact: { }, dismissReportPeer: { }, deleteChat: { - }, beginCall: { + }, beginCall: { _ in }, toggleMessageStickerStarred: { _ in }, presentController: { _, _ in }, getNavigationController: { diff --git a/submodules/TelegramUI/Sources/SharedAccountContext.swift b/submodules/TelegramUI/Sources/SharedAccountContext.swift index adc6f03605..f7108af284 100644 --- a/submodules/TelegramUI/Sources/SharedAccountContext.swift +++ b/submodules/TelegramUI/Sources/SharedAccountContext.swift @@ -207,6 +207,43 @@ public final class SharedAccountContextImpl: SharedAccountContext { self.mediaManager = MediaManagerImpl(accountManager: accountManager, inForeground: applicationBindings.applicationInForeground, presentationData: presentationData) + self.mediaManager.overlayMediaManager.updatePossibleEmbeddingItem = { [weak self] item in + guard let strongSelf = self else { + return + } + guard let navigationController = strongSelf.mainWindow?.viewController as? NavigationController else { + return + } + var content: NavigationControllerDropContent? + if let item = item { + content = NavigationControllerDropContent( + position: item.position, + item: VideoNavigationControllerDropContentItem( + itemNode: item.itemNode + ) + ) + } + + navigationController.updatePossibleControllerDropContent(content: content) + } + + self.mediaManager.overlayMediaManager.embedPossibleEmbeddingItem = { [weak self] item in + guard let strongSelf = self else { + return false + } + guard let navigationController = strongSelf.mainWindow?.viewController as? NavigationController else { + return false + } + let content = NavigationControllerDropContent( + position: item.position, + item: VideoNavigationControllerDropContentItem( + itemNode: item.itemNode + ) + ) + + return navigationController.acceptPossibleControllerDropContent(content: content) + } + self._autodownloadSettings.set(.single(initialPresentationDataAndSettings.autodownloadSettings) |> then(accountManager.sharedData(keys: [SharedDataKeys.autodownloadSettings]) |> map { sharedData in @@ -537,7 +574,7 @@ public final class SharedAccountContextImpl: SharedAccountContext { }) if let mainWindow = mainWindow, applicationBindings.isMainApp { - let callManager = PresentationCallManagerImpl(accountManager: self.accountManager, getDeviceAccessData: { + let callManager = PresentationCallManagerImpl(accountManager: self.accountManager, enableVideoCalls: self.immediateExperimentalUISettings.videoCalls, getDeviceAccessData: { return (self.currentPresentationData.with { $0 }, { [weak self] c, a in self?.presentGlobalController(c, a) }, { @@ -1120,7 +1157,7 @@ public final class SharedAccountContextImpl: SharedAccountContext { return nil }, reactionContainerNode: { return nil - }, presentGlobalOverlayController: { _, _ in }, callPeer: { _ in }, longTap: { _, _ in }, openCheckoutOrReceipt: { _ in }, openSearch: { }, setupReply: { _ in + }, presentGlobalOverlayController: { _, _ in }, callPeer: { _, _ in }, longTap: { _, _ in }, openCheckoutOrReceipt: { _ in }, openSearch: { }, setupReply: { _ in }, canSetupReply: { _ in return .none }, navigateToFirstDateMessage: { _ in diff --git a/submodules/TelegramUniversalVideoContent/Sources/OverlayUniversalVideoNode.swift b/submodules/TelegramUniversalVideoContent/Sources/OverlayUniversalVideoNode.swift index 38a13e0eac..6265ef0b31 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/OverlayUniversalVideoNode.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/OverlayUniversalVideoNode.swift @@ -10,7 +10,7 @@ import TelegramAudio import AccountContext public final class OverlayUniversalVideoNode: OverlayMediaItemNode { - private let content: UniversalVideoContent + public let content: UniversalVideoContent private let videoNode: UniversalVideoNode private let decoration: OverlayVideoDecoration @@ -30,8 +30,16 @@ public final class OverlayUniversalVideoNode: OverlayMediaItemNode { } } + private let defaultExpand: () -> Void + public var customExpand: (() -> Void)? + public var customClose: (() -> Void)? + public init(postbox: Postbox, audioSession: ManagedAudioSession, manager: UniversalVideoManager, content: UniversalVideoContent, expand: @escaping () -> Void, close: @escaping () -> Void) { self.content = content + self.defaultExpand = expand + + var expandImpl: (() -> Void)? + var unminimizeImpl: (() -> Void)? var togglePlayPauseImpl: (() -> Void)? var closeImpl: (() -> Void)? @@ -40,7 +48,7 @@ public final class OverlayUniversalVideoNode: OverlayMediaItemNode { }, togglePlayPause: { togglePlayPauseImpl?() }, expand: { - expand() + expandImpl?() }, close: { closeImpl?() }) @@ -49,6 +57,17 @@ public final class OverlayUniversalVideoNode: OverlayMediaItemNode { super.init() + expandImpl = { [weak self] in + guard let strongSelf = self else { + return + } + if let customExpand = strongSelf.customExpand { + customExpand() + } else { + strongSelf.defaultExpand() + } + } + unminimizeImpl = { [weak self] in self?.unminimize?() } @@ -57,6 +76,10 @@ public final class OverlayUniversalVideoNode: OverlayMediaItemNode { } closeImpl = { [weak self] in if let strongSelf = self { + if let customClose = strongSelf.customClose { + customClose() + return + } if strongSelf.videoNode.hasAttachedContext { strongSelf.videoNode.continuePlayingWithoutSound() } @@ -104,18 +127,32 @@ public final class OverlayUniversalVideoNode: OverlayMediaItemNode { override public func updateLayout(_ size: CGSize) { if size != self.validLayoutSize { - self.updateLayoutImpl(size) + self.updateLayoutImpl(size, transition: .immediate) } } - private func updateLayoutImpl(_ size: CGSize) { + public func updateLayout(_ size: CGSize, transition: ContainedViewLayoutTransition) { + if size != self.validLayoutSize { + self.updateLayoutImpl(size, transition: transition) + } + } + + private func updateLayoutImpl(_ size: CGSize, transition: ContainedViewLayoutTransition) { self.validLayoutSize = size - self.videoNode.frame = CGRect(origin: CGPoint(), size: size) - self.videoNode.updateLayout(size: size, transition: .immediate) + transition.updateFrame(node: self.videoNode, frame: CGRect(origin: CGPoint(), size: size)) + self.videoNode.updateLayout(size: size, transition: transition) } override public func updateMinimizedEdge(_ edge: OverlayMediaItemMinimizationEdge?, adjusting: Bool) { self.decoration.updateMinimizedEdge(edge, adjusting: adjusting) } + + public func updateRoundCorners(_ value: Bool, transition: ContainedViewLayoutTransition) { + transition.updateCornerRadius(node: self, cornerRadius: value ? 4.0 : 0.0) + } + + public func showControls() { + self.decoration.showControls() + } } diff --git a/submodules/TelegramUniversalVideoContent/Sources/OverlayVideoDecoration.swift b/submodules/TelegramUniversalVideoContent/Sources/OverlayVideoDecoration.swift index 4ec927ab21..eb6ed63083 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/OverlayVideoDecoration.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/OverlayVideoDecoration.swift @@ -148,6 +148,13 @@ final class OverlayVideoDecoration: UniversalVideoDecoration { } } + func showControls() { + if self.controlsNode.alpha.isZero { + self.controlsNode.alpha = 1.0 + self.controlsNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3) + } + } + func setStatus(_ status: Signal) { self.controlsNode.status = status |> map { value -> MediaPlayerStatus in if let value = value { diff --git a/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift b/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift index 96677f2472..bf291fa07e 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift @@ -109,12 +109,12 @@ final class PictureInPictureVideoControlsNode: ASDisplayNode { let buttonSize = TGEmbedPIPButtonSize - self.leaveButton.frame = CGRect(origin: CGPoint(x: forth - floor(buttonSize.width / 2.0) - 10.0, y: size.height - buttonSize.height - 15.0), size: buttonSize) + transition.updateFrame(view: self.leaveButton, frame: CGRect(origin: CGPoint(x: forth - floor(buttonSize.width / 2.0) - 10.0, y: size.height - buttonSize.height - 15.0), size: buttonSize)) - self.pauseButton.frame = CGRect(origin: CGPoint(x: floor((size.width - buttonSize.width) / 2.0), y: size.height - buttonSize.height - 15.0), size: buttonSize) - self.playButton.frame = CGRect(origin: CGPoint(x: floor((size.width - buttonSize.width) / 2.0), y: size.height - buttonSize.height - 15.0), size: buttonSize) + transition.updateFrame(view: self.pauseButton, frame: CGRect(origin: CGPoint(x: floor((size.width - buttonSize.width) / 2.0), y: size.height - buttonSize.height - 15.0), size: buttonSize)) + transition.updateFrame(view: self.playButton, frame: CGRect(origin: CGPoint(x: floor((size.width - buttonSize.width) / 2.0), y: size.height - buttonSize.height - 15.0), size: buttonSize)) - self.closeButton.frame = CGRect(origin: CGPoint(x: self.playButton.frame.origin.x + forth + 10.0, y: size.height - buttonSize.height - 15.0), size: buttonSize) + transition.updateFrame(view: self.closeButton, frame: CGRect(origin: CGPoint(x: self.playButton.frame.origin.x + forth + 10.0, y: size.height - buttonSize.height - 15.0), size: buttonSize)) } @objc func leavePressed() { diff --git a/submodules/TelegramVoip/Sources/OngoingCallContext.swift b/submodules/TelegramVoip/Sources/OngoingCallContext.swift index c4b9041c7d..5f9834ebb7 100644 --- a/submodules/TelegramVoip/Sources/OngoingCallContext.swift +++ b/submodules/TelegramVoip/Sources/OngoingCallContext.swift @@ -100,13 +100,22 @@ public struct OngoingCallContextState: Equatable { case reconnecting case failed } + public enum VideoState: Equatable { case notAvailable case available(Bool) case active + case activeOutgoing } + + public enum RemoteVideoState: Equatable { + case inactive + case active + } + public let state: State public let videoState: VideoState + public let remoteVideoState: RemoteVideoState } private final class OngoingCallThreadLocalContextQueueImpl: NSObject, OngoingCallThreadLocalContextQueue, OngoingCallThreadLocalContextQueueWebrtc /*, OngoingCallThreadLocalContextQueueWebrtcCustom*/ { @@ -395,6 +404,27 @@ private extension OngoingCallContextState.State { }*/ public final class OngoingCallContext { + public struct AuxiliaryServer { + public enum Connection { + case stun + case turn(username: String, password: String) + } + + public let host: String + public let port: Int + public let connection: Connection + + public init( + host: String, + port: Int, + connection: Connection + ) { + self.host = host + self.port = port + self.connection = connection + } + } + public let internalId: CallSessionInternalId private let queue = Queue() @@ -433,7 +463,7 @@ public final class OngoingCallContext { return result } - public init(account: Account, callSessionManager: CallSessionManager, internalId: CallSessionInternalId, proxyServer: ProxyServerSettings?, initialNetworkType: NetworkType, updatedNetworkType: Signal, serializedData: String?, dataSaving: VoiceCallDataSaving, derivedState: VoipDerivedState, key: Data, isOutgoing: Bool, connections: CallSessionConnectionSet, maxLayer: Int32, version: String, allowP2P: Bool, audioSessionActive: Signal, logName: String) { + public init(account: Account, callSessionManager: CallSessionManager, internalId: CallSessionInternalId, proxyServer: ProxyServerSettings?, auxiliaryServers: [AuxiliaryServer], initialNetworkType: NetworkType, updatedNetworkType: Signal, serializedData: String?, dataSaving: VoiceCallDataSaving, derivedState: VoipDerivedState, key: Data, isOutgoing: Bool, isVideo: Bool, connections: CallSessionConnectionSet, maxLayer: Int32, version: String, allowP2P: Bool, audioSessionActive: Signal, logName: String) { let _ = setupLogs OngoingCallThreadLocalContext.applyServerConfig(serializedData) //OngoingCallThreadLocalContextWebrtc.applyServerConfig(serializedData) @@ -491,12 +521,33 @@ public final class OngoingCallContext { break } } - let context = OngoingCallThreadLocalContextWebrtc(queue: OngoingCallThreadLocalContextQueueImpl(queue: queue), proxy: voipProxyServer, networkType: ongoingNetworkTypeForTypeWebrtc(initialNetworkType), dataSaving: ongoingDataSavingForTypeWebrtc(dataSaving), derivedState: derivedState.data, key: key, isOutgoing: isOutgoing, primaryConnection: callConnectionDescriptionWebrtc(connections.primary), alternativeConnections: connections.alternatives.map(callConnectionDescriptionWebrtc), maxLayer: maxLayer, allowP2P: allowP2P, logPath: logPath, sendSignalingData: { [weak callSessionManager] data in + var rtcServers: [VoipRtcServerWebrtc] = [] + for server in auxiliaryServers { + switch server.connection { + case .stun: + rtcServers.append(VoipRtcServerWebrtc( + host: server.host, + port: Int32(clamping: server.port), + username: "", + password: "", + isTurn: false + )) + case let .turn(username, password): + rtcServers.append(VoipRtcServerWebrtc( + host: server.host, + port: Int32(clamping: server.port), + username: username, + password: password, + isTurn: true + )) + } + } + let context = OngoingCallThreadLocalContextWebrtc(queue: OngoingCallThreadLocalContextQueueImpl(queue: queue), proxy: voipProxyServer, rtcServers: rtcServers, networkType: ongoingNetworkTypeForTypeWebrtc(initialNetworkType), dataSaving: ongoingDataSavingForTypeWebrtc(dataSaving), derivedState: derivedState.data, key: key, isOutgoing: isOutgoing, isVideo: isVideo, primaryConnection: callConnectionDescriptionWebrtc(connections.primary), alternativeConnections: connections.alternatives.map(callConnectionDescriptionWebrtc), maxLayer: maxLayer, allowP2P: allowP2P, logPath: logPath, sendSignalingData: { [weak callSessionManager] data in callSessionManager?.sendSignalingData(internalId: internalId, data: data) }) strongSelf.contextRef = Unmanaged.passRetained(OngoingCallThreadLocalContextHolder(context)) - context.stateChanged = { state, videoState in + context.stateChanged = { state, videoState, remoteVideoState in queue.async { guard let strongSelf = self else { return @@ -508,12 +559,21 @@ public final class OngoingCallContext { mappedVideoState = .available(true) case .active: mappedVideoState = .active - case .invited, .requesting: - mappedVideoState = .available(false) + case .activeOutgoing: + mappedVideoState = .activeOutgoing @unknown default: mappedVideoState = .available(false) } - strongSelf.contextState.set(.single(OngoingCallContextState(state: mappedState, videoState: mappedVideoState))) + let mappedRemoteVideoState: OngoingCallContextState.RemoteVideoState + switch remoteVideoState { + case .inactive: + mappedRemoteVideoState = .inactive + case .active: + mappedRemoteVideoState = .active + @unknown default: + mappedRemoteVideoState = .inactive + } + strongSelf.contextState.set(.single(OngoingCallContextState(state: mappedState, videoState: mappedVideoState, remoteVideoState: mappedRemoteVideoState))) } } context.signalBarsChanged = { signalBars in @@ -540,7 +600,7 @@ public final class OngoingCallContext { strongSelf.contextRef = Unmanaged.passRetained(OngoingCallThreadLocalContextHolder(context)) context.stateChanged = { state in - self?.contextState.set(.single(OngoingCallContextState(state: OngoingCallContextState.State(state), videoState: .notAvailable))) + self?.contextState.set(.single(OngoingCallContextState(state: OngoingCallContextState.State(state), videoState: .notAvailable, remoteVideoState: .inactive))) } context.signalBarsChanged = { signalBars in self?.receptionPromise.set(.single(signalBars)) diff --git a/submodules/TgVoipWebrtc/Impl/CodecsApple.h b/submodules/TgVoipWebrtc/Impl/CodecsApple.h index 960ef42736..442df44018 100644 --- a/submodules/TgVoipWebrtc/Impl/CodecsApple.h +++ b/submodules/TgVoipWebrtc/Impl/CodecsApple.h @@ -20,7 +20,7 @@ std::unique_ptr makeVideoEncoderFactory(); std::unique_ptr makeVideoDecoderFactory(); bool supportsH265Encoding(); rtc::scoped_refptr makeVideoSource(rtc::Thread *signalingThread, rtc::Thread *workerThread); -std::unique_ptr makeVideoCapturer(rtc::scoped_refptr source, bool useFrontCamera); +std::unique_ptr makeVideoCapturer(rtc::scoped_refptr source, bool useFrontCamera, std::function isActiveUpdated); #ifdef TGVOIP_NAMESPACE } diff --git a/submodules/TgVoipWebrtc/Impl/CodecsApple.mm b/submodules/TgVoipWebrtc/Impl/CodecsApple.mm index e45d0e077f..71e4d06a24 100644 --- a/submodules/TgVoipWebrtc/Impl/CodecsApple.mm +++ b/submodules/TgVoipWebrtc/Impl/CodecsApple.mm @@ -40,12 +40,12 @@ @implementation VideoCapturerInterfaceImplReference -- (instancetype)initWithSource:(rtc::scoped_refptr)source useFrontCamera:(bool)useFrontCamera { +- (instancetype)initWithSource:(rtc::scoped_refptr)source useFrontCamera:(bool)useFrontCamera isActiveUpdated:(void (^)(bool))isActiveUpdated { self = [super init]; if (self != nil) { assert([NSThread isMainThread]); - _videoCapturer = [[VideoCameraCapturer alloc] initWithSource:source]; + _videoCapturer = [[VideoCameraCapturer alloc] initWithSource:source isActiveUpdated:isActiveUpdated]; AVCaptureDevice *frontCamera = nil; AVCaptureDevice *backCamera = nil; @@ -130,12 +130,14 @@ namespace TGVOIP_NAMESPACE { class VideoCapturerInterfaceImpl: public VideoCapturerInterface { public: - VideoCapturerInterfaceImpl(rtc::scoped_refptr source, bool useFrontCamera) : + VideoCapturerInterfaceImpl(rtc::scoped_refptr source, bool useFrontCamera, std::function isActiveUpdated) : _source(source) { _implReference = [[VideoCapturerInterfaceImplHolder alloc] init]; VideoCapturerInterfaceImplHolder *implReference = _implReference; dispatch_async(dispatch_get_main_queue(), ^{ - VideoCapturerInterfaceImplReference *value = [[VideoCapturerInterfaceImplReference alloc] initWithSource:source useFrontCamera:useFrontCamera]; + VideoCapturerInterfaceImplReference *value = [[VideoCapturerInterfaceImplReference alloc] initWithSource:source useFrontCamera:useFrontCamera isActiveUpdated:^(bool isActive) { + isActiveUpdated(isActive); + }]; if (value != nil) { implReference.reference = (void *)CFBridgingRetain(value); } @@ -185,8 +187,8 @@ rtc::scoped_refptr makeVideoSource(rtc::Threa return webrtc::VideoTrackSourceProxy::Create(signalingThread, workerThread, objCVideoTrackSource); } -std::unique_ptr makeVideoCapturer(rtc::scoped_refptr source, bool useFrontCamera) { - return std::make_unique(source, useFrontCamera); +std::unique_ptr makeVideoCapturer(rtc::scoped_refptr source, bool useFrontCamera, std::function isActiveUpdated) { + return std::make_unique(source, useFrontCamera, isActiveUpdated); } #ifdef TGVOIP_NAMESPACE diff --git a/submodules/TgVoipWebrtc/Impl/Manager.cpp b/submodules/TgVoipWebrtc/Impl/Manager.cpp index 19ce0f977c..6ffced3943 100644 --- a/submodules/TgVoipWebrtc/Impl/Manager.cpp +++ b/submodules/TgVoipWebrtc/Impl/Manager.cpp @@ -36,15 +36,21 @@ Manager::Manager( rtc::Thread *thread, TgVoipEncryptionKey encryptionKey, bool enableP2P, + std::vector const &rtcServers, + bool isVideo, std::function stateUpdated, std::function videoStateUpdated, + std::function remoteVideoIsActiveUpdated, std::function &)> signalingDataEmitted ) : _thread(thread), _encryptionKey(encryptionKey), _enableP2P(enableP2P), +_rtcServers(rtcServers), +_startWithVideo(isVideo), _stateUpdated(stateUpdated), _videoStateUpdated(videoStateUpdated), +_remoteVideoIsActiveUpdated(remoteVideoIsActiveUpdated), _signalingDataEmitted(signalingDataEmitted), _isVideoRequested(false) { assert(_thread->IsCurrent()); @@ -56,11 +62,12 @@ Manager::~Manager() { void Manager::start() { auto weakThis = std::weak_ptr(shared_from_this()); - _networkManager.reset(new ThreadLocalObject(getNetworkThread(), [encryptionKey = _encryptionKey, enableP2P = _enableP2P, thread = _thread, weakThis, signalingDataEmitted = _signalingDataEmitted]() { + _networkManager.reset(new ThreadLocalObject(getNetworkThread(), [encryptionKey = _encryptionKey, enableP2P = _enableP2P, rtcServers = _rtcServers, thread = _thread, weakThis, signalingDataEmitted = _signalingDataEmitted]() { return new NetworkManager( getNetworkThread(), encryptionKey, enableP2P, + rtcServers, [thread, weakThis](const NetworkManager::State &state) { thread->PostTask(RTC_FROM_HERE, [weakThis, state]() { auto strongThis = weakThis.lock(); @@ -104,10 +111,11 @@ void Manager::start() { ); })); bool isOutgoing = _encryptionKey.isOutgoing; - _mediaManager.reset(new ThreadLocalObject(getMediaThread(), [isOutgoing, thread = _thread, weakThis]() { + _mediaManager.reset(new ThreadLocalObject(getMediaThread(), [isOutgoing, thread = _thread, startWithVideo = _startWithVideo, weakThis]() { return new MediaManager( getMediaThread(), isOutgoing, + startWithVideo, [thread, weakThis](const rtc::CopyOnWriteBuffer &packet) { thread->PostTask(RTC_FROM_HERE, [weakThis, packet]() { auto strongThis = weakThis.lock(); @@ -118,6 +126,15 @@ void Manager::start() { networkManager->sendPacket(packet); }); }); + }, + [thread, weakThis](bool isActive) { + thread->PostTask(RTC_FROM_HERE, [weakThis, isActive]() { + auto strongThis = weakThis.lock(); + if (strongThis == nullptr) { + return; + } + strongThis->notifyIsLocalVideoActive(isActive); + }); } ); })); @@ -148,6 +165,11 @@ void Manager::receiveSignalingData(const std::vector &data) { _networkManager->perform([candidatesData](NetworkManager *networkManager) { networkManager->receiveSignalingData(candidatesData); }); + } else if (mode == 4) { + uint8_t value = 0; + if (reader.ReadUInt8(&value)) { + _remoteVideoIsActiveUpdated(value != 0); + } } } @@ -159,6 +181,7 @@ void Manager::setSendVideo(bool sendVideo) { rtc::CopyOnWriteBuffer buffer; uint8_t mode = 1; buffer.AppendData(&mode, 1); + std::vector data; data.resize(buffer.size()); memcpy(data.data(), buffer.data(), buffer.size()); @@ -174,12 +197,31 @@ void Manager::setSendVideo(bool sendVideo) { } } +void Manager::setMuteOutgoingAudio(bool mute) { + _mediaManager->perform([mute](MediaManager *mediaManager) { + mediaManager->setMuteOutgoingAudio(mute); + }); +} + void Manager::switchVideoCamera() { _mediaManager->perform([](MediaManager *mediaManager) { mediaManager->switchVideoCamera(); }); } +void Manager::notifyIsLocalVideoActive(bool isActive) { + rtc::CopyOnWriteBuffer buffer; + uint8_t mode = 4; + buffer.AppendData(&mode, 1); + uint8_t value = isActive ? 1 : 0; + buffer.AppendData(&value, 1); + + std::vector data; + data.resize(buffer.size()); + memcpy(data.data(), buffer.data(), buffer.size()); + _signalingDataEmitted(data); +} + void Manager::setIncomingVideoOutput(std::shared_ptr> sink) { _mediaManager->perform([sink](MediaManager *mediaManager) { mediaManager->setIncomingVideoOutput(sink); diff --git a/submodules/TgVoipWebrtc/Impl/Manager.h b/submodules/TgVoipWebrtc/Impl/Manager.h index d9dcc41d55..79e8583937 100644 --- a/submodules/TgVoipWebrtc/Impl/Manager.h +++ b/submodules/TgVoipWebrtc/Impl/Manager.h @@ -16,8 +16,11 @@ public: rtc::Thread *thread, TgVoipEncryptionKey encryptionKey, bool enableP2P, + std::vector const &rtcServers, + bool isVideo, std::function stateUpdated, std::function videoStateUpdated, + std::function remoteVideoIsActiveUpdated, std::function &)> signalingDataEmitted ); ~Manager(); @@ -25,7 +28,9 @@ public: void start(); void receiveSignalingData(const std::vector &data); void setSendVideo(bool sendVideo); + void setMuteOutgoingAudio(bool mute); void switchVideoCamera(); + void notifyIsLocalVideoActive(bool isActive); void setIncomingVideoOutput(std::shared_ptr> sink); void setOutgoingVideoOutput(std::shared_ptr> sink); @@ -33,8 +38,11 @@ private: rtc::Thread *_thread; TgVoipEncryptionKey _encryptionKey; bool _enableP2P; + std::vector _rtcServers; + bool _startWithVideo; std::function _stateUpdated; std::function _videoStateUpdated; + std::function _remoteVideoIsActiveUpdated; std::function &)> _signalingDataEmitted; std::unique_ptr> _networkManager; std::unique_ptr> _mediaManager; diff --git a/submodules/TgVoipWebrtc/Impl/MediaManager.cpp b/submodules/TgVoipWebrtc/Impl/MediaManager.cpp index 91c4363191..b1e22eb78f 100644 --- a/submodules/TgVoipWebrtc/Impl/MediaManager.cpp +++ b/submodules/TgVoipWebrtc/Impl/MediaManager.cpp @@ -172,9 +172,12 @@ static rtc::Thread *getWorkerThread() { MediaManager::MediaManager( rtc::Thread *thread, bool isOutgoing, - std::function packetEmitted + bool startWithVideo, + std::function packetEmitted, + std::function localVideoCaptureActiveUpdated ) : _packetEmitted(packetEmitted), +_localVideoCaptureActiveUpdated(localVideoCaptureActiveUpdated), _thread(thread), _eventLog(std::make_unique()), _taskQueueFactory(webrtc::CreateDefaultTaskQueueFactory()) { @@ -190,6 +193,7 @@ _taskQueueFactory(webrtc::CreateDefaultTaskQueueFactory()) { _enableFlexfec = true; _isConnected = false; + _muteOutgoingAudio = false; auto videoEncoderFactory = makeVideoEncoderFactory(); _videoCodecs = AssignPayloadTypesAndDefaultCodecs(videoEncoderFactory->GetSupportedFormats()); @@ -280,6 +284,10 @@ _taskQueueFactory(webrtc::CreateDefaultTaskQueueFactory()) { _videoChannel->SetInterface(_videoNetworkInterface.get(), webrtc::MediaTransportConfig()); _nativeVideoSource = makeVideoSource(_thread, getWorkerThread()); + + if (startWithVideo) { + setSendVideo(true); + } } MediaManager::~MediaManager() { @@ -318,7 +326,7 @@ void MediaManager::setIsConnected(bool isConnected) { if (_audioChannel) { _audioChannel->OnReadyToSend(_isConnected); _audioChannel->SetSend(_isConnected); - _audioChannel->SetAudioSend(_ssrcAudio.outgoing, _isConnected, nullptr, &_audioSource); + _audioChannel->SetAudioSend(_ssrcAudio.outgoing, _isConnected && !_muteOutgoingAudio, nullptr, &_audioSource); } if (_isSendingVideo && _videoChannel) { _videoChannel->OnReadyToSend(_isConnected); @@ -364,7 +372,9 @@ void MediaManager::setSendVideo(bool sendVideo) { codec.SetParam(cricket::kCodecParamStartBitrate, 512); codec.SetParam(cricket::kCodecParamMaxBitrate, 2500); - _videoCapturer = makeVideoCapturer(_nativeVideoSource, _useFrontCamera); + _videoCapturer = makeVideoCapturer(_nativeVideoSource, _useFrontCamera, [localVideoCaptureActiveUpdated = _localVideoCaptureActiveUpdated](bool isActive) { + localVideoCaptureActiveUpdated(isActive); + }); cricket::VideoSendParameters videoSendParameters; videoSendParameters.codecs.push_back(codec); @@ -450,10 +460,18 @@ void MediaManager::setSendVideo(bool sendVideo) { } } +void MediaManager::setMuteOutgoingAudio(bool mute) { + _muteOutgoingAudio = mute; + + _audioChannel->SetAudioSend(_ssrcAudio.outgoing, _isConnected && !_muteOutgoingAudio, nullptr, &_audioSource); +} + void MediaManager::switchVideoCamera() { if (_isSendingVideo) { _useFrontCamera = !_useFrontCamera; - _videoCapturer = makeVideoCapturer(_nativeVideoSource, _useFrontCamera); + _videoCapturer = makeVideoCapturer(_nativeVideoSource, _useFrontCamera, [localVideoCaptureActiveUpdated = _localVideoCaptureActiveUpdated](bool isActive) { + localVideoCaptureActiveUpdated(isActive); + }); } } diff --git a/submodules/TgVoipWebrtc/Impl/MediaManager.h b/submodules/TgVoipWebrtc/Impl/MediaManager.h index 470fc7e835..5e49c94ff4 100644 --- a/submodules/TgVoipWebrtc/Impl/MediaManager.h +++ b/submodules/TgVoipWebrtc/Impl/MediaManager.h @@ -57,7 +57,9 @@ public: MediaManager( rtc::Thread *thread, bool isOutgoing, - std::function packetEmitted + bool startWithVideo, + std::function packetEmitted, + std::function localVideoCaptureActiveUpdated ); ~MediaManager(); @@ -65,12 +67,14 @@ public: void receivePacket(const rtc::CopyOnWriteBuffer &packet); void notifyPacketSent(const rtc::SentPacket &sentPacket); void setSendVideo(bool sendVideo); + void setMuteOutgoingAudio(bool mute); void switchVideoCamera(); void setIncomingVideoOutput(std::shared_ptr> sink); void setOutgoingVideoOutput(std::shared_ptr> sink); protected: std::function _packetEmitted; + std::function _localVideoCaptureActiveUpdated; private: rtc::Thread *_thread; @@ -82,6 +86,7 @@ private: bool _enableFlexfec; bool _isConnected; + bool _muteOutgoingAudio; std::vector _videoCodecs; bool _isSendingVideo; diff --git a/submodules/TgVoipWebrtc/Impl/NetworkManager.cpp b/submodules/TgVoipWebrtc/Impl/NetworkManager.cpp index ba46d5e005..202785bf51 100644 --- a/submodules/TgVoipWebrtc/Impl/NetworkManager.cpp +++ b/submodules/TgVoipWebrtc/Impl/NetworkManager.cpp @@ -154,6 +154,7 @@ NetworkManager::NetworkManager( rtc::Thread *thread, TgVoipEncryptionKey encryptionKey, bool enableP2P, + std::vector const &rtcServers, std::function stateUpdated, std::function packetReceived, std::function &)> signalingDataEmitted @@ -178,16 +179,35 @@ _signalingDataEmitted(signalingDataEmitted) { _portAllocator->set_flags(_portAllocator->flags() | flags); _portAllocator->Initialize(); - rtc::SocketAddress defaultStunAddress = rtc::SocketAddress("134.122.52.178", 3478); cricket::ServerAddresses stunServers; - stunServers.insert(defaultStunAddress); std::vector turnServers; - turnServers.push_back(cricket::RelayServerConfig( - rtc::SocketAddress("134.122.52.178", 3478), - "openrelay", - "openrelay", - cricket::PROTO_UDP - )); + + if (rtcServers.size() == 0) { + rtc::SocketAddress defaultStunAddress = rtc::SocketAddress("134.122.52.178", 3478); + stunServers.insert(defaultStunAddress); + + turnServers.push_back(cricket::RelayServerConfig( + rtc::SocketAddress("134.122.52.178", 3478), + "openrelay", + "openrelay", + cricket::PROTO_UDP + )); + } else { + for (auto &server : rtcServers) { + if (server.isTurn) { + turnServers.push_back(cricket::RelayServerConfig( + rtc::SocketAddress(server.host, server.port), + server.login, + server.password, + cricket::PROTO_UDP + )); + } else { + rtc::SocketAddress stunAddress = rtc::SocketAddress(server.host, server.port); + stunServers.insert(stunAddress); + } + } + } + _portAllocator->SetConfiguration(stunServers, turnServers, 2, webrtc::NO_PRUNE); _asyncResolverFactory = std::make_unique(); diff --git a/submodules/TgVoipWebrtc/Impl/NetworkManager.h b/submodules/TgVoipWebrtc/Impl/NetworkManager.h index 3d17b92624..47e2b84393 100644 --- a/submodules/TgVoipWebrtc/Impl/NetworkManager.h +++ b/submodules/TgVoipWebrtc/Impl/NetworkManager.h @@ -41,6 +41,7 @@ public: rtc::Thread *thread, TgVoipEncryptionKey encryptionKey, bool enableP2P, + std::vector const &rtcServers, std::function stateUpdated, std::function packetReceived, std::function &)> signalingDataEmitted diff --git a/submodules/TgVoipWebrtc/Impl/TgVoip.h b/submodules/TgVoipWebrtc/Impl/TgVoip.h index b134ebd3bc..c3be58baf5 100644 --- a/submodules/TgVoipWebrtc/Impl/TgVoip.h +++ b/submodules/TgVoipWebrtc/Impl/TgVoip.h @@ -26,6 +26,14 @@ struct TgVoipProxy { std::string password; }; +struct TgVoipRtcServer { + std::string host; + uint16_t port; + std::string login; + std::string password; + bool isTurn; +}; + enum class TgVoipEndpointType { Inet, Lan, @@ -135,10 +143,13 @@ public: TgVoipPersistentState const &persistentState, std::vector const &endpoints, std::unique_ptr const &proxy, + std::vector const &rtcServers, TgVoipNetworkType initialNetworkType, TgVoipEncryptionKey const &encryptionKey, + bool isVideo, std::function stateUpdated, std::function videoStateUpdated, + std::function remoteVideoIsActiveUpdated, std::function &)> signalingDataEmitted ); diff --git a/submodules/TgVoipWebrtc/Impl/TgVoip.mm b/submodules/TgVoipWebrtc/Impl/TgVoip.mm index 5adaa6173a..905f997955 100644 --- a/submodules/TgVoipWebrtc/Impl/TgVoip.mm +++ b/submodules/TgVoipWebrtc/Impl/TgVoip.mm @@ -139,11 +139,14 @@ public: std::vector const &endpoints, TgVoipPersistentState const &persistentState, std::unique_ptr const &proxy, + std::vector const &rtcServers, TgVoipConfig const &config, TgVoipEncryptionKey const &encryptionKey, + bool isVideo, TgVoipNetworkType initialNetworkType, std::function stateUpdated, std::function videoStateUpdated, + std::function remoteVideoIsActiveUpdated, std::function &)> signalingDataEmitted ) : _stateUpdated(stateUpdated), @@ -157,17 +160,22 @@ public: bool enableP2P = config.enableP2P; - _manager.reset(new ThreadLocalObject(getManagerThread(), [encryptionKey = encryptionKey, enableP2P = enableP2P, stateUpdated, videoStateUpdated, signalingDataEmitted](){ + _manager.reset(new ThreadLocalObject(getManagerThread(), [encryptionKey = encryptionKey, enableP2P = enableP2P, isVideo, stateUpdated, videoStateUpdated, remoteVideoIsActiveUpdated, signalingDataEmitted, rtcServers](){ return new Manager( getManagerThread(), encryptionKey, enableP2P, + rtcServers, + isVideo, [stateUpdated](const TgVoipState &state) { stateUpdated(state); }, [videoStateUpdated](bool isActive) { videoStateUpdated(isActive); }, + [remoteVideoIsActiveUpdated](bool isActive) { + remoteVideoIsActiveUpdated(isActive); + }, [signalingDataEmitted](const std::vector &data) { signalingDataEmitted(data); } @@ -249,7 +257,9 @@ public: } void setMuteMicrophone(bool muteMicrophone) override { - //controller_->SetMute(muteMicrophone); + _manager->perform([muteMicrophone](Manager *manager) { + manager->setMuteOutgoingAudio(muteMicrophone); + }); } void setIncomingVideoOutput(std::shared_ptr> sink) override { @@ -374,21 +384,27 @@ TgVoip *TgVoip::makeInstance( TgVoipPersistentState const &persistentState, std::vector const &endpoints, std::unique_ptr const &proxy, + std::vector const &rtcServers, TgVoipNetworkType initialNetworkType, TgVoipEncryptionKey const &encryptionKey, + bool isVideo, std::function stateUpdated, std::function videoStateUpdated, + std::function remoteVideoIsActiveUpdated, std::function &)> signalingDataEmitted ) { return new TgVoipImpl( endpoints, persistentState, proxy, + rtcServers, config, encryptionKey, + isVideo, initialNetworkType, stateUpdated, videoStateUpdated, + remoteVideoIsActiveUpdated, signalingDataEmitted ); } diff --git a/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.h b/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.h index a19023032d..5c8c24e9c2 100644 --- a/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.h +++ b/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.h @@ -13,7 +13,7 @@ + (NSArray *)captureDevices; + (NSArray *)supportedFormatsForDevice:(AVCaptureDevice *)device; -- (instancetype)initWithSource:(rtc::scoped_refptr)source; +- (instancetype)initWithSource:(rtc::scoped_refptr)source isActiveUpdated:(void (^)(bool))isActiveUpdated; - (void)startCaptureWithDevice:(AVCaptureDevice *)device format:(AVCaptureDeviceFormat *)format fps:(NSInteger)fps; - (void)stopCapture; diff --git a/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.mm b/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.mm index ec2ed05650..723145155f 100644 --- a/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.mm +++ b/submodules/TgVoipWebrtc/Impl/VideoCameraCapturer.mm @@ -37,16 +37,20 @@ static webrtc::ObjCVideoTrackSource *getObjCVideoSource(const rtc::scoped_refptr FourCharCode _outputPixelFormat; RTCVideoRotation _rotation; UIDeviceOrientation _orientation; + + void (^_isActiveUpdated)(bool); } @end @implementation VideoCameraCapturer -- (instancetype)initWithSource:(rtc::scoped_refptr)source { +- (instancetype)initWithSource:(rtc::scoped_refptr)source isActiveUpdated:(void (^)(bool))isActiveUpdated { self = [super init]; if (self != nil) { _source = source; + _isActiveUpdated = [isActiveUpdated copy]; + if (![self setupCaptureSession:[[AVCaptureSession alloc] init]]) { return nil; } @@ -116,6 +120,7 @@ static webrtc::ObjCVideoTrackSource *getObjCVideoSource(const rtc::scoped_refptr } - (void)stopCapture { + _isActiveUpdated = nil; [self stopCaptureWithCompletionHandler:nil]; } @@ -310,10 +315,17 @@ static webrtc::ObjCVideoTrackSource *getObjCVideoSource(const rtc::scoped_refptr // allow future retries on fatal errors. _hasRetriedOnFatalError = NO; }]; + + if (_isActiveUpdated) { + _isActiveUpdated(true); + } } - (void)handleCaptureSessionDidStopRunning:(NSNotification *)notification { RTCLog(@"Capture session stopped."); + if (_isActiveUpdated) { + _isActiveUpdated(false); + } } - (void)handleFatalError { diff --git a/submodules/TgVoipWebrtc/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h b/submodules/TgVoipWebrtc/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h index 92a3fdc99d..1582e4351a 100644 --- a/submodules/TgVoipWebrtc/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h +++ b/submodules/TgVoipWebrtc/PublicHeaders/TgVoip/OngoingCallThreadLocalContext.h @@ -25,11 +25,15 @@ typedef NS_ENUM(int32_t, OngoingCallStateWebrtc) { typedef NS_ENUM(int32_t, OngoingCallVideoStateWebrtc) { OngoingCallVideoStateInactive, - OngoingCallVideoStateRequesting, - OngoingCallVideoStateInvited, + OngoingCallVideoStateActiveOutgoing, OngoingCallVideoStateActive }; +typedef NS_ENUM(int32_t, OngoingCallRemoteVideoStateWebrtc) { + OngoingCallRemoteVideoStateInactive, + OngoingCallRemoteVideoStateActive +}; + typedef NS_ENUM(int32_t, OngoingCallNetworkTypeWebrtc) { OngoingCallNetworkTypeWifi, OngoingCallNetworkTypeCellularGprs, @@ -62,6 +66,18 @@ typedef NS_ENUM(int32_t, OngoingCallDataSavingWebrtc) { @end +@interface VoipRtcServerWebrtc : NSObject + +@property (nonatomic, strong, readonly) NSString * _Nonnull host; +@property (nonatomic, readonly) int32_t port; +@property (nonatomic, strong, readonly) NSString * _Nullable username; +@property (nonatomic, strong, readonly) NSString * _Nullable password; +@property (nonatomic, readonly) bool isTurn; + +- (instancetype _Nonnull)initWithHost:(NSString * _Nonnull)host port:(int32_t)port username:(NSString * _Nullable)username password:(NSString * _Nullable)password isTurn:(bool)isTurn; + +@end + @interface OngoingCallThreadLocalContextWebrtc : NSObject + (void)setupLoggingFunction:(void (* _Nullable)(NSString * _Nullable))loggingFunction; @@ -69,10 +85,10 @@ typedef NS_ENUM(int32_t, OngoingCallDataSavingWebrtc) { + (int32_t)maxLayer; + (NSString * _Nonnull)version; -@property (nonatomic, copy) void (^ _Nullable stateChanged)(OngoingCallStateWebrtc, OngoingCallVideoStateWebrtc); +@property (nonatomic, copy) void (^ _Nullable stateChanged)(OngoingCallStateWebrtc, OngoingCallVideoStateWebrtc, OngoingCallRemoteVideoStateWebrtc); @property (nonatomic, copy) void (^ _Nullable signalBarsChanged)(int32_t); -- (instancetype _Nonnull)initWithQueue:(id _Nonnull)queue proxy:(VoipProxyServerWebrtc * _Nullable)proxy networkType:(OngoingCallNetworkTypeWebrtc)networkType dataSaving:(OngoingCallDataSavingWebrtc)dataSaving derivedState:(NSData * _Nonnull)derivedState key:(NSData * _Nonnull)key isOutgoing:(bool)isOutgoing primaryConnection:(OngoingCallConnectionDescriptionWebrtc * _Nonnull)primaryConnection alternativeConnections:(NSArray * _Nonnull)alternativeConnections maxLayer:(int32_t)maxLayer allowP2P:(BOOL)allowP2P logPath:(NSString * _Nonnull)logPath sendSignalingData:(void (^)(NSData * _Nonnull))sendSignalingData; +- (instancetype _Nonnull)initWithQueue:(id _Nonnull)queue proxy:(VoipProxyServerWebrtc * _Nullable)proxy rtcServers:(NSArray * _Nonnull)rtcServers networkType:(OngoingCallNetworkTypeWebrtc)networkType dataSaving:(OngoingCallDataSavingWebrtc)dataSaving derivedState:(NSData * _Nonnull)derivedState key:(NSData * _Nonnull)key isOutgoing:(bool)isOutgoing isVideo:(bool)isVideo primaryConnection:(OngoingCallConnectionDescriptionWebrtc * _Nonnull)primaryConnection alternativeConnections:(NSArray * _Nonnull)alternativeConnections maxLayer:(int32_t)maxLayer allowP2P:(BOOL)allowP2P logPath:(NSString * _Nonnull)logPath sendSignalingData:(void (^)(NSData * _Nonnull))sendSignalingData; - (void)stop:(void (^_Nullable)(NSString * _Nullable debugLog, int64_t bytesSentWifi, int64_t bytesReceivedWifi, int64_t bytesSentMobile, int64_t bytesReceivedMobile))completion; - (bool)needRate; diff --git a/submodules/TgVoipWebrtc/Sources/OngoingCallThreadLocalContext.mm b/submodules/TgVoipWebrtc/Sources/OngoingCallThreadLocalContext.mm index 93e6432285..a10e9950be 100644 --- a/submodules/TgVoipWebrtc/Sources/OngoingCallThreadLocalContext.mm +++ b/submodules/TgVoipWebrtc/Sources/OngoingCallThreadLocalContext.mm @@ -35,6 +35,7 @@ using namespace TGVOIP_NAMESPACE; OngoingCallStateWebrtc _state; OngoingCallVideoStateWebrtc _videoState; + OngoingCallRemoteVideoStateWebrtc _remoteVideoState; int32_t _signalBars; NSData *_lastDerivedState; @@ -62,6 +63,22 @@ using namespace TGVOIP_NAMESPACE; @end +@implementation VoipRtcServerWebrtc + +- (instancetype _Nonnull)initWithHost:(NSString * _Nonnull)host port:(int32_t)port username:(NSString * _Nullable)username password:(NSString * _Nullable)password isTurn:(bool)isTurn { + self = [super init]; + if (self != nil) { + _host = host; + _port = port; + _username = username; + _password = password; + _isTurn = isTurn; + } + return self; +} + +@end + static TgVoipNetworkType callControllerNetworkTypeForType(OngoingCallNetworkTypeWebrtc type) { switch (type) { case OngoingCallNetworkTypeWifi: @@ -117,7 +134,7 @@ static void (*InternalVoipLoggingFunction)(NSString *) = NULL; return @"2.7.7"; } -- (instancetype _Nonnull)initWithQueue:(id _Nonnull)queue proxy:(VoipProxyServerWebrtc * _Nullable)proxy networkType:(OngoingCallNetworkTypeWebrtc)networkType dataSaving:(OngoingCallDataSavingWebrtc)dataSaving derivedState:(NSData * _Nonnull)derivedState key:(NSData * _Nonnull)key isOutgoing:(bool)isOutgoing primaryConnection:(OngoingCallConnectionDescriptionWebrtc * _Nonnull)primaryConnection alternativeConnections:(NSArray * _Nonnull)alternativeConnections maxLayer:(int32_t)maxLayer allowP2P:(BOOL)allowP2P logPath:(NSString * _Nonnull)logPath sendSignalingData:(void (^)(NSData * _Nonnull))sendSignalingData; { +- (instancetype _Nonnull)initWithQueue:(id _Nonnull)queue proxy:(VoipProxyServerWebrtc * _Nullable)proxy rtcServers:(NSArray * _Nonnull)rtcServers networkType:(OngoingCallNetworkTypeWebrtc)networkType dataSaving:(OngoingCallDataSavingWebrtc)dataSaving derivedState:(NSData * _Nonnull)derivedState key:(NSData * _Nonnull)key isOutgoing:(bool)isOutgoing isVideo:(bool)isVideo primaryConnection:(OngoingCallConnectionDescriptionWebrtc * _Nonnull)primaryConnection alternativeConnections:(NSArray * _Nonnull)alternativeConnections maxLayer:(int32_t)maxLayer allowP2P:(BOOL)allowP2P logPath:(NSString * _Nonnull)logPath sendSignalingData:(void (^)(NSData * _Nonnull))sendSignalingData; { self = [super init]; if (self != nil) { _queue = queue; @@ -129,7 +146,13 @@ static void (*InternalVoipLoggingFunction)(NSString *) = NULL; _callPacketTimeout = 10.0; _networkType = networkType; _sendSignalingData = [sendSignalingData copy]; - _videoState = OngoingCallVideoStateInactive; + if (isVideo) { + _videoState = OngoingCallVideoStateActiveOutgoing; + _remoteVideoState = OngoingCallRemoteVideoStateActive; + } else { + _videoState = OngoingCallVideoStateInactive; + _remoteVideoState = OngoingCallRemoteVideoStateInactive; + } std::vector derivedStateValue; derivedStateValue.resize(derivedState.length); @@ -145,6 +168,17 @@ static void (*InternalVoipLoggingFunction)(NSString *) = NULL; proxyValue = std::unique_ptr(proxyObject); } + std::vector parsedRtcServers; + for (VoipRtcServerWebrtc *server in rtcServers) { + parsedRtcServers.push_back((TgVoipRtcServer){ + .host = server.host.UTF8String, + .port = (uint16_t)server.port, + .login = server.username.UTF8String, + .password = server.password.UTF8String, + .isTurn = server.isTurn + }); + } + /*TgVoipCrypto crypto; crypto.sha1 = &TGCallSha1; crypto.sha256 = &TGCallSha256; @@ -199,8 +233,10 @@ static void (*InternalVoipLoggingFunction)(NSString *) = NULL; { derivedStateValue }, endpoints, proxyValue, + parsedRtcServers, callControllerNetworkTypeForType(networkType), encryptionKey, + isVideo, [weakSelf, queue](TgVoipState state) { [queue dispatch:^{ __strong OngoingCallThreadLocalContextWebrtc *strongSelf = weakSelf; @@ -222,7 +258,26 @@ static void (*InternalVoipLoggingFunction)(NSString *) = NULL; if (strongSelf->_videoState != videoState) { strongSelf->_videoState = videoState; if (strongSelf->_stateChanged) { - strongSelf->_stateChanged(strongSelf->_state, strongSelf->_videoState); + strongSelf->_stateChanged(strongSelf->_state, strongSelf->_videoState, strongSelf->_remoteVideoState); + } + } + } + }]; + }, + [weakSelf, queue](bool isActive) { + [queue dispatch:^{ + __strong OngoingCallThreadLocalContextWebrtc *strongSelf = weakSelf; + if (strongSelf) { + OngoingCallRemoteVideoStateWebrtc remoteVideoState; + if (isActive) { + remoteVideoState = OngoingCallRemoteVideoStateActive; + } else { + remoteVideoState = OngoingCallRemoteVideoStateInactive; + } + if (strongSelf->_remoteVideoState != remoteVideoState) { + strongSelf->_remoteVideoState = remoteVideoState; + if (strongSelf->_stateChanged) { + strongSelf->_stateChanged(strongSelf->_state, strongSelf->_videoState, strongSelf->_remoteVideoState); } } } @@ -322,7 +377,12 @@ static void (*InternalVoipLoggingFunction)(NSString *) = NULL; _state = callState; if (_stateChanged) { - _stateChanged(_state, _videoState); + if (_videoState == OngoingCallVideoStateActiveOutgoing) { + if (_state == OngoingCallStateConnected) { + _videoState = OngoingCallVideoStateActive; + } + } + _stateChanged(_state, _videoState, _remoteVideoState); } } } diff --git a/submodules/WatchBridge/Sources/WatchBridge.swift b/submodules/WatchBridge/Sources/WatchBridge.swift index 29ada56d2b..e01c5941be 100644 --- a/submodules/WatchBridge/Sources/WatchBridge.swift +++ b/submodules/WatchBridge/Sources/WatchBridge.swift @@ -211,7 +211,7 @@ func makeBridgeMedia(message: Message, strings: PresentationStrings, chatPeer: P bridgeAction?.actionType = .channelCreated } } - case let .phoneCall(_, discardReason, _): + case let .phoneCall(_, discardReason, _, _): let bridgeAttachment = TGBridgeUnsupportedMediaAttachment() let incoming = message.flags.contains(.Incoming) var compactTitle: String = ""