From 19c1ee8c44dfc820033867e4e860c99a5835d424 Mon Sep 17 00:00:00 2001 From: Ilya Laktyushin Date: Wed, 7 Aug 2019 11:28:04 +0300 Subject: [PATCH] Scheduled messages --- NotificationService/Serialization.swift | 2 +- SiriIntents/IntentMessages.swift | 2 +- Telegram-iOS/en.lproj/Localizable.strings | 13 + .../project.pbxproj | 8 +- ...cation.swift => ChatHistoryLocation.swift} | 1 + .../Display/ContextMenuContainerNode.swift | 2 +- .../ItemListUI/Sources/ItemListItem.swift | 6 +- .../CachedResourceRepresentations.swift | 52 +- .../Postbox/Postbox/MessageHistoryView.swift | 38 +- .../Postbox/MessageHistoryViewState.swift | 44 +- .../Postbox/MessageOfInterestHolesView.swift | 4 +- submodules/Postbox/Postbox/Postbox.swift | 16 +- .../Sources/StickerResources.swift | 26 +- submodules/TelegramApi/Sources/Api0.swift | 2 + submodules/TelegramApi/Sources/Api1.swift | 54 + submodules/TelegramApi/Sources/Api3.swift | 356 +- submodules/TelegramApi/Sources/Api4.swift | 0 .../Sources/TelegramBaseController.swift | 2 +- .../AccountStateManagementUtils.swift | 10 +- .../TelegramCore/AccountViewTracker.swift | 12 +- .../TelegramCore/AppChangelog.swift | 8 +- .../TelegramCore/ApplyUpdateMessage.swift | 7 +- .../AutoremoveTimeoutMessageAttribute.swift | 6 +- .../TelegramCore/ForwardGame.swift | 2 +- .../TelegramCore/TelegramCore/Holes.swift | 240 +- ...gedCloudChatRemoveMessagesOperations.swift | 91 +- ...kAllUnseenPersonalMessagesOperations.swift | 6 +- .../TelegramCore/Namespaces.swift | 7 +- .../OutgoingContentInfoMessageAttribute.swift | 27 +- .../OutgoingMessageInfoAttribute.swift | 2 +- .../TelegramCore/PendingMessageManager.swift | 17 +- .../PendingMessageUploadedContent.swift | 4 +- .../TelegramCore/TelegramCore/Polls.swift | 2 +- .../TelegramCore/RequestEditMessage.swift | 6 +- .../TelegramCore/Serialization.swift | 2 +- .../TelegramCore/StandaloneSendMessage.swift | 9 +- .../TelegramCore/StoreMessage_Telegram.swift | 6 +- .../TelegramCore/UpdatesApiUtils.swift | 23 +- .../Sources/PresentationStrings.swift | 5758 +++++++++-------- .../PresentationThemeEssentialGraphics.swift | 7 +- .../Resources/PresentationResourceKey.swift | 2 + .../Resources/PresentationResourcesChat.swift | 25 + .../Empty Chat/Chat.imageset/Contents.json | 12 - .../Chat.imageset/telegram_plane_flat.pdf | Bin 6186 -> 0 bytes .../Menu/ScheduleIcon.imageset/Contents.json | 22 + .../ScheduleIcon.imageset/Schedule@2x.png | Bin 0 -> 1004 bytes .../ScheduleIcon.imageset/Schedule@3x.png | Bin 0 -> 1453 bytes .../Input/ScheduleIcon.imageset/Contents.json | 22 + .../ScheduleSendButton@2x.png | Bin 0 -> 1114 bytes .../ScheduleSendButton@3x.png | Bin 0 -> 1665 bytes .../Contents.json | 22 + .../ScheduleInput@2x.png | Bin 0 -> 1767 bytes .../ScheduleInput@3x.png | Bin 0 -> 2664 bytes .../TelegramUI/AnimatedStickerNode.swift | 5 +- .../TelegramUI/AnimatedStickerUtils.swift | 466 +- .../TelegramUI/TelegramUI/AppDelegate.swift | 8 +- .../TelegramUI/ApplicationContext.swift | 2 +- ...ceAwaitingAccountResetControllerNode.swift | 4 +- .../TelegramUI/BundleResource.swift | 82 + .../TelegramUI/ChatAnimationGalleryItem.swift | 2 +- .../TelegramUI/ChatController.swift | 105 +- .../ChatControllerInteraction.swift | 5 +- .../TelegramUI/ChatControllerNode.swift | 17 +- .../ChatHistoryEntriesForView.swift | 2 +- .../TelegramUI/ChatHistoryListNode.swift | 64 +- .../ChatHistoryViewForLocation.swift | 69 + .../ChatInterfaceInputContexts.swift | 6 +- .../ChatInterfaceTitlePanelNodes.swift | 2 +- .../TelegramUI/ChatListController.swift | 2 +- .../ChatMessageAnimatedStickerItemNode.swift | 19 +- .../TelegramUI/ChatMessageDateHeader.swift | 14 +- .../TelegramUI/ChatMessageItem.swift | 20 +- .../ChatPanelInterfaceInteraction.swift | 4 +- .../ChatPresentationInterfaceState.swift | 88 +- .../ChatRecentActionsController.swift | 1 + .../ChatRecentActionsControllerNode.swift | 1 + .../ChatScheduleTimeController.swift | 71 + .../ChatScheduleTimeControllerNode.swift | 245 + ...ChatSendMessageActionSheetController.swift | 3 + ...SendMessageActionSheetControllerNode.swift | 57 +- .../ChatTextInputAccessoryItem.swift | 1 + .../TelegramUI/ChatTextInputPanelNode.swift | 18 +- .../TelegramUI/TelegramUI/ChatTitleView.swift | 55 +- .../TelegramUI/ChatUnreadItem.swift | 2 +- .../TelegramUI/TelegramUI/EmojiUtils.swift | 9 +- .../FetchCachedRepresentations.swift | 20 +- .../TelegramUI/GalleryController.swift | 2 +- .../TelegramUI/GifPaneSearchContentNode.swift | 2 +- .../TelegramUI/GroupInfoController.swift | 2 +- .../HashtagChatInputPanelItem.swift | 2 +- .../HashtagSearchControllerNode.swift | 2 +- .../InstalledStickerPacksController.swift | 1 + .../TelegramUI/InstantPageAudioNode.swift | 4 - .../TelegramUI/InstantPageMediaPlaylist.swift | 2 +- .../InstantPageReferenceControllerNode.swift | 2 +- .../TelegramUI/LegacyFileImport.swift | 1 - .../TelegramUI/NavigateToChatController.swift | 2 +- .../TelegramUI/OpenResolvedUrl.swift | 2 +- .../OverlayPlayerControllerNode.swift | 7 +- .../OverlayPlayerControlsNode.swift | 1 - .../PeerMediaCollectionController.swift | 4 +- .../PeerMediaCollectionControllerNode.swift | 8 +- .../PeerMessagesMediaPlaylist.swift | 6 +- .../TelegramUI/PermissionContentNode.swift | 5 +- .../Resources/PresentationStrings.mapping | Bin 122421 -> 122861 bytes ...SecureIdAuthPasswordSetupContentNode.swift | 2 +- .../TelegramUI/SettingsSearchableItems.swift | 9 +- .../TelegramUI/SolidRoundedButtonNode.swift | 11 +- .../StickerPackPreviewController.swift | 2 +- .../StringForMessageTimestampStatus.swift | 8 +- .../TelegramUI/TelegramUI/VolumeButtons.swift | 2 +- .../project.pbxproj | 16 + .../Sources/OngoingCallContext.swift | 2 + 113 files changed, 4805 insertions(+), 3756 deletions(-) rename submodules/AccountContext/Sources/{ChatHistroyLocation.swift => ChatHistoryLocation.swift} (97%) delete mode 100644 submodules/TelegramApi/Sources/Api4.swift delete mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/Contents.json delete mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/telegram_plane_flat.pdf create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Contents.json create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@2x.png create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@3x.png create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/Contents.json create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@2x.png create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@3x.png create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/Contents.json create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@2x.png create mode 100644 submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@3x.png create mode 100644 submodules/TelegramUI/TelegramUI/BundleResource.swift create mode 100644 submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift create mode 100644 submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift diff --git a/NotificationService/Serialization.swift b/NotificationService/Serialization.swift index 425f455c35..685b3cacb9 100644 --- a/NotificationService/Serialization.swift +++ b/NotificationService/Serialization.swift @@ -14,7 +14,7 @@ public class BoxedMessage: NSObject { public class Serialization: NSObject, MTSerialization { public func currentLayer() -> UInt { - return 103 + return 105 } public func parseMessage(_ data: Data!) -> Any! { diff --git a/SiriIntents/IntentMessages.swift b/SiriIntents/IntentMessages.swift index 904faa445c..cbbc6aec54 100644 --- a/SiriIntents/IntentMessages.swift +++ b/SiriIntents/IntentMessages.swift @@ -31,7 +31,7 @@ func unreadMessages(account: Account) -> Signal<[INMessage], NoError> { } if !isMuted && hasUnread { - signals.append(account.postbox.aroundMessageHistoryViewForLocation(.peer(index.messageIndex.id.peerId), anchor: .upperBound, count: 10, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: Set(), tagMask: nil, orderStatistics: .combinedLocation) + signals.append(account.postbox.aroundMessageHistoryViewForLocation(.peer(index.messageIndex.id.peerId), anchor: .upperBound, count: 10, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: Set(), tagMask: nil, excludeNamespaces: [Namespaces.Message.CloudScheduled], orderStatistics: .combinedLocation) |> take(1) |> map { view -> [INMessage] in var messages: [INMessage] = [] diff --git a/Telegram-iOS/en.lproj/Localizable.strings b/Telegram-iOS/en.lproj/Localizable.strings index 99bb3394ee..9c6d4369c6 100644 --- a/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram-iOS/en.lproj/Localizable.strings @@ -4497,6 +4497,7 @@ Any member of this group will be able to see messages in the channel."; "Group.EditAdmin.RankAdminPlaceholder" = "admin"; "Conversation.SendMessage.SendSilently" = "Send Without Sound"; +"Conversation.SendMessage.ScheduleMessage" = "Schedule Message"; "Appearance.ThemeCarouselTintedNight" = "Tinted Night"; "Appearance.ThemeCarouselNewNight" = "Night"; @@ -4590,3 +4591,15 @@ Any member of this group will be able to see messages in the channel."; "VoiceOver.MessageContextOpenMessageMenu" = "Open message menu"; "ProxyServer.VoiceOver.Active" = "Active"; + +"Conversation.ScheduleMessage.Title" = "Schedule Message"; +"Conversation.ScheduleMessage.SendToday" = "Send today at %@"; +"Conversation.ScheduleMessage.SendOn" = "Send on %@ at %@"; + +"ScheduledMessages.Title" = "Scheduled Messages"; +"ScheduledMessages.RemindersTitle" = "Reminders"; +"ScheduledMessages.ScheduledDate" = "Scheduled for %@"; +"ScheduledMessages.SendNow" = "Send Now"; +"ScheduledMessages.EditTime" = "Edit Time"; + +"Conversation.SendMessage.SetReminder" = "Set a Reminder"; diff --git a/submodules/AccountContext/AccountContext_Xcode.xcodeproj/project.pbxproj b/submodules/AccountContext/AccountContext_Xcode.xcodeproj/project.pbxproj index 8de3624517..85b975e8f3 100644 --- a/submodules/AccountContext/AccountContext_Xcode.xcodeproj/project.pbxproj +++ b/submodules/AccountContext/AccountContext_Xcode.xcodeproj/project.pbxproj @@ -12,7 +12,7 @@ D0879A4A22F6584B00C4D6B3 /* SharedMediaPlayer.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0879A4922F6584B00C4D6B3 /* SharedMediaPlayer.swift */; }; D0879A4C22F65A7A00C4D6B3 /* UniversalMediaPlayer.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = D0879A4B22F65A7A00C4D6B3 /* UniversalMediaPlayer.framework */; }; D0879A4E22F65B2A00C4D6B3 /* MediaManager.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0879A4D22F65B2A00C4D6B3 /* MediaManager.swift */; }; - D0879A5022F65D4D00C4D6B3 /* ChatHistroyLocation.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0879A4F22F65D4D00C4D6B3 /* ChatHistroyLocation.swift */; }; + D0879A5022F65D4D00C4D6B3 /* ChatHistoryLocation.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0879A4F22F65D4D00C4D6B3 /* ChatHistoryLocation.swift */; }; D0879AA222F6FEC800C4D6B3 /* OverlayAudioPlayerController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0879AA122F6FEC800C4D6B3 /* OverlayAudioPlayerController.swift */; }; D0879B1922F70C7400C4D6B3 /* OpenChatMessage.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0879B1822F70C7400C4D6B3 /* OpenChatMessage.swift */; }; D0879B1B22F70CF400C4D6B3 /* ChatController.swift in Sources */ = {isa = PBXBuildFile; fileRef = D0879B1A22F70CF400C4D6B3 /* ChatController.swift */; }; @@ -47,7 +47,7 @@ D0879A4922F6584B00C4D6B3 /* SharedMediaPlayer.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SharedMediaPlayer.swift; sourceTree = ""; }; D0879A4B22F65A7A00C4D6B3 /* UniversalMediaPlayer.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; path = UniversalMediaPlayer.framework; sourceTree = BUILT_PRODUCTS_DIR; }; D0879A4D22F65B2A00C4D6B3 /* MediaManager.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MediaManager.swift; sourceTree = ""; }; - D0879A4F22F65D4D00C4D6B3 /* ChatHistroyLocation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatHistroyLocation.swift; sourceTree = ""; }; + D0879A4F22F65D4D00C4D6B3 /* ChatHistoryLocation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatHistoryLocation.swift; sourceTree = ""; }; D0879AA122F6FEC800C4D6B3 /* OverlayAudioPlayerController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OverlayAudioPlayerController.swift; sourceTree = ""; }; D0879B1822F70C7400C4D6B3 /* OpenChatMessage.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenChatMessage.swift; sourceTree = ""; }; D0879B1A22F70CF400C4D6B3 /* ChatController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatController.swift; sourceTree = ""; }; @@ -128,7 +128,7 @@ D0879B6422F7AC8700C4D6B3 /* OverlayMediaManager.swift */, D0879B6022F7A7A600C4D6B3 /* UniversalVideoNode.swift */, D0879B6222F7A97F00C4D6B3 /* OverlayMediaItemNode.swift */, - D0879A4F22F65D4D00C4D6B3 /* ChatHistroyLocation.swift */, + D0879A4F22F65D4D00C4D6B3 /* ChatHistoryLocation.swift */, D0879AA122F6FEC800C4D6B3 /* OverlayAudioPlayerController.swift */, D0879B1822F70C7400C4D6B3 /* OpenChatMessage.swift */, D0879B1A22F70CF400C4D6B3 /* ChatController.swift */, @@ -258,7 +258,7 @@ D0879B1922F70C7400C4D6B3 /* OpenChatMessage.swift in Sources */, D0879B1D22F7112E00C4D6B3 /* GalleryController.swift in Sources */, D0879B1B22F70CF400C4D6B3 /* ChatController.swift in Sources */, - D0879A5022F65D4D00C4D6B3 /* ChatHistroyLocation.swift in Sources */, + D0879A5022F65D4D00C4D6B3 /* ChatHistoryLocation.swift in Sources */, D0879A4622F651D400C4D6B3 /* LiveLocationManager.swift in Sources */, D0879AA222F6FEC800C4D6B3 /* OverlayAudioPlayerController.swift in Sources */, D0D3285F22F335B000D07EE2 /* AccountContext.swift in Sources */, diff --git a/submodules/AccountContext/Sources/ChatHistroyLocation.swift b/submodules/AccountContext/Sources/ChatHistoryLocation.swift similarity index 97% rename from submodules/AccountContext/Sources/ChatHistroyLocation.swift rename to submodules/AccountContext/Sources/ChatHistoryLocation.swift index 5541df6c25..f339694d0f 100644 --- a/submodules/AccountContext/Sources/ChatHistroyLocation.swift +++ b/submodules/AccountContext/Sources/ChatHistoryLocation.swift @@ -12,6 +12,7 @@ public enum ChatHistoryLocation: Equatable { case InitialSearch(location: ChatHistoryInitialSearchLocation, count: Int) case Navigation(index: MessageHistoryAnchorIndex, anchorIndex: MessageHistoryAnchorIndex, count: Int) case Scroll(index: MessageHistoryAnchorIndex, anchorIndex: MessageHistoryAnchorIndex, sourceIndex: MessageHistoryAnchorIndex, scrollPosition: ListViewScrollPosition, animated: Bool) + case Scheduled } public struct ChatHistoryLocationInput: Equatable { diff --git a/submodules/Display/Display/ContextMenuContainerNode.swift b/submodules/Display/Display/ContextMenuContainerNode.swift index b8b5a282ca..fe191a6f23 100644 --- a/submodules/Display/Display/ContextMenuContainerNode.swift +++ b/submodules/Display/Display/ContextMenuContainerNode.swift @@ -75,7 +75,7 @@ public final class ContextMenuContainerNode: ASDisplayNode { path.addLine(to: CGPoint(x: arrowPosition - arrowWidth / 2.0, y: maskParams.size.height - verticalInset)) } path.addLine(to: CGPoint(x: cornerRadius, y: maskParams.size.height - verticalInset)) - path.addArc(withCenter: CGPoint(x: cornerRadius, y: maskParams.size.height - cornerRadius - verticalInset), radius: cornerRadius, startAngle: CGFloat(CGFloat.pi / 2.0), endAngle: CGFloat(M_PI), clockwise: true) + path.addArc(withCenter: CGPoint(x: cornerRadius, y: maskParams.size.height - cornerRadius - verticalInset), radius: cornerRadius, startAngle: CGFloat(CGFloat.pi / 2.0), endAngle: CGFloat.pi, clockwise: true) path.close() self.cachedMaskParams = maskParams diff --git a/submodules/ItemListUI/Sources/ItemListItem.swift b/submodules/ItemListUI/Sources/ItemListItem.swift index 9f77101298..78e49e9e3c 100644 --- a/submodules/ItemListUI/Sources/ItemListItem.swift +++ b/submodules/ItemListUI/Sources/ItemListItem.swift @@ -14,15 +14,15 @@ public protocol ItemListItem { } public extension ItemListItem { - public var isAlwaysPlain: Bool { + var isAlwaysPlain: Bool { return false } - public var tag: ItemListItemTag? { + var tag: ItemListItemTag? { return nil } - public var requestsNoInset: Bool { + var requestsNoInset: Bool { return false } } diff --git a/submodules/MediaResources/Sources/CachedResourceRepresentations.swift b/submodules/MediaResources/Sources/CachedResourceRepresentations.swift index 426255d1f0..c215bb643b 100644 --- a/submodules/MediaResources/Sources/CachedResourceRepresentations.swift +++ b/submodules/MediaResources/Sources/CachedResourceRepresentations.swift @@ -240,19 +240,50 @@ public final class CachedEmojiRepresentation: CachedMediaResourceRepresentation } } +public enum EmojiFitzModifier: Int32, Equatable { + case type12 + case type3 + case type4 + case type5 + case type6 + + public init?(emoji: String) { + switch emoji.unicodeScalars.first?.value { + case 0x1f3fb: + self = .type12 + case 0x1f3fc: + self = .type3 + case 0x1f3fd: + self = .type4 + case 0x1f3fe: + self = .type5 + case 0x1f3ff: + self = .type6 + default: + return nil + } + } +} + public final class CachedAnimatedStickerFirstFrameRepresentation: CachedMediaResourceRepresentation { public let keepDuration: CachedMediaRepresentationKeepDuration = .general public let width: Int32 public let height: Int32 + public let fitzModifier: EmojiFitzModifier? - public init(width: Int32, height: Int32) { + public init(width: Int32, height: Int32, fitzModifier: EmojiFitzModifier? = nil) { self.width = width self.height = height + self.fitzModifier = fitzModifier } public var uniqueId: String { - return "animated-sticker-first-frame-\(self.width)x\(self.height)-v1" + if let fitzModifier = self.fitzModifier { + return "animated-sticker-first-frame-\(self.width)x\(self.height)-fitz\(fitzModifier.rawValue)-v1" + } else { + return "animated-sticker-first-frame-\(self.width)x\(self.height)-v1" + } } public func isEqual(to: CachedMediaResourceRepresentation) -> Bool { @@ -263,6 +294,9 @@ public final class CachedAnimatedStickerFirstFrameRepresentation: CachedMediaRes if other.height != self.height { return false } + if other.fitzModifier != self.fitzModifier { + return false + } return true } else { return false @@ -275,14 +309,21 @@ public final class CachedAnimatedStickerRepresentation: CachedMediaResourceRepre public let width: Int32 public let height: Int32 + public let fitzModifier: EmojiFitzModifier? public var uniqueId: String { - return "animated-sticker-\(self.width)x\(self.height)-v8" + let version: Int = 8 + if let fitzModifier = self.fitzModifier { + return "animated-sticker-\(self.width)x\(self.height)-fitz\(fitzModifier.rawValue)-v\(version)" + } else { + return "animated-sticker-\(self.width)x\(self.height)-v\(version)" + } } - public init(width: Int32, height: Int32) { + public init(width: Int32, height: Int32, fitzModifier: EmojiFitzModifier? = nil) { self.width = width self.height = height + self.fitzModifier = fitzModifier } public func isEqual(to: CachedMediaResourceRepresentation) -> Bool { @@ -293,6 +334,9 @@ public final class CachedAnimatedStickerRepresentation: CachedMediaResourceRepre if other.height != self.height { return false } + if other.fitzModifier != self.fitzModifier { + return false + } return true } else { return false diff --git a/submodules/Postbox/Postbox/MessageHistoryView.swift b/submodules/Postbox/Postbox/MessageHistoryView.swift index b32d8a04f0..bdc9608b73 100644 --- a/submodules/Postbox/Postbox/MessageHistoryView.swift +++ b/submodules/Postbox/Postbox/MessageHistoryView.swift @@ -227,6 +227,7 @@ public enum HistoryViewInputAnchor: Equatable { final class MutableMessageHistoryView { private(set) var peerIds: MessageHistoryViewPeerIds let tag: MessageTags? + let excludeNamespaces: [MessageId.Namespace] private let orderStatistics: MessageHistoryViewOrderStatistics private let anchor: HistoryViewInputAnchor @@ -241,7 +242,7 @@ final class MutableMessageHistoryView { fileprivate(set) var sampledState: HistoryViewSample - init(postbox: Postbox, orderStatistics: MessageHistoryViewOrderStatistics, peerIds: MessageHistoryViewPeerIds, anchor inputAnchor: HistoryViewInputAnchor, combinedReadStates: MessageHistoryViewReadState?, transientReadStates: MessageHistoryViewReadState?, tag: MessageTags?, count: Int, topTaggedMessages: [MessageId.Namespace: MessageHistoryTopTaggedMessage?], additionalDatas: [AdditionalMessageHistoryViewDataEntry], getMessageCountInRange: (MessageIndex, MessageIndex) -> Int32) { + init(postbox: Postbox, orderStatistics: MessageHistoryViewOrderStatistics, peerIds: MessageHistoryViewPeerIds, anchor inputAnchor: HistoryViewInputAnchor, combinedReadStates: MessageHistoryViewReadState?, transientReadStates: MessageHistoryViewReadState?, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], count: Int, topTaggedMessages: [MessageId.Namespace: MessageHistoryTopTaggedMessage?], additionalDatas: [AdditionalMessageHistoryViewDataEntry], getMessageCountInRange: (MessageIndex, MessageIndex) -> Int32) { self.anchor = inputAnchor self.orderStatistics = orderStatistics @@ -249,16 +250,17 @@ final class MutableMessageHistoryView { self.combinedReadStates = combinedReadStates self.transientReadStates = transientReadStates self.tag = tag + self.excludeNamespaces = excludeNamespaces self.fillCount = count self.topTaggedMessages = topTaggedMessages self.additionalDatas = additionalDatas - self.state = HistoryViewState(postbox: postbox, inputAnchor: inputAnchor, tag: tag, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds) + self.state = HistoryViewState(postbox: postbox, inputAnchor: inputAnchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds) if case let .loading(loadingState) = self.state { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: self.orderStatistics, halfLimit: count + 1, locations: peerIds, postbox: postbox, holes: holes)) self.sampledState = self.state.sample(postbox: postbox) case .loadHole: break @@ -270,12 +272,12 @@ final class MutableMessageHistoryView { } private func reset(postbox: Postbox) { - self.state = HistoryViewState(postbox: postbox, inputAnchor: self.anchor, tag: self.tag, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds) + self.state = HistoryViewState(postbox: postbox, inputAnchor: self.anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds) if case let .loading(loadingState) = self.state { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) case .loadHole: break } @@ -284,7 +286,7 @@ final class MutableMessageHistoryView { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) case .loadHole: break } @@ -470,7 +472,7 @@ final class MutableMessageHistoryView { let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) + self.state = .loaded(HistoryViewLoadedState(anchor: anchor, tag: self.tag, excludeNamespaces: self.excludeNamespaces, statistics: self.orderStatistics, halfLimit: self.fillCount + 1, locations: self.peerIds, postbox: postbox, holes: holes)) case .loadHole: break } @@ -712,19 +714,23 @@ public final class MessageHistoryView { entries = [] if let transientReadStates = mutableView.transientReadStates, case let .peer(states) = transientReadStates { for entry in state.entries { - let read: Bool - if entry.message.flags.contains(.Incoming) { - read = false - } else if let readState = states[entry.message.id.peerId] { - read = readState.isOutgoingMessageIndexRead(entry.message.index) - } else { - read = false + if !mutableView.excludeNamespaces.contains(entry.message.id.namespace) { + let read: Bool + if entry.message.flags.contains(.Incoming) { + read = false + } else if let readState = states[entry.message.id.peerId] { + read = readState.isOutgoingMessageIndexRead(entry.message.index) + } else { + read = false + } + entries.append(MessageHistoryEntry(message: entry.message, isRead: read, location: entry.location, monthLocation: entry.monthLocation, attributes: entry.attributes)) } - entries.append(MessageHistoryEntry(message: entry.message, isRead: read, location: entry.location, monthLocation: entry.monthLocation, attributes: entry.attributes)) } } else { for entry in state.entries { - entries.append(MessageHistoryEntry(message: entry.message, isRead: false, location: entry.location, monthLocation: entry.monthLocation, attributes: entry.attributes)) + if !mutableView.excludeNamespaces.contains(entry.message.id.namespace) { + entries.append(MessageHistoryEntry(message: entry.message, isRead: false, location: entry.location, monthLocation: entry.monthLocation, attributes: entry.attributes)) + } } } assert(Set(entries.map({ $0.message.stableId })).count == entries.count) diff --git a/submodules/Postbox/Postbox/MessageHistoryViewState.swift b/submodules/Postbox/Postbox/MessageHistoryViewState.swift index f10678b9d4..f6f5d5d38c 100644 --- a/submodules/Postbox/Postbox/MessageHistoryViewState.swift +++ b/submodules/Postbox/Postbox/MessageHistoryViewState.swift @@ -748,6 +748,7 @@ struct HistoryViewLoadedSample { final class HistoryViewLoadedState { let anchor: HistoryViewAnchor let tag: MessageTags? + let excludeNamespaces: [MessageId.Namespace] let statistics: MessageHistoryViewOrderStatistics let halfLimit: Int let seedConfiguration: SeedConfiguration @@ -755,10 +756,11 @@ final class HistoryViewLoadedState { var holes: HistoryViewHoles var spacesWithRemovals = Set() - init(anchor: HistoryViewAnchor, tag: MessageTags?, statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds, postbox: Postbox, holes: HistoryViewHoles) { + init(anchor: HistoryViewAnchor, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds, postbox: Postbox, holes: HistoryViewHoles) { precondition(halfLimit >= 3) self.anchor = anchor self.tag = tag + self.excludeNamespaces = excludeNamespaces self.statistics = statistics self.halfLimit = halfLimit self.seedConfiguration = postbox.seedConfiguration @@ -779,7 +781,9 @@ final class HistoryViewLoadedState { var spaces: [PeerIdAndNamespace] = [] for peerId in peerIds { for namespace in postbox.messageHistoryIndexTable.existingNamespaces(peerId: peerId) { - spaces.append(PeerIdAndNamespace(peerId: peerId, namespace: namespace)) + if !excludeNamespaces.contains(namespace) { + spaces.append(PeerIdAndNamespace(peerId: peerId, namespace: namespace)) + } } } @@ -1174,7 +1178,7 @@ final class HistoryViewLoadedState { } } -private func fetchHoles(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?) -> [PeerIdAndNamespace: IndexSet] { +private func fetchHoles(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace]) -> [PeerIdAndNamespace: IndexSet] { var holesBySpace: [PeerIdAndNamespace: IndexSet] = [:] var peerIds: [PeerId] = [] switch locations { @@ -1189,11 +1193,13 @@ private func fetchHoles(postbox: Postbox, locations: MessageHistoryViewPeerIds, let holeSpace = tag.flatMap(MessageHistoryHoleSpace.tag) ?? .everywhere for peerId in peerIds { for namespace in postbox.messageHistoryHoleIndexTable.existingNamespaces(peerId: peerId, holeSpace: holeSpace) { - let indices = postbox.messageHistoryHoleIndexTable.closest(peerId: peerId, namespace: namespace, space: holeSpace, range: 1 ... (Int32.max - 1)) - if !indices.isEmpty { - let peerIdAndNamespace = PeerIdAndNamespace(peerId: peerId, namespace: namespace) - assert(canContainHoles(peerIdAndNamespace, seedConfiguration: postbox.seedConfiguration)) - holesBySpace[peerIdAndNamespace] = indices + if !excludeNamespaces.contains(namespace) { + let indices = postbox.messageHistoryHoleIndexTable.closest(peerId: peerId, namespace: namespace, space: holeSpace, range: 1 ... (Int32.max - 1)) + if !indices.isEmpty { + let peerIdAndNamespace = PeerIdAndNamespace(peerId: peerId, namespace: namespace) + assert(canContainHoles(peerIdAndNamespace, seedConfiguration: postbox.seedConfiguration)) + holesBySpace[peerIdAndNamespace] = indices + } } } } @@ -1211,11 +1217,11 @@ final class HistoryViewLoadingState { let halfLimit: Int var holes: HistoryViewHoles - init(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?, messageId: MessageId, halfLimit: Int) { + init(postbox: Postbox, locations: MessageHistoryViewPeerIds, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], messageId: MessageId, halfLimit: Int) { self.messageId = messageId self.tag = tag self.halfLimit = halfLimit - self.holes = HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag)) + self.holes = HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)) } func insertHole(space: PeerIdAndNamespace, range: ClosedRange) -> Bool { @@ -1255,14 +1261,14 @@ enum HistoryViewState { case loaded(HistoryViewLoadedState) case loading(HistoryViewLoadingState) - init(postbox: Postbox, inputAnchor: HistoryViewInputAnchor, tag: MessageTags?, statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds) { + init(postbox: Postbox, inputAnchor: HistoryViewInputAnchor, tag: MessageTags?, excludeNamespaces: [MessageId.Namespace], statistics: MessageHistoryViewOrderStatistics, halfLimit: Int, locations: MessageHistoryViewPeerIds) { switch inputAnchor { case let .index(index): - self = .loaded(HistoryViewLoadedState(anchor: .index(index), tag: tag, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag)))) + self = .loaded(HistoryViewLoadedState(anchor: .index(index), tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) case .lowerBound: - self = .loaded(HistoryViewLoadedState(anchor: .lowerBound, tag: tag, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag)))) + self = .loaded(HistoryViewLoadedState(anchor: .lowerBound, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) case .upperBound: - self = .loaded(HistoryViewLoadedState(anchor: .upperBound, tag: tag, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag)))) + self = .loaded(HistoryViewLoadedState(anchor: .upperBound, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) case .unread: let anchorPeerId: PeerId switch locations { @@ -1295,26 +1301,26 @@ enum HistoryViewState { } } if let messageId = messageId { - let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, messageId: messageId, halfLimit: halfLimit) + let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces, messageId: messageId, halfLimit: halfLimit) let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) + self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) case .loadHole: self = .loading(loadingState) } } else { - self = .loaded(HistoryViewLoadedState(anchor: anchor ?? .upperBound, tag: tag, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag)))) + self = .loaded(HistoryViewLoadedState(anchor: anchor ?? .upperBound, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: HistoryViewHoles(holesBySpace: fetchHoles(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces)))) } } else { preconditionFailure() } case let .message(messageId): - let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, messageId: messageId, halfLimit: halfLimit) + let loadingState = HistoryViewLoadingState(postbox: postbox, locations: locations, tag: tag, excludeNamespaces: excludeNamespaces, messageId: messageId, halfLimit: halfLimit) let sampledState = loadingState.checkAndSample(postbox: postbox) switch sampledState { case let .ready(anchor, holes): - self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) + self = .loaded(HistoryViewLoadedState(anchor: anchor, tag: tag, excludeNamespaces: excludeNamespaces, statistics: statistics, halfLimit: halfLimit, locations: locations, postbox: postbox, holes: holes)) case .loadHole: self = .loading(loadingState) } diff --git a/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift b/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift index 79290b74c8..3458f527fc 100644 --- a/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift +++ b/submodules/Postbox/Postbox/MessageOfInterestHolesView.swift @@ -52,7 +52,7 @@ final class MutableMessageOfInterestHolesView: MutablePostboxView { } } self.anchor = anchor - self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) + self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, excludeNamespaces: [], count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) let _ = self.updateFromView() } @@ -117,7 +117,7 @@ final class MutableMessageOfInterestHolesView: MutablePostboxView { if self.anchor != anchor { self.anchor = anchor - self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) + self.wrappedView = MutableMessageHistoryView(postbox: postbox, orderStatistics: [], peerIds: .single(peerId), anchor: self.anchor, combinedReadStates: nil, transientReadStates: nil, tag: nil, excludeNamespaces: [], count: self.count, topTaggedMessages: [:], additionalDatas: [], getMessageCountInRange: { _, _ in return 0}) return self.updateFromView() } else if self.wrappedView.replay(postbox: postbox, transaction: transaction) { return self.updateFromView() diff --git a/submodules/Postbox/Postbox/Postbox.swift b/submodules/Postbox/Postbox/Postbox.swift index 08a58f189f..a845cff0ee 100644 --- a/submodules/Postbox/Postbox/Postbox.swift +++ b/submodules/Postbox/Postbox/Postbox.swift @@ -2218,7 +2218,7 @@ public final class Postbox { return peerIds } - public func aroundMessageOfInterestHistoryViewForChatLocation(_ chatLocation: ChatLocation, count: Int, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageOfInterestHistoryViewForChatLocation(_ chatLocation: ChatLocation, count: Int, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { return self.transactionSignal(userInteractive: true, { subscriber, transaction in let peerIds = self.peerIdsForLocation(chatLocation, tagMask: tagMask) @@ -2262,26 +2262,26 @@ public final class Postbox { } } } - return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, orderStatistics: orderStatistics, additionalData: additionalData) + return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: additionalData) }) } - public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { return self.transactionSignal { subscriber, transaction in let peerIds = self.peerIdsForLocation(chatLocation, tagMask: tagMask) - return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: .message(messageId), fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, orderStatistics: orderStatistics, additionalData: additionalData) + return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: .message(messageId), fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: additionalData) } } - public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, anchor: HistoryViewInputAnchor, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, anchor: HistoryViewInputAnchor, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { return self.transactionSignal { subscriber, transaction in let peerIds = self.peerIdsForLocation(chatLocation, tagMask: tagMask) - return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, orderStatistics: orderStatistics, additionalData: additionalData) + return self.syncAroundMessageHistoryViewForPeerId(subscriber: subscriber, peerIds: peerIds, count: count, anchor: anchor, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: topTaggedMessageIdNamespaces, tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: additionalData) } } - private func syncAroundMessageHistoryViewForPeerId(subscriber: Subscriber<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError>, peerIds: MessageHistoryViewPeerIds, count: Int, anchor: HistoryViewInputAnchor, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Disposable { + private func syncAroundMessageHistoryViewForPeerId(subscriber: Subscriber<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError>, peerIds: MessageHistoryViewPeerIds, count: Int, anchor: HistoryViewInputAnchor, fixedCombinedReadStates: MessageHistoryViewReadState?, topTaggedMessageIdNamespaces: Set, tagMask: MessageTags?, excludeNamespaces: [MessageId.Namespace], orderStatistics: MessageHistoryViewOrderStatistics, additionalData: [AdditionalMessageHistoryViewData]) -> Disposable { var topTaggedMessages: [MessageId.Namespace: MessageHistoryTopTaggedMessage?] = [:] var mainPeerId: PeerId? switch peerIds { @@ -2370,7 +2370,7 @@ public final class Postbox { readStates = transientReadStates } - let mutableView = MutableMessageHistoryView(postbox: self, orderStatistics: orderStatistics, peerIds: peerIds, anchor: anchor, combinedReadStates: readStates, transientReadStates: transientReadStates, tag: tagMask, count: count, topTaggedMessages: topTaggedMessages, additionalDatas: additionalDataEntries, getMessageCountInRange: { lowerBound, upperBound in + let mutableView = MutableMessageHistoryView(postbox: self, orderStatistics: orderStatistics, peerIds: peerIds, anchor: anchor, combinedReadStates: readStates, transientReadStates: transientReadStates, tag: tagMask, excludeNamespaces: excludeNamespaces, count: count, topTaggedMessages: topTaggedMessages, additionalDatas: additionalDataEntries, getMessageCountInRange: { lowerBound, upperBound in if let tagMask = tagMask { return Int32(self.messageHistoryTable.getMessageCountInRange(peerId: lowerBound.id.peerId, namespace: lowerBound.id.namespace, tag: tagMask, lowerBound: lowerBound, upperBound: upperBound)) } else { diff --git a/submodules/StickerResources/Sources/StickerResources.swift b/submodules/StickerResources/Sources/StickerResources.swift index 59b4c7ed9f..c3fc250747 100644 --- a/submodules/StickerResources/Sources/StickerResources.swift +++ b/submodules/StickerResources/Sources/StickerResources.swift @@ -98,11 +98,12 @@ private func chatMessageStickerDatas(postbox: Postbox, file: TelegramMediaFile, } } -public func chatMessageAnimatedStickerDatas(postbox: Postbox, file: TelegramMediaFile, small: Bool, size: CGSize, fetched: Bool, onlyFullSize: Bool, synchronousLoad: Bool) -> Signal, NoError> { +public func chatMessageAnimatedStickerDatas(postbox: Postbox, file: TelegramMediaFile, small: Bool, size: CGSize, fitzModifier: EmojiFitzModifier? = nil, fetched: Bool, onlyFullSize: Bool, synchronousLoad: Bool) -> Signal, NoError> { let thumbnailResource = chatMessageStickerResource(file: file, small: true) let resource = chatMessageStickerResource(file: file, small: small) - let maybeFetched = postbox.mediaBox.cachedResourceRepresentation(resource, representation: CachedAnimatedStickerFirstFrameRepresentation(width: Int32(size.width), height: Int32(size.height)), complete: false, fetch: false, attemptSynchronously: synchronousLoad) + let firstFrameRepresentation = CachedAnimatedStickerFirstFrameRepresentation(width: Int32(size.width), height: Int32(size.height), fitzModifier: fitzModifier) + let maybeFetched = postbox.mediaBox.cachedResourceRepresentation(resource, representation: firstFrameRepresentation, complete: false, fetch: false, attemptSynchronously: synchronousLoad) return maybeFetched |> take(1) @@ -113,7 +114,7 @@ public func chatMessageAnimatedStickerDatas(postbox: Postbox, file: TelegramMedi return .single(Tuple(nil, loadedData, true)) } else { let thumbnailData = postbox.mediaBox.cachedResourceRepresentation(thumbnailResource, representation: CachedStickerAJpegRepresentation(size: nil), complete: false) - let fullSizeData = postbox.mediaBox.cachedResourceRepresentation(resource, representation: CachedAnimatedStickerFirstFrameRepresentation(width: Int32(size.width), height: Int32(size.height)), complete: onlyFullSize) + let fullSizeData = postbox.mediaBox.cachedResourceRepresentation(resource, representation: firstFrameRepresentation, complete: onlyFullSize) |> map { next in return (next.size == 0 ? nil : try? Data(contentsOf: URL(fileURLWithPath: next.path), options: .mappedIfSafe), next.complete) } @@ -164,8 +165,7 @@ private func chatMessageStickerThumbnailData(postbox: Postbox, file: TelegramMed let thumbnailData = postbox.mediaBox.cachedResourceRepresentation(thumbnailResource, representation: CachedStickerAJpegRepresentation(size: nil), complete: false) return Signal { subscriber in - var fetchThumbnail = fetchedMediaResource(mediaBox: postbox.mediaBox, reference: stickerPackFileReference(file).resourceReference(thumbnailResource)).start() - + let fetchThumbnail = fetchedMediaResource(mediaBox: postbox.mediaBox, reference: stickerPackFileReference(file).resourceReference(thumbnailResource)).start() let disposable = (thumbnailData |> map { thumbnailData -> Data? in return thumbnailData.complete ? try? Data(contentsOf: URL(fileURLWithPath: thumbnailData.path)) : nil @@ -227,25 +227,23 @@ private func chatMessageStickerPackThumbnailData(postbox: Postbox, resource: Med } } -public func chatMessageAnimationData(postbox: Postbox, resource: MediaResource, width: Int, height: Int, synchronousLoad: Bool) -> Signal { - let maybeFetched = postbox.mediaBox.cachedResourceRepresentation(resource, representation: CachedAnimatedStickerRepresentation(width: Int32(width), height: Int32(height)), complete: false, fetch: false, attemptSynchronously: synchronousLoad) - +public func chatMessageAnimationData(postbox: Postbox, resource: MediaResource, fitzModifier: EmojiFitzModifier? = nil, width: Int, height: Int, synchronousLoad: Bool) -> Signal { + let representation = CachedAnimatedStickerRepresentation(width: Int32(width), height: Int32(height), fitzModifier: fitzModifier) + let maybeFetched = postbox.mediaBox.cachedResourceRepresentation(resource, representation: representation, complete: false, fetch: false, attemptSynchronously: synchronousLoad) return maybeFetched |> take(1) |> mapToSignal { maybeData in if maybeData.complete { return .single(maybeData) } else { - return postbox.mediaBox.cachedResourceRepresentation(resource, representation: CachedAnimatedStickerRepresentation(width: Int32(width), height: Int32(height)), complete: false) + return postbox.mediaBox.cachedResourceRepresentation(resource, representation: representation, complete: false) } } } -public func chatMessageAnimatedStrickerBackingData(postbox: Postbox, fileReference: FileMediaReference, synchronousLoad: Bool) -> Signal, NoError> { +public func chatMessageAnimatedStickerBackingData(postbox: Postbox, fileReference: FileMediaReference, synchronousLoad: Bool) -> Signal, NoError> { let resource = fileReference.media.resource - let maybeFetched = postbox.mediaBox.resourceData(resource, option: .complete(waitUntilFetchStatus: false), attemptSynchronously: synchronousLoad) - return maybeFetched |> take(1) |> mapToSignal { maybeData in @@ -466,7 +464,7 @@ public func chatMessageSticker(postbox: Postbox, file: TelegramMediaFile, small: } } -public func chatMessageAnimatedSticker(postbox: Postbox, file: TelegramMediaFile, small: Bool, size: CGSize, fetched: Bool = false, onlyFullSize: Bool = false, thumbnail: Bool = false, synchronousLoad: Bool = false) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { +public func chatMessageAnimatedSticker(postbox: Postbox, file: TelegramMediaFile, small: Bool, size: CGSize, fitzModifier: EmojiFitzModifier? = nil, fetched: Bool = false, onlyFullSize: Bool = false, thumbnail: Bool = false, synchronousLoad: Bool = false) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { let signal: Signal, NoError> if thumbnail { signal = chatMessageStickerThumbnailData(postbox: postbox, file: file, synchronousLoad: synchronousLoad) @@ -474,7 +472,7 @@ public func chatMessageAnimatedSticker(postbox: Postbox, file: TelegramMediaFile return Tuple(data, nil, false) } } else { - signal = chatMessageAnimatedStickerDatas(postbox: postbox, file: file, small: small, size: size, fetched: fetched, onlyFullSize: onlyFullSize, synchronousLoad: synchronousLoad) + signal = chatMessageAnimatedStickerDatas(postbox: postbox, file: file, small: small, size: size, fitzModifier: fitzModifier, fetched: fetched, onlyFullSize: onlyFullSize, synchronousLoad: synchronousLoad) } return signal |> map { value in diff --git a/submodules/TelegramApi/Sources/Api0.swift b/submodules/TelegramApi/Sources/Api0.swift index 06a2721880..a6825262c7 100644 --- a/submodules/TelegramApi/Sources/Api0.swift +++ b/submodules/TelegramApi/Sources/Api0.swift @@ -235,6 +235,8 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[-1667805217] = { return Api.Update.parse_updateReadHistoryInbox($0) } dict[1786671974] = { return Api.Update.parse_updatePeerSettings($0) } dict[-1263546448] = { return Api.Update.parse_updatePeerLocated($0) } + dict[967122427] = { return Api.Update.parse_updateNewScheduledMessage($0) } + dict[-1870238482] = { return Api.Update.parse_updateDeleteScheduledMessages($0) } dict[1558266229] = { return Api.PopularContact.parse_popularContact($0) } dict[-373643672] = { return Api.FolderPeer.parse_folderPeer($0) } dict[367766557] = { return Api.ChannelParticipant.parse_channelParticipant($0) } diff --git a/submodules/TelegramApi/Sources/Api1.swift b/submodules/TelegramApi/Sources/Api1.swift index 391a88b56b..8b3db037f1 100644 --- a/submodules/TelegramApi/Sources/Api1.swift +++ b/submodules/TelegramApi/Sources/Api1.swift @@ -4019,6 +4019,8 @@ public extension Api { case updateReadHistoryInbox(flags: Int32, folderId: Int32?, peer: Api.Peer, maxId: Int32, stillUnreadCount: Int32, pts: Int32, ptsCount: Int32) case updatePeerSettings(peer: Api.Peer, settings: Api.PeerSettings) case updatePeerLocated(peers: [Api.PeerLocated]) + case updateNewScheduledMessage(message: Api.Message) + case updateDeleteScheduledMessages(peer: Api.Peer, messages: [Int32]) public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { switch self { @@ -4620,6 +4622,23 @@ public extension Api { item.serialize(buffer, true) } break + case .updateNewScheduledMessage(let message): + if boxed { + buffer.appendInt32(967122427) + } + message.serialize(buffer, true) + break + case .updateDeleteScheduledMessages(let peer, let messages): + if boxed { + buffer.appendInt32(-1870238482) + } + peer.serialize(buffer, true) + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(messages.count)) + for item in messages { + serializeInt32(item, buffer: buffer, boxed: false) + } + break } } @@ -4767,6 +4786,10 @@ public extension Api { return ("updatePeerSettings", [("peer", peer), ("settings", settings)]) case .updatePeerLocated(let peers): return ("updatePeerLocated", [("peers", peers)]) + case .updateNewScheduledMessage(let message): + return ("updateNewScheduledMessage", [("message", message)]) + case .updateDeleteScheduledMessages(let peer, let messages): + return ("updateDeleteScheduledMessages", [("peer", peer), ("messages", messages)]) } } @@ -5981,6 +6004,37 @@ public extension Api { return nil } } + public static func parse_updateNewScheduledMessage(_ reader: BufferReader) -> Update? { + var _1: Api.Message? + if let signature = reader.readInt32() { + _1 = Api.parse(reader, signature: signature) as? Api.Message + } + let _c1 = _1 != nil + if _c1 { + return Api.Update.updateNewScheduledMessage(message: _1!) + } + else { + return nil + } + } + public static func parse_updateDeleteScheduledMessages(_ reader: BufferReader) -> Update? { + var _1: Api.Peer? + if let signature = reader.readInt32() { + _1 = Api.parse(reader, signature: signature) as? Api.Peer + } + var _2: [Int32]? + if let _ = reader.readInt32() { + _2 = Api.parseVector(reader, elementSignature: -1471112230, elementType: Int32.self) + } + let _c1 = _1 != nil + let _c2 = _2 != nil + if _c1 && _c2 { + return Api.Update.updateDeleteScheduledMessages(peer: _1!, messages: _2!) + } + else { + return nil + } + } } public enum PopularContact: TypeConstructorDescription { diff --git a/submodules/TelegramApi/Sources/Api3.swift b/submodules/TelegramApi/Sources/Api3.swift index d5a1815eb7..f6985d310d 100644 --- a/submodules/TelegramApi/Sources/Api3.swift +++ b/submodules/TelegramApi/Sources/Api3.swift @@ -1211,30 +1211,6 @@ public extension Api { }) } - public static func sendMessage(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, message: String, randomId: Int64, replyMarkup: Api.ReplyMarkup?, entities: [Api.MessageEntity]?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { - let buffer = Buffer() - buffer.appendInt32(-91733382) - serializeInt32(flags, buffer: buffer, boxed: false) - peer.serialize(buffer, true) - if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} - serializeString(message, buffer: buffer, boxed: false) - serializeInt64(randomId, buffer: buffer, boxed: false) - if Int(flags) & Int(1 << 2) != 0 {replyMarkup!.serialize(buffer, true)} - if Int(flags) & Int(1 << 3) != 0 {buffer.appendInt32(481674261) - buffer.appendInt32(Int32(entities!.count)) - for item in entities! { - item.serialize(buffer, true) - }} - return (FunctionDescription(name: "messages.sendMessage", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("message", message), ("randomId", randomId), ("replyMarkup", replyMarkup), ("entities", entities)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in - let reader = BufferReader(buffer) - var result: Api.Updates? - if let signature = reader.readInt32() { - result = Api.parse(reader, signature: signature) as? Api.Updates - } - return result - }) - } - public static func reportSpam(peer: Api.InputPeer) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { let buffer = Buffer() buffer.appendInt32(-820669733) @@ -1850,25 +1826,6 @@ public extension Api { }) } - public static func sendInlineBotResult(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, randomId: Int64, queryId: Int64, id: String) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { - let buffer = Buffer() - buffer.appendInt32(-1318189314) - serializeInt32(flags, buffer: buffer, boxed: false) - peer.serialize(buffer, true) - if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} - serializeInt64(randomId, buffer: buffer, boxed: false) - serializeInt64(queryId, buffer: buffer, boxed: false) - serializeString(id, buffer: buffer, boxed: false) - return (FunctionDescription(name: "messages.sendInlineBotResult", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("randomId", randomId), ("queryId", queryId), ("id", id)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in - let reader = BufferReader(buffer) - var result: Api.Updates? - if let signature = reader.readInt32() { - result = Api.parse(reader, signature: signature) as? Api.Updates - } - return result - }) - } - public static func getMessageEditData(peer: Api.InputPeer, id: Int32) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { let buffer = Buffer() buffer.appendInt32(-39416522) @@ -2321,53 +2278,6 @@ public extension Api { }) } - public static func sendMultiMedia(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, multiMedia: [Api.InputSingleMedia]) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { - let buffer = Buffer() - buffer.appendInt32(546656559) - serializeInt32(flags, buffer: buffer, boxed: false) - peer.serialize(buffer, true) - if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} - buffer.appendInt32(481674261) - buffer.appendInt32(Int32(multiMedia.count)) - for item in multiMedia { - item.serialize(buffer, true) - } - return (FunctionDescription(name: "messages.sendMultiMedia", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("multiMedia", multiMedia)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in - let reader = BufferReader(buffer) - var result: Api.Updates? - if let signature = reader.readInt32() { - result = Api.parse(reader, signature: signature) as? Api.Updates - } - return result - }) - } - - public static func forwardMessages(flags: Int32, fromPeer: Api.InputPeer, id: [Int32], randomId: [Int64], toPeer: Api.InputPeer) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { - let buffer = Buffer() - buffer.appendInt32(1888354709) - serializeInt32(flags, buffer: buffer, boxed: false) - fromPeer.serialize(buffer, true) - buffer.appendInt32(481674261) - buffer.appendInt32(Int32(id.count)) - for item in id { - serializeInt32(item, buffer: buffer, boxed: false) - } - buffer.appendInt32(481674261) - buffer.appendInt32(Int32(randomId.count)) - for item in randomId { - serializeInt64(item, buffer: buffer, boxed: false) - } - toPeer.serialize(buffer, true) - return (FunctionDescription(name: "messages.forwardMessages", parameters: [("flags", flags), ("fromPeer", fromPeer), ("id", id), ("randomId", randomId), ("toPeer", toPeer)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in - let reader = BufferReader(buffer) - var result: Api.Updates? - if let signature = reader.readInt32() { - result = Api.parse(reader, signature: signature) as? Api.Updates - } - return result - }) - } - public static func uploadEncryptedFile(peer: Api.InputEncryptedChat, file: Api.InputEncryptedFile) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { let buffer = Buffer() buffer.appendInt32(1347929239) @@ -2403,31 +2313,6 @@ public extension Api { }) } - public static func sendMedia(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, media: Api.InputMedia, message: String, randomId: Int64, replyMarkup: Api.ReplyMarkup?, entities: [Api.MessageEntity]?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { - let buffer = Buffer() - buffer.appendInt32(-1194252757) - serializeInt32(flags, buffer: buffer, boxed: false) - peer.serialize(buffer, true) - if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} - media.serialize(buffer, true) - serializeString(message, buffer: buffer, boxed: false) - serializeInt64(randomId, buffer: buffer, boxed: false) - if Int(flags) & Int(1 << 2) != 0 {replyMarkup!.serialize(buffer, true)} - if Int(flags) & Int(1 << 3) != 0 {buffer.appendInt32(481674261) - buffer.appendInt32(Int32(entities!.count)) - for item in entities! { - item.serialize(buffer, true) - }} - return (FunctionDescription(name: "messages.sendMedia", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("media", media), ("message", message), ("randomId", randomId), ("replyMarkup", replyMarkup), ("entities", entities)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in - let reader = BufferReader(buffer) - var result: Api.Updates? - if let signature = reader.readInt32() { - result = Api.parse(reader, signature: signature) as? Api.Updates - } - return result - }) - } - public static func getMessages(id: [Api.InputMessage]) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { let buffer = Buffer() buffer.appendInt32(1673946374) @@ -2682,30 +2567,6 @@ public extension Api { }) } - public static func editMessage(flags: Int32, peer: Api.InputPeer, id: Int32, message: String?, media: Api.InputMedia?, replyMarkup: Api.ReplyMarkup?, entities: [Api.MessageEntity]?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { - let buffer = Buffer() - buffer.appendInt32(-787025122) - serializeInt32(flags, buffer: buffer, boxed: false) - peer.serialize(buffer, true) - serializeInt32(id, buffer: buffer, boxed: false) - if Int(flags) & Int(1 << 11) != 0 {serializeString(message!, buffer: buffer, boxed: false)} - if Int(flags) & Int(1 << 14) != 0 {media!.serialize(buffer, true)} - if Int(flags) & Int(1 << 2) != 0 {replyMarkup!.serialize(buffer, true)} - if Int(flags) & Int(1 << 3) != 0 {buffer.appendInt32(481674261) - buffer.appendInt32(Int32(entities!.count)) - for item in entities! { - item.serialize(buffer, true) - }} - return (FunctionDescription(name: "messages.editMessage", parameters: [("flags", flags), ("peer", peer), ("id", id), ("message", message), ("media", media), ("replyMarkup", replyMarkup), ("entities", entities)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in - let reader = BufferReader(buffer) - var result: Api.Updates? - if let signature = reader.readInt32() { - result = Api.parse(reader, signature: signature) as? Api.Updates - } - return result - }) - } - public static func editInlineBotMessage(flags: Int32, id: Api.InputBotInlineMessageID, message: String?, media: Api.InputMedia?, replyMarkup: Api.ReplyMarkup?, entities: [Api.MessageEntity]?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { let buffer = Buffer() buffer.appendInt32(-2091549254) @@ -2955,6 +2816,223 @@ public extension Api { return result }) } + + public static func sendMessage(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, message: String, randomId: Int64, replyMarkup: Api.ReplyMarkup?, entities: [Api.MessageEntity]?, scheduleDate: Int32?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(1376532592) + serializeInt32(flags, buffer: buffer, boxed: false) + peer.serialize(buffer, true) + if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} + serializeString(message, buffer: buffer, boxed: false) + serializeInt64(randomId, buffer: buffer, boxed: false) + if Int(flags) & Int(1 << 2) != 0 {replyMarkup!.serialize(buffer, true)} + if Int(flags) & Int(1 << 3) != 0 {buffer.appendInt32(481674261) + buffer.appendInt32(Int32(entities!.count)) + for item in entities! { + item.serialize(buffer, true) + }} + if Int(flags) & Int(1 << 10) != 0 {serializeInt32(scheduleDate!, buffer: buffer, boxed: false)} + return (FunctionDescription(name: "messages.sendMessage", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("message", message), ("randomId", randomId), ("replyMarkup", replyMarkup), ("entities", entities), ("scheduleDate", scheduleDate)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func sendMedia(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, media: Api.InputMedia, message: String, randomId: Int64, replyMarkup: Api.ReplyMarkup?, entities: [Api.MessageEntity]?, scheduleDate: Int32?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(881978281) + serializeInt32(flags, buffer: buffer, boxed: false) + peer.serialize(buffer, true) + if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} + media.serialize(buffer, true) + serializeString(message, buffer: buffer, boxed: false) + serializeInt64(randomId, buffer: buffer, boxed: false) + if Int(flags) & Int(1 << 2) != 0 {replyMarkup!.serialize(buffer, true)} + if Int(flags) & Int(1 << 3) != 0 {buffer.appendInt32(481674261) + buffer.appendInt32(Int32(entities!.count)) + for item in entities! { + item.serialize(buffer, true) + }} + if Int(flags) & Int(1 << 10) != 0 {serializeInt32(scheduleDate!, buffer: buffer, boxed: false)} + return (FunctionDescription(name: "messages.sendMedia", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("media", media), ("message", message), ("randomId", randomId), ("replyMarkup", replyMarkup), ("entities", entities), ("scheduleDate", scheduleDate)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func forwardMessages(flags: Int32, fromPeer: Api.InputPeer, id: [Int32], randomId: [Int64], toPeer: Api.InputPeer, scheduleDate: Int32?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(-637606386) + serializeInt32(flags, buffer: buffer, boxed: false) + fromPeer.serialize(buffer, true) + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(id.count)) + for item in id { + serializeInt32(item, buffer: buffer, boxed: false) + } + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(randomId.count)) + for item in randomId { + serializeInt64(item, buffer: buffer, boxed: false) + } + toPeer.serialize(buffer, true) + if Int(flags) & Int(1 << 10) != 0 {serializeInt32(scheduleDate!, buffer: buffer, boxed: false)} + return (FunctionDescription(name: "messages.forwardMessages", parameters: [("flags", flags), ("fromPeer", fromPeer), ("id", id), ("randomId", randomId), ("toPeer", toPeer), ("scheduleDate", scheduleDate)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func sendInlineBotResult(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, randomId: Int64, queryId: Int64, id: String, scheduleDate: Int32?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(570955184) + serializeInt32(flags, buffer: buffer, boxed: false) + peer.serialize(buffer, true) + if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} + serializeInt64(randomId, buffer: buffer, boxed: false) + serializeInt64(queryId, buffer: buffer, boxed: false) + serializeString(id, buffer: buffer, boxed: false) + if Int(flags) & Int(1 << 10) != 0 {serializeInt32(scheduleDate!, buffer: buffer, boxed: false)} + return (FunctionDescription(name: "messages.sendInlineBotResult", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("randomId", randomId), ("queryId", queryId), ("id", id), ("scheduleDate", scheduleDate)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func editMessage(flags: Int32, peer: Api.InputPeer, id: Int32, message: String?, media: Api.InputMedia?, replyMarkup: Api.ReplyMarkup?, entities: [Api.MessageEntity]?, scheduleDate: Int32?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(1224152952) + serializeInt32(flags, buffer: buffer, boxed: false) + peer.serialize(buffer, true) + serializeInt32(id, buffer: buffer, boxed: false) + if Int(flags) & Int(1 << 11) != 0 {serializeString(message!, buffer: buffer, boxed: false)} + if Int(flags) & Int(1 << 14) != 0 {media!.serialize(buffer, true)} + if Int(flags) & Int(1 << 2) != 0 {replyMarkup!.serialize(buffer, true)} + if Int(flags) & Int(1 << 3) != 0 {buffer.appendInt32(481674261) + buffer.appendInt32(Int32(entities!.count)) + for item in entities! { + item.serialize(buffer, true) + }} + if Int(flags) & Int(1 << 15) != 0 {serializeInt32(scheduleDate!, buffer: buffer, boxed: false)} + return (FunctionDescription(name: "messages.editMessage", parameters: [("flags", flags), ("peer", peer), ("id", id), ("message", message), ("media", media), ("replyMarkup", replyMarkup), ("entities", entities), ("scheduleDate", scheduleDate)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func sendMultiMedia(flags: Int32, peer: Api.InputPeer, replyToMsgId: Int32?, multiMedia: [Api.InputSingleMedia], scheduleDate: Int32?) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(-872345397) + serializeInt32(flags, buffer: buffer, boxed: false) + peer.serialize(buffer, true) + if Int(flags) & Int(1 << 0) != 0 {serializeInt32(replyToMsgId!, buffer: buffer, boxed: false)} + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(multiMedia.count)) + for item in multiMedia { + item.serialize(buffer, true) + } + if Int(flags) & Int(1 << 10) != 0 {serializeInt32(scheduleDate!, buffer: buffer, boxed: false)} + return (FunctionDescription(name: "messages.sendMultiMedia", parameters: [("flags", flags), ("peer", peer), ("replyToMsgId", replyToMsgId), ("multiMedia", multiMedia), ("scheduleDate", scheduleDate)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func getScheduledHistory(peer: Api.InputPeer, hash: Int32) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(-490575781) + peer.serialize(buffer, true) + serializeInt32(hash, buffer: buffer, boxed: false) + return (FunctionDescription(name: "messages.getScheduledHistory", parameters: [("peer", peer), ("hash", hash)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.messages.Messages? in + let reader = BufferReader(buffer) + var result: Api.messages.Messages? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.messages.Messages + } + return result + }) + } + + public static func getScheduledMessages(peer: Api.InputPeer, id: [Int32]) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(-1111817116) + peer.serialize(buffer, true) + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(id.count)) + for item in id { + serializeInt32(item, buffer: buffer, boxed: false) + } + return (FunctionDescription(name: "messages.getScheduledMessages", parameters: [("peer", peer), ("id", id)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.messages.Messages? in + let reader = BufferReader(buffer) + var result: Api.messages.Messages? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.messages.Messages + } + return result + }) + } + + public static func sendScheduledMessages(peer: Api.InputPeer, id: [Int32]) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(-1120369398) + peer.serialize(buffer, true) + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(id.count)) + for item in id { + serializeInt32(item, buffer: buffer, boxed: false) + } + return (FunctionDescription(name: "messages.sendScheduledMessages", parameters: [("peer", peer), ("id", id)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } + + public static func deleteScheduledMessages(peer: Api.InputPeer, id: [Int32]) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { + let buffer = Buffer() + buffer.appendInt32(1504586518) + peer.serialize(buffer, true) + buffer.appendInt32(481674261) + buffer.appendInt32(Int32(id.count)) + for item in id { + serializeInt32(item, buffer: buffer, boxed: false) + } + return (FunctionDescription(name: "messages.deleteScheduledMessages", parameters: [("peer", peer), ("id", id)]), buffer, DeserializeFunctionResponse { (buffer: Buffer) -> Api.Updates? in + let reader = BufferReader(buffer) + var result: Api.Updates? + if let signature = reader.readInt32() { + result = Api.parse(reader, signature: signature) as? Api.Updates + } + return result + }) + } } public struct channels { public static func readHistory(channel: Api.InputChannel, maxId: Int32) -> (FunctionDescription, Buffer, DeserializeFunctionResponse) { diff --git a/submodules/TelegramApi/Sources/Api4.swift b/submodules/TelegramApi/Sources/Api4.swift deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/submodules/TelegramBaseController/Sources/TelegramBaseController.swift b/submodules/TelegramBaseController/Sources/TelegramBaseController.swift index cd66aa00b9..5e59a874f6 100644 --- a/submodules/TelegramBaseController/Sources/TelegramBaseController.swift +++ b/submodules/TelegramBaseController/Sources/TelegramBaseController.swift @@ -169,7 +169,7 @@ open class TelegramBaseController: ViewController, KeyShortcutResponder { }) } - if let liveLocationManager = context.liveLocationManager { + if false, let liveLocationManager = context.liveLocationManager { switch locationBroadcastPanelSource { case .none: self.locationBroadcastMode = nil diff --git a/submodules/TelegramCore/TelegramCore/AccountStateManagementUtils.swift b/submodules/TelegramCore/TelegramCore/AccountStateManagementUtils.swift index cc01b1c903..12a1543f61 100644 --- a/submodules/TelegramCore/TelegramCore/AccountStateManagementUtils.swift +++ b/submodules/TelegramCore/TelegramCore/AccountStateManagementUtils.swift @@ -275,7 +275,7 @@ private func peerIdsRequiringLocalChatStateFromDifference(_ difference: Api.upda switch difference { case let .difference(newMessages, _, otherUpdates, _, _, _): for message in newMessages { - if let messageId = message.id { + if let messageId = message.id() { peerIds.insert(messageId.peerId) } } @@ -296,7 +296,7 @@ private func peerIdsRequiringLocalChatStateFromDifference(_ difference: Api.upda break case let .differenceSlice(newMessages, _, otherUpdates, _, _, _): for message in newMessages { - if let messageId = message.id { + if let messageId = message.id() { peerIds.insert(messageId.peerId) } } @@ -1299,6 +1299,12 @@ private func finalStateWithUpdatesAndServerTime(postbox: Postbox, network: Netwo peersNearby.append(PeerNearby(id: peer.peerId, expires: expires, distance: distance)) } updatedState.updatePeersNearby(peersNearby) + case let .updateDeleteScheduledMessages(peer, messages): + var messageIds: [MessageId] = [] + for message in messages { + messageIds.append(MessageId(peerId: peer.peerId, namespace: Namespaces.Message.CloudScheduled, id: message)) + } + updatedState.deleteMessages(messageIds) default: break } diff --git a/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift b/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift index f18bd66255..f88a700665 100644 --- a/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift +++ b/submodules/TelegramCore/TelegramCore/AccountViewTracker.swift @@ -914,25 +914,25 @@ public final class AccountViewTracker { } } - public func aroundMessageOfInterestHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, tagMask: MessageTags? = nil, orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageOfInterestHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, tagMask: MessageTags? = nil, excludeNamespaces: [MessageId.Namespace] = [Namespaces.Message.CloudScheduled], orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { if let account = self.account { - let signal = account.postbox.aroundMessageOfInterestHistoryViewForChatLocation(chatLocation, count: count, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) + let signal = account.postbox.aroundMessageOfInterestHistoryViewForChatLocation(chatLocation, count: count, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) return wrappedMessageHistorySignal(chatLocation: chatLocation, signal: signal) } else { return .never() } } - public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, tagMask: MessageTags? = nil, orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundIdMessageHistoryViewForLocation(_ chatLocation: ChatLocation, count: Int, messageId: MessageId, tagMask: MessageTags? = nil, excludeNamespaces: [MessageId.Namespace] = [Namespaces.Message.CloudScheduled], orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { if let account = self.account { - let signal = account.postbox.aroundIdMessageHistoryViewForLocation(chatLocation, count: count, messageId: messageId, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) + let signal = account.postbox.aroundIdMessageHistoryViewForLocation(chatLocation, count: count, messageId: messageId, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) return wrappedMessageHistorySignal(chatLocation: chatLocation, signal: signal) } else { return .never() } } - public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, index: MessageHistoryAnchorIndex, anchorIndex: MessageHistoryAnchorIndex, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, tagMask: MessageTags? = nil, orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { + public func aroundMessageHistoryViewForLocation(_ chatLocation: ChatLocation, index: MessageHistoryAnchorIndex, anchorIndex: MessageHistoryAnchorIndex, count: Int, fixedCombinedReadStates: MessageHistoryViewReadState?, tagMask: MessageTags? = nil, excludeNamespaces: [MessageId.Namespace] = [Namespaces.Message.CloudScheduled], orderStatistics: MessageHistoryViewOrderStatistics = [], additionalData: [AdditionalMessageHistoryViewData] = []) -> Signal<(MessageHistoryView, ViewUpdateType, InitialMessageHistoryData?), NoError> { if let account = self.account { let inputAnchor: HistoryViewInputAnchor switch index { @@ -943,7 +943,7 @@ public final class AccountViewTracker { case let .message(index): inputAnchor = .index(index) } - let signal = account.postbox.aroundMessageHistoryViewForLocation(chatLocation, anchor: inputAnchor, count: count, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) + let signal = account.postbox.aroundMessageHistoryViewForLocation(chatLocation, anchor: inputAnchor, count: count, fixedCombinedReadStates: fixedCombinedReadStates, topTaggedMessageIdNamespaces: [Namespaces.Message.Cloud], tagMask: tagMask, excludeNamespaces: excludeNamespaces, orderStatistics: orderStatistics, additionalData: wrappedHistoryViewAdditionalData(chatLocation: chatLocation, additionalData: additionalData)) return wrappedMessageHistorySignal(chatLocation: chatLocation, signal: signal) } else { return .never() diff --git a/submodules/TelegramCore/TelegramCore/AppChangelog.swift b/submodules/TelegramCore/TelegramCore/AppChangelog.swift index 0b5ca59dee..ec4c8ef4e3 100644 --- a/submodules/TelegramCore/TelegramCore/AppChangelog.swift +++ b/submodules/TelegramCore/TelegramCore/AppChangelog.swift @@ -24,11 +24,11 @@ func managedAppChangelog(postbox: Postbox, network: Network, stateManager: Accou } |> mapToSignal { appChangelogState -> Signal in let appChangelogState = appChangelogState - if appChangelogState.checkedVersion == appVersion { - return .complete() - } +// if appChangelogState.checkedVersion == appVersion { +// return .complete() +// } let previousVersion = appChangelogState.previousVersion - return network.request(Api.functions.help.getAppChangelog(prevAppVersion: previousVersion)) + return network.request(Api.functions.help.getAppChangelog(prevAppVersion: "5.9")) //previousVersion)) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) diff --git a/submodules/TelegramCore/TelegramCore/ApplyUpdateMessage.swift b/submodules/TelegramCore/TelegramCore/ApplyUpdateMessage.swift index 851095631b..060a07e923 100644 --- a/submodules/TelegramCore/TelegramCore/ApplyUpdateMessage.swift +++ b/submodules/TelegramCore/TelegramCore/ApplyUpdateMessage.swift @@ -40,7 +40,7 @@ func applyUpdateMessage(postbox: Postbox, stateManager: AccountStateManager, mes var apiMessage: Api.Message? for resultMessage in result.messages { - if let id = resultMessage.id { + if let id = resultMessage.id(namespace: message.scheduleTime != nil ? Namespaces.Message.CloudScheduled : Namespaces.Message.Cloud) { if id.peerId == message.id.peerId { apiMessage = resultMessage break @@ -48,7 +48,7 @@ func applyUpdateMessage(postbox: Postbox, stateManager: AccountStateManager, mes } } - if let apiMessage = apiMessage, let id = apiMessage.id { + if let apiMessage = apiMessage, let id = apiMessage.id(namespace: message.scheduleTime != nil ? Namespaces.Message.CloudScheduled : Namespaces.Message.Cloud) { messageId = id.id } else { messageId = result.rawMessageIds.first @@ -85,7 +85,8 @@ func applyUpdateMessage(postbox: Postbox, stateManager: AccountStateManager, mes transaction.updateMessage(message.id, update: { currentMessage in let updatedId: MessageId if let messageId = messageId { - updatedId = MessageId(peerId: currentMessage.id.peerId, namespace: Namespaces.Message.Cloud, id: messageId) + let namespace = message.scheduleTime != nil ? Namespaces.Message.CloudScheduled : Namespaces.Message.Cloud + updatedId = MessageId(peerId: currentMessage.id.peerId, namespace: namespace, id: messageId) } else { updatedId = currentMessage.id } diff --git a/submodules/TelegramCore/TelegramCore/AutoremoveTimeoutMessageAttribute.swift b/submodules/TelegramCore/TelegramCore/AutoremoveTimeoutMessageAttribute.swift index c0a4f6eea9..5b9b18cd53 100644 --- a/submodules/TelegramCore/TelegramCore/AutoremoveTimeoutMessageAttribute.swift +++ b/submodules/TelegramCore/TelegramCore/AutoremoveTimeoutMessageAttribute.swift @@ -40,7 +40,7 @@ public class AutoremoveTimeoutMessageAttribute: MessageAttribute { } public extension Message { - public var containsSecretMedia: Bool { + var containsSecretMedia: Bool { var found = false for attribute in self.attributes { if let attribute = attribute as? AutoremoveTimeoutMessageAttribute { @@ -72,10 +72,10 @@ public extension Message { return false } - public var secretMediaDuration: Int32? { + var secretMediaDuration: Int32? { var found = false for attribute in self.attributes { - if let attribute = attribute as? AutoremoveTimeoutMessageAttribute { + if let _ = attribute as? AutoremoveTimeoutMessageAttribute { found = true break } diff --git a/submodules/TelegramCore/TelegramCore/ForwardGame.swift b/submodules/TelegramCore/TelegramCore/ForwardGame.swift index d782cc890e..c2facd228f 100644 --- a/submodules/TelegramCore/TelegramCore/ForwardGame.swift +++ b/submodules/TelegramCore/TelegramCore/ForwardGame.swift @@ -12,7 +12,7 @@ import Foundation public func forwardGameWithScore(account: Account, messageId: MessageId, to peerId: PeerId) -> Signal { return account.postbox.transaction { transaction -> Signal in if let message = transaction.getMessage(messageId), let fromPeer = transaction.getPeer(messageId.peerId), let fromInputPeer = apiInputPeer(fromPeer), let toPeer = transaction.getPeer(peerId), let toInputPeer = apiInputPeer(toPeer) { - return account.network.request(Api.functions.messages.forwardMessages(flags: 1 << 8, fromPeer: fromInputPeer, id: [messageId.id], randomId: [arc4random64()], toPeer: toInputPeer)) + return account.network.request(Api.functions.messages.forwardMessages(flags: 1 << 8, fromPeer: fromInputPeer, id: [messageId.id], randomId: [arc4random64()], toPeer: toInputPeer, scheduleDate: nil)) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) diff --git a/submodules/TelegramCore/TelegramCore/Holes.swift b/submodules/TelegramCore/TelegramCore/Holes.swift index 1b7511e425..406deb904b 100644 --- a/submodules/TelegramCore/TelegramCore/Holes.swift +++ b/submodules/TelegramCore/TelegramCore/Holes.swift @@ -150,57 +150,17 @@ func fetchMessageHistoryHole(accountPeerId: PeerId, source: FetchMessageHistoryH let request: Signal var implicitelyFillHole = false let minMaxRange: ClosedRange - switch space { - case .everywhere: - let offsetId: Int32 - let addOffset: Int32 - let selectedLimit = limit - let maxId: Int32 - let minId: Int32 - - switch direction { - case let .range(start, end): - if start.id <= end.id { - offsetId = start.id <= 1 ? 1 : (start.id - 1) - addOffset = Int32(-selectedLimit) - maxId = end.id - minId = start.id - 1 - - let rangeStartId = start.id - let rangeEndId = min(end.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } - } else { - offsetId = start.id == Int32.max ? start.id : (start.id + 1) - addOffset = 0 - maxId = start.id == Int32.max ? start.id : (start.id + 1) - minId = end.id - - let rangeStartId = end.id - let rangeEndId = min(start.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } - } - case let .aroundId(id): - offsetId = id.id - addOffset = Int32(-selectedLimit / 2) - maxId = Int32.max - minId = 1 - minMaxRange = 1 ... Int32.max - 1 - } - - request = source.request(Api.functions.messages.getHistory(peer: inputPeer, offsetId: offsetId, offsetDate: 0, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) - case let .tag(tag): - assert(tag.containsSingleElement) - if tag == .unseenPersonalMessage { + + if namespace == Namespaces.Message.CloudScheduled { + switch direction { + case .aroundId, .range: + implicitelyFillHole = true + } + minMaxRange = 1 ... (Int32.max - 1) + request = source.request(Api.functions.messages.getScheduledHistory(peer: inputPeer, hash: 0)) + } else { + switch space { + case .everywhere: let offsetId: Int32 let addOffset: Int32 let selectedLimit = limit @@ -243,72 +203,122 @@ func fetchMessageHistoryHole(accountPeerId: PeerId, source: FetchMessageHistoryH addOffset = Int32(-selectedLimit / 2) maxId = Int32.max minId = 1 - minMaxRange = 1 ... Int32.max - 1 } - request = source.request(Api.functions.messages.getUnreadMentions(peer: inputPeer, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId)) - } else if tag == .liveLocation { - let selectedLimit = limit - - switch direction { - case .aroundId, .range: - implicitelyFillHole = true - } - minMaxRange = 1 ... (Int32.max - 1) - request = source.request(Api.functions.messages.getRecentLocations(peer: inputPeer, limit: Int32(selectedLimit), hash: 0)) - } else if let filter = messageFilterForTagMask(tag) { - let offsetId: Int32 - let addOffset: Int32 - let selectedLimit = limit - let maxId: Int32 - let minId: Int32 - - switch direction { - case let .range(start, end): - if start.id <= end.id { - offsetId = start.id <= 1 ? 1 : (start.id - 1) - addOffset = Int32(-selectedLimit) - maxId = end.id - minId = start.id - 1 - - let rangeStartId = start.id - let rangeEndId = min(end.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } - } else { - offsetId = start.id == Int32.max ? start.id : (start.id + 1) - addOffset = 0 - maxId = start.id == Int32.max ? start.id : (start.id + 1) - minId = end.id - - let rangeStartId = end.id - let rangeEndId = min(start.id, Int32.max - 1) - if rangeStartId <= rangeEndId { - minMaxRange = rangeStartId ... rangeEndId - } else { - minMaxRange = rangeStartId ... rangeStartId - assertionFailure() - } - } - case let .aroundId(id): - offsetId = id.id - addOffset = Int32(-selectedLimit / 2) - maxId = Int32.max - minId = 1 + request = source.request(Api.functions.messages.getHistory(peer: inputPeer, offsetId: offsetId, offsetDate: 0, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) + case let .tag(tag): + assert(tag.containsSingleElement) + if tag == .unseenPersonalMessage { + let offsetId: Int32 + let addOffset: Int32 + let selectedLimit = limit + let maxId: Int32 + let minId: Int32 - minMaxRange = 1 ... (Int32.max - 1) - } - - request = source.request(Api.functions.messages.search(flags: 0, peer: inputPeer, q: "", fromId: nil, filter: filter, minDate: 0, maxDate: 0, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) - } else { - assertionFailure() - minMaxRange = 1 ... 1 - request = .never() + switch direction { + case let .range(start, end): + if start.id <= end.id { + offsetId = start.id <= 1 ? 1 : (start.id - 1) + addOffset = Int32(-selectedLimit) + maxId = end.id + minId = start.id - 1 + + let rangeStartId = start.id + let rangeEndId = min(end.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId + } else { + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() + } + } else { + offsetId = start.id == Int32.max ? start.id : (start.id + 1) + addOffset = 0 + maxId = start.id == Int32.max ? start.id : (start.id + 1) + minId = end.id + + let rangeStartId = end.id + let rangeEndId = min(start.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId + } else { + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() + } + } + case let .aroundId(id): + offsetId = id.id + addOffset = Int32(-selectedLimit / 2) + maxId = Int32.max + minId = 1 + + minMaxRange = 1 ... Int32.max - 1 + } + + request = source.request(Api.functions.messages.getUnreadMentions(peer: inputPeer, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId)) + } else if tag == .liveLocation { + let selectedLimit = limit + + switch direction { + case .aroundId, .range: + implicitelyFillHole = true + } + minMaxRange = 1 ... (Int32.max - 1) + request = source.request(Api.functions.messages.getRecentLocations(peer: inputPeer, limit: Int32(selectedLimit), hash: 0)) + } else if let filter = messageFilterForTagMask(tag) { + let offsetId: Int32 + let addOffset: Int32 + let selectedLimit = limit + let maxId: Int32 + let minId: Int32 + + switch direction { + case let .range(start, end): + if start.id <= end.id { + offsetId = start.id <= 1 ? 1 : (start.id - 1) + addOffset = Int32(-selectedLimit) + maxId = end.id + minId = start.id - 1 + + let rangeStartId = start.id + let rangeEndId = min(end.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId + } else { + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() + } + } else { + offsetId = start.id == Int32.max ? start.id : (start.id + 1) + addOffset = 0 + maxId = start.id == Int32.max ? start.id : (start.id + 1) + minId = end.id + + let rangeStartId = end.id + let rangeEndId = min(start.id, Int32.max - 1) + if rangeStartId <= rangeEndId { + minMaxRange = rangeStartId ... rangeEndId + } else { + minMaxRange = rangeStartId ... rangeStartId + assertionFailure() + } + } + case let .aroundId(id): + offsetId = id.id + addOffset = Int32(-selectedLimit / 2) + maxId = Int32.max + minId = 1 + + minMaxRange = 1 ... (Int32.max - 1) + } + + request = source.request(Api.functions.messages.search(flags: 0, peer: inputPeer, q: "", fromId: nil, filter: filter, minDate: 0, maxDate: 0, offsetId: offsetId, addOffset: addOffset, limit: Int32(selectedLimit), maxId: maxId, minId: minId, hash: 0)) + } else { + assertionFailure() + minMaxRange = 1 ... 1 + request = .never() + } } } @@ -357,7 +367,7 @@ func fetchMessageHistoryHole(accountPeerId: PeerId, source: FetchMessageHistoryH var storeMessages: [StoreMessage] = [] for message in messages { - if let storeMessage = StoreMessage(apiMessage: message) { + if let storeMessage = StoreMessage(apiMessage: message, namespace: namespace) { if let channelPts = channelPts { var attributes = storeMessage.attributes attributes.append(ChannelMessageStateVersionAttribute(pts: channelPts)) @@ -372,7 +382,7 @@ func fetchMessageHistoryHole(accountPeerId: PeerId, source: FetchMessageHistoryH let _ = transaction.addMessages(storeMessages, location: .Random) let _ = transaction.addMessages(additionalMessages, location: .Random) let filledRange: ClosedRange - let ids = messages.compactMap({ $0.id?.id }) + let ids = messages.compactMap({ $0.id()?.id }) if ids.count == 0 || implicitelyFillHole { filledRange = minMaxRange } else { diff --git a/submodules/TelegramCore/TelegramCore/ManagedCloudChatRemoveMessagesOperations.swift b/submodules/TelegramCore/TelegramCore/ManagedCloudChatRemoveMessagesOperations.swift index 1ea8492b16..c8c00c8453 100644 --- a/submodules/TelegramCore/TelegramCore/ManagedCloudChatRemoveMessagesOperations.swift +++ b/submodules/TelegramCore/TelegramCore/ManagedCloudChatRemoveMessagesOperations.swift @@ -165,38 +165,73 @@ private func removeMessages(postbox: Postbox, network: Network, stateManager: Ac return .complete() } } else { - var flags: Int32 - switch operation.type { - case .forEveryone: - flags = (1 << 0) - default: - flags = 0 + var isScheduled = false + for id in operation.messageIds { + if id.namespace == Namespaces.Message.CloudScheduled { + isScheduled = true + break + } } - - var signal: Signal = .complete() - for s in stride(from: 0, to: operation.messageIds.count, by: 100) { - let ids = Array(operation.messageIds[s ..< min(s + 100, operation.messageIds.count)]) - let partSignal = network.request(Api.functions.messages.deleteMessages(flags: flags, id: ids.map { $0.id })) - |> map { result -> Api.messages.AffectedMessages? in - return result - } - |> `catch` { _ in - return .single(nil) - } - |> mapToSignal { result -> Signal in - if let result = result { - switch result { - case let .affectedMessages(pts, ptsCount): - stateManager.addUpdateGroups([.updatePts(pts: pts, ptsCount: ptsCount)]) + if isScheduled { + if let inputPeer = apiInputPeer(peer) { + var signal: Signal = .complete() + for s in stride(from: 0, to: operation.messageIds.count, by: 100) { + let ids = Array(operation.messageIds[s ..< min(s + 100, operation.messageIds.count)]) + let partSignal = network.request(Api.functions.messages.deleteScheduledMessages(peer: inputPeer, id: ids.map { $0.id })) + |> map { result -> Api.Updates? in + return result } + |> `catch` { _ in + return .single(nil) + } + |> mapToSignal { updates -> Signal in + if let updates = updates { + stateManager.addUpdates(updates) + } + return .complete() + } + + signal = signal + |> then(partSignal) } + return signal + } else { return .complete() } + } else { + var flags: Int32 + switch operation.type { + case .forEveryone: + flags = (1 << 0) + default: + flags = 0 + } - signal = signal - |> then(partSignal) + var signal: Signal = .complete() + for s in stride(from: 0, to: operation.messageIds.count, by: 100) { + let ids = Array(operation.messageIds[s ..< min(s + 100, operation.messageIds.count)]) + let partSignal = network.request(Api.functions.messages.deleteMessages(flags: flags, id: ids.map { $0.id })) + |> map { result -> Api.messages.AffectedMessages? in + return result + } + |> `catch` { _ in + return .single(nil) + } + |> mapToSignal { result -> Signal in + if let result = result { + switch result { + case let .affectedMessages(pts, ptsCount): + stateManager.addUpdateGroups([.updatePts(pts: pts, ptsCount: ptsCount)]) + } + } + return .complete() + } + + signal = signal + |> then(partSignal) + } + return signal } - return signal } } @@ -216,9 +251,9 @@ private func removeChat(transaction: Transaction, postbox: Postbox, network: Net let reportSignal: Signal if let inputPeer = apiInputPeer(peer), operation.reportChatSpam { reportSignal = network.request(Api.functions.messages.reportSpam(peer: inputPeer)) - |> `catch` { _ -> Signal in - return .single(.boolFalse) - } + |> `catch` { _ -> Signal in + return .single(.boolFalse) + } } else { reportSignal = .single(.boolTrue) } diff --git a/submodules/TelegramCore/TelegramCore/ManagedSynchronizeMarkAllUnseenPersonalMessagesOperations.swift b/submodules/TelegramCore/TelegramCore/ManagedSynchronizeMarkAllUnseenPersonalMessagesOperations.swift index 239f132567..d5185e07df 100644 --- a/submodules/TelegramCore/TelegramCore/ManagedSynchronizeMarkAllUnseenPersonalMessagesOperations.swift +++ b/submodules/TelegramCore/TelegramCore/ManagedSynchronizeMarkAllUnseenPersonalMessagesOperations.swift @@ -137,13 +137,13 @@ private func synchronizeMarkAllUnseen(transaction: Transaction, postbox: Postbox |> mapToSignal { result -> Signal<[MessageId], MTRpcError> in switch result { case let .messages(messages, _, _): - return .single(messages.compactMap({ $0.id })) + return .single(messages.compactMap({ $0.id() })) case let .channelMessages(channelMessages): - return .single(channelMessages.messages.compactMap({ $0.id })) + return .single(channelMessages.messages.compactMap({ $0.id() })) case .messagesNotModified: return .single([]) case let .messagesSlice(messagesSlice): - return .single(messagesSlice.messages.compactMap({ $0.id })) + return .single(messagesSlice.messages.compactMap({ $0.id() })) } } |> mapToSignal { ids -> Signal in diff --git a/submodules/TelegramCore/TelegramCore/Namespaces.swift b/submodules/TelegramCore/TelegramCore/Namespaces.swift index 367b947145..0cb523bdc6 100644 --- a/submodules/TelegramCore/TelegramCore/Namespaces.swift +++ b/submodules/TelegramCore/TelegramCore/Namespaces.swift @@ -10,6 +10,7 @@ public struct Namespaces { public static let Cloud: Int32 = 0 public static let Local: Int32 = 1 public static let SecretIncoming: Int32 = 2 + public static let CloudScheduled: Int32 = 3 } public struct Media { @@ -135,9 +136,9 @@ public struct OperationLogTags { } public extension PeerSummaryCounterTags { - public static let regularChatsAndPrivateGroups = PeerSummaryCounterTags(rawValue: 1 << 0) - public static let publicGroups = PeerSummaryCounterTags(rawValue: 1 << 1) - public static let channels = PeerSummaryCounterTags(rawValue: 1 << 2) + static let regularChatsAndPrivateGroups = PeerSummaryCounterTags(rawValue: 1 << 0) + static let publicGroups = PeerSummaryCounterTags(rawValue: 1 << 1) + static let channels = PeerSummaryCounterTags(rawValue: 1 << 2) } private enum PreferencesKeyValues: Int32 { diff --git a/submodules/TelegramCore/TelegramCore/OutgoingContentInfoMessageAttribute.swift b/submodules/TelegramCore/TelegramCore/OutgoingContentInfoMessageAttribute.swift index 75be97b25a..132bc279fc 100644 --- a/submodules/TelegramCore/TelegramCore/OutgoingContentInfoMessageAttribute.swift +++ b/submodules/TelegramCore/TelegramCore/OutgoingContentInfoMessageAttribute.swift @@ -21,20 +21,43 @@ public struct OutgoingContentInfoFlags: OptionSet { public class OutgoingContentInfoMessageAttribute: MessageAttribute { public let flags: OutgoingContentInfoFlags + public let scheduleTime: Int32? - public init(flags: OutgoingContentInfoFlags) { + public init(flags: OutgoingContentInfoFlags, scheduleTime: Int32?) { self.flags = flags + self.scheduleTime = scheduleTime } required public init(decoder: PostboxDecoder) { self.flags = OutgoingContentInfoFlags(rawValue: decoder.decodeInt32ForKey("f", orElse: 0)) + self.scheduleTime = decoder.decodeOptionalInt32ForKey("t") } public func encode(_ encoder: PostboxEncoder) { encoder.encodeInt32(self.flags.rawValue, forKey: "f") + if let scheduleTime = self.scheduleTime { + encoder.encodeInt32(scheduleTime, forKey: "t") + } else { + encoder.encodeNil(forKey: "t") + } } public func withUpdatedFlags(_ flags: OutgoingContentInfoFlags) -> OutgoingContentInfoMessageAttribute { - return OutgoingContentInfoMessageAttribute(flags: flags) + return OutgoingContentInfoMessageAttribute(flags: flags, scheduleTime: self.scheduleTime) + } + + public func withUpdatedScheduleTime(_ scheduleTime: Int32?) -> OutgoingContentInfoMessageAttribute { + return OutgoingContentInfoMessageAttribute(flags: self.flags, scheduleTime: scheduleTime) + } +} + +public extension Message { + var scheduleTime: Int32? { + for attribute in self.attributes { + if let attribute = attribute as? OutgoingContentInfoMessageAttribute, let scheduleTime = attribute.scheduleTime { + return scheduleTime + } + } + return nil } } diff --git a/submodules/TelegramCore/TelegramCore/OutgoingMessageInfoAttribute.swift b/submodules/TelegramCore/TelegramCore/OutgoingMessageInfoAttribute.swift index 123124fc26..93cb325e89 100644 --- a/submodules/TelegramCore/TelegramCore/OutgoingMessageInfoAttribute.swift +++ b/submodules/TelegramCore/TelegramCore/OutgoingMessageInfoAttribute.swift @@ -52,7 +52,7 @@ public class OutgoingMessageInfoAttribute: MessageAttribute { } public extension Message { - public var isSentOrAcknowledged: Bool { + var isSentOrAcknowledged: Bool { if self.flags.contains(.Failed) { return false } else if self.flags.isSending { diff --git a/submodules/TelegramCore/TelegramCore/PendingMessageManager.swift b/submodules/TelegramCore/TelegramCore/PendingMessageManager.swift index f3b3013918..06daa8b574 100644 --- a/submodules/TelegramCore/TelegramCore/PendingMessageManager.swift +++ b/submodules/TelegramCore/TelegramCore/PendingMessageManager.swift @@ -663,7 +663,7 @@ public final class PendingMessageManager { } else if let inputSourcePeerId = forwardPeerIds.first, let inputSourcePeer = transaction.getPeer(inputSourcePeerId).flatMap(apiInputPeer) { let dependencyTag = PendingMessageRequestDependencyTag(messageId: messages[0].0.id) - sendMessageRequest = network.request(Api.functions.messages.forwardMessages(flags: flags, fromPeer: inputSourcePeer, id: forwardIds.map { $0.0.id }, randomId: forwardIds.map { $0.1 }, toPeer: inputPeer), tag: dependencyTag) + sendMessageRequest = network.request(Api.functions.messages.forwardMessages(flags: flags, fromPeer: inputSourcePeer, id: forwardIds.map { $0.0.id }, randomId: forwardIds.map { $0.1 }, toPeer: inputPeer, scheduleDate: nil), tag: dependencyTag) } else { assertionFailure() sendMessageRequest = .fail(MTRpcError(errorCode: 400, errorDescription: "Invalid forward source")) @@ -707,7 +707,7 @@ public final class PendingMessageManager { } } - sendMessageRequest = network.request(Api.functions.messages.sendMultiMedia(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, multiMedia: singleMedias)) + sendMessageRequest = network.request(Api.functions.messages.sendMultiMedia(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, multiMedia: singleMedias, scheduleDate: nil)) } return sendMessageRequest @@ -877,6 +877,7 @@ public final class PendingMessageManager { var forwardSourceInfoAttribute: ForwardSourceInfoAttribute? var messageEntities: [Api.MessageEntity]? var replyMessageId: Int32? + var scheduleTime: Int32? var flags: Int32 = 0 @@ -893,6 +894,10 @@ public final class PendingMessageManager { if attribute.flags.contains(.disableLinkPreviews) { flags |= Int32(1 << 1) } + if let time = attribute.scheduleTime { + flags |= Int32(1 << 10) + scheduleTime = time + } } else if let attribute = attribute as? NotificationInfoMessageAttribute { if attribute.flags.contains(.muted) { flags |= Int32(1 << 5) @@ -917,13 +922,13 @@ public final class PendingMessageManager { let sendMessageRequest: Signal, MTRpcError> switch content.content { case .text: - sendMessageRequest = network.requestWithAdditionalInfo(Api.functions.messages.sendMessage(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, message: message.text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities), info: .acknowledgement, tag: dependencyTag) + sendMessageRequest = network.requestWithAdditionalInfo(Api.functions.messages.sendMessage(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, message: message.text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities, scheduleDate: scheduleTime), info: .acknowledgement, tag: dependencyTag) case let .media(inputMedia, text): - sendMessageRequest = network.request(Api.functions.messages.sendMedia(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, media: inputMedia, message: text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities), tag: dependencyTag) + sendMessageRequest = network.request(Api.functions.messages.sendMedia(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, media: inputMedia, message: text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities, scheduleDate: scheduleTime), tag: dependencyTag) |> map(NetworkRequestResult.result) case let .forward(sourceInfo): if let forwardSourceInfoAttribute = forwardSourceInfoAttribute, let sourcePeer = transaction.getPeer(forwardSourceInfoAttribute.messageId.peerId), let sourceInputPeer = apiInputPeer(sourcePeer) { - sendMessageRequest = network.request(Api.functions.messages.forwardMessages(flags: flags, fromPeer: sourceInputPeer, id: [sourceInfo.messageId.id], randomId: [uniqueId], toPeer: inputPeer), tag: dependencyTag) + sendMessageRequest = network.request(Api.functions.messages.forwardMessages(flags: flags, fromPeer: sourceInputPeer, id: [sourceInfo.messageId.id], randomId: [uniqueId], toPeer: inputPeer, scheduleDate: nil), tag: dependencyTag) |> map(NetworkRequestResult.result) } else { sendMessageRequest = .fail(MTRpcError(errorCode: 400, errorDescription: "internal")) @@ -932,7 +937,7 @@ public final class PendingMessageManager { if chatContextResult.hideVia { flags |= Int32(1 << 11) } - sendMessageRequest = network.request(Api.functions.messages.sendInlineBotResult(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, randomId: uniqueId, queryId: chatContextResult.queryId, id: chatContextResult.id)) + sendMessageRequest = network.request(Api.functions.messages.sendInlineBotResult(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, randomId: uniqueId, queryId: chatContextResult.queryId, id: chatContextResult.id, scheduleDate: nil)) |> map(NetworkRequestResult.result) case .messageScreenshot: sendMessageRequest = network.request(Api.functions.messages.sendScreenshotNotification(peer: inputPeer, replyToMsgId: replyMessageId ?? 0, randomId: uniqueId)) diff --git a/submodules/TelegramCore/TelegramCore/PendingMessageUploadedContent.swift b/submodules/TelegramCore/TelegramCore/PendingMessageUploadedContent.swift index d4a62c5ba5..d2b84f230e 100644 --- a/submodules/TelegramCore/TelegramCore/PendingMessageUploadedContent.swift +++ b/submodules/TelegramCore/TelegramCore/PendingMessageUploadedContent.swift @@ -304,7 +304,7 @@ private func uploadedMediaImageContent(network: Network, postbox: Postbox, trans storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: nil) } var updatedAttributes = currentMessage.attributes - if let index = updatedAttributes.index(where: { $0 is OutgoingMessageInfoAttribute }){ + if let index = updatedAttributes.firstIndex(where: { $0 is OutgoingMessageInfoAttribute }){ let attribute = updatedAttributes[index] as! OutgoingMessageInfoAttribute updatedAttributes[index] = attribute.withUpdatedFlags(attribute.flags.union([.transformedMedia])) } else { @@ -566,7 +566,7 @@ private func uploadedMediaFileContent(network: Network, postbox: Postbox, auxili storeForwardInfo = StoreMessageForwardInfo(authorId: forwardInfo.author?.id, sourceId: forwardInfo.source?.id, sourceMessageId: forwardInfo.sourceMessageId, date: forwardInfo.date, authorSignature: nil) } var updatedAttributes = currentMessage.attributes - if let index = updatedAttributes.index(where: { $0 is OutgoingMessageInfoAttribute }){ + if let index = updatedAttributes.firstIndex(where: { $0 is OutgoingMessageInfoAttribute }){ let attribute = updatedAttributes[index] as! OutgoingMessageInfoAttribute updatedAttributes[index] = attribute.withUpdatedFlags(attribute.flags.union([.transformedMedia])) } else { diff --git a/submodules/TelegramCore/TelegramCore/Polls.swift b/submodules/TelegramCore/TelegramCore/Polls.swift index c6223c533d..155aa5c311 100644 --- a/submodules/TelegramCore/TelegramCore/Polls.swift +++ b/submodules/TelegramCore/TelegramCore/Polls.swift @@ -60,7 +60,7 @@ public func requestClosePoll(postbox: Postbox, network: Network, stateManager: A } var flags: Int32 = 0 flags |= 1 << 14 - return network.request(Api.functions.messages.editMessage(flags: flags, peer: inputPeer, id: messageId.id, message: nil, media: .inputMediaPoll(poll: .poll(id: poll.pollId.id, flags: 1 << 0, question: poll.text, answers: poll.options.map({ $0.apiOption }))), replyMarkup: nil, entities: nil)) + return network.request(Api.functions.messages.editMessage(flags: flags, peer: inputPeer, id: messageId.id, message: nil, media: .inputMediaPoll(poll: .poll(id: poll.pollId.id, flags: 1 << 0, question: poll.text, answers: poll.options.map({ $0.apiOption }))), replyMarkup: nil, entities: nil, scheduleDate: nil)) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) diff --git a/submodules/TelegramCore/TelegramCore/RequestEditMessage.swift b/submodules/TelegramCore/TelegramCore/RequestEditMessage.swift index 3cb90b9ed0..4652f9782e 100644 --- a/submodules/TelegramCore/TelegramCore/RequestEditMessage.swift +++ b/submodules/TelegramCore/TelegramCore/RequestEditMessage.swift @@ -150,7 +150,7 @@ private func requestEditMessageInternal(account: Account, messageId: MessageId, flags |= Int32(1 << 14) } - return account.network.request(Api.functions.messages.editMessage(flags: flags, peer: inputPeer, id: messageId.id, message: text, media: inputMedia, replyMarkup: nil, entities: apiEntities)) + return account.network.request(Api.functions.messages.editMessage(flags: flags, peer: inputPeer, id: messageId.id, message: text, media: inputMedia, replyMarkup: nil, entities: apiEntities, scheduleDate: nil)) |> map { result -> Api.Updates? in return result } @@ -173,7 +173,7 @@ private func requestEditMessageInternal(account: Account, messageId: MessageId, if let result = result { return account.postbox.transaction { transaction -> RequestEditMessageResult in var toMedia: Media? - if let message = result.messages.first.flatMap(StoreMessage.init(apiMessage:)) { + if let message = result.messages.first.flatMap({ StoreMessage(apiMessage: $0) }) { toMedia = message.media.first } @@ -223,7 +223,7 @@ public func requestEditLiveLocation(postbox: Postbox, network: Network, stateMan } else { inputMedia = .inputMediaGeoLive(flags: 1 << 0, geoPoint: .inputGeoPoint(lat: media.latitude, long: media.longitude), period: nil) } - return network.request(Api.functions.messages.editMessage(flags: 1 << 14, peer: inputPeer, id: messageId.id, message: nil, media: inputMedia, replyMarkup: nil, entities: nil)) + return network.request(Api.functions.messages.editMessage(flags: 1 << 14, peer: inputPeer, id: messageId.id, message: nil, media: inputMedia, replyMarkup: nil, entities: nil, scheduleDate: nil)) |> map(Optional.init) |> `catch` { _ -> Signal in return .single(nil) diff --git a/submodules/TelegramCore/TelegramCore/Serialization.swift b/submodules/TelegramCore/TelegramCore/Serialization.swift index 2a78e8b6c2..06a094ff21 100644 --- a/submodules/TelegramCore/TelegramCore/Serialization.swift +++ b/submodules/TelegramCore/TelegramCore/Serialization.swift @@ -220,7 +220,7 @@ public class BoxedMessage: NSObject { public class Serialization: NSObject, MTSerialization { public func currentLayer() -> UInt { - return 104 + return 105 } public func parseMessage(_ data: Data!) -> Any! { diff --git a/submodules/TelegramCore/TelegramCore/StandaloneSendMessage.swift b/submodules/TelegramCore/TelegramCore/StandaloneSendMessage.swift index 692a5f5916..2ffda19507 100644 --- a/submodules/TelegramCore/TelegramCore/StandaloneSendMessage.swift +++ b/submodules/TelegramCore/TelegramCore/StandaloneSendMessage.swift @@ -87,6 +87,7 @@ private func sendMessageContent(account: Account, peerId: PeerId, attributes: [M //var forwardSourceInfoAttribute: ForwardSourceInfoAttribute? var messageEntities: [Api.MessageEntity]? var replyMessageId: Int32? + var scheduleTime: Int32? var flags: Int32 = 0 @@ -105,6 +106,10 @@ private func sendMessageContent(account: Account, peerId: PeerId, attributes: [M if attribute.flags.contains(.disableLinkPreviews) { flags |= Int32(1 << 1) } + if let time = attribute.scheduleTime { + flags |= Int32(1 << 10) + scheduleTime = time + } } } @@ -118,12 +123,12 @@ private func sendMessageContent(account: Account, peerId: PeerId, attributes: [M let sendMessageRequest: Signal switch content { case let .text(text): - sendMessageRequest = account.network.request(Api.functions.messages.sendMessage(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, message: text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities)) + sendMessageRequest = account.network.request(Api.functions.messages.sendMessage(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, message: text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities, scheduleDate: scheduleTime)) |> `catch` { _ -> Signal in return .complete() } case let .media(inputMedia, text): - sendMessageRequest = account.network.request(Api.functions.messages.sendMedia(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, media: inputMedia, message: text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities)) + sendMessageRequest = account.network.request(Api.functions.messages.sendMedia(flags: flags, peer: inputPeer, replyToMsgId: replyMessageId, media: inputMedia, message: text, randomId: uniqueId, replyMarkup: nil, entities: messageEntities, scheduleDate: scheduleTime)) |> `catch` { _ -> Signal in return .complete() } diff --git a/submodules/TelegramCore/TelegramCore/StoreMessage_Telegram.swift b/submodules/TelegramCore/TelegramCore/StoreMessage_Telegram.swift index b6c467fac7..81dd0bca2c 100644 --- a/submodules/TelegramCore/TelegramCore/StoreMessage_Telegram.swift +++ b/submodules/TelegramCore/TelegramCore/StoreMessage_Telegram.swift @@ -380,7 +380,7 @@ func messageTextEntitiesFromApiEntities(_ entities: [Api.MessageEntity]) -> [Mes } extension StoreMessage { - convenience init?(apiMessage: Api.Message) { + convenience init?(apiMessage: Api.Message, namespace: MessageId.Namespace = Namespaces.Message.Cloud) { switch apiMessage { case let .message(flags, id, fromId, toId, fwdFrom, viaBotId, replyToMsgId, date, message, media, replyMarkup, entities, views, editDate, postAuthor, groupingId): let peerId: PeerId @@ -568,7 +568,7 @@ extension StoreMessage { storeFlags.insert(.CanBeGroupedIntoFeed) - self.init(id: MessageId(peerId: peerId, namespace: Namespaces.Message.Cloud, id: id), globallyUniqueId: nil, groupingKey: groupingId, timestamp: date, flags: storeFlags, tags: tags, globalTags: globalTags, localTags: [], forwardInfo: forwardInfo, authorId: authorId, text: messageText, attributes: attributes, media: medias) + self.init(id: MessageId(peerId: peerId, namespace: namespace, id: id), globallyUniqueId: nil, groupingKey: groupingId, timestamp: date, flags: storeFlags, tags: tags, globalTags: globalTags, localTags: [], forwardInfo: forwardInfo, authorId: authorId, text: messageText, attributes: attributes, media: medias) case .messageEmpty: return nil case let .messageService(flags, id, fromId, toId, replyToMsgId, date, action): @@ -632,7 +632,7 @@ extension StoreMessage { storeFlags.insert(.CanBeGroupedIntoFeed) - self.init(id: MessageId(peerId: peerId, namespace: Namespaces.Message.Cloud, id: id), globallyUniqueId: nil, groupingKey: nil, timestamp: date, flags: storeFlags, tags: tags, globalTags: globalTags, localTags: [], forwardInfo: nil, authorId: authorId, text: "", attributes: attributes, media: media) + self.init(id: MessageId(peerId: peerId, namespace: namespace, id: id), globallyUniqueId: nil, groupingKey: nil, timestamp: date, flags: storeFlags, tags: tags, globalTags: globalTags, localTags: [], forwardInfo: nil, authorId: authorId, text: "", attributes: attributes, media: media) } } } diff --git a/submodules/TelegramCore/TelegramCore/UpdatesApiUtils.swift b/submodules/TelegramCore/TelegramCore/UpdatesApiUtils.swift index a44ed98572..e46f7a08f1 100644 --- a/submodules/TelegramCore/TelegramCore/UpdatesApiUtils.swift +++ b/submodules/TelegramCore/TelegramCore/UpdatesApiUtils.swift @@ -109,19 +109,25 @@ extension Api.Message { } } - var id: MessageId? { + func id(namespace: MessageId.Namespace = Namespaces.Message.Cloud) -> MessageId? { switch self { case let .message(flags, id, fromId, toId, _, _, _, _, _, _, _, _, _, _, _, _): let peerId: PeerId switch toId { case let .peerUser(userId): - peerId = PeerId(namespace: Namespaces.Peer.CloudUser, id: (flags & Int32(2)) != 0 ? userId : (fromId ?? userId)) + let id: PeerId.Id + if namespace == Namespaces.Message.CloudScheduled { + id = userId + } else { + id = (flags & Int32(2)) != 0 ? userId : (fromId ?? userId) + } + peerId = PeerId(namespace: Namespaces.Peer.CloudUser, id: id) case let .peerChat(chatId): peerId = PeerId(namespace: Namespaces.Peer.CloudGroup, id: chatId) case let .peerChannel(channelId): peerId = PeerId(namespace: Namespaces.Peer.CloudChannel, id: channelId) } - return MessageId(peerId: peerId, namespace: Namespaces.Message.Cloud, id: id) + return MessageId(peerId: peerId, namespace: namespace, id: id) case .messageEmpty: return nil case let .messageService(flags, id, fromId, toId, _, _, _): @@ -134,7 +140,6 @@ extension Api.Message { case let .peerChannel(channelId): peerId = PeerId(namespace: Namespaces.Peer.CloudChannel, id: channelId) } - return MessageId(peerId: peerId, namespace: Namespaces.Message.Cloud, id: id) } } @@ -238,9 +243,9 @@ extension Api.Update { var messageId: MessageId? { switch self { case let .updateNewMessage(message, _, _): - return message.id + return message.id() case let .updateNewChannelMessage(message, _, _): - return message.id + return message.id() default: return nil } @@ -256,6 +261,8 @@ extension Api.Update { return message case let .updateEditChannelMessage(message, _, _): return message + case let .updateNewScheduledMessage(message): + return message default: return nil } @@ -315,6 +322,8 @@ extension Api.Update { } case let .updateDraftMessage(peer: peer, draft: _): return [peer.peerId] + case let .updateNewScheduledMessage(message): + return apiMessagePeerIds(message) default: return [] } @@ -328,6 +337,8 @@ extension Api.Update { return apiMessageAssociatedMessageIds(message) case let .updateEditChannelMessage(message, _, _): return apiMessageAssociatedMessageIds(message) + case let .updateNewScheduledMessage(message): + return apiMessageAssociatedMessageIds(message) default: break } diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 67eaf8ce9e..e7eff075f4 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -934,3687 +934,3703 @@ public final class PresentationStrings { public var Calls_Missed: String { return self._s[682]! } public var Cache_Photos: String { return self._s[686]! } public var GroupPermission_NoAddMembers: String { return self._s[687]! } + public var ScheduledMessages_Title: String { return self._s[688]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[688]!, self._r[688]!, [_0]) + return formatWithArgumentRanges(self._s[689]!, self._r[689]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[689]! } - public var Settings_ProxyDisabled: String { return self._s[690]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[690]! } + public var Settings_ProxyDisabled: String { return self._s[691]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[691]!, self._r[691]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[692]!, self._r[692]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[692]!, self._r[692]!, [_0]) + return formatWithArgumentRanges(self._s[693]!, self._r[693]!, [_0]) } - public var Appearance_Title: String { return self._s[694]! } + public var Appearance_Title: String { return self._s[695]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[696]!, self._r[696]!, [_0]) + return formatWithArgumentRanges(self._s[697]!, self._r[697]!, [_0]) } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[697]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[698]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[699]! } - public var Preview_DeletePhoto: String { return self._s[700]! } - public var Appearance_AppIconFilledX: String { return self._s[701]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[702]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[698]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[699]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[700]! } + public var Preview_DeletePhoto: String { return self._s[701]! } + public var Appearance_AppIconFilledX: String { return self._s[702]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[703]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[703]!, self._r[703]!, [_0]) + return formatWithArgumentRanges(self._s[704]!, self._r[704]!, [_0]) } - public var Coub_TapForSound: String { return self._s[705]! } - public var Map_LocatingError: String { return self._s[706]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[708]! } - public var Conversation_SendMessage_SendSilently: String { return self._s[709]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[710]! } - public var Passport_ForgottenPassword: String { return self._s[711]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[712]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[713]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[715]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[716]! } - public var Message_Location: String { return self._s[717]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[718]! } - public var Channel_Management_Title: String { return self._s[719]! } - public var DialogList_SearchSectionDialogs: String { return self._s[721]! } - public var Compose_NewChannel_Members: String { return self._s[722]! } + public var Coub_TapForSound: String { return self._s[706]! } + public var Map_LocatingError: String { return self._s[707]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[709]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[710]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[711]! } + public var Passport_ForgottenPassword: String { return self._s[712]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[713]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[714]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[716]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[717]! } + public var Message_Location: String { return self._s[718]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[719]! } + public var Channel_Management_Title: String { return self._s[720]! } + public var DialogList_SearchSectionDialogs: String { return self._s[722]! } + public var Compose_NewChannel_Members: String { return self._s[723]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[723]!, self._r[723]!, [_0]) + return formatWithArgumentRanges(self._s[724]!, self._r[724]!, [_0]) } - public var GroupInfo_Location: String { return self._s[724]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[725]! } - public var PhotoEditor_WarmthTool: String { return self._s[726]! } - public var Passport_Language_tr: String { return self._s[727]! } + public var GroupInfo_Location: String { return self._s[725]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[726]! } + public var PhotoEditor_WarmthTool: String { return self._s[727]! } + public var Passport_Language_tr: String { return self._s[728]! } public func PUSH_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[728]!, self._r[728]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[729]!, self._r[729]!, [_1, _2, _3]) } - public var Login_ResetAccountProtected_Reset: String { return self._s[730]! } - public var Watch_PhotoView_Title: String { return self._s[731]! } - public var Passport_Phone_Delete: String { return self._s[732]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[733]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[734]! } - public var GroupInfo_Permissions: String { return self._s[735]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[736]! } - public var Profile_ShareContactButton: String { return self._s[737]! } - public var ChatSettings_Other: String { return self._s[738]! } - public var UserInfo_NotificationsDisabled: String { return self._s[739]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[740]! } - public var LastSeen_WithinAMonth: String { return self._s[741]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[742]! } - public var Conversation_ReportGroupLocation: String { return self._s[743]! } - public var Conversation_EncryptionCanceled: String { return self._s[744]! } - public var MediaPicker_GroupDescription: String { return self._s[745]! } - public var WebSearch_Images: String { return self._s[746]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[731]! } + public var Watch_PhotoView_Title: String { return self._s[732]! } + public var Passport_Phone_Delete: String { return self._s[733]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[734]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[735]! } + public var GroupInfo_Permissions: String { return self._s[736]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[737]! } + public var Profile_ShareContactButton: String { return self._s[738]! } + public var ChatSettings_Other: String { return self._s[739]! } + public var UserInfo_NotificationsDisabled: String { return self._s[740]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[741]! } + public var LastSeen_WithinAMonth: String { return self._s[742]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[743]! } + public var Conversation_ReportGroupLocation: String { return self._s[744]! } + public var Conversation_EncryptionCanceled: String { return self._s[745]! } + public var MediaPicker_GroupDescription: String { return self._s[746]! } + public var WebSearch_Images: String { return self._s[747]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[747]!, self._r[747]!, [_0]) + return formatWithArgumentRanges(self._s[748]!, self._r[748]!, [_0]) } - public var Message_Photo: String { return self._s[748]! } - public var PasscodeSettings_HelpBottom: String { return self._s[749]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[750]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[751]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[752]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[753]! } - public var NotificationsSound_Calypso: String { return self._s[754]! } - public var Map_Map: String { return self._s[755]! } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[757]! } - public var ChatSettings_TextSizeUnits: String { return self._s[758]! } + public var Message_Photo: String { return self._s[749]! } + public var PasscodeSettings_HelpBottom: String { return self._s[750]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[751]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[752]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[753]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[754]! } + public var NotificationsSound_Calypso: String { return self._s[755]! } + public var Map_Map: String { return self._s[756]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[758]! } + public var ChatSettings_TextSizeUnits: String { return self._s[759]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[759]!, self._r[759]!, [_0]) + return formatWithArgumentRanges(self._s[760]!, self._r[760]!, [_0]) } - public var Common_of: String { return self._s[760]! } - public var Conversation_ForwardContacts: String { return self._s[763]! } + public var Common_of: String { return self._s[761]! } + public var Conversation_ForwardContacts: String { return self._s[764]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[765]!, self._r[765]!, [_0]) + return formatWithArgumentRanges(self._s[766]!, self._r[766]!, [_0]) } - public var Passport_Language_hy: String { return self._s[766]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[767]! } - public var AutoDownloadSettings_Reset: String { return self._s[768]! } - public var Paint_ClearConfirm: String { return self._s[769]! } - public var Camera_VideoMode: String { return self._s[770]! } + public var Passport_Language_hy: String { return self._s[767]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[768]! } + public var AutoDownloadSettings_Reset: String { return self._s[769]! } + public var Paint_ClearConfirm: String { return self._s[770]! } + public var Camera_VideoMode: String { return self._s[771]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[771]!, self._r[771]!, [_0]) + return formatWithArgumentRanges(self._s[772]!, self._r[772]!, [_0]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[772]! } - public var Conversation_ViewBackground: String { return self._s[773]! } - public var Passport_Language_el: String { return self._s[774]! } - public var PhotoEditor_Original: String { return self._s[775]! } - public var Settings_FAQ_Button: String { return self._s[777]! } - public var Channel_Setup_PublicNoLink: String { return self._s[779]! } - public var Conversation_UnsupportedMedia: String { return self._s[780]! } - public var Conversation_SlideToCancel: String { return self._s[781]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[782]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[783]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[784]! } - public var AutoNightTheme_NotAvailable: String { return self._s[785]! } - public var Conversation_Owner: String { return self._s[786]! } - public var Common_Create: String { return self._s[787]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[788]! } - public var Localization_ChooseLanguage: String { return self._s[790]! } - public var Settings_Proxy: String { return self._s[793]! } - public var Privacy_TopPeersHelp: String { return self._s[794]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[795]! } - public var Chat_UnsendMyMessages: String { return self._s[796]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[773]! } + public var Conversation_ViewBackground: String { return self._s[774]! } + public var Passport_Language_el: String { return self._s[775]! } + public var PhotoEditor_Original: String { return self._s[776]! } + public var Settings_FAQ_Button: String { return self._s[778]! } + public var Channel_Setup_PublicNoLink: String { return self._s[780]! } + public var Conversation_UnsupportedMedia: String { return self._s[781]! } + public var Conversation_SlideToCancel: String { return self._s[782]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[783]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[784]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[785]! } + public var AutoNightTheme_NotAvailable: String { return self._s[786]! } + public var Conversation_Owner: String { return self._s[787]! } + public var Common_Create: String { return self._s[788]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[789]! } + public var Localization_ChooseLanguage: String { return self._s[791]! } + public var Settings_Proxy: String { return self._s[794]! } + public var Privacy_TopPeersHelp: String { return self._s[795]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[796]! } + public var Chat_UnsendMyMessages: String { return self._s[797]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[797]!, self._r[797]!, [_0]) + return formatWithArgumentRanges(self._s[798]!, self._r[798]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[798]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[799]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[800]!, self._r[800]!, [_0]) + return formatWithArgumentRanges(self._s[801]!, self._r[801]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[801]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[802]! } - public var Cache_Title: String { return self._s[803]! } + public var Contacts_SortedByPresence: String { return self._s[802]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[803]! } + public var Cache_Title: String { return self._s[804]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[804]!, self._r[804]!, [_0]) + return formatWithArgumentRanges(self._s[805]!, self._r[805]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[805]! } - public var Channel_Moderator_Title: String { return self._s[806]! } - public var InstantPage_AutoNightTheme: String { return self._s[808]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[806]! } + public var Channel_Moderator_Title: String { return self._s[807]! } + public var InstantPage_AutoNightTheme: String { return self._s[809]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[811]!, self._r[811]!, [_1]) + return formatWithArgumentRanges(self._s[812]!, self._r[812]!, [_1]) } - public var Passport_Scans_Upload: String { return self._s[812]! } - public var Undo_Undo: String { return self._s[814]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[815]! } - public var TwoStepAuth_RemovePassword: String { return self._s[816]! } - public var Common_Delete: String { return self._s[817]! } - public var Contacts_AddPeopleNearby: String { return self._s[819]! } - public var Conversation_ContextMenuDelete: String { return self._s[820]! } - public var SocksProxySetup_Credentials: String { return self._s[821]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[823]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[826]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[827]! } - public var Passport_Language_id: String { return self._s[829]! } - public var WallpaperSearch_ColorTeal: String { return self._s[830]! } - public var ChannelIntro_Title: String { return self._s[831]! } + public var Passport_Scans_Upload: String { return self._s[813]! } + public var Undo_Undo: String { return self._s[815]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[816]! } + public var TwoStepAuth_RemovePassword: String { return self._s[817]! } + public var Common_Delete: String { return self._s[818]! } + public var Contacts_AddPeopleNearby: String { return self._s[820]! } + public var Conversation_ContextMenuDelete: String { return self._s[821]! } + public var SocksProxySetup_Credentials: String { return self._s[822]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[824]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[827]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[828]! } + public var Passport_Language_id: String { return self._s[830]! } + public var WallpaperSearch_ColorTeal: String { return self._s[831]! } + public var ChannelIntro_Title: String { return self._s[832]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[832]!, self._r[832]!, [_0]) + return formatWithArgumentRanges(self._s[833]!, self._r[833]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[834]! } - public var VoiceOver_Chat_Reply: String { return self._s[835]! } - public var Channel_Info_Description: String { return self._s[836]! } - public var Stickers_FavoriteStickers: String { return self._s[837]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[838]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[839]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[840]! } - public var Group_PublicLink_Placeholder: String { return self._s[841]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[842]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[835]! } + public var VoiceOver_Chat_Reply: String { return self._s[836]! } + public var Channel_Info_Description: String { return self._s[837]! } + public var Stickers_FavoriteStickers: String { return self._s[838]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[839]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[840]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[841]! } + public var Group_PublicLink_Placeholder: String { return self._s[842]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[843]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[843]!, self._r[843]!, [_1]) + return formatWithArgumentRanges(self._s[844]!, self._r[844]!, [_1]) } - public var TextFormat_Underline: String { return self._s[844]! } + public var TextFormat_Underline: String { return self._s[845]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[845]!, self._r[845]!, [_1, _2]) + return formatWithArgumentRanges(self._s[846]!, self._r[846]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[846]!, self._r[846]!, [_0]) + return formatWithArgumentRanges(self._s[847]!, self._r[847]!, [_0]) } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[847]!, self._r[847]!, [_1, _2]) + return formatWithArgumentRanges(self._s[848]!, self._r[848]!, [_1, _2]) } - public var GroupPermission_Delete: String { return self._s[848]! } - public var Passport_Language_uk: String { return self._s[849]! } - public var StickerPack_HideStickers: String { return self._s[851]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[852]! } + public var GroupPermission_Delete: String { return self._s[849]! } + public var Passport_Language_uk: String { return self._s[850]! } + public var StickerPack_HideStickers: String { return self._s[852]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[853]! } public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[853]!, self._r[853]!, [_1, _2]) + return formatWithArgumentRanges(self._s[854]!, self._r[854]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[854]! } + public var Activity_UploadingVideoMessage: String { return self._s[855]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[855]!, self._r[855]!, [_0]) + return formatWithArgumentRanges(self._s[856]!, self._r[856]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[856]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[857]! } - public var Settings_CallSettings: String { return self._s[858]! } - public var Camera_SquareMode: String { return self._s[859]! } - public var GroupInfo_SharedMediaNone: String { return self._s[860]! } + public var Channel_TitleInfo: String { return self._s[857]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[858]! } + public var Settings_CallSettings: String { return self._s[859]! } + public var Camera_SquareMode: String { return self._s[860]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[861]! } + public var GroupInfo_SharedMediaNone: String { return self._s[862]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[861]!, self._r[861]!, [_1]) + return formatWithArgumentRanges(self._s[863]!, self._r[863]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[862]! } - public var Application_Update: String { return self._s[864]! } - public var Month_ShortJanuary: String { return self._s[865]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[866]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[867]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[868]! } - public var Passport_Address_Street2Placeholder: String { return self._s[869]! } + public var Bot_GenericBotStatus: String { return self._s[864]! } + public var Application_Update: String { return self._s[866]! } + public var Month_ShortJanuary: String { return self._s[867]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[868]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[869]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[870]! } + public var Passport_Address_Street2Placeholder: String { return self._s[871]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[870]!, self._r[870]!, [_0]) + return formatWithArgumentRanges(self._s[872]!, self._r[872]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[871]! } - public var Appearance_PreviewOutgoingText: String { return self._s[872]! } - public var Notifications_PermissionsAllowInSettings: String { return self._s[873]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[875]! } - public var Map_Directions: String { return self._s[876]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[878]! } - public var Appearance_ThemeDay: String { return self._s[879]! } - public var LogoutOptions_LogOut: String { return self._s[880]! } - public var Group_PublicLink_Title: String { return self._s[882]! } - public var Channel_AddBotErrorNoRights: String { return self._s[883]! } - public var Passport_Identity_AddPassport: String { return self._s[884]! } - public var LocalGroup_ButtonTitle: String { return self._s[885]! } - public var Call_Message: String { return self._s[886]! } - public var PhotoEditor_ExposureTool: String { return self._s[887]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[889]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[891]! } - public var Appearance_Preview: String { return self._s[892]! } - public var Compose_ChannelMembers: String { return self._s[893]! } - public var Conversation_DeleteManyMessages: String { return self._s[894]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[895]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[896]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[897]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[900]! } - public var Conversation_UpdateTelegram: String { return self._s[901]! } + public var NetworkUsageSettings_Cellular: String { return self._s[873]! } + public var Appearance_PreviewOutgoingText: String { return self._s[874]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[875]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[877]! } + public var Map_Directions: String { return self._s[878]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[880]! } + public var Appearance_ThemeDay: String { return self._s[881]! } + public var LogoutOptions_LogOut: String { return self._s[882]! } + public var Group_PublicLink_Title: String { return self._s[884]! } + public var Channel_AddBotErrorNoRights: String { return self._s[885]! } + public var Passport_Identity_AddPassport: String { return self._s[886]! } + public var LocalGroup_ButtonTitle: String { return self._s[887]! } + public var Call_Message: String { return self._s[888]! } + public var PhotoEditor_ExposureTool: String { return self._s[889]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[891]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[893]! } + public var Appearance_Preview: String { return self._s[894]! } + public var Compose_ChannelMembers: String { return self._s[895]! } + public var Conversation_DeleteManyMessages: String { return self._s[896]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[897]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[898]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[899]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[902]! } + public var Conversation_UpdateTelegram: String { return self._s[903]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[902]!, self._r[902]!, [_0]) + return formatWithArgumentRanges(self._s[904]!, self._r[904]!, [_0]) } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[903]!, self._r[903]!, [_1]) + return formatWithArgumentRanges(self._s[905]!, self._r[905]!, [_1]) } - public var GroupInfo_Administrators_Title: String { return self._s[904]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[905]! } + public var GroupInfo_Administrators_Title: String { return self._s[906]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[907]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[906]!, self._r[906]!, [_0]) + return formatWithArgumentRanges(self._s[908]!, self._r[908]!, [_0]) } - public var Tour_Title3: String { return self._s[907]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[908]! } - public var Clipboard_SendPhoto: String { return self._s[912]! } - public var MediaPicker_Videos: String { return self._s[913]! } - public var Passport_Email_Title: String { return self._s[914]! } + public var Tour_Title3: String { return self._s[909]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[910]! } + public var Clipboard_SendPhoto: String { return self._s[914]! } + public var MediaPicker_Videos: String { return self._s[915]! } + public var Passport_Email_Title: String { return self._s[916]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[915]!, self._r[915]!, [_0]) + return formatWithArgumentRanges(self._s[917]!, self._r[917]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[916]! } - public var Conversation_MessageDialogDelete: String { return self._s[917]! } - public var Privacy_Calls_CustomHelp: String { return self._s[919]! } - public var Message_Wallpaper: String { return self._s[920]! } - public var MemberSearch_BotSection: String { return self._s[921]! } - public var GroupInfo_SetSound: String { return self._s[922]! } - public var Core_ServiceUserStatus: String { return self._s[923]! } - public var LiveLocationUpdated_JustNow: String { return self._s[924]! } - public var Call_StatusFailed: String { return self._s[925]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[926]! } - public var TwoStepAuth_SetPassword: String { return self._s[927]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[928]! } + public var StickerPacksSettings_Title: String { return self._s[918]! } + public var Conversation_MessageDialogDelete: String { return self._s[919]! } + public var Privacy_Calls_CustomHelp: String { return self._s[921]! } + public var Message_Wallpaper: String { return self._s[922]! } + public var MemberSearch_BotSection: String { return self._s[923]! } + public var GroupInfo_SetSound: String { return self._s[924]! } + public var Core_ServiceUserStatus: String { return self._s[925]! } + public var LiveLocationUpdated_JustNow: String { return self._s[926]! } + public var Call_StatusFailed: String { return self._s[927]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[928]! } + public var TwoStepAuth_SetPassword: String { return self._s[929]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[930]! } public func SocksProxySetup_ProxyStatusPing(_ _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 Calls_SubmitRating: String { return self._s[931]! } - public var Profile_Username: String { return self._s[932]! } - public var Bot_DescriptionTitle: String { return self._s[933]! } - public var MaskStickerSettings_Title: String { return self._s[934]! } - public var SharedMedia_CategoryOther: String { return self._s[935]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[936]! } - public var Common_NotNow: String { return self._s[937]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[938]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[939]! } - public var Map_Location: String { return self._s[940]! } - public var Invitation_JoinGroup: String { return self._s[941]! } - public var AutoDownloadSettings_Title: String { return self._s[943]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[944]! } - public var Channel_ErrorAddBlocked: String { return self._s[945]! } - public var Conversation_UnblockUser: String { return self._s[946]! } - public var Watch_Bot_Restart: String { return self._s[947]! } - public var TwoStepAuth_Title: String { return self._s[948]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[949]! } - public var Checkout_ShippingMethod: String { return self._s[950]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[951]! } + public var Calls_SubmitRating: String { return self._s[933]! } + public var Profile_Username: String { return self._s[934]! } + public var Bot_DescriptionTitle: String { return self._s[935]! } + public var MaskStickerSettings_Title: String { return self._s[936]! } + public var SharedMedia_CategoryOther: String { return self._s[937]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[938]! } + public var Common_NotNow: String { return self._s[939]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[940]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[941]! } + public var Map_Location: String { return self._s[942]! } + public var Invitation_JoinGroup: String { return self._s[943]! } + public var AutoDownloadSettings_Title: String { return self._s[945]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[946]! } + public var Channel_ErrorAddBlocked: String { return self._s[947]! } + public var Conversation_UnblockUser: String { return self._s[948]! } + public var Watch_Bot_Restart: String { return self._s[949]! } + public var TwoStepAuth_Title: String { return self._s[950]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[951]! } + public var Checkout_ShippingMethod: String { return self._s[952]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[953]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[952]!, self._r[952]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[954]!, self._r[954]!, [_1, _2, _3]) } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[954]!, self._r[954]!, [_0]) + return formatWithArgumentRanges(self._s[956]!, self._r[956]!, [_0]) } public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[955]!, self._r[955]!, [_0]) + return formatWithArgumentRanges(self._s[957]!, self._r[957]!, [_0]) } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[956]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[957]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[958]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[959]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[960]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[961]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[962]! } - public var Checkout_PaymentMethod_Title: String { return self._s[963]! } - public var SocksProxySetup_Connection: String { return self._s[964]! } - public var Group_MessagePhotoRemoved: String { return self._s[965]! } - public var Channel_Stickers_NotFound: String { return self._s[967]! } - public var Group_About_Help: String { return self._s[968]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[969]! } - public var PeopleNearby_Title: String { return self._s[971]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[958]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[959]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[960]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[961]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[962]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[963]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[964]! } + public var Checkout_PaymentMethod_Title: String { return self._s[965]! } + public var SocksProxySetup_Connection: String { return self._s[966]! } + public var Group_MessagePhotoRemoved: String { return self._s[967]! } + public var Channel_Stickers_NotFound: String { return self._s[969]! } + public var Group_About_Help: String { return self._s[970]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[971]! } + public var PeopleNearby_Title: String { return self._s[973]! } public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[972]!, self._r[972]!, [_1]) + return formatWithArgumentRanges(self._s[974]!, self._r[974]!, [_1]) } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[974]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[975]! } - public var SocksProxySetup_Password: String { return self._s[976]! } - public var Notifications_PermissionsEnable: String { return self._s[977]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[979]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[976]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[977]! } + public var SocksProxySetup_Password: String { return self._s[978]! } + public var Notifications_PermissionsEnable: String { return self._s[979]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[981]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[980]!, self._r[980]!, [_1]) + return formatWithArgumentRanges(self._s[982]!, self._r[982]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[982]!, self._r[982]!, [_0]) + return formatWithArgumentRanges(self._s[984]!, self._r[984]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[983]! } - public var ArchivedPacksAlert_Title: String { return self._s[984]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[985]! } + public var ArchivedPacksAlert_Title: String { return self._s[986]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[985]!, self._r[985]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[987]!, self._r[987]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[986]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[988]! } - public var Conversation_StatusTyping: String { return self._s[989]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[990]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[991]! } - public var UserInfo_CreateNewContact: String { return self._s[992]! } - public var Passport_Identity_FrontSide: String { return self._s[993]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[994]! } - public var Calls_CallTabTitle: String { return self._s[995]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[996]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[988]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[990]! } + public var Conversation_StatusTyping: String { return self._s[991]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[992]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[993]! } + public var UserInfo_CreateNewContact: String { return self._s[994]! } + public var Passport_Identity_FrontSide: String { return self._s[995]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[996]! } + public var Calls_CallTabTitle: String { return self._s[997]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[998]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[997]!, self._r[997]!, [_0]) + return formatWithArgumentRanges(self._s[999]!, self._r[999]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[998]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[999]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1000]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1001]! } - public var Paint_Stickers: String { return self._s[1002]! } - public var Privacy_GroupsAndChannels: String { return self._s[1003]! } - public var UserInfo_AddContact: String { return self._s[1005]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1000]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1001]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1002]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1003]! } + public var Paint_Stickers: String { return self._s[1004]! } + public var Privacy_GroupsAndChannels: String { return self._s[1005]! } + public var UserInfo_AddContact: String { return self._s[1007]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1006]!, self._r[1006]!, [_0]) + return formatWithArgumentRanges(self._s[1008]!, self._r[1008]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1008]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1010]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1010]!, self._r[1010]!, [_0]) + return formatWithArgumentRanges(self._s[1012]!, self._r[1012]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1011]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1012]! } - public var BlockedUsers_BlockUser: String { return self._s[1013]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1014]! } - public var MediaPicker_UngroupDescription: String { return self._s[1015]! } - public var Watch_NoConnection: String { return self._s[1016]! } - public var Month_GenSeptember: String { return self._s[1017]! } - public var Conversation_ViewGroup: String { return self._s[1018]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1021]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1022]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1023]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1024]! } - public var MediaPicker_CameraRoll: String { return self._s[1026]! } - public var Month_GenAugust: String { return self._s[1027]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1028]! } - public var SharedMedia_EmptyText: String { return self._s[1029]! } - public var Map_ShareLiveLocation: String { return self._s[1030]! } - public var Calls_All: String { return self._s[1031]! } - public var Appearance_ThemeNight: String { return self._s[1034]! } - public var Conversation_HoldForAudio: String { return self._s[1035]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1038]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1039]! } - public var SocksProxySetup_Secret: String { return self._s[1040]! } + public var DialogList_NoMessagesTitle: String { return self._s[1013]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1014]! } + public var BlockedUsers_BlockUser: String { return self._s[1015]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1016]! } + public var MediaPicker_UngroupDescription: String { return self._s[1017]! } + public var Watch_NoConnection: String { return self._s[1018]! } + public var Month_GenSeptember: String { return self._s[1019]! } + public var Conversation_ViewGroup: String { return self._s[1020]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1023]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1024]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1025]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1026]! } + public var MediaPicker_CameraRoll: String { return self._s[1028]! } + public var Month_GenAugust: String { return self._s[1029]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1030]! } + public var SharedMedia_EmptyText: String { return self._s[1031]! } + public var Map_ShareLiveLocation: String { return self._s[1032]! } + public var Calls_All: String { return self._s[1033]! } + public var Appearance_ThemeNight: String { return self._s[1036]! } + public var Conversation_HoldForAudio: String { return self._s[1037]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1040]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1041]! } + public var SocksProxySetup_Secret: String { return self._s[1042]! } public func Activity_RemindAboutChannel(_ _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 Channel_BanList_RestrictedTitle: String { return self._s[1043]! } - public var Conversation_Location: String { return self._s[1044]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1045]! } + public var Conversation_Location: String { return self._s[1046]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1045]!, self._r[1045]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1047]!, self._r[1047]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1047]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1048]! } - public var Notifications_PermissionsText: String { return self._s[1049]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1050]! } - public var Call_Flip: String { return self._s[1051]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1053]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1055]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1057]! } - public var Channel_TooMuchBots: String { return self._s[1059]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1060]! } - public var Login_InvalidCodeError: String { return self._s[1061]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1062]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1049]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1050]! } + public var Notifications_PermissionsText: String { return self._s[1051]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1052]! } + public var Call_Flip: String { return self._s[1053]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1055]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1057]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1059]! } + public var Channel_TooMuchBots: String { return self._s[1061]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1062]! } + public var Login_InvalidCodeError: String { return self._s[1063]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1064]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1063]!, self._r[1063]!, [_0]) + return formatWithArgumentRanges(self._s[1065]!, self._r[1065]!, [_0]) } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1064]!, self._r[1064]!, [_0]) + return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1065]! } - public var Call_CallInProgressTitle: String { return self._s[1066]! } - public var Month_ShortSeptember: String { return self._s[1067]! } - public var Watch_ChannelInfo_Title: String { return self._s[1068]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1071]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1072]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1073]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1074]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1075]! } - public var PhotoEditor_CropReset: String { return self._s[1076]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1078]! } - public var Channel_Management_LabelEditor: String { return self._s[1079]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1081]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1082]! } - public var UserInfo_Title: String { return self._s[1083]! } - public var ChatList_HideAction: String { return self._s[1084]! } - public var AccessDenied_Title: String { return self._s[1085]! } - public var DialogList_SearchLabel: String { return self._s[1086]! } - public var Group_Setup_HistoryHidden: String { return self._s[1087]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1088]! } - public var State_Updating: String { return self._s[1090]! } - public var Contacts_TabTitle: String { return self._s[1091]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1093]! } - public var GroupInfo_GroupHistory: String { return self._s[1094]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1095]! } - public var Wallpaper_SetColor: String { return self._s[1096]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1097]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1098]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1099]! } - public var Contacts_NotRegisteredSection: String { return self._s[1100]! } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1067]! } + public var Call_CallInProgressTitle: String { return self._s[1068]! } + public var Month_ShortSeptember: String { return self._s[1069]! } + public var Watch_ChannelInfo_Title: String { return self._s[1070]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1073]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1074]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1075]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1076]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1077]! } + public var PhotoEditor_CropReset: String { return self._s[1078]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1080]! } + public var Channel_Management_LabelEditor: String { return self._s[1081]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1083]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1084]! } + public var UserInfo_Title: String { return self._s[1085]! } + public var ChatList_HideAction: String { return self._s[1086]! } + public var AccessDenied_Title: String { return self._s[1087]! } + public var DialogList_SearchLabel: String { return self._s[1088]! } + public var Group_Setup_HistoryHidden: String { return self._s[1089]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1090]! } + public var State_Updating: String { return self._s[1092]! } + public var Contacts_TabTitle: String { return self._s[1093]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1095]! } + public var GroupInfo_GroupHistory: String { return self._s[1096]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1097]! } + public var Wallpaper_SetColor: String { return self._s[1098]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1099]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1100]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1101]! } + public var Contacts_NotRegisteredSection: String { return self._s[1102]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1101]!, self._r[1101]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1103]!, self._r[1103]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1102]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1103]! } - public var SocksProxySetup_Connecting: String { return self._s[1104]! } - public var ExplicitContent_AlertChannel: String { return self._s[1105]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1106]! } - public var Conversation_Contact: String { return self._s[1107]! } - public var Login_CodeExpired: String { return self._s[1108]! } - public var Passport_DiscardMessageAction: String { return self._s[1109]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1110]! } + public var Paint_Clear: String { return self._s[1104]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1105]! } + public var SocksProxySetup_Connecting: String { return self._s[1106]! } + public var ExplicitContent_AlertChannel: String { return self._s[1107]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1108]! } + public var Conversation_Contact: String { return self._s[1109]! } + public var Login_CodeExpired: String { return self._s[1110]! } + public var Passport_DiscardMessageAction: String { return self._s[1111]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1112]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1111]!, self._r[1111]!, [_0]) + return formatWithArgumentRanges(self._s[1113]!, self._r[1113]!, [_0]) } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1112]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1113]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1114]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1115]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1114]!, self._r[1114]!, [_0]) + return formatWithArgumentRanges(self._s[1116]!, self._r[1116]!, [_0]) } - public var Month_ShortApril: String { return self._s[1115]! } - public var AuthSessions_CurrentSession: String { return self._s[1116]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1119]! } - public var WallpaperPreview_CropTopText: String { return self._s[1121]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1122]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1123]! } - public var Channel_Setup_TypePrivate: String { return self._s[1125]! } - public var Forward_ChannelReadOnly: String { return self._s[1128]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1129]! } - public var AddContact_SharedContactException: String { return self._s[1130]! } - public var UserInfo_BotPrivacy: String { return self._s[1132]! } - public var Notification_PassportValueEmail: String { return self._s[1133]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1134]! } - public var GroupPermission_NewTitle: String { return self._s[1135]! } - public var CallFeedback_ReasonDropped: String { return self._s[1136]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1137]! } - public var Channel_SignMessages_Help: String { return self._s[1139]! } - public var Undo_ChatDeleted: String { return self._s[1141]! } - public var Conversation_ChatBackground: String { return self._s[1142]! } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1143]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1144]! } - public var Passport_Language_pt: String { return self._s[1145]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1146]! } - public var NotificationsSound_Popcorn: String { return self._s[1149]! } - public var AutoNightTheme_Disabled: String { return self._s[1150]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1151]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1152]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1153]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1154]! } + public var Month_ShortApril: String { return self._s[1117]! } + public var AuthSessions_CurrentSession: String { return self._s[1118]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1121]! } + public var WallpaperPreview_CropTopText: String { return self._s[1123]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1124]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1125]! } + public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1126]!, self._r[1126]!, [_0, _1]) + } + public var Channel_Setup_TypePrivate: String { return self._s[1128]! } + public var Forward_ChannelReadOnly: String { return self._s[1131]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1132]! } + public var AddContact_SharedContactException: String { return self._s[1133]! } + public var UserInfo_BotPrivacy: String { return self._s[1135]! } + public var Notification_PassportValueEmail: String { return self._s[1136]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1137]! } + public var GroupPermission_NewTitle: String { return self._s[1138]! } + public var CallFeedback_ReasonDropped: String { return self._s[1139]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1140]! } + public var Channel_SignMessages_Help: String { return self._s[1142]! } + public var Undo_ChatDeleted: String { return self._s[1144]! } + public var Conversation_ChatBackground: String { return self._s[1145]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1146]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1147]! } + public var Passport_Language_pt: String { return self._s[1148]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1149]! } + public var NotificationsSound_Popcorn: String { return self._s[1152]! } + public var AutoNightTheme_Disabled: String { return self._s[1153]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1154]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1155]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1156]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1157]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1155]!, self._r[1155]!, [_0]) + return formatWithArgumentRanges(self._s[1158]!, self._r[1158]!, [_0]) } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1156]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1157]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1159]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1159]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1160]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1162]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1160]!, self._r[1160]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1163]!, self._r[1163]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1163]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1164]! } - public var Compose_NewEncryptedChat: String { return self._s[1165]! } - public var Login_CodeFloodError: String { return self._s[1166]! } - public var Calls_TabTitle: String { return self._s[1167]! } - public var Privacy_ProfilePhoto: String { return self._s[1168]! } - public var Passport_Language_he: String { return self._s[1169]! } - public var GroupPermission_Title: String { return self._s[1170]! } + public var SocksProxySetup_Hostname: String { return self._s[1166]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1167]! } + public var Compose_NewEncryptedChat: String { return self._s[1168]! } + public var Login_CodeFloodError: String { return self._s[1169]! } + public var Calls_TabTitle: String { return self._s[1170]! } + public var Privacy_ProfilePhoto: String { return self._s[1171]! } + public var Passport_Language_he: String { return self._s[1172]! } + public var GroupPermission_Title: String { return self._s[1173]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1171]!, self._r[1171]!, [_0]) + return formatWithArgumentRanges(self._s[1174]!, self._r[1174]!, [_0]) } - public var GroupPermission_NoChangeInfo: String { return self._s[1172]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1173]! } - public var Tour_Text1: String { return self._s[1174]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1175]! } - public var Month_ShortFebruary: String { return self._s[1176]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1177]! } - public var NotificationsSound_Glass: String { return self._s[1178]! } - public var Appearance_ThemeNightBlue: String { return self._s[1179]! } - public var CheckoutInfo_Pay: String { return self._s[1180]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1182]! } - public var Call_CallAgain: String { return self._s[1184]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1185]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1186]! } - public var Passport_InvalidPasswordError: String { return self._s[1187]! } - public var Watch_Message_Game: String { return self._s[1188]! } - public var Stickers_Install: String { return self._s[1189]! } - public var VoiceOver_Chat_Message: String { return self._s[1190]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1191]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1193]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1194]! } - public var AuthSessions_OtherSessions: String { return self._s[1195]! } - public var Channel_Username_Help: String { return self._s[1196]! } - public var Camera_Title: String { return self._s[1197]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1199]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1200]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1201]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1202]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1203]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1204]! } - public var Conversation_RestrictedStickers: String { return self._s[1205]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1207]! } - public var UserInfo_TelegramCall: String { return self._s[1209]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1210]! } - public var CreatePoll_OptionsHeader: String { return self._s[1211]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1212]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1213]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1214]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1215]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1175]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1176]! } + public var Tour_Text1: String { return self._s[1177]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1178]! } + public var Month_ShortFebruary: String { return self._s[1179]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1180]! } + public var NotificationsSound_Glass: String { return self._s[1181]! } + public var Appearance_ThemeNightBlue: String { return self._s[1182]! } + public var CheckoutInfo_Pay: String { return self._s[1183]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1185]! } + public var Call_CallAgain: String { return self._s[1187]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1188]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1189]! } + public var Passport_InvalidPasswordError: String { return self._s[1190]! } + public var Watch_Message_Game: String { return self._s[1191]! } + public var Stickers_Install: String { return self._s[1192]! } + public var VoiceOver_Chat_Message: String { return self._s[1193]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1194]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1196]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1197]! } + public var AuthSessions_OtherSessions: String { return self._s[1198]! } + public var Channel_Username_Help: String { return self._s[1199]! } + public var Camera_Title: String { return self._s[1200]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1202]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1203]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1204]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1205]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1206]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1207]! } + public var Conversation_RestrictedStickers: String { return self._s[1208]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1210]! } + public var UserInfo_TelegramCall: String { return self._s[1212]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1213]! } + public var CreatePoll_OptionsHeader: String { return self._s[1214]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1215]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1216]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1217]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1218]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1216]!, self._r[1216]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1219]!, self._r[1219]!, [_1, _2, _3]) } - public var Settings_SaveEditedPhotos: String { return self._s[1217]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1218]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1219]! } - public var Conversation_MessageDialogRetry: String { return self._s[1220]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1221]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1222]! } - public var Group_Setup_TypeHeader: String { return self._s[1223]! } - public var Paint_RecentStickers: String { return self._s[1224]! } - public var PhotoEditor_GrainTool: String { return self._s[1225]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1226]! } - public var EmptyGroupInfo_Line4: String { return self._s[1227]! } - public var Watch_AuthRequired: String { return self._s[1229]! } + public var Settings_SaveEditedPhotos: String { return self._s[1220]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1221]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1222]! } + public var Conversation_MessageDialogRetry: String { return self._s[1223]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1224]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1225]! } + public var Group_Setup_TypeHeader: String { return self._s[1226]! } + public var Paint_RecentStickers: String { return self._s[1227]! } + public var PhotoEditor_GrainTool: String { return self._s[1228]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1229]! } + public var EmptyGroupInfo_Line4: String { return self._s[1230]! } + public var Watch_AuthRequired: String { return self._s[1232]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1230]!, self._r[1230]!, [_0]) + return formatWithArgumentRanges(self._s[1233]!, self._r[1233]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1231]! } - public var ChannelIntro_Text: String { return self._s[1232]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1233]! } - public var GroupPermission_NoSendMedia: String { return self._s[1234]! } - public var Calls_AddTab: String { return self._s[1235]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1236]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1237]! } - public var Notification_MessageLifetime1d: String { return self._s[1238]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1239]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1240]! } - public var Passport_Identity_GenderFemale: String { return self._s[1241]! } - public var BlockedUsers_BlockTitle: String { return self._s[1242]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1234]! } + public var ChannelIntro_Text: String { return self._s[1235]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1236]! } + public var GroupPermission_NoSendMedia: String { return self._s[1237]! } + public var Calls_AddTab: String { return self._s[1238]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1239]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1240]! } + public var Notification_MessageLifetime1d: String { return self._s[1241]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1242]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1243]! } + public var Passport_Identity_GenderFemale: String { return self._s[1244]! } + public var BlockedUsers_BlockTitle: String { return self._s[1245]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1243]!, self._r[1243]!, [_1]) + return formatWithArgumentRanges(self._s[1246]!, self._r[1246]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1244]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1245]! } - public var ChatList_ArchiveAction: String { return self._s[1246]! } - public var AutoNightTheme_Scheduled: String { return self._s[1247]! } + public var Weekday_Yesterday: String { return self._s[1247]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1248]! } + public var ChatList_ArchiveAction: String { return self._s[1249]! } + public var AutoNightTheme_Scheduled: String { return self._s[1250]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1248]!, self._r[1248]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1251]!, self._r[1251]!, [_1, _2, _3, _4, _5, _6]) } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1249]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1252]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1250]!, self._r[1250]!, [_1, _2]) - } - public var CreatePoll_Create: String { return self._s[1251]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1252]! } - public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1253]!, self._r[1253]!, [_1, _2]) } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1254]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1256]! } - public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1257]!, self._r[1257]!, [_1]) + public var CreatePoll_Create: String { return self._s[1254]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1255]! } + public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1256]!, self._r[1256]!, [_1, _2]) } - public var Preview_OpenInInstagram: String { return self._s[1258]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1259]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1257]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1259]! } + public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1260]!, self._r[1260]!, [_1]) + } + public var Preview_OpenInInstagram: String { return self._s[1261]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1262]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1260]!, self._r[1260]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1263]!, self._r[1263]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1261]!, self._r[1261]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1264]!, self._r[1264]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1262]! } - public var ArchivedChats_IntroText3: String { return self._s[1263]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1264]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1265]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1266]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1265]! } + public var ArchivedChats_IntroText3: String { return self._s[1266]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1267]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1268]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1269]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1267]!, self._r[1267]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1270]!, self._r[1270]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1269]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1270]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1271]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1272]! } - public var Gif_NoGifsFound: String { return self._s[1273]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1274]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1275]! } - public var GroupInfo_ActionPromote: String { return self._s[1276]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1277]! } - public var GroupInfo_Permissions_Title: String { return self._s[1278]! } - public var Permissions_ContactsText_v0: String { return self._s[1279]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1280]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1283]! } - public var Passport_FieldEmailHelp: String { return self._s[1284]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1272]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1273]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1274]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1275]! } + public var Gif_NoGifsFound: String { return self._s[1276]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1277]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1278]! } + public var GroupInfo_ActionPromote: String { return self._s[1279]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1280]! } + public var GroupInfo_Permissions_Title: String { return self._s[1281]! } + public var Permissions_ContactsText_v0: String { return self._s[1282]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1283]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1286]! } + public var Passport_FieldEmailHelp: String { return self._s[1287]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1285]!, self._r[1285]!, [_0]) + return formatWithArgumentRanges(self._s[1288]!, self._r[1288]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1286]! } - public var Weekday_ShortSaturday: String { return self._s[1287]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1288]! } - public var Watch_Conversation_UserInfo: String { return self._s[1289]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1290]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1291]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1292]! } - public var PhotoEditor_VignetteTool: String { return self._s[1293]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1294]! } - public var Passport_Language_et: String { return self._s[1295]! } - public var AppUpgrade_Running: String { return self._s[1296]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1298]! } - public var Passport_Language_bg: String { return self._s[1299]! } - public var Stickers_NoStickersFound: String { return self._s[1301]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1289]! } + public var Weekday_ShortSaturday: String { return self._s[1290]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1291]! } + public var Watch_Conversation_UserInfo: String { return self._s[1292]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1293]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1294]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1295]! } + public var PhotoEditor_VignetteTool: String { return self._s[1296]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1297]! } + public var Passport_Language_et: String { return self._s[1298]! } + public var AppUpgrade_Running: String { return self._s[1299]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1301]! } + public var Passport_Language_bg: String { return self._s[1302]! } + public var Stickers_NoStickersFound: String { return self._s[1304]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1303]!, self._r[1303]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1306]!, self._r[1306]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1304]!, self._r[1304]!, [_0]) + return formatWithArgumentRanges(self._s[1307]!, self._r[1307]!, [_0]) } - public var Settings_About: String { return self._s[1305]! } + public var Settings_About: String { return self._s[1308]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1306]!, self._r[1306]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1309]!, self._r[1309]!, [_0, _1, _2]) } - public var KeyCommand_NewMessage: String { return self._s[1308]! } - public var Group_ErrorAddBlocked: String { return self._s[1309]! } + public var KeyCommand_NewMessage: String { return self._s[1311]! } + public var Group_ErrorAddBlocked: String { return self._s[1312]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1310]!, self._r[1310]!, [_0]) + return formatWithArgumentRanges(self._s[1313]!, self._r[1313]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1311]! } - public var ReportGroupLocation_Title: String { return self._s[1312]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1313]! } - public var Cache_ClearProgress: String { return self._s[1314]! } + public var Map_LocationTitle: String { return self._s[1314]! } + public var ReportGroupLocation_Title: String { return self._s[1315]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1316]! } + public var Cache_ClearProgress: String { return self._s[1317]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1315]!, self._r[1315]!, [_0]) + return formatWithArgumentRanges(self._s[1318]!, self._r[1318]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1316]! } - public var Passport_UpdateRequiredError: String { return self._s[1317]! } + public var GroupRemoved_AddToGroup: String { return self._s[1319]! } + public var Passport_UpdateRequiredError: String { return self._s[1320]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1318]!, self._r[1318]!, [_1]) + return formatWithArgumentRanges(self._s[1321]!, self._r[1321]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1320]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1321]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1322]! } - public var Passport_Language_ka: String { return self._s[1323]! } - public var Call_Decline: String { return self._s[1324]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1325]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1323]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1324]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1325]! } + public var Passport_Language_ka: String { return self._s[1326]! } + public var Call_Decline: String { return self._s[1327]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1328]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1328]!, self._r[1328]!, [_0]) + return formatWithArgumentRanges(self._s[1331]!, self._r[1331]!, [_0]) } - public var CallFeedback_Send: String { return self._s[1329]! } + public var CallFeedback_Send: String { return self._s[1332]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1330]!, self._r[1330]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1333]!, self._r[1333]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1331]! } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1333]! } - public var Passport_DeletePassport: String { return self._s[1334]! } - public var Appearance_AppIconFilled: String { return self._s[1335]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1336]! } - public var Month_ShortDecember: String { return self._s[1337]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1339]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1334]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1336]! } + public var Passport_DeletePassport: String { return self._s[1337]! } + public var Appearance_AppIconFilled: String { return self._s[1338]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1339]! } + public var Month_ShortDecember: String { return self._s[1340]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1342]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1340]!, self._r[1340]!, [_0]) + return formatWithArgumentRanges(self._s[1343]!, self._r[1343]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1341]! } - public var Conversation_EncryptedDescription1: String { return self._s[1342]! } - public var Conversation_EncryptedDescription2: String { return self._s[1343]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1344]! } - public var Conversation_EncryptedDescription3: String { return self._s[1345]! } - public var PhotoEditor_SharpenTool: String { return self._s[1346]! } + public var Channel_Stickers_Searching: String { return self._s[1344]! } + public var Conversation_EncryptedDescription1: String { return self._s[1345]! } + public var Conversation_EncryptedDescription2: String { return self._s[1346]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1347]! } + public var Conversation_EncryptedDescription3: String { return self._s[1348]! } + public var PhotoEditor_SharpenTool: String { return self._s[1349]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1347]!, self._r[1347]!, [_0]) + return formatWithArgumentRanges(self._s[1350]!, self._r[1350]!, [_0]) } - public var Conversation_EncryptedDescription4: String { return self._s[1349]! } - public var Channel_Members_AddMembers: String { return self._s[1350]! } - public var Wallpaper_Search: String { return self._s[1351]! } - public var Weekday_Friday: String { return self._s[1352]! } - public var Privacy_ContactsSync: String { return self._s[1353]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1354]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1355]! } + public var Conversation_EncryptedDescription4: String { return self._s[1352]! } + public var Channel_Members_AddMembers: String { return self._s[1353]! } + public var Wallpaper_Search: String { return self._s[1354]! } + public var Weekday_Friday: String { return self._s[1355]! } + public var Privacy_ContactsSync: String { return self._s[1356]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1357]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1358]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1356]!, self._r[1356]!, [_0]) - } - public var GroupInfo_Permissions_Removed: String { return self._s[1357]! } - public var Passport_Identity_GenderMale: String { return self._s[1358]! } - public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1359]!, self._r[1359]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1360]! } - public var Conversation_JumpToDate: String { return self._s[1361]! } - public var Contacts_GlobalSearch: String { return self._s[1362]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1363]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1364]! } - public var Profile_MessageLifetime1d: String { return self._s[1365]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1360]! } + public var Passport_Identity_GenderMale: String { return self._s[1361]! } + public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1362]!, self._r[1362]!, [_0]) + } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1363]! } + public var Conversation_JumpToDate: String { return self._s[1364]! } + public var Contacts_GlobalSearch: String { return self._s[1365]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1366]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1367]! } + public var Profile_MessageLifetime1d: String { return self._s[1368]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1366]!, self._r[1366]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1369]!, self._r[1369]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1369]! } + public var StickerPack_BuiltinPackName: String { return self._s[1372]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1370]!, self._r[1370]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1373]!, self._r[1373]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1371]! } - public var Passport_InfoTitle: String { return self._s[1373]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1374]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1374]! } + public var Passport_InfoTitle: String { return self._s[1376]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1377]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1378]!, self._r[1378]!, [_0]) + return formatWithArgumentRanges(self._s[1381]!, self._r[1381]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1379]!, self._r[1379]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1382]!, self._r[1382]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1380]! } - public var Profile_BotInfo: String { return self._s[1381]! } - public var Watch_Compose_CreateMessage: String { return self._s[1382]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1383]! } - public var Month_ShortNovember: String { return self._s[1384]! } - public var Conversation_ScamWarning: String { return self._s[1385]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1386]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1387]! } - public var NotificationsSound_Chime: String { return self._s[1388]! } - public var Passport_Language_ko: String { return self._s[1390]! } - public var InviteText_URL: String { return self._s[1391]! } - public var TextFormat_Monospace: String { return self._s[1392]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1383]! } + public var Profile_BotInfo: String { return self._s[1384]! } + public var Watch_Compose_CreateMessage: String { return self._s[1385]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1386]! } + public var Month_ShortNovember: String { return self._s[1387]! } + public var Conversation_ScamWarning: String { return self._s[1388]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1389]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1390]! } + public var NotificationsSound_Chime: String { return self._s[1391]! } + public var Passport_Language_ko: String { return self._s[1393]! } + public var InviteText_URL: String { return self._s[1394]! } + public var TextFormat_Monospace: String { return self._s[1395]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1393]!, self._r[1393]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1396]!, self._r[1396]!, [_1, _2, _3]) } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1394]!, self._r[1394]!, [_0]) + return formatWithArgumentRanges(self._s[1397]!, self._r[1397]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1395]!, self._r[1395]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1398]!, self._r[1398]!, [_1, _2]) } - public var Passport_InfoLearnMore: String { return self._s[1397]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1398]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1399]! } - public var Your_card_has_expired: String { return self._s[1400]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1401]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1402]! } - public var Conversation_Report: String { return self._s[1406]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1407]! } - public var Notification_MessageLifetime1m: String { return self._s[1408]! } - public var Privacy_ContactsTitle: String { return self._s[1409]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1410]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1411]! } - public var Channel_Members_Title: String { return self._s[1412]! } - public var Map_OpenInWaze: String { return self._s[1413]! } - public var Login_PhoneBannedError: String { return self._s[1414]! } + public var Passport_InfoLearnMore: String { return self._s[1400]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1401]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1402]! } + public var Your_card_has_expired: String { return self._s[1403]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1404]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1405]! } + public var Conversation_Report: String { return self._s[1409]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1410]! } + public var Notification_MessageLifetime1m: String { return self._s[1411]! } + public var Privacy_ContactsTitle: String { return self._s[1412]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1413]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1414]! } + public var Channel_Members_Title: String { return self._s[1415]! } + public var Map_OpenInWaze: String { return self._s[1416]! } + public var Login_PhoneBannedError: String { return self._s[1417]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1415]!, self._r[1415]!, [_0]) + return formatWithArgumentRanges(self._s[1418]!, self._r[1418]!, [_0]) } - public var Group_Management_AddModeratorHelp: String { return self._s[1416]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1417]! } - public var Common_OK: String { return self._s[1418]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1419]! } - public var Cache_Music: String { return self._s[1420]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1421]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1422]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1423]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1419]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1420]! } + public var Common_OK: String { return self._s[1421]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1422]! } + public var Cache_Music: String { return self._s[1423]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1424]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1425]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1426]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1424]!, self._r[1424]!, [_1]) + return formatWithArgumentRanges(self._s[1427]!, self._r[1427]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1425]!, self._r[1425]!, [_0]) + return formatWithArgumentRanges(self._s[1428]!, self._r[1428]!, [_0]) } public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1426]!, self._r[1426]!, [_0]) + return formatWithArgumentRanges(self._s[1429]!, self._r[1429]!, [_0]) } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1428]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1429]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1431]! } - public var State_ConnectingToProxyInfo: String { return self._s[1432]! } - public var Message_VideoMessage: String { return self._s[1434]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1435]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1436]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1437]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1438]! } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1439]! } - public var Activity_RecordingAudio: String { return self._s[1440]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1441]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1442]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1431]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1432]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1434]! } + public var State_ConnectingToProxyInfo: String { return self._s[1435]! } + public var Message_VideoMessage: String { return self._s[1437]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1438]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1439]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1440]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1441]! } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1442]! } + public var Activity_RecordingAudio: String { return self._s[1443]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1444]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1445]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1444]!, self._r[1444]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1447]!, self._r[1447]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1448]!, self._r[1448]!, [_0]) + return formatWithArgumentRanges(self._s[1451]!, self._r[1451]!, [_0]) } - public var Conversation_ApplyLocalization: String { return self._s[1449]! } - public var UserInfo_AddPhone: String { return self._s[1450]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1451]! } + public var Conversation_ApplyLocalization: String { return self._s[1452]! } + public var UserInfo_AddPhone: String { return self._s[1453]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1454]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, [_0]) + return formatWithArgumentRanges(self._s[1455]!, self._r[1455]!, [_0]) } - public var Passport_Scans: String { return self._s[1454]! } - public var BlockedUsers_Unblock: String { return self._s[1455]! } + public var Passport_Scans: String { return self._s[1457]! } + public var BlockedUsers_Unblock: String { return self._s[1458]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1456]!, self._r[1456]!, [_1]) + return formatWithArgumentRanges(self._s[1459]!, self._r[1459]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1457]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1458]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1459]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1460]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1461]! } + public var Channel_Management_LabelCreator: String { return self._s[1460]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1461]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1462]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1463]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1464]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1462]!, self._r[1462]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1465]!, self._r[1465]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1463]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1464]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1465]! } - public var ChannelIntro_CreateChannel: String { return self._s[1466]! } - public var Conversation_UnreadMessages: String { return self._s[1467]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1468]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1469]! } - public var Notification_GroupActivated: String { return self._s[1470]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1471]! } + public var Login_PhoneNumberHelp: String { return self._s[1466]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1467]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1468]! } + public var ChannelIntro_CreateChannel: String { return self._s[1469]! } + public var Conversation_UnreadMessages: String { return self._s[1470]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1471]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1472]! } + public var Notification_GroupActivated: String { return self._s[1473]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1474]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1472]!, self._r[1472]!, [_0]) + return formatWithArgumentRanges(self._s[1475]!, self._r[1475]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1473]!, self._r[1473]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1475]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1478]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_0]) - } - public var Undo_DeletedChannel: String { return self._s[1477]! } - public var CallFeedback_AddComment: String { return self._s[1478]! } - public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1479]!, self._r[1479]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1480]! } + public var Undo_DeletedChannel: String { return self._s[1480]! } + public var CallFeedback_AddComment: String { return self._s[1481]! } + public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1482]!, self._r[1482]!, [_0]) + } + public var Document_TargetConfirmationFormat: String { return self._s[1483]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1481]!, self._r[1481]!, [_0]) + return formatWithArgumentRanges(self._s[1484]!, self._r[1484]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1482]! } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1485]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1483]!, self._r[1483]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1486]!, self._r[1486]!, [_1, _2, _3, _4]) } - public var Contacts_SortByName: String { return self._s[1484]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1485]! } + public var Contacts_SortByName: String { return self._s[1487]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1488]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1487]!, self._r[1487]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1490]!, self._r[1490]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1488]! } - public var Conversation_ClearSelfHistory: String { return self._s[1489]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1490]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1491]! } - public var Stickers_SuggestNone: String { return self._s[1492]! } - public var ChatSettings_Cache: String { return self._s[1493]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1494]! } - public var Media_ShareThisPhoto: String { return self._s[1495]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1496]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1497]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1498]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1499]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1500]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1501]! } - public var Permissions_CellularDataTitle_v0: String { return self._s[1502]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1504]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1505]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1506]! } - public var Map_OpenIn: String { return self._s[1507]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1491]! } + public var ScheduledMessages_EditTime: String { return self._s[1492]! } + public var Conversation_ClearSelfHistory: String { return self._s[1493]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1494]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1495]! } + public var Stickers_SuggestNone: String { return self._s[1496]! } + public var ChatSettings_Cache: String { return self._s[1497]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1498]! } + public var Media_ShareThisPhoto: String { return self._s[1499]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1500]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1501]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1502]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1503]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1504]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1505]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1506]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1508]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1509]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1510]! } + public var Map_OpenIn: String { return self._s[1511]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1510]!, self._r[1510]!, [_1]) + return formatWithArgumentRanges(self._s[1514]!, self._r[1514]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1511]!, self._r[1511]!, [_0]) + return formatWithArgumentRanges(self._s[1515]!, self._r[1515]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1512]! } - public var MessagePoll_LabelClosed: String { return self._s[1513]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1515]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1516]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1517]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1518]! } - public var Login_SelectCountry_Title: String { return self._s[1519]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1520]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1516]! } + public var MessagePoll_LabelClosed: String { return self._s[1517]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1519]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1520]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1521]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1522]! } + public var Login_SelectCountry_Title: String { return self._s[1523]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1524]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1521]!, self._r[1521]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1522]! } - public var Watch_Suggestion_BRB: String { return self._s[1523]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1524]! } - public var Contacts_PermissionsTitle: String { return self._s[1525]! } - public var Conversation_RestrictedInline: String { return self._s[1526]! } - public var StickerPack_ViewPack: String { return self._s[1528]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1526]! } + public var Watch_Suggestion_BRB: String { return self._s[1527]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1528]! } + public var Contacts_PermissionsTitle: String { return self._s[1529]! } + public var Conversation_RestrictedInline: String { return self._s[1530]! } + public var StickerPack_ViewPack: String { return self._s[1532]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1529]!, self._r[1529]!, [_0]) + return formatWithArgumentRanges(self._s[1533]!, self._r[1533]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1531]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1534]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1536]! } - public var Channel_Info_Stickers: String { return self._s[1537]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1538]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1539]! } - public var Passport_DeletePersonalDetails: String { return self._s[1540]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1541]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1542]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1543]! } - public var Conversation_SearchNoResults: String { return self._s[1545]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1546]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1547]! } - public var Login_Code: String { return self._s[1548]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1549]! } - public var Weekday_ShortThursday: String { return self._s[1550]! } - public var Resolve_ErrorNotFound: String { return self._s[1552]! } - public var LastSeen_Offline: String { return self._s[1553]! } - public var PeopleNearby_NoMembers: String { return self._s[1554]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1555]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1556]! } - public var GroupInfo_Title: String { return self._s[1557]! } - public var NotificationsSound_Note: String { return self._s[1558]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1559]! } - public var Watch_Message_Poll: String { return self._s[1560]! } - public var Privacy_Calls: String { return self._s[1561]! } + public var Compose_NewChannel: String { return self._s[1535]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1538]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1540]! } + public var Channel_Info_Stickers: String { return self._s[1541]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1542]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1543]! } + public var Passport_DeletePersonalDetails: String { return self._s[1544]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1545]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1546]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1547]! } + public var Conversation_SearchNoResults: String { return self._s[1549]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1550]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1551]! } + public var Login_Code: String { return self._s[1552]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1553]! } + public var Weekday_ShortThursday: String { return self._s[1554]! } + public var Resolve_ErrorNotFound: String { return self._s[1556]! } + public var LastSeen_Offline: String { return self._s[1557]! } + public var PeopleNearby_NoMembers: String { return self._s[1558]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1559]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1560]! } + public var GroupInfo_Title: String { return self._s[1561]! } + public var NotificationsSound_Note: String { return self._s[1562]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1563]! } + public var Watch_Message_Poll: String { return self._s[1564]! } + public var Privacy_Calls: String { return self._s[1565]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1562]!, self._r[1562]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1566]!, self._r[1566]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1563]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1564]! } - public var Notifications_Reset: String { return self._s[1565]! } - public var Conversation_Pin: String { return self._s[1566]! } - public var Passport_Language_lv: String { return self._s[1567]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1568]! } - public var BlockedUsers_Info: String { return self._s[1569]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1571]! } - public var Watch_Conversation_Unblock: String { return self._s[1573]! } + public var Month_ShortAugust: String { return self._s[1567]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1568]! } + public var Notifications_Reset: String { return self._s[1569]! } + public var Conversation_Pin: String { return self._s[1570]! } + public var Passport_Language_lv: String { return self._s[1571]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1572]! } + public var BlockedUsers_Info: String { return self._s[1573]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1575]! } + public var Watch_Conversation_Unblock: String { return self._s[1577]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1574]!, self._r[1574]!, [_0]) + return formatWithArgumentRanges(self._s[1578]!, self._r[1578]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1575]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1576]! } + public var CloudStorage_Title: String { return self._s[1579]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1580]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1577]!, self._r[1577]!, [_0]) + return formatWithArgumentRanges(self._s[1581]!, self._r[1581]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1578]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1579]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1580]! } - public var Passport_Address_EditBankStatement: String { return self._s[1581]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1582]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1583]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1584]! } + public var Passport_Address_EditBankStatement: String { return self._s[1585]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1582]!, self._r[1582]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1586]!, self._r[1586]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1583]! } - public var ShareMenu_Comment: String { return self._s[1584]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1585]! } - public var Notifications_PermissionsTitle: String { return self._s[1586]! } - public var GroupPermission_NoSendLinks: String { return self._s[1587]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1588]! } - public var Settings_Support: String { return self._s[1589]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1590]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1591]! } - public var Privacy_Forwards_Preview: String { return self._s[1592]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1593]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1594]! } - public var Common_Select: String { return self._s[1596]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1597]! } - public var WallpaperSearch_ColorGray: String { return self._s[1599]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1600]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1601]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1602]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1603]! } - public var Widget_AuthRequired: String { return self._s[1604]! } - public var Camera_FlashOn: String { return self._s[1605]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1606]! } - public var Watch_Suggestion_OK: String { return self._s[1607]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1587]! } + public var ShareMenu_Comment: String { return self._s[1588]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1589]! } + public var Notifications_PermissionsTitle: String { return self._s[1590]! } + public var GroupPermission_NoSendLinks: String { return self._s[1591]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1592]! } + public var Settings_Support: String { return self._s[1593]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1594]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1595]! } + public var Privacy_Forwards_Preview: String { return self._s[1596]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1597]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1598]! } + public var Common_Select: String { return self._s[1600]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1601]! } + public var WallpaperSearch_ColorGray: String { return self._s[1603]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1604]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1605]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1606]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1607]! } + public var Widget_AuthRequired: String { return self._s[1608]! } + public var Camera_FlashOn: String { return self._s[1609]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1610]! } + public var Watch_Suggestion_OK: String { return self._s[1611]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1609]!, self._r[1609]!, [_0]) + return formatWithArgumentRanges(self._s[1613]!, self._r[1613]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1611]!, self._r[1611]!, [_0]) + return formatWithArgumentRanges(self._s[1615]!, self._r[1615]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1612]! } - public var DialogList_AdLabel: String { return self._s[1613]! } - public var WatchRemote_NotificationText: String { return self._s[1614]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1615]! } - public var Conversation_ReportSpam: String { return self._s[1616]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1617]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1619]! } - public var PhoneLabel_Title: String { return self._s[1620]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1621]! } - public var Settings_ChangePhoneNumber: String { return self._s[1622]! } - public var Notifications_ExceptionsTitle: String { return self._s[1623]! } - public var Notifications_AlertTones: String { return self._s[1624]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1625]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1626]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1627]! } - public var VoiceOver_Chat_Photo: String { return self._s[1629]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1630]! } - public var ReportPeer_ReasonOther: String { return self._s[1631]! } - public var KeyCommand_ScrollDown: String { return self._s[1633]! } + public var TextFormat_Strikethrough: String { return self._s[1616]! } + public var DialogList_AdLabel: String { return self._s[1617]! } + public var WatchRemote_NotificationText: String { return self._s[1618]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1619]! } + public var Conversation_ReportSpam: String { return self._s[1620]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1621]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1623]! } + public var PhoneLabel_Title: String { return self._s[1624]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1625]! } + public var Settings_ChangePhoneNumber: String { return self._s[1626]! } + public var Notifications_ExceptionsTitle: String { return self._s[1627]! } + public var Notifications_AlertTones: String { return self._s[1628]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1629]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1630]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1631]! } + public var VoiceOver_Chat_Photo: String { return self._s[1633]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1634]! } + public var ReportPeer_ReasonOther: String { return self._s[1635]! } + public var KeyCommand_ScrollDown: String { return self._s[1637]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1638]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_0]) + return formatWithArgumentRanges(self._s[1639]!, self._r[1639]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1635]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1636]! } - public var AuthSessions_LogOut: String { return self._s[1637]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1638]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1639]! } - public var Passport_Phone_Title: String { return self._s[1640]! } - public var Settings_PhoneNumber: String { return self._s[1641]! } - public var NotificationsSound_Alert: String { return self._s[1642]! } - public var WebSearch_SearchNoResults: String { return self._s[1643]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1645]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1646]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[1647]! } - public var PhotoEditor_CurvesTool: String { return self._s[1648]! } - public var Checkout_PaymentMethod: String { return self._s[1650]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1640]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1641]! } + public var AuthSessions_LogOut: String { return self._s[1642]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1643]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1644]! } + public var Passport_Phone_Title: String { return self._s[1645]! } + public var Settings_PhoneNumber: String { return self._s[1646]! } + public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1647]!, self._r[1647]!, [_0]) + } + public var NotificationsSound_Alert: String { return self._s[1648]! } + public var WebSearch_SearchNoResults: String { return self._s[1649]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1651]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1652]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[1653]! } + public var PhotoEditor_CurvesTool: String { return self._s[1654]! } + public var Checkout_PaymentMethod: String { return self._s[1656]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1651]!, self._r[1651]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1657]!, self._r[1657]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[1652]! } - public var Camera_PhotoMode: String { return self._s[1655]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1657]! } - public var CallSettings_OnMobile: String { return self._s[1658]! } - public var Tour_Text2: String { return self._s[1659]! } + public var Contacts_AccessDeniedError: String { return self._s[1658]! } + public var Camera_PhotoMode: String { return self._s[1661]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1663]! } + public var CallSettings_OnMobile: String { return self._s[1664]! } + public var Tour_Text2: String { return self._s[1665]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1660]!, self._r[1660]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1666]!, self._r[1666]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1662]! } - public var Permissions_Skip: String { return self._s[1663]! } - public var SecretImage_Title: String { return self._s[1664]! } - public var Watch_MessageView_Title: String { return self._s[1665]! } - public var Channel_DiscussionGroupAdd: String { return self._s[1666]! } - public var AttachmentMenu_Poll: String { return self._s[1667]! } + public var DialogList_EncryptionProcessing: String { return self._s[1668]! } + public var Permissions_Skip: String { return self._s[1669]! } + public var SecretImage_Title: String { return self._s[1670]! } + public var Watch_MessageView_Title: String { return self._s[1671]! } + public var Channel_DiscussionGroupAdd: String { return self._s[1672]! } + public var AttachmentMenu_Poll: String { return self._s[1673]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1668]!, self._r[1668]!, [_0]) + return formatWithArgumentRanges(self._s[1674]!, self._r[1674]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1669]!, self._r[1669]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1675]!, self._r[1675]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[1670]! } - public var WallpaperPreview_Title: String { return self._s[1671]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1672]! } - public var Settings_ProxyConnecting: String { return self._s[1673]! } - public var Settings_CheckPhoneNumberText: String { return self._s[1675]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[1676]! } - public var Profile_MessageLifetime5s: String { return self._s[1677]! } - public var Username_InvalidCharacters: String { return self._s[1678]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1679]! } - public var WallpaperPreview_CropBottomText: String { return self._s[1680]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1681]! } - public var Settings_AddAccount: String { return self._s[1682]! } - public var Notification_CreatedChannel: String { return self._s[1685]! } + public var Notification_CallCanceled: String { return self._s[1676]! } + public var WallpaperPreview_Title: String { return self._s[1677]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1678]! } + public var Settings_ProxyConnecting: String { return self._s[1679]! } + public var Settings_CheckPhoneNumberText: String { return self._s[1681]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[1682]! } + public var Profile_MessageLifetime5s: String { return self._s[1683]! } + public var Username_InvalidCharacters: String { return self._s[1684]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1685]! } + public var WallpaperPreview_CropBottomText: String { return self._s[1686]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1687]! } + public var Settings_AddAccount: String { return self._s[1688]! } + public var Notification_CreatedChannel: String { return self._s[1691]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1686]!, self._r[1686]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1692]!, self._r[1692]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[1688]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1689]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[1690]! } - public var Contacts_TopSection: String { return self._s[1691]! } + public var Passcode_AppLockedAlert: String { return self._s[1694]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1695]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[1696]! } + public var Contacts_TopSection: String { return self._s[1697]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1692]!, self._r[1692]!, [_0]) + return formatWithArgumentRanges(self._s[1698]!, self._r[1698]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[1693]! } - public var UserInfo_TapToCall: String { return self._s[1694]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1696]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1697]! } - public var Common_Search: String { return self._s[1698]! } + public var ReportPeer_ReasonSpam: String { return self._s[1699]! } + public var UserInfo_TapToCall: String { return self._s[1700]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1702]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1703]! } + public var Common_Search: String { return self._s[1704]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1699]!, self._r[1699]!, [_0]) + return formatWithArgumentRanges(self._s[1705]!, self._r[1705]!, [_0]) } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1700]! } - public var Message_InvoiceLabel: String { return self._s[1701]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1702]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1703]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1706]! } + public var Message_InvoiceLabel: String { return self._s[1707]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1708]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1709]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1704]!, self._r[1704]!, [_0]) + return formatWithArgumentRanges(self._s[1710]!, self._r[1710]!, [_0]) } - public var Conversation_Info: String { return self._s[1705]! } - public var Login_InfoDeletePhoto: String { return self._s[1706]! } - public var Passport_Language_vi: String { return self._s[1708]! } - public var UserInfo_ScamUserWarning: String { return self._s[1709]! } - public var Conversation_Search: String { return self._s[1710]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1711]! } - public var ReportPeer_ReasonPornography: String { return self._s[1712]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[1713]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1714]! } - public var Map_LiveLocationGroupDescription: String { return self._s[1715]! } - public var Channel_Setup_TypeHeader: String { return self._s[1716]! } - public var AuthSessions_LoggedIn: String { return self._s[1717]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1718]! } - public var Login_SmsRequestState3: String { return self._s[1719]! } - public var Passport_Address_EditUtilityBill: String { return self._s[1720]! } - public var Appearance_ReduceMotionInfo: String { return self._s[1721]! } - public var Join_ChannelsTooMuch: String { return self._s[1722]! } - public var Channel_Edit_LinkItem: String { return self._s[1723]! } - public var Privacy_Calls_P2PNever: String { return self._s[1724]! } - public var Conversation_AddToReadingList: String { return self._s[1726]! } - public var Share_MultipleMessagesDisabled: String { return self._s[1727]! } - public var Message_Animation: String { return self._s[1728]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[1729]! } - public var Map_Unknown: String { return self._s[1730]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[1731]! } + public var Conversation_Info: String { return self._s[1711]! } + public var Login_InfoDeletePhoto: String { return self._s[1712]! } + public var Passport_Language_vi: String { return self._s[1714]! } + public var UserInfo_ScamUserWarning: String { return self._s[1715]! } + public var Conversation_Search: String { return self._s[1716]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1717]! } + public var ReportPeer_ReasonPornography: String { return self._s[1718]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[1719]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1720]! } + public var Map_LiveLocationGroupDescription: String { return self._s[1721]! } + public var Channel_Setup_TypeHeader: String { return self._s[1722]! } + public var AuthSessions_LoggedIn: String { return self._s[1723]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1724]! } + public var Login_SmsRequestState3: String { return self._s[1725]! } + public var Passport_Address_EditUtilityBill: String { return self._s[1726]! } + public var Appearance_ReduceMotionInfo: String { return self._s[1727]! } + public var Join_ChannelsTooMuch: String { return self._s[1728]! } + public var Channel_Edit_LinkItem: String { return self._s[1729]! } + public var Privacy_Calls_P2PNever: String { return self._s[1730]! } + public var Conversation_AddToReadingList: String { return self._s[1732]! } + public var Share_MultipleMessagesDisabled: String { return self._s[1733]! } + public var Message_Animation: String { return self._s[1734]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[1735]! } + public var Map_Unknown: String { return self._s[1736]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[1737]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1732]!, self._r[1732]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1738]!, self._r[1738]!, [_1, _2]) } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1733]!, self._r[1733]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1739]!, self._r[1739]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[1734]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[1735]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1736]! } + public var Call_StatusRequesting: String { return self._s[1740]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[1741]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1742]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1737]!, self._r[1737]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1743]!, self._r[1743]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1738]!, self._r[1738]!, [_0]) + return formatWithArgumentRanges(self._s[1744]!, self._r[1744]!, [_0]) } - public var Update_Skip: String { return self._s[1739]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1740]! } - public var Message_PinnedPollMessage: String { return self._s[1741]! } - public var BlockedUsers_Title: String { return self._s[1742]! } + public var Update_Skip: String { return self._s[1745]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1746]! } + public var Message_PinnedPollMessage: String { return self._s[1747]! } + public var BlockedUsers_Title: String { return self._s[1748]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1743]!, self._r[1743]!, [_1]) + return formatWithArgumentRanges(self._s[1749]!, self._r[1749]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[1744]! } - public var NotificationsSound_Bell: String { return self._s[1745]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[1746]! } - public var Weekday_Monday: String { return self._s[1747]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1748]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1749]! } - public var ChatSettings_Groups: String { return self._s[1750]! } - public var Your_card_was_declined: String { return self._s[1751]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1753]! } - public var ChatList_Unmute: String { return self._s[1754]! } - public var PhotoEditor_CurvesAll: String { return self._s[1755]! } - public var Weekday_ShortTuesday: String { return self._s[1756]! } - public var DialogList_Read: String { return self._s[1757]! } - public var Appearance_AppIconClassic: String { return self._s[1758]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1759]! } - public var Passport_Identity_Gender: String { return self._s[1760]! } + public var Username_CheckingUsername: String { return self._s[1750]! } + public var NotificationsSound_Bell: String { return self._s[1751]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[1752]! } + public var Weekday_Monday: String { return self._s[1753]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1754]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1755]! } + public var ChatSettings_Groups: String { return self._s[1756]! } + public var Your_card_was_declined: String { return self._s[1757]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1759]! } + public var ChatList_Unmute: String { return self._s[1760]! } + public var PhotoEditor_CurvesAll: String { return self._s[1761]! } + public var Weekday_ShortTuesday: String { return self._s[1762]! } + public var DialogList_Read: String { return self._s[1763]! } + public var Appearance_AppIconClassic: String { return self._s[1764]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[1765]! } + public var Passport_Identity_Gender: String { return self._s[1766]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1761]!, self._r[1761]!, [_0]) + return formatWithArgumentRanges(self._s[1767]!, self._r[1767]!, [_0]) } - public var Target_SelectGroup: String { return self._s[1762]! } + public var Target_SelectGroup: String { return self._s[1768]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1764]!, self._r[1764]!, [_0]) + return formatWithArgumentRanges(self._s[1770]!, self._r[1770]!, [_0]) } - public var Passport_Language_en: String { return self._s[1765]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[1766]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1767]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[1768]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[1770]! } - public var Login_InfoHelp: String { return self._s[1771]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1772]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[1773]! } + public var Passport_Language_en: String { return self._s[1771]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[1772]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[1773]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[1774]! } + public var ScheduledMessages_SendNow: String { return self._s[1775]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[1777]! } + public var Login_InfoHelp: String { return self._s[1778]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[1779]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[1780]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1774]!, self._r[1774]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1781]!, self._r[1781]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[1777]! } - public var CreatePoll_Title: String { return self._s[1778]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[1779]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1780]! } - public var UserInfo_GroupsInCommon: String { return self._s[1781]! } - public var Call_AudioRouteHide: String { return self._s[1782]! } - public var ContactInfo_PhoneLabelMobile: String { return self._s[1784]! } + public var SocksProxySetup_AddProxy: String { return self._s[1784]! } + public var CreatePoll_Title: String { return self._s[1785]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[1786]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[1787]! } + public var UserInfo_GroupsInCommon: String { return self._s[1788]! } + public var Call_AudioRouteHide: String { return self._s[1789]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[1791]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1785]!, self._r[1785]!, [_0]) + return formatWithArgumentRanges(self._s[1792]!, self._r[1792]!, [_0]) } - public var TextFormat_Bold: String { return self._s[1786]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[1787]! } - public var Notifications_Title: String { return self._s[1788]! } - public var Group_Username_InvalidTooShort: String { return self._s[1789]! } - public var Channel_ErrorAddTooMuch: String { return self._s[1790]! } + public var TextFormat_Bold: String { return self._s[1793]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[1794]! } + public var Notifications_Title: String { return self._s[1795]! } + public var Group_Username_InvalidTooShort: String { return self._s[1796]! } + public var Channel_ErrorAddTooMuch: String { return self._s[1797]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1791]!, self._r[1791]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1798]!, self._r[1798]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[1793]! } - public var Stickers_SuggestAdded: String { return self._s[1794]! } - public var Login_CountryCode: String { return self._s[1795]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[1796]! } - public var Map_GetDirections: String { return self._s[1797]! } - public var Login_PhoneFloodError: String { return self._s[1798]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[1800]! } + public var Stickers_SuggestAdded: String { return self._s[1801]! } + public var Login_CountryCode: String { return self._s[1802]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[1803]! } + public var Map_GetDirections: String { return self._s[1804]! } + public var Login_PhoneFloodError: String { return self._s[1805]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1799]!, self._r[1799]!, [_0]) + return formatWithArgumentRanges(self._s[1806]!, self._r[1806]!, [_0]) } - public var Settings_SetUsername: String { return self._s[1801]! } - public var Group_Location_ChangeLocation: String { return self._s[1802]! } - public var Notification_GroupInviterSelf: String { return self._s[1803]! } - public var InstantPage_TapToOpenLink: String { return self._s[1804]! } + public var Settings_SetUsername: String { return self._s[1808]! } + public var Group_Location_ChangeLocation: String { return self._s[1809]! } + public var Notification_GroupInviterSelf: String { return self._s[1810]! } + public var InstantPage_TapToOpenLink: String { return self._s[1811]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1805]!, self._r[1805]!, [_0]) + return formatWithArgumentRanges(self._s[1812]!, self._r[1812]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[1806]! } - public var SecretChat_Title: String { return self._s[1807]! } - public var Group_UpgradeNoticeText1: String { return self._s[1808]! } - public var AuthSessions_Title: String { return self._s[1809]! } + public var Watch_Suggestion_TalkLater: String { return self._s[1813]! } + public var SecretChat_Title: String { return self._s[1814]! } + public var Group_UpgradeNoticeText1: String { return self._s[1815]! } + public var AuthSessions_Title: String { return self._s[1816]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1810]!, self._r[1810]!, [_0]) + return formatWithArgumentRanges(self._s[1817]!, self._r[1817]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[1811]! } - public var Channel_About_Title: String { return self._s[1812]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[1813]! } + public var PhotoEditor_CropAuto: String { return self._s[1818]! } + public var Channel_About_Title: String { return self._s[1819]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[1820]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1815]!, self._r[1815]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1822]!, self._r[1822]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[1816]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1818]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[1819]! } + public var VoiceOver_MessageContextReport: String { return self._s[1823]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[1825]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[1826]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1820]!, self._r[1820]!, [_1]) + return formatWithArgumentRanges(self._s[1827]!, self._r[1827]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1822]!, self._r[1822]!, [_0]) + return formatWithArgumentRanges(self._s[1829]!, self._r[1829]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1823]!, self._r[1823]!, [_0]) + return formatWithArgumentRanges(self._s[1830]!, self._r[1830]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[1824]! } - public var Presence_online: String { return self._s[1826]! } - public var PasscodeSettings_Title: String { return self._s[1827]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1828]! } - public var Web_OpenExternal: String { return self._s[1829]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[1831]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[1832]! } - public var LocalGroup_Title: String { return self._s[1833]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[1831]! } + public var Presence_online: String { return self._s[1833]! } + public var PasscodeSettings_Title: String { return self._s[1834]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[1835]! } + public var Web_OpenExternal: String { return self._s[1836]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[1838]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[1839]! } + public var LocalGroup_Title: String { return self._s[1840]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1834]!, self._r[1834]!, [_0]) - } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1835]! } - public var Map_YouAreHere: String { return self._s[1836]! } - public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1837]!, self._r[1837]!, [_0]) - } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_0]) - } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1839]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1840]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1841]!, self._r[1841]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1842]!, self._r[1842]!, [_0]) + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[1842]! } + public var Map_YouAreHere: String { return self._s[1843]! } + public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1844]!, self._r[1844]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[1843]! } - public var Bot_Start: String { return self._s[1844]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1845]!, self._r[1845]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1846]!, self._r[1846]!, [_0]) + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[1846]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[1847]! } + public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1848]!, self._r[1848]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[1847]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1849]! } + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1849]!, self._r[1849]!, [_0]) + } + public var SocksProxySetup_Username: String { return self._s[1850]! } + public var Bot_Start: String { return self._s[1851]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1852]!, self._r[1852]!, [_0]) + } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1853]!, self._r[1853]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[1854]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[1856]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1850]!, self._r[1850]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1857]!, self._r[1857]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1851]!, self._r[1851]!, [_0]) + return formatWithArgumentRanges(self._s[1858]!, self._r[1858]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1852]!, self._r[1852]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1859]!, self._r[1859]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[1853]! } - public var Login_InfoAvatarPhoto: String { return self._s[1854]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1855]! } - public var Tour_Title4: String { return self._s[1856]! } - public var Passport_Identity_Translation: String { return self._s[1857]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[1858]! } - public var Login_TermsOfServiceLabel: String { return self._s[1860]! } - public var Passport_Language_it: String { return self._s[1861]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1862]! } - public var Passport_Identity_SelfieHelp: String { return self._s[1863]! } - public var Conversation_ClearAll: String { return self._s[1865]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[1867]! } - public var TwoStepAuth_FloodError: String { return self._s[1868]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[1860]! } + public var Login_InfoAvatarPhoto: String { return self._s[1861]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[1862]! } + public var Tour_Title4: String { return self._s[1863]! } + public var Passport_Identity_Translation: String { return self._s[1864]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[1865]! } + public var Login_TermsOfServiceLabel: String { return self._s[1867]! } + public var Passport_Language_it: String { return self._s[1868]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[1869]! } + public var Passport_Identity_SelfieHelp: String { return self._s[1870]! } + public var Conversation_ClearAll: String { return self._s[1872]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[1874]! } + public var TwoStepAuth_FloodError: String { return self._s[1875]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1869]!, self._r[1869]!, [_1]) + return formatWithArgumentRanges(self._s[1876]!, self._r[1876]!, [_1]) } - public var Paint_Delete: String { return self._s[1870]! } - public var Privacy_AddNewPeer: String { return self._s[1871]! } + public var Paint_Delete: String { return self._s[1877]! } + public var Privacy_AddNewPeer: String { return self._s[1878]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1872]!, self._r[1872]!, [_1]) + return formatWithArgumentRanges(self._s[1879]!, self._r[1879]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[1873]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[1880]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1874]!, self._r[1874]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1881]!, self._r[1881]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[1875]! } + public var Message_PinnedAudioMessage: String { return self._s[1882]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1876]!, self._r[1876]!, [_0]) + return formatWithArgumentRanges(self._s[1883]!, self._r[1883]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[1877]! } - public var Notifications_GroupNotificationsSound: String { return self._s[1878]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[1879]! } - public var Conversation_MessageEditedLabel: String { return self._s[1880]! } - public var Notification_Exceptions_AlwaysOff: String { return self._s[1881]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[1882]! } + public var Notification_Mute1hMin: String { return self._s[1884]! } + public var Notifications_GroupNotificationsSound: String { return self._s[1885]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[1886]! } + public var Conversation_MessageEditedLabel: String { return self._s[1887]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[1888]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[1889]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1883]!, self._r[1883]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1890]!, self._r[1890]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[1884]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[1891]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1885]!, self._r[1885]!, [_1]) + return formatWithArgumentRanges(self._s[1892]!, self._r[1892]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[1886]! } - public var Month_GenOctober: String { return self._s[1887]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1888]! } - public var EnterPasscode_EnterPasscode: String { return self._s[1889]! } - public var MediaPicker_TimerTooltip: String { return self._s[1891]! } - public var SharedMedia_TitleAll: String { return self._s[1892]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[1895]! } - public var Conversation_RestrictedMedia: String { return self._s[1896]! } - public var AccessDenied_PhotosRestricted: String { return self._s[1897]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[1899]! } - public var ChangePhoneNumberCode_Called: String { return self._s[1900]! } + public var AccessDenied_LocationTracking: String { return self._s[1893]! } + public var Month_GenOctober: String { return self._s[1894]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[1895]! } + public var EnterPasscode_EnterPasscode: String { return self._s[1896]! } + public var MediaPicker_TimerTooltip: String { return self._s[1898]! } + public var SharedMedia_TitleAll: String { return self._s[1899]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[1902]! } + public var Conversation_RestrictedMedia: String { return self._s[1903]! } + public var AccessDenied_PhotosRestricted: String { return self._s[1904]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[1906]! } + public var ChangePhoneNumberCode_Called: String { return self._s[1907]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1901]!, self._r[1901]!, [_0]) + return formatWithArgumentRanges(self._s[1908]!, self._r[1908]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[1904]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[1906]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1907]! } + public var Conversation_SavedMessages: String { return self._s[1911]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[1913]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[1914]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1909]!, self._r[1909]!, [_0]) + return formatWithArgumentRanges(self._s[1916]!, self._r[1916]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[1910]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[1917]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1911]!, self._r[1911]!, [_0]) + return formatWithArgumentRanges(self._s[1918]!, self._r[1918]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[1912]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1913]! } + public var ReportPeer_AlertSuccess: String { return self._s[1919]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[1920]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1914]!, self._r[1914]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1921]!, self._r[1921]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[1915]! } - public var PhotoEditor_FadeTool: String { return self._s[1916]! } - public var Privacy_ContactsReset: String { return self._s[1917]! } + public var Checkout_PasswordEntry_Title: String { return self._s[1922]! } + public var PhotoEditor_FadeTool: String { return self._s[1923]! } + public var Privacy_ContactsReset: String { return self._s[1924]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1919]!, self._r[1919]!, [_0]) + return formatWithArgumentRanges(self._s[1926]!, self._r[1926]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[1920]! } - public var ChatList_Mute: String { return self._s[1921]! } - public var Permissions_CellularDataText_v0: String { return self._s[1922]! } - public var ShareMenu_SelectChats: String { return self._s[1924]! } - public var MusicPlayer_VoiceNote: String { return self._s[1925]! } - public var Conversation_RestrictedText: String { return self._s[1926]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[1927]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[1928]! } - public var Cache_Videos: String { return self._s[1929]! } - public var PrivacySettings_PhoneNumber: String { return self._s[1930]! } - public var FeatureDisabled_Oops: String { return self._s[1932]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[1933]! } + public var Message_PinnedVideoMessage: String { return self._s[1927]! } + public var ChatList_Mute: String { return self._s[1928]! } + public var Permissions_CellularDataText_v0: String { return self._s[1929]! } + public var ShareMenu_SelectChats: String { return self._s[1931]! } + public var MusicPlayer_VoiceNote: String { return self._s[1932]! } + public var Conversation_RestrictedText: String { return self._s[1933]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[1934]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[1935]! } + public var Cache_Videos: String { return self._s[1936]! } + public var PrivacySettings_PhoneNumber: String { return self._s[1937]! } + public var FeatureDisabled_Oops: String { return self._s[1939]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[1940]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1934]!, self._r[1934]!, [_0]) + return formatWithArgumentRanges(self._s[1941]!, self._r[1941]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[1935]! } - public var GroupPermission_NoSendPolls: String { return self._s[1936]! } - public var Message_VideoExpired: String { return self._s[1938]! } - public var Notifications_Badge: String { return self._s[1939]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[1940]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[1941]! } - public var Username_InvalidTooShort: String { return self._s[1942]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1943]! } - public var Channel_AdminLog_PinMessages: String { return self._s[1944]! } - public var ArchivedChats_IntroTitle3: String { return self._s[1945]! } + public var Stickers_GroupStickersHelp: String { return self._s[1942]! } + public var GroupPermission_NoSendPolls: String { return self._s[1943]! } + public var Message_VideoExpired: String { return self._s[1945]! } + public var Notifications_Badge: String { return self._s[1946]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[1947]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[1948]! } + public var Username_InvalidTooShort: String { return self._s[1949]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[1950]! } + public var Channel_AdminLog_PinMessages: String { return self._s[1951]! } + public var ArchivedChats_IntroTitle3: String { return self._s[1952]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1946]!, self._r[1946]!, [_1]) + return formatWithArgumentRanges(self._s[1953]!, self._r[1953]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[1947]! } - public var Conversation_DefaultRestrictedText: String { return self._s[1948]! } - public var SharedMedia_CategoryDocs: String { return self._s[1951]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[1954]! } + public var Conversation_DefaultRestrictedText: String { return self._s[1955]! } + public var SharedMedia_CategoryDocs: String { return self._s[1958]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1952]!, self._r[1952]!, [_1]) + return formatWithArgumentRanges(self._s[1959]!, self._r[1959]!, [_1]) } - public var Privacy_Forwards_NeverLink: String { return self._s[1954]! } + public var Privacy_Forwards_NeverLink: String { return self._s[1961]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1955]!, self._r[1955]!, [_1]) + return formatWithArgumentRanges(self._s[1962]!, self._r[1962]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1956]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[1963]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1957]!, self._r[1957]!, [_0]) + return formatWithArgumentRanges(self._s[1964]!, self._r[1964]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[1958]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[1959]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[1960]! } - public var Channel_UpdatePhotoItem: String { return self._s[1961]! } - public var GroupInfo_LeftStatus: String { return self._s[1962]! } - public var Watch_MessageView_Forward: String { return self._s[1964]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[1965]! } - public var Cache_ClearEmpty: String { return self._s[1967]! } - public var Localization_LanguageName: String { return self._s[1968]! } - public var WebSearch_GIFs: String { return self._s[1969]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1970]! } - public var Username_InvalidStartsWithNumber: String { return self._s[1971]! } - public var Common_Back: String { return self._s[1972]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1973]! } + public var ChatSettings_PrivateChats: String { return self._s[1965]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[1966]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[1967]! } + public var Channel_UpdatePhotoItem: String { return self._s[1968]! } + public var GroupInfo_LeftStatus: String { return self._s[1969]! } + public var Watch_MessageView_Forward: String { return self._s[1971]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[1972]! } + public var Cache_ClearEmpty: String { return self._s[1974]! } + public var Localization_LanguageName: String { return self._s[1975]! } + public var WebSearch_GIFs: String { return self._s[1976]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[1977]! } + public var Username_InvalidStartsWithNumber: String { return self._s[1978]! } + public var Common_Back: String { return self._s[1979]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[1980]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1974]!, self._r[1974]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1981]!, self._r[1981]!, [_1, _2]) } - public var Passport_Email_Help: String { return self._s[1975]! } - public var Watch_Conversation_Reply: String { return self._s[1977]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[1979]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1980]! } - public var Channel_BanUser_Unban: String { return self._s[1982]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1983]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[1984]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1986]! } - public var Passport_Identity_Name: String { return self._s[1987]! } + public var Passport_Email_Help: String { return self._s[1982]! } + public var Watch_Conversation_Reply: String { return self._s[1984]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[1986]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[1987]! } + public var Channel_BanUser_Unban: String { return self._s[1989]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[1990]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[1991]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[1993]! } + public var Passport_Identity_Name: String { return self._s[1994]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1988]!, self._r[1988]!, [_0]) + return formatWithArgumentRanges(self._s[1995]!, self._r[1995]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[1989]! } - public var Conversation_BlockUser: String { return self._s[1990]! } - public var Month_GenJanuary: String { return self._s[1991]! } - public var ChatSettings_TextSize: String { return self._s[1992]! } - public var Notification_PassportValuePhone: String { return self._s[1993]! } - public var Passport_Language_ne: String { return self._s[1994]! } - public var Notification_CallBack: String { return self._s[1995]! } - public var TwoStepAuth_EmailHelp: String { return self._s[1996]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[1996]! } + public var Conversation_BlockUser: String { return self._s[1997]! } + public var Month_GenJanuary: String { return self._s[1998]! } + public var ChatSettings_TextSize: String { return self._s[1999]! } + public var Notification_PassportValuePhone: String { return self._s[2000]! } + public var Passport_Language_ne: String { return self._s[2001]! } + public var Notification_CallBack: String { return self._s[2002]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2003]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1997]!, self._r[1997]!, [_0]) + return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_0]) } - public var Channel_Info_Management: String { return self._s[1998]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[1999]! } - public var Stickers_FrequentlyUsed: String { return self._s[2000]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2001]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2003]! } + public var Channel_Info_Management: String { return self._s[2005]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2006]! } + public var Stickers_FrequentlyUsed: String { return self._s[2007]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2008]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2010]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2011]!, self._r[2011]!, [_1, "\(_2)"]) } - public var Passport_Address_EditResidentialAddress: String { return self._s[2005]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2006]! } - public var CreatePoll_TextHeader: String { return self._s[2007]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2012]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2013]! } + public var CreatePoll_TextHeader: String { return self._s[2014]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2008]!, self._r[2008]!, [_0]) - } - public var PhotoEditor_QualityMedium: String { return self._s[2009]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2010]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2012]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2013]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2014]! } - public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2015]!, self._r[2015]!, [_0]) } + public var PhotoEditor_QualityMedium: String { return self._s[2016]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2017]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2019]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2020]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2021]! } + public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2022]!, self._r[2022]!, [_0]) + } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2016]!, self._r[2016]!, [_1]) + return formatWithArgumentRanges(self._s[2023]!, self._r[2023]!, [_1]) } - public var Conversation_LinkDialogOpen: String { return self._s[2018]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2019]! } - public var Settings_Username: String { return self._s[2021]! } - public var Conversation_Block: String { return self._s[2023]! } - public var Wallpaper_Wallpaper: String { return self._s[2024]! } - public var SocksProxySetup_UseProxy: String { return self._s[2026]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2027]! } - public var MessageTimer_Forever: String { return self._s[2028]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2029]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2030]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2031]! } - public var Passport_Language_da: String { return self._s[2032]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2033]! } + public var Conversation_LinkDialogOpen: String { return self._s[2025]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2026]! } + public var Settings_Username: String { return self._s[2028]! } + public var Conversation_Block: String { return self._s[2030]! } + public var Wallpaper_Wallpaper: String { return self._s[2031]! } + public var SocksProxySetup_UseProxy: String { return self._s[2033]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2034]! } + public var MessageTimer_Forever: String { return self._s[2035]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2036]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2037]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2038]! } + public var Passport_Language_da: String { return self._s[2039]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2040]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2034]!, self._r[2034]!, [_0]) + return formatWithArgumentRanges(self._s[2041]!, self._r[2041]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2035]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2042]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2037]!, self._r[2037]!, [_0]) + return formatWithArgumentRanges(self._s[2044]!, self._r[2044]!, [_0]) } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2039]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2040]! } - public var Conversation_PinnedPoll: String { return self._s[2041]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2042]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2046]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2047]! } + public var Conversation_PinnedPoll: String { return self._s[2048]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2049]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2043]!, self._r[2043]!, [_1]) + return formatWithArgumentRanges(self._s[2050]!, self._r[2050]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2044]! } - public var Cache_ByPeerHeader: String { return self._s[2045]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2051]! } + public var Cache_ByPeerHeader: String { return self._s[2052]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2046]!, self._r[2046]!, [_0]) + return formatWithArgumentRanges(self._s[2053]!, self._r[2053]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2047]! } - public var Notification_PinnedMessage: String { return self._s[2050]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2052]! } - public var Contacts_SortBy: String { return self._s[2053]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2054]! } + public var Notification_PinnedMessage: String { return self._s[2057]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2059]! } + public var Contacts_SortBy: String { return self._s[2060]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2054]!, self._r[2054]!, [_1]) + return formatWithArgumentRanges(self._s[2061]!, self._r[2061]!, [_1]) } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2056]!, self._r[2056]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2063]!, self._r[2063]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2057]! } - public var Watch_UserInfo_Service: String { return self._s[2058]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2060]! } - public var Conversation_Unpin: String { return self._s[2062]! } - public var CancelResetAccount_Title: String { return self._s[2063]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2064]! } + public var Call_EncryptionKey_Title: String { return self._s[2064]! } + public var Watch_UserInfo_Service: String { return self._s[2065]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2067]! } + public var Conversation_Unpin: String { return self._s[2069]! } + public var CancelResetAccount_Title: String { return self._s[2070]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2071]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2066]!, self._r[2066]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2073]!, self._r[2073]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2067]! } - public var CallSettings_Title: String { return self._s[2068]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2069]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2071]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2072]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2074]! } + public var CallSettings_Title: String { return self._s[2075]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2076]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2078]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2079]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2073]!, self._r[2073]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2080]!, self._r[2080]!, [_1, _2]) } - public var Passport_Identity_DocumentDetails: String { return self._s[2074]! } - public var LoginPassword_PasswordHelp: String { return self._s[2075]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2076]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2077]! } - public var Checkout_TotalPaidAmount: String { return self._s[2078]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2081]! } + public var LoginPassword_PasswordHelp: String { return self._s[2082]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2083]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2084]! } + public var Checkout_TotalPaidAmount: String { return self._s[2085]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2079]!, self._r[2079]!, [_0]) + return formatWithArgumentRanges(self._s[2086]!, self._r[2086]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[2080]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2082]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2083]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2087]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2089]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2090]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2084]!, self._r[2084]!, [_1]) + return formatWithArgumentRanges(self._s[2091]!, self._r[2091]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2085]! } - public var Contacts_InviteFriends: String { return self._s[2087]! } - public var Map_ChooseLocationTitle: String { return self._s[2088]! } - public var Conversation_StopPoll: String { return self._s[2090]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2092]! } + public var Contacts_InviteFriends: String { return self._s[2094]! } + public var Map_ChooseLocationTitle: String { return self._s[2095]! } + public var Conversation_StopPoll: String { return self._s[2097]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2091]!, self._r[2091]!, [_0]) + return formatWithArgumentRanges(self._s[2098]!, self._r[2098]!, [_0]) } - public var Call_Camera: String { return self._s[2092]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2093]! } - public var Calls_RatingFeedback: String { return self._s[2094]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2095]! } - public var NotificationsSound_Pulse: String { return self._s[2096]! } - public var Watch_LastSeen_Lately: String { return self._s[2097]! } - public var ReportGroupLocation_Report: String { return self._s[2100]! } - public var Widget_NoUsers: String { return self._s[2101]! } - public var Conversation_UnvotePoll: String { return self._s[2102]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2104]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2105]! } - public var NotificationsSound_Circles: String { return self._s[2106]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2108]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2109]! } - public var Proxy_TooltipUnavailable: String { return self._s[2110]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2112]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2114]! } - public var Conversation_FileDropbox: String { return self._s[2115]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2116]! } - public var Tour_Text3: String { return self._s[2118]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2120]! } - public var GroupPermission_NoSendMessages: String { return self._s[2121]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2122]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2123]! } + public var Call_Camera: String { return self._s[2099]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2100]! } + public var Calls_RatingFeedback: String { return self._s[2101]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2102]! } + public var NotificationsSound_Pulse: String { return self._s[2103]! } + public var Watch_LastSeen_Lately: String { return self._s[2104]! } + public var ReportGroupLocation_Report: String { return self._s[2107]! } + public var Widget_NoUsers: String { return self._s[2108]! } + public var Conversation_UnvotePoll: String { return self._s[2109]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2111]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2112]! } + public var NotificationsSound_Circles: String { return self._s[2113]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2115]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2116]! } + public var Proxy_TooltipUnavailable: String { return self._s[2117]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2119]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2121]! } + public var Conversation_FileDropbox: String { return self._s[2122]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2123]! } + public var Tour_Text3: String { return self._s[2125]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2127]! } + public var GroupPermission_NoSendMessages: String { return self._s[2128]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2129]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2130]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2125]!, self._r[2125]!, [_0]) + return formatWithArgumentRanges(self._s[2132]!, self._r[2132]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2126]! } - public var Checkout_ShippingOption_Title: String { return self._s[2127]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2128]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2133]! } + public var Checkout_ShippingOption_Title: String { return self._s[2134]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2135]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2129]!, self._r[2129]!, [_0]) + return formatWithArgumentRanges(self._s[2136]!, self._r[2136]!, [_0]) } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2130]!, self._r[2130]!, [_0]) + return formatWithArgumentRanges(self._s[2137]!, self._r[2137]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2131]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2132]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2133]! } - public var AutoDownloadSettings_Photos: String { return self._s[2135]! } - public var Appearance_PreviewIncomingText: String { return self._s[2136]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2137]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2138]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2139]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2140]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2141]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2142]! } - public var Notification_SecretChatScreenshot: String { return self._s[2143]! } - public var AccessDenied_Wallpapers: String { return self._s[2144]! } - public var Passport_Address_City: String { return self._s[2146]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2147]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2148]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2149]! } - public var AccessDenied_LocationDisabled: String { return self._s[2150]! } - public var Group_Location_Title: String { return self._s[2151]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2153]! } - public var GroupInfo_Sound: String { return self._s[2154]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2155]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2156]! } - public var Contacts_Title: String { return self._s[2157]! } - public var Passport_Language_fr: String { return self._s[2158]! } - public var Notifications_ResetAllNotifications: String { return self._s[2159]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2162]! } - public var Checkout_NewCard_Title: String { return self._s[2163]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2164]! } - public var Conversation_ForwardChats: String { return self._s[2165]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2167]! } - public var Settings_FAQ: String { return self._s[2169]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2170]! } - public var Conversation_ContextMenuForward: String { return self._s[2171]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2174]! } - public var PrivacyPolicy_Title: String { return self._s[2177]! } - public var Notifications_TextTone: String { return self._s[2178]! } - public var Profile_CreateNewContact: String { return self._s[2179]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2180]! } - public var Call_Speaker: String { return self._s[2182]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2183]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2185]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2186]! } + public var Channel_Management_LabelAdministrator: String { return self._s[2138]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2139]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2140]! } + public var AutoDownloadSettings_Photos: String { return self._s[2142]! } + public var Appearance_PreviewIncomingText: String { return self._s[2143]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2144]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2145]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2146]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2147]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2148]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2149]! } + public var Notification_SecretChatScreenshot: String { return self._s[2150]! } + public var AccessDenied_Wallpapers: String { return self._s[2151]! } + public var Passport_Address_City: String { return self._s[2153]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2154]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2155]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2156]! } + public var AccessDenied_LocationDisabled: String { return self._s[2157]! } + public var Group_Location_Title: String { return self._s[2158]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2160]! } + public var GroupInfo_Sound: String { return self._s[2161]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2162]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2163]! } + public var Contacts_Title: String { return self._s[2164]! } + public var Passport_Language_fr: String { return self._s[2165]! } + public var Notifications_ResetAllNotifications: String { return self._s[2166]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2169]! } + public var Checkout_NewCard_Title: String { return self._s[2170]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2171]! } + public var Conversation_ForwardChats: String { return self._s[2172]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2174]! } + public var Settings_FAQ: String { return self._s[2176]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2177]! } + public var Conversation_ContextMenuForward: String { return self._s[2178]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2181]! } + public var PrivacyPolicy_Title: String { return self._s[2184]! } + public var Notifications_TextTone: String { return self._s[2185]! } + public var Profile_CreateNewContact: String { return self._s[2186]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2187]! } + public var Call_Speaker: String { return self._s[2189]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2190]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2192]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2193]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2187]!, self._r[2187]!, [_0]) + return formatWithArgumentRanges(self._s[2194]!, self._r[2194]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2188]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2189]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2190]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2191]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2192]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2193]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2194]! } - public var Bot_Unblock: String { return self._s[2195]! } - public var TextFormat_Italic: String { return self._s[2196]! } - public var WallpaperSearch_ColorPink: String { return self._s[2197]! } - public var Settings_About_Help: String { return self._s[2198]! } - public var SearchImages_Title: String { return self._s[2199]! } - public var Weekday_Wednesday: String { return self._s[2200]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2201]! } - public var ExplicitContent_AlertTitle: String { return self._s[2202]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2195]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2196]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2197]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2198]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2199]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2200]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2201]! } + public var Bot_Unblock: String { return self._s[2202]! } + public var TextFormat_Italic: String { return self._s[2203]! } + public var WallpaperSearch_ColorPink: String { return self._s[2204]! } + public var Settings_About_Help: String { return self._s[2205]! } + public var SearchImages_Title: String { return self._s[2206]! } + public var Weekday_Wednesday: String { return self._s[2207]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2208]! } + public var ExplicitContent_AlertTitle: String { return self._s[2209]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2210]!, self._r[2210]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2204]! } - public var Weekday_Thursday: String { return self._s[2205]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2206]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2207]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2211]! } + public var Weekday_Thursday: String { return self._s[2212]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2213]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2214]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2208]!, self._r[2208]!, [_0]) + return formatWithArgumentRanges(self._s[2215]!, self._r[2215]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2209]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2210]! } - public var Passport_RequestedInformation: String { return self._s[2211]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2212]! } - public var Conversation_EncryptionProcessing: String { return self._s[2214]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2215]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2217]! } - public var Channel_Setup_Title: String { return self._s[2218]! } - public var Conversation_SearchPlaceholder: String { return self._s[2219]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2220]! } - public var Checkout_ErrorGeneric: String { return self._s[2221]! } - public var Passport_Language_hu: String { return self._s[2222]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2216]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2217]! } + public var Passport_RequestedInformation: String { return self._s[2218]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2219]! } + public var Conversation_EncryptionProcessing: String { return self._s[2221]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2222]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2224]! } + public var Channel_Setup_Title: String { return self._s[2225]! } + public var Conversation_SearchPlaceholder: String { return self._s[2226]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2227]! } + public var Checkout_ErrorGeneric: String { return self._s[2228]! } + public var Passport_Language_hu: String { return self._s[2229]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2224]!, self._r[2224]!, [_0]) + return formatWithArgumentRanges(self._s[2231]!, self._r[2231]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2227]!, self._r[2227]!, [_1]) + return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_1]) } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2228]!, self._r[2228]!, [_0]) + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_0]) } - public var Group_Location_Info: String { return self._s[2229]! } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2230]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2231]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2232]! } + public var Group_Location_Info: String { return self._s[2236]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2237]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2238]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2239]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2233]!, self._r[2233]!, [_0]) + return formatWithArgumentRanges(self._s[2240]!, self._r[2240]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2234]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2235]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2236]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2241]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2242]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2243]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2237]!, self._r[2237]!, [_0]) + return formatWithArgumentRanges(self._s[2244]!, self._r[2244]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2238]! } - public var Message_PinnedAnimationMessage: String { return self._s[2240]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2242]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2243]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2245]! } - public var Embed_PlayingInPIP: String { return self._s[2246]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2247]! } + public var Passport_Language_cs: String { return self._s[2245]! } + public var Message_PinnedAnimationMessage: String { return self._s[2247]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2249]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2250]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2252]! } + public var Embed_PlayingInPIP: String { return self._s[2253]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2254]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2248]!, self._r[2248]!, [_0]) + return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2249]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2256]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2250]!, self._r[2250]!, [_1]) + return formatWithArgumentRanges(self._s[2257]!, self._r[2257]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2251]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2252]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2253]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2254]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2255]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2256]! } + public var Notification_PaymentSent: String { return self._s[2258]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2259]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2260]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2261]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2262]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2263]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2259]!, self._r[2259]!, [_1]) + return formatWithArgumentRanges(self._s[2266]!, self._r[2266]!, [_1]) } public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2260]!, self._r[2260]!, [_1]) + return formatWithArgumentRanges(self._s[2267]!, self._r[2267]!, [_1]) } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2261]!, self._r[2261]!, [_1]) + return formatWithArgumentRanges(self._s[2268]!, self._r[2268]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2263]! } - public var PasscodeSettings_HelpTop: String { return self._s[2264]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2265]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2266]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2267]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2268]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2269]! } - public var Call_Accept: String { return self._s[2271]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2272]! } - public var Month_GenMarch: String { return self._s[2274]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2275]! } - public var LoginPassword_Title: String { return self._s[2276]! } - public var Call_End: String { return self._s[2277]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2278]! } - public var VoiceOver_Chat_Contact: String { return self._s[2279]! } - public var CallSettings_Always: String { return self._s[2280]! } - public var CallFeedback_Success: String { return self._s[2281]! } - public var TwoStepAuth_SetupHint: String { return self._s[2282]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2270]! } + public var PasscodeSettings_HelpTop: String { return self._s[2271]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2272]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2273]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2274]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2275]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2276]! } + public var Call_Accept: String { return self._s[2278]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2279]! } + public var Month_GenMarch: String { return self._s[2281]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2282]! } + public var LoginPassword_Title: String { return self._s[2283]! } + public var Call_End: String { return self._s[2284]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2285]! } + public var VoiceOver_Chat_Contact: String { return self._s[2286]! } + public var CallSettings_Always: String { return self._s[2287]! } + public var CallFeedback_Success: String { return self._s[2288]! } + public var TwoStepAuth_SetupHint: String { return self._s[2289]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2283]!, self._r[2283]!, [_1]) + return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2284]! } - public var Login_PhoneTitle: String { return self._s[2285]! } - public var Passport_FieldPhoneHelp: String { return self._s[2286]! } - public var Weekday_ShortSunday: String { return self._s[2287]! } - public var Passport_InfoFAQ_URL: String { return self._s[2288]! } - public var ContactInfo_Job: String { return self._s[2290]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2291]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2292]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2293]! } - public var Invite_ChannelsTooMuch: String { return self._s[2294]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2295]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2296]! } - public var CallFeedback_ReasonNoise: String { return self._s[2297]! } - public var Appearance_AppIconDefault: String { return self._s[2299]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2300]! } - public var MediaPicker_AddCaption: String { return self._s[2301]! } - public var CallSettings_TabIconDescription: String { return self._s[2302]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2291]! } + public var Login_PhoneTitle: String { return self._s[2292]! } + public var Passport_FieldPhoneHelp: String { return self._s[2293]! } + public var Weekday_ShortSunday: String { return self._s[2294]! } + public var Passport_InfoFAQ_URL: String { return self._s[2295]! } + public var ContactInfo_Job: String { return self._s[2297]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2298]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2299]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2300]! } + public var Invite_ChannelsTooMuch: String { return self._s[2301]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2302]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2303]! } + public var CallFeedback_ReasonNoise: String { return self._s[2304]! } + public var Appearance_AppIconDefault: String { return self._s[2306]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2307]! } + public var MediaPicker_AddCaption: String { return self._s[2308]! } + public var CallSettings_TabIconDescription: String { return self._s[2309]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_0]) + return formatWithArgumentRanges(self._s[2310]!, self._r[2310]!, [_0]) } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2304]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2305]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2306]! } - public var DialogList_SearchSectionRecent: String { return self._s[2307]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2308]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2311]! } - public var LastSeen_WithinAWeek: String { return self._s[2312]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2313]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2315]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2316]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2311]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2312]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2313]! } + public var DialogList_SearchSectionRecent: String { return self._s[2314]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2315]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2318]! } + public var LastSeen_WithinAWeek: String { return self._s[2319]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2320]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2322]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2323]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2317]!, self._r[2317]!, [_0]) + return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2318]! } - public var Conversation_StatusLeftGroup: String { return self._s[2319]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2320]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2322]! } - public var GroupPermission_AddSuccess: String { return self._s[2323]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2325]! } - public var Conversation_ContextMenuCopy: String { return self._s[2326]! } - public var AccessDenied_CallMicrophone: String { return self._s[2327]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2325]! } + public var Conversation_StatusLeftGroup: String { return self._s[2326]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2327]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2329]! } + public var GroupPermission_AddSuccess: String { return self._s[2330]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2332]! } + public var Conversation_ContextMenuCopy: String { return self._s[2333]! } + public var AccessDenied_CallMicrophone: String { return self._s[2334]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2328]!, self._r[2328]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2335]!, self._r[2335]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2329]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2330]! } - public var Checkout_PaymentMethod_New: String { return self._s[2331]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2332]! } - public var PhotoEditor_QualityTool: String { return self._s[2333]! } - public var Login_SendCodeViaSms: String { return self._s[2334]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2335]! } - public var Login_EmailNotConfiguredError: String { return self._s[2336]! } - public var SocksProxySetup_Status: String { return self._s[2337]! } - public var PrivacyPolicy_Accept: String { return self._s[2338]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2339]! } - public var Appearance_AppIconClassicX: String { return self._s[2340]! } + public var Login_InvalidFirstNameError: String { return self._s[2336]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2337]! } + public var Checkout_PaymentMethod_New: String { return self._s[2338]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2339]! } + public var PhotoEditor_QualityTool: String { return self._s[2340]! } + public var Login_SendCodeViaSms: String { return self._s[2341]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2342]! } + public var Login_EmailNotConfiguredError: String { return self._s[2343]! } + public var SocksProxySetup_Status: String { return self._s[2344]! } + public var PrivacyPolicy_Accept: String { return self._s[2345]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2346]! } + public var Appearance_AppIconClassicX: String { return self._s[2347]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2341]!, self._r[2341]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2348]!, self._r[2348]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2342]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2343]! } - public var AutoNightTheme_Automatic: String { return self._s[2344]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2345]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2346]! } - public var Cache_Help: String { return self._s[2347]! } - public var Group_ErrorAccessDenied: String { return self._s[2348]! } - public var Passport_Language_fa: String { return self._s[2349]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2350]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2351]! } - public var PrivacySettings_LastSeen: String { return self._s[2352]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2349]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2350]! } + public var AutoNightTheme_Automatic: String { return self._s[2351]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2352]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2353]! } + public var Cache_Help: String { return self._s[2354]! } + public var Group_ErrorAccessDenied: String { return self._s[2355]! } + public var Passport_Language_fa: String { return self._s[2356]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2357]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2358]! } + public var PrivacySettings_LastSeen: String { return self._s[2359]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2360]!, self._r[2360]!, [_0, _1]) } - public var Preview_SaveGif: String { return self._s[2357]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2358]! } - public var Profile_About: String { return self._s[2359]! } - public var Channel_About_Placeholder: String { return self._s[2360]! } - public var Login_InfoTitle: String { return self._s[2361]! } + public var Preview_SaveGif: String { return self._s[2364]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2365]! } + public var Profile_About: String { return self._s[2366]! } + public var Channel_About_Placeholder: String { return self._s[2367]! } + public var Login_InfoTitle: String { return self._s[2368]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2362]!, self._r[2362]!, [_0]) + return formatWithArgumentRanges(self._s[2369]!, self._r[2369]!, [_0]) } - public var Watch_Suggestion_CantTalk: String { return self._s[2364]! } - public var ContactInfo_Title: String { return self._s[2365]! } - public var Media_ShareThisVideo: String { return self._s[2366]! } - public var Weekday_ShortFriday: String { return self._s[2367]! } - public var AccessDenied_Contacts: String { return self._s[2368]! } - public var Notification_CallIncomingShort: String { return self._s[2369]! } - public var Group_Setup_TypePublic: String { return self._s[2370]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2371]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2372]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2375]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2376]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2377]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2378]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2379]! } - public var DialogList_Typing: String { return self._s[2380]! } - public var CallFeedback_IncludeLogs: String { return self._s[2382]! } - public var Checkout_Phone: String { return self._s[2384]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2387]! } - public var Privacy_Calls_Integration: String { return self._s[2388]! } - public var Notifications_PermissionsAllow: String { return self._s[2389]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2393]! } - public var Settings_ChatSettings: String { return self._s[2394]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2371]! } + public var ContactInfo_Title: String { return self._s[2372]! } + public var Media_ShareThisVideo: String { return self._s[2373]! } + public var Weekday_ShortFriday: String { return self._s[2374]! } + public var AccessDenied_Contacts: String { return self._s[2375]! } + public var Notification_CallIncomingShort: String { return self._s[2376]! } + public var Group_Setup_TypePublic: String { return self._s[2377]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2378]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2379]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2382]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2383]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2384]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2385]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2386]! } + public var DialogList_Typing: String { return self._s[2387]! } + public var CallFeedback_IncludeLogs: String { return self._s[2389]! } + public var Checkout_Phone: String { return self._s[2391]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2394]! } + public var Privacy_Calls_Integration: String { return self._s[2395]! } + public var Notifications_PermissionsAllow: String { return self._s[2396]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2400]! } + public var Settings_ChatSettings: String { return self._s[2401]! } public func PUSH_MESSAGE_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2395]!, self._r[2395]!, [_1]) + return formatWithArgumentRanges(self._s[2402]!, self._r[2402]!, [_1]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2396]!, self._r[2396]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2403]!, self._r[2403]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2398]! } + public var GroupRemoved_DeleteUser: String { return self._s[2405]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2399]!, self._r[2399]!, [_0]) + return formatWithArgumentRanges(self._s[2406]!, self._r[2406]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2400]!, self._r[2400]!, [_1]) + return formatWithArgumentRanges(self._s[2407]!, self._r[2407]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2401]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2402]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2404]! } - public var Conversation_Unblock: String { return self._s[2405]! } - public var PrivacySettings_DataSettings: String { return self._s[2406]! } - public var Group_PublicLink_Info: String { return self._s[2407]! } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2408]! } + public var Login_ContinueWithLocalization: String { return self._s[2408]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2409]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2411]! } + public var Conversation_Unblock: String { return self._s[2412]! } + public var PrivacySettings_DataSettings: String { return self._s[2413]! } + public var Group_PublicLink_Info: String { return self._s[2414]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2415]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2409]!, self._r[2409]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2416]!, self._r[2416]!, [_0, _1]) } - public var PrivacySettings_Passcode: String { return self._s[2412]! } - public var Call_Mute: String { return self._s[2413]! } - public var Passport_Language_dz: String { return self._s[2414]! } - public var Passport_Language_tk: String { return self._s[2415]! } + public var PrivacySettings_Passcode: String { return self._s[2419]! } + public var Call_Mute: String { return self._s[2420]! } + public var Passport_Language_dz: String { return self._s[2421]! } + public var Passport_Language_tk: String { return self._s[2422]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2416]!, self._r[2416]!, [_0]) + return formatWithArgumentRanges(self._s[2423]!, self._r[2423]!, [_0]) } - public var Settings_Search: String { return self._s[2417]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2418]! } - public var Conversation_ContextMenuReply: String { return self._s[2419]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2420]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2421]! } - public var Tour_Title1: String { return self._s[2422]! } - public var Conversation_ClearGroupHistory: String { return self._s[2424]! } - public var WallpaperPreview_Motion: String { return self._s[2425]! } + public var Settings_Search: String { return self._s[2424]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2425]! } + public var Conversation_ContextMenuReply: String { return self._s[2426]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2427]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2428]! } + public var Tour_Title1: String { return self._s[2429]! } + public var Conversation_ClearGroupHistory: String { return self._s[2431]! } + public var WallpaperPreview_Motion: String { return self._s[2432]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2426]!, self._r[2426]!, [_0]) + return formatWithArgumentRanges(self._s[2433]!, self._r[2433]!, [_0]) } - public var Call_RateCall: String { return self._s[2427]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2428]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2429]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2430]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2432]! } + public var Call_RateCall: String { return self._s[2434]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2435]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2436]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2437]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2439]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2434]!, self._r[2434]!, [_0]) + return formatWithArgumentRanges(self._s[2441]!, self._r[2441]!, [_0]) } - public var Compose_Create: String { return self._s[2435]! } - public var Contacts_InviteToTelegram: String { return self._s[2436]! } - public var GroupInfo_Notifications: String { return self._s[2437]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2439]! } - public var Month_GenApril: String { return self._s[2440]! } - public var Appearance_AutoNightTheme: String { return self._s[2441]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2443]! } - public var Login_CodeSentSms: String { return self._s[2445]! } + public var Compose_Create: String { return self._s[2442]! } + public var Contacts_InviteToTelegram: String { return self._s[2443]! } + public var GroupInfo_Notifications: String { return self._s[2444]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2446]! } + public var Month_GenApril: String { return self._s[2447]! } + public var Appearance_AutoNightTheme: String { return self._s[2448]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2450]! } + public var Login_CodeSentSms: String { return self._s[2452]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2446]!, self._r[2446]!, [_0]) + return formatWithArgumentRanges(self._s[2453]!, self._r[2453]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2447]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2448]! } - public var Passport_Language_hr: String { return self._s[2449]! } - public var Common_ActionNotAllowedError: String { return self._s[2450]! } + public var EmptyGroupInfo_Line3: String { return self._s[2454]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2455]! } + public var Passport_Language_hr: String { return self._s[2456]! } + public var Common_ActionNotAllowedError: String { return self._s[2457]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2451]!, self._r[2451]!, [_0]) + return formatWithArgumentRanges(self._s[2458]!, self._r[2458]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2452]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2453]! } - public var Privacy_SecretChatsTitle: String { return self._s[2454]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2456]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2457]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2458]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2459]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2460]! } - public var Preview_DeleteGif: String { return self._s[2461]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2462]! } - public var Group_ErrorNotMutualContact: String { return self._s[2463]! } - public var Notification_MessageLifetime5s: String { return self._s[2464]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2459]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2460]! } + public var Privacy_SecretChatsTitle: String { return self._s[2461]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2463]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2464]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2465]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2466]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2467]! } + public var Preview_DeleteGif: String { return self._s[2468]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2469]! } + public var Group_ErrorNotMutualContact: String { return self._s[2470]! } + public var Notification_MessageLifetime5s: String { return self._s[2471]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2465]!, self._r[2465]!, [_0]) + return formatWithArgumentRanges(self._s[2472]!, self._r[2472]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2466]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2468]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2469]! } - public var Passport_Address_AddBankStatement: String { return self._s[2470]! } - public var Notification_CallIncoming: String { return self._s[2471]! } - public var Compose_NewGroupTitle: String { return self._s[2472]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2474]! } - public var Passport_Address_Postcode: String { return self._s[2476]! } + public var VoiceOver_Chat_Video: String { return self._s[2473]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2475]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2476]! } + public var Passport_Address_AddBankStatement: String { return self._s[2477]! } + public var Notification_CallIncoming: String { return self._s[2478]! } + public var Compose_NewGroupTitle: String { return self._s[2479]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2481]! } + public var Passport_Address_Postcode: String { return self._s[2483]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2477]!, self._r[2477]!, [_0]) - } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2478]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2479]! } - public var WallpaperColors_Title: String { return self._s[2480]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2481]! } - public var VoiceOver_MessageContextForward: String { return self._s[2482]! } - public var GroupPermission_Duration: String { return self._s[2483]! } - public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2484]!, self._r[2484]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2485]! } - public var Username_Placeholder: String { return self._s[2486]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2487]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2488]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2489]! } - public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_1, _2]) + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2485]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2486]! } + public var WallpaperColors_Title: String { return self._s[2487]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2488]! } + public var VoiceOver_MessageContextForward: String { return self._s[2489]! } + public var GroupPermission_Duration: String { return self._s[2490]! } + public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_0]) } - public var Passport_PasswordDescription: String { return self._s[2492]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2493]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2494]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2495]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2496]! } - public var Conversation_ContextMenuMore: String { return self._s[2497]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2498]! } - public var CallSettings_TabIcon: String { return self._s[2499]! } - public var KeyCommand_Find: String { return self._s[2500]! } - public var Message_PinnedGame: String { return self._s[2501]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2502]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2504]! } - public var Login_CallRequestState2: String { return self._s[2506]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2508]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2492]! } + public var Username_Placeholder: String { return self._s[2493]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2494]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2495]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2496]! } + public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2498]!, self._r[2498]!, [_1, _2]) + } + public var Passport_PasswordDescription: String { return self._s[2499]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2500]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2501]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2502]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2503]! } + public var Conversation_ContextMenuMore: String { return self._s[2504]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2505]! } + public var CallSettings_TabIcon: String { return self._s[2506]! } + public var KeyCommand_Find: String { return self._s[2507]! } + public var Message_PinnedGame: String { return self._s[2508]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2509]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2511]! } + public var Login_CallRequestState2: String { return self._s[2513]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2515]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2509]!, self._r[2509]!, [_0]) + return formatWithArgumentRanges(self._s[2516]!, self._r[2516]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2511]!, self._r[2511]!, [_0]) + return formatWithArgumentRanges(self._s[2518]!, self._r[2518]!, [_0]) } - public var WallpaperPreview_Blurred: String { return self._s[2512]! } - public var Conversation_InstantPagePreview: String { return self._s[2513]! } + public var WallpaperPreview_Blurred: String { return self._s[2519]! } + public var Conversation_InstantPagePreview: String { return self._s[2520]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2514]!, self._r[2514]!, [_0]) + return formatWithArgumentRanges(self._s[2521]!, self._r[2521]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2517]! } - public var WallpaperSearch_ColorRed: String { return self._s[2518]! } - public var GroupPermission_NoPinMessages: String { return self._s[2519]! } - public var Passport_Language_es: String { return self._s[2520]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2522]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2523]! } + public var SecretTimer_VideoDescription: String { return self._s[2524]! } + public var WallpaperSearch_ColorRed: String { return self._s[2525]! } + public var GroupPermission_NoPinMessages: String { return self._s[2526]! } + public var Passport_Language_es: String { return self._s[2527]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2529]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2530]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2524]!, self._r[2524]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2531]!, self._r[2531]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2525]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2526]! } - public var Watch_UserInfo_Unmute: String { return self._s[2527]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2528]! } - public var AccessDenied_CameraRestricted: String { return self._s[2530]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2532]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2533]! } + public var Watch_UserInfo_Unmute: String { return self._s[2534]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2535]! } + public var AccessDenied_CameraRestricted: String { return self._s[2537]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2531]!, self._r[2531]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2538]!, self._r[2538]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2533]! } - public var Settings_CopyUsername: String { return self._s[2534]! } - public var Contacts_SearchLabel: String { return self._s[2535]! } - public var Map_OpenInYandexNavigator: String { return self._s[2537]! } - public var PasscodeSettings_EncryptData: String { return self._s[2538]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2539]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2540]! } - public var DialogList_AdNoticeAlert: String { return self._s[2541]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2543]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2544]! } - public var Localization_LanguageCustom: String { return self._s[2545]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2546]! } - public var CallFeedback_Title: String { return self._s[2547]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2550]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2551]! } - public var Conversation_InfoGroup: String { return self._s[2552]! } - public var Compose_NewMessage: String { return self._s[2553]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2554]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2555]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2556]! } + public var ChatList_ReadAll: String { return self._s[2540]! } + public var Settings_CopyUsername: String { return self._s[2541]! } + public var Contacts_SearchLabel: String { return self._s[2542]! } + public var Map_OpenInYandexNavigator: String { return self._s[2544]! } + public var PasscodeSettings_EncryptData: String { return self._s[2545]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2546]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2547]! } + public var DialogList_AdNoticeAlert: String { return self._s[2548]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2550]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2551]! } + public var Localization_LanguageCustom: String { return self._s[2552]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2553]! } + public var CallFeedback_Title: String { return self._s[2554]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2557]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2558]! } + public var Conversation_InfoGroup: String { return self._s[2559]! } + public var Compose_NewMessage: String { return self._s[2560]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2561]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2562]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2563]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2557]!, self._r[2557]!, [_0]) + return formatWithArgumentRanges(self._s[2564]!, self._r[2564]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2558]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2559]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2560]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2561]! } - public var Channel_BlackList_Title: String { return self._s[2562]! } - public var UserInfo_PhoneCall: String { return self._s[2563]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2565]! } - public var State_connecting: String { return self._s[2566]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2565]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2566]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2567]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2568]! } + public var Channel_BlackList_Title: String { return self._s[2569]! } + public var UserInfo_PhoneCall: String { return self._s[2570]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2572]! } + public var State_connecting: String { return self._s[2573]! } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2567]!, self._r[2567]!, [_0]) + return formatWithArgumentRanges(self._s[2574]!, self._r[2574]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2568]! } - public var Passport_Identity_EditPassport: String { return self._s[2569]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2571]! } - public var Localization_EnglishLanguageName: String { return self._s[2572]! } - public var Share_AuthDescription: String { return self._s[2573]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2574]! } - public var Passport_Identity_Surname: String { return self._s[2575]! } - public var Compose_TokenListPlaceholder: String { return self._s[2576]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2577]! } - public var Settings_AboutEmpty: String { return self._s[2578]! } - public var Conversation_Unmute: String { return self._s[2579]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[2581]! } + public var Notifications_GroupNotifications: String { return self._s[2575]! } + public var Passport_Identity_EditPassport: String { return self._s[2576]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2578]! } + public var Localization_EnglishLanguageName: String { return self._s[2579]! } + public var Share_AuthDescription: String { return self._s[2580]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2581]! } + public var Passport_Identity_Surname: String { return self._s[2582]! } + public var Compose_TokenListPlaceholder: String { return self._s[2583]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2584]! } + public var Settings_AboutEmpty: String { return self._s[2585]! } + public var Conversation_Unmute: String { return self._s[2586]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[2588]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2582]!, self._r[2582]!, [_1]) - } - public var Login_CodeSentCall: String { return self._s[2583]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2585]! } - public var ChatSettings_Appearance: String { return self._s[2586]! } - public var Appearance_PickAccentColor: String { return self._s[2587]! } - public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2588]!, self._r[2588]!, [_1, _2]) - } - public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2589]!, self._r[2589]!, [_1]) } - public var Notification_CallMissed: String { return self._s[2590]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2591]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2592]! } - public var ChatAdmins_AdminLabel: String { return self._s[2594]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2595]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2597]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2598]! } - public var Month_GenJune: String { return self._s[2599]! } - public var Watch_Location_Current: String { return self._s[2600]! } - public var Conversation_TitleMute: String { return self._s[2601]! } + public var Login_CodeSentCall: String { return self._s[2590]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2592]! } + public var ChatSettings_Appearance: String { return self._s[2593]! } + public var Appearance_PickAccentColor: String { return self._s[2594]! } + public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2595]!, self._r[2595]!, [_1, _2]) + } + public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2596]!, self._r[2596]!, [_1]) + } + public var Notification_CallMissed: String { return self._s[2597]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2598]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2599]! } + public var ChatAdmins_AdminLabel: String { return self._s[2601]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2602]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2604]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2605]! } + public var Month_GenJune: String { return self._s[2606]! } + public var Watch_Location_Current: String { return self._s[2607]! } + public var Conversation_TitleMute: String { return self._s[2608]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2602]!, self._r[2602]!, [_1]) + return formatWithArgumentRanges(self._s[2609]!, self._r[2609]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2603]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2610]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2604]!, self._r[2604]!, [_0]) + return formatWithArgumentRanges(self._s[2611]!, self._r[2611]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[2605]! } - public var Chat_SlowmodeSendError: String { return self._s[2606]! } - public var MaskStickerSettings_Info: String { return self._s[2607]! } + public var Call_ReportPlaceholder: String { return self._s[2612]! } + public var Chat_SlowmodeSendError: String { return self._s[2613]! } + public var MaskStickerSettings_Info: String { return self._s[2614]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2608]!, self._r[2608]!, [_0]) + return formatWithArgumentRanges(self._s[2615]!, self._r[2615]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2609]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2611]! } - public var Contacts_ShareTelegram: String { return self._s[2612]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2613]! } - public var Channel_ErrorAccessDenied: String { return self._s[2614]! } - public var UserInfo_ScamBotWarning: String { return self._s[2616]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2617]! } - public var Call_ConnectionErrorTitle: String { return self._s[2618]! } - public var UserInfo_NotificationsEnable: String { return self._s[2619]! } - public var ArchivedChats_IntroText1: String { return self._s[2620]! } - public var Tour_Text4: String { return self._s[2623]! } - public var WallpaperSearch_Recent: String { return self._s[2624]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[2625]! } - public var Profile_MessageLifetime2s: String { return self._s[2627]! } - public var Notification_MessageLifetime2s: String { return self._s[2628]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2616]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2618]! } + public var Contacts_ShareTelegram: String { return self._s[2619]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2620]! } + public var Channel_ErrorAccessDenied: String { return self._s[2621]! } + public var UserInfo_ScamBotWarning: String { return self._s[2623]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2624]! } + public var Call_ConnectionErrorTitle: String { return self._s[2625]! } + public var UserInfo_NotificationsEnable: String { return self._s[2626]! } + public var ArchivedChats_IntroText1: String { return self._s[2627]! } + public var Tour_Text4: String { return self._s[2630]! } + public var WallpaperSearch_Recent: String { return self._s[2631]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[2632]! } + public var Profile_MessageLifetime2s: String { return self._s[2634]! } + public var Notification_MessageLifetime2s: String { return self._s[2635]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2629]!, self._r[2629]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2636]!, self._r[2636]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[2630]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[2631]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2632]! } + public var Cache_ClearCache: String { return self._s[2637]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[2638]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[2639]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2636]!, self._r[2636]!, [_0]) + return formatWithArgumentRanges(self._s[2643]!, self._r[2643]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2638]!, self._r[2638]!, [_0]) + return formatWithArgumentRanges(self._s[2645]!, self._r[2645]!, [_0]) } - public var LocalGroup_Text: String { return self._s[2639]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2640]! } - public var SocksProxySetup_TypeSocks: String { return self._s[2641]! } - public var ChatList_UnarchiveAction: String { return self._s[2642]! } - public var AutoNightTheme_Title: String { return self._s[2643]! } - public var InstantPage_FeedbackButton: String { return self._s[2644]! } - public var Passport_FieldAddress: String { return self._s[2645]! } + public var LocalGroup_Text: String { return self._s[2646]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[2647]! } + public var SocksProxySetup_TypeSocks: String { return self._s[2648]! } + public var ChatList_UnarchiveAction: String { return self._s[2649]! } + public var AutoNightTheme_Title: String { return self._s[2650]! } + public var InstantPage_FeedbackButton: String { return self._s[2651]! } + public var Passport_FieldAddress: String { return self._s[2652]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2646]!, self._r[2646]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2653]!, self._r[2653]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[2647]! } + public var Month_ShortMarch: String { return self._s[2654]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2648]!, self._r[2648]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2655]!, self._r[2655]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2649]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2650]! } - public var Passport_FloodError: String { return self._s[2651]! } - public var SecretGif_Title: String { return self._s[2652]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[2653]! } - public var Passport_Language_th: String { return self._s[2655]! } - public var Passport_Address_Address: String { return self._s[2656]! } - public var Login_InvalidLastNameError: String { return self._s[2657]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[2658]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[2659]! } - public var SettingsSearch_FAQ: String { return self._s[2660]! } - public var ShareMenu_Send: String { return self._s[2661]! } - public var WallpaperSearch_ColorYellow: String { return self._s[2663]! } - public var Month_GenNovember: String { return self._s[2665]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[2667]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[2656]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[2657]! } + public var Passport_FloodError: String { return self._s[2658]! } + public var SecretGif_Title: String { return self._s[2659]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[2660]! } + public var Passport_Language_th: String { return self._s[2662]! } + public var Passport_Address_Address: String { return self._s[2663]! } + public var Login_InvalidLastNameError: String { return self._s[2664]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[2665]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[2666]! } + public var SettingsSearch_FAQ: String { return self._s[2667]! } + public var ShareMenu_Send: String { return self._s[2668]! } + public var WallpaperSearch_ColorYellow: String { return self._s[2670]! } + public var Month_GenNovember: String { return self._s[2672]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[2674]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2668]!, self._r[2668]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2675]!, self._r[2675]!, [_1, _2]) } - public var Checkout_Email: String { return self._s[2669]! } - public var NotificationsSound_Tritone: String { return self._s[2670]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[2672]! } + public var Checkout_Email: String { return self._s[2676]! } + public var NotificationsSound_Tritone: String { return self._s[2677]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[2679]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2675]!, self._r[2675]!, [_1]) + return formatWithArgumentRanges(self._s[2682]!, self._r[2682]!, [_1]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[2676]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[2683]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2677]!, self._r[2677]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[2684]!, self._r[2684]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[2678]! } - public var Notification_Exceptions_Add: String { return self._s[2679]! } - public var DialogList_You: String { return self._s[2680]! } - public var MediaPicker_Send: String { return self._s[2683]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[2684]! } - public var Call_AudioRouteSpeaker: String { return self._s[2685]! } - public var Watch_UserInfo_Title: String { return self._s[2686]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[2687]! } - public var Appearance_AccentColor: String { return self._s[2688]! } + public var ChatList_UndoArchiveTitle: String { return self._s[2685]! } + public var Notification_Exceptions_Add: String { return self._s[2686]! } + public var DialogList_You: String { return self._s[2687]! } + public var MediaPicker_Send: String { return self._s[2690]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[2691]! } + public var Call_AudioRouteSpeaker: String { return self._s[2692]! } + public var Watch_UserInfo_Title: String { return self._s[2693]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[2694]! } + public var Appearance_AccentColor: String { return self._s[2695]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2689]!, self._r[2689]!, [_0]) + return formatWithArgumentRanges(self._s[2696]!, self._r[2696]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2690]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[2697]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2691]!, self._r[2691]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2698]!, self._r[2698]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[2692]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[2693]! } - public var Notification_CallOutgoing: String { return self._s[2694]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2695]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[2696]! } - public var Call_RecordingDisabledMessage: String { return self._s[2697]! } - public var Message_Game: String { return self._s[2698]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[2699]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2700]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[2701]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2702]! } - public var Date_DialogDateFormat: String { return self._s[2703]! } - public var WallpaperColors_SetCustomColor: String { return self._s[2704]! } - public var Notifications_InAppNotifications: String { return self._s[2705]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[2699]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[2700]! } + public var Notification_CallOutgoing: String { return self._s[2701]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[2702]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[2703]! } + public var Call_RecordingDisabledMessage: String { return self._s[2704]! } + public var Message_Game: String { return self._s[2705]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[2706]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[2707]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[2708]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[2709]! } + public var Date_DialogDateFormat: String { return self._s[2710]! } + public var WallpaperColors_SetCustomColor: String { return self._s[2711]! } + public var Notifications_InAppNotifications: String { return self._s[2712]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2706]!, self._r[2706]!, [_0]) + return formatWithArgumentRanges(self._s[2713]!, self._r[2713]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2714]!, self._r[2714]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[2708]! } + public var NewContact_Title: String { return self._s[2715]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2709]!, self._r[2709]!, [_0]) + return formatWithArgumentRanges(self._s[2716]!, self._r[2716]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[2710]! } + public var Conversation_ViewContactDetails: String { return self._s[2717]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2712]!, self._r[2712]!, [_1]) + return formatWithArgumentRanges(self._s[2719]!, self._r[2719]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2713]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[2714]! } - public var PrivacySettings_Title: String { return self._s[2715]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2718]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[2719]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[2720]! } - public var Contacts_PhoneNumber: String { return self._s[2721]! } - public var Map_ShowPlaces: String { return self._s[2723]! } - public var ChatAdmins_Title: String { return self._s[2724]! } - public var InstantPage_Reference: String { return self._s[2726]! } - public var ReportGroupLocation_Text: String { return self._s[2727]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[2720]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[2721]! } + public var PrivacySettings_Title: String { return self._s[2722]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[2725]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[2726]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[2727]! } + public var Contacts_PhoneNumber: String { return self._s[2728]! } + public var Map_ShowPlaces: String { return self._s[2730]! } + public var ChatAdmins_Title: String { return self._s[2731]! } + public var InstantPage_Reference: String { return self._s[2733]! } + public var ReportGroupLocation_Text: String { return self._s[2734]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2728]!, self._r[2728]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2735]!, self._r[2735]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[2729]! } - public var Watch_UserInfo_Block: String { return self._s[2730]! } - public var ChatSettings_Stickers: String { return self._s[2731]! } - public var ChatSettings_DownloadInBackground: String { return self._s[2732]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[2733]! } + public var Camera_FlashOff: String { return self._s[2736]! } + public var Watch_UserInfo_Block: String { return self._s[2737]! } + public var ChatSettings_Stickers: String { return self._s[2738]! } + public var ChatSettings_DownloadInBackground: String { return self._s[2739]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[2740]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2734]!, self._r[2734]!, [_0]) - } - public var Settings_ViewPhoto: String { return self._s[2735]! } - public var Login_CheckOtherSessionMessages: String { return self._s[2736]! } - public var AutoDownloadSettings_Cellular: String { return self._s[2737]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[2738]! } - public var VoiceOver_MessageContextShare: String { return self._s[2739]! } - public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2741]!, self._r[2741]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[2742]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[2743]! } + public var Settings_ViewPhoto: String { return self._s[2742]! } + public var Login_CheckOtherSessionMessages: String { return self._s[2743]! } + public var AutoDownloadSettings_Cellular: String { return self._s[2744]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[2745]! } + public var VoiceOver_MessageContextShare: String { return self._s[2746]! } + public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2748]!, self._r[2748]!, [_0]) + } + public var Privacy_DeleteDrafts: String { return self._s[2749]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[2750]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_0]) - } - public var DialogList_SavedMessagesHelp: String { return self._s[2745]! } - public var DialogList_SavedMessages: String { return self._s[2746]! } - public var GroupInfo_UpgradeButton: String { return self._s[2747]! } - public var DialogList_Pin: String { return self._s[2749]! } - public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2750]!, self._r[2750]!, [_0, _1]) - } - public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[2752]! } - public var UserInfo_NotificationsDisable: String { return self._s[2753]! } - public var Paint_Outlined: String { return self._s[2754]! } - public var Activity_PlayingGame: String { return self._s[2755]! } - public var SearchImages_NoImagesFound: String { return self._s[2756]! } - public var SocksProxySetup_ProxyType: String { return self._s[2757]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[2759]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[2760]! } - public var Settings_AppLanguage: String { return self._s[2761]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[2762]! } - public var Common_ChoosePhoto: String { return self._s[2763]! } - public var CallFeedback_ReasonEcho: String { return self._s[2764]! } + public var DialogList_SavedMessagesHelp: String { return self._s[2752]! } + public var DialogList_SavedMessages: String { return self._s[2753]! } + public var GroupInfo_UpgradeButton: String { return self._s[2754]! } + public var DialogList_Pin: String { return self._s[2756]! } + public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2757]!, self._r[2757]!, [_0, _1]) + } + public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2758]!, self._r[2758]!, [_0]) + } + public var Notification_Exceptions_AlwaysOn: String { return self._s[2759]! } + public var UserInfo_NotificationsDisable: String { return self._s[2760]! } + public var Paint_Outlined: String { return self._s[2761]! } + public var Activity_PlayingGame: String { return self._s[2762]! } + public var SearchImages_NoImagesFound: String { return self._s[2763]! } + public var SocksProxySetup_ProxyType: String { return self._s[2764]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[2766]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[2767]! } + public var Settings_AppLanguage: String { return self._s[2768]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[2769]! } + public var Common_ChoosePhoto: String { return self._s[2770]! } + public var CallFeedback_ReasonEcho: String { return self._s[2771]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2765]!, self._r[2765]!, [_1]) + return formatWithArgumentRanges(self._s[2772]!, self._r[2772]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[2766]! } - public var Activity_UploadingVideo: String { return self._s[2767]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2768]! } - public var NetworkUsageSettings_Wifi: String { return self._s[2769]! } - public var VoiceOver_Editing_ClearText: String { return self._s[2770]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[2771]! } - public var Checkout_PayWithTouchId: String { return self._s[2772]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[2773]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[2773]! } + public var Activity_UploadingVideo: String { return self._s[2774]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2775]! } + public var NetworkUsageSettings_Wifi: String { return self._s[2776]! } + public var VoiceOver_Editing_ClearText: String { return self._s[2777]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[2778]! } + public var Checkout_PayWithTouchId: String { return self._s[2779]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[2780]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2775]!, self._r[2775]!, [_1]) + return formatWithArgumentRanges(self._s[2782]!, self._r[2782]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[2776]! } + public var Notifications_ExceptionsNone: String { return self._s[2783]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2777]!, self._r[2777]!, [_0]) + return formatWithArgumentRanges(self._s[2784]!, self._r[2784]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2778]!, self._r[2778]!, [_1]) + return formatWithArgumentRanges(self._s[2785]!, self._r[2785]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[2780]! } - public var Passport_Address_Region: String { return self._s[2783]! } - public var ChatList_DeleteChat: String { return self._s[2784]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[2785]! } - public var PhotoEditor_TiltShift: String { return self._s[2786]! } - public var Settings_FAQ_URL: String { return self._s[2787]! } - public var Passport_Language_sl: String { return self._s[2788]! } - public var Settings_PrivacySettings: String { return self._s[2790]! } - public var SharedMedia_TitleLink: String { return self._s[2791]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[2792]! } - public var Settings_SetProfilePhoto: String { return self._s[2793]! } - public var Channel_About_Help: String { return self._s[2794]! } - public var Contacts_PermissionsEnable: String { return self._s[2795]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[2796]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[2797]! } - public var CallFeedback_ReasonInterruption: String { return self._s[2799]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[2800]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[2801]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[2802]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[2803]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[2805]! } - public var Map_OpenInYandexMaps: String { return self._s[2807]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[2808]! } - public var VoiceOver_MessageContextReply: String { return self._s[2809]! } - public var PhotoEditor_SaturationTool: String { return self._s[2810]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[2787]! } + public var Passport_Address_Region: String { return self._s[2790]! } + public var ChatList_DeleteChat: String { return self._s[2791]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[2792]! } + public var PhotoEditor_TiltShift: String { return self._s[2793]! } + public var Settings_FAQ_URL: String { return self._s[2794]! } + public var Passport_Language_sl: String { return self._s[2795]! } + public var Settings_PrivacySettings: String { return self._s[2797]! } + public var SharedMedia_TitleLink: String { return self._s[2798]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[2799]! } + public var Settings_SetProfilePhoto: String { return self._s[2800]! } + public var Channel_About_Help: String { return self._s[2801]! } + public var Contacts_PermissionsEnable: String { return self._s[2802]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[2803]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[2804]! } + public var CallFeedback_ReasonInterruption: String { return self._s[2806]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[2807]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[2808]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[2809]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[2810]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[2812]! } + public var Map_OpenInYandexMaps: String { return self._s[2814]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[2815]! } + public var VoiceOver_MessageContextReply: String { return self._s[2816]! } + public var PhotoEditor_SaturationTool: String { return self._s[2817]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2811]!, self._r[2811]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2818]!, self._r[2818]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[2812]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2813]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[2814]! } - public var Appearance_TextSize: String { return self._s[2815]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[2819]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[2820]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[2821]! } + public var Appearance_TextSize: String { return self._s[2822]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2816]!, self._r[2816]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_1, "\(_2)"]) } - public var Channel_Username_InvalidTooShort: String { return self._s[2818]! } + public var Channel_Username_InvalidTooShort: String { return self._s[2825]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2819]!, self._r[2819]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2826]!, self._r[2826]!, [_1, _2]) } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2820]!, self._r[2820]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2827]!, self._r[2827]!, [_1, _2, _3]) } - public var GroupInfo_PublicLinkAdd: String { return self._s[2821]! } - public var Passport_PassportInformation: String { return self._s[2824]! } - public var WatchRemote_AlertTitle: String { return self._s[2825]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2826]! } - public var ConvertToSupergroup_HelpText: String { return self._s[2828]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[2828]! } + public var Passport_PassportInformation: String { return self._s[2831]! } + public var WatchRemote_AlertTitle: String { return self._s[2832]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[2833]! } + public var ConvertToSupergroup_HelpText: String { return self._s[2835]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2829]!, self._r[2829]!, [_0]) + return formatWithArgumentRanges(self._s[2836]!, self._r[2836]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2830]!, self._r[2830]!, [_1]) + return formatWithArgumentRanges(self._s[2837]!, self._r[2837]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2831]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2833]! } - public var AccessDenied_CameraDisabled: String { return self._s[2834]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2838]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[2840]! } + public var AccessDenied_CameraDisabled: String { return self._s[2841]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2835]!, self._r[2835]!, [_0]) + return formatWithArgumentRanges(self._s[2842]!, self._r[2842]!, [_0]) } - public var PhotoEditor_ContrastTool: String { return self._s[2838]! } + public var PhotoEditor_ContrastTool: String { return self._s[2845]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2839]!, self._r[2839]!, [_1]) + return formatWithArgumentRanges(self._s[2846]!, self._r[2846]!, [_1]) } - public var DialogList_Draft: String { return self._s[2840]! } - public var Privacy_TopPeersDelete: String { return self._s[2842]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[2843]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2844]! } - public var WebSearch_RecentSectionClear: String { return self._s[2845]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[2847]! } - public var Common_Done: String { return self._s[2849]! } - public var AuthSessions_EmptyText: String { return self._s[2850]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[2851]! } - public var Tour_Title5: String { return self._s[2852]! } + public var DialogList_Draft: String { return self._s[2847]! } + public var Privacy_TopPeersDelete: String { return self._s[2849]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[2850]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[2851]! } + public var WebSearch_RecentSectionClear: String { return self._s[2852]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[2854]! } + public var Common_Done: String { return self._s[2856]! } + public var AuthSessions_EmptyText: String { return self._s[2857]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[2858]! } + public var Tour_Title5: String { return self._s[2859]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2853]!, self._r[2853]!, [_0]) + return formatWithArgumentRanges(self._s[2860]!, self._r[2860]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2854]! } - public var Conversation_LinkDialogSave: String { return self._s[2855]! } - public var GroupInfo_ActionRestrict: String { return self._s[2856]! } - public var Checkout_Title: String { return self._s[2857]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[2859]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[2861]! } - public var Notification_RenamedGroup: String { return self._s[2862]! } - public var PeopleNearby_Groups: String { return self._s[2863]! } - public var Checkout_PayWithFaceId: String { return self._s[2864]! } - public var Channel_BanList_BlockedTitle: String { return self._s[2865]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[2867]! } - public var Checkout_WebConfirmation_Title: String { return self._s[2868]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[2869]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[2861]! } + public var Conversation_LinkDialogSave: String { return self._s[2862]! } + public var GroupInfo_ActionRestrict: String { return self._s[2863]! } + public var Checkout_Title: String { return self._s[2864]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[2866]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[2868]! } + public var Notification_RenamedGroup: String { return self._s[2869]! } + public var PeopleNearby_Groups: String { return self._s[2870]! } + public var Checkout_PayWithFaceId: String { return self._s[2871]! } + public var Channel_BanList_BlockedTitle: String { return self._s[2872]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[2874]! } + public var Checkout_WebConfirmation_Title: String { return self._s[2875]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[2876]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2870]!, self._r[2870]!, [_0]) + return formatWithArgumentRanges(self._s[2877]!, self._r[2877]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[2872]! } + public var Profile_AddToExisting: String { return self._s[2879]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2880]!, self._r[2880]!, [_0, _1]) } - public var Cache_Files: String { return self._s[2875]! } - public var Permissions_PrivacyPolicy: String { return self._s[2876]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[2877]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2878]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[2880]! } - public var Calls_NoCallsPlaceholder: String { return self._s[2882]! } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2883]! } - public var VoiceOver_AttachMedia: String { return self._s[2885]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2886]! } + public var Cache_Files: String { return self._s[2882]! } + public var Permissions_PrivacyPolicy: String { return self._s[2883]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[2884]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[2885]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[2887]! } + public var Calls_NoCallsPlaceholder: String { return self._s[2889]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2890]! } + public var VoiceOver_AttachMedia: String { return self._s[2892]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[2893]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2887]!, self._r[2887]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2894]!, self._r[2894]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[2888]! } - public var Passport_FieldAddressHelp: String { return self._s[2889]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2890]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[2895]! } + public var Passport_FieldAddressHelp: String { return self._s[2896]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2897]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, [_0]) + return formatWithArgumentRanges(self._s[2898]!, self._r[2898]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[2892]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[2894]! } - public var Login_UnknownError: String { return self._s[2895]! } - public var Group_UpgradeNoticeText2: String { return self._s[2897]! } - public var Watch_Compose_AddContact: String { return self._s[2898]! } - public var Web_Error: String { return self._s[2899]! } - public var Gif_Search: String { return self._s[2900]! } - public var Profile_MessageLifetime1h: String { return self._s[2901]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2902]! } - public var Channel_Username_CheckingUsername: String { return self._s[2903]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[2904]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[2905]! } - public var Channel_AboutItem: String { return self._s[2906]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2908]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[2909]! } - public var GroupInfo_SharedMedia: String { return self._s[2910]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[2899]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[2901]! } + public var Login_UnknownError: String { return self._s[2902]! } + public var Group_UpgradeNoticeText2: String { return self._s[2904]! } + public var Watch_Compose_AddContact: String { return self._s[2905]! } + public var Web_Error: String { return self._s[2906]! } + public var Gif_Search: String { return self._s[2907]! } + public var Profile_MessageLifetime1h: String { return self._s[2908]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[2909]! } + public var Channel_Username_CheckingUsername: String { return self._s[2910]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[2911]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[2912]! } + public var Channel_AboutItem: String { return self._s[2913]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[2915]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[2916]! } + public var GroupInfo_SharedMedia: String { return self._s[2917]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2911]!, self._r[2911]!, [_1]) + return formatWithArgumentRanges(self._s[2918]!, self._r[2918]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[2912]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[2919]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2913]!, self._r[2913]!, [_1]) + return formatWithArgumentRanges(self._s[2920]!, self._r[2920]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[2914]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2915]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[2916]! } - public var CreatePoll_AddOption: String { return self._s[2917]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2918]! } - public var Group_UpgradeNoticeHeader: String { return self._s[2919]! } - public var Channel_Management_AddModerator: String { return self._s[2920]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[2921]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[2922]! } - public var NotificationsSound_Hello: String { return self._s[2923]! } - public var SocksProxySetup_SavedProxies: String { return self._s[2924]! } - public var Channel_Stickers_Placeholder: String { return self._s[2926]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[2921]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[2922]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[2923]! } + public var CreatePoll_AddOption: String { return self._s[2924]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[2925]! } + public var Group_UpgradeNoticeHeader: String { return self._s[2926]! } + public var Channel_Management_AddModerator: String { return self._s[2927]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[2928]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[2929]! } + public var NotificationsSound_Hello: String { return self._s[2930]! } + public var SocksProxySetup_SavedProxies: String { return self._s[2931]! } + public var Channel_Stickers_Placeholder: String { return self._s[2933]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2927]!, self._r[2927]!, [_0]) + return formatWithArgumentRanges(self._s[2934]!, self._r[2934]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2928]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[2929]! } - public var ContactInfo_BirthdayLabel: String { return self._s[2930]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2931]! } - public var AutoDownloadSettings_Channels: String { return self._s[2932]! } - public var Passport_Language_mn: String { return self._s[2933]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[2936]! } - public var Passport_Language_ja: String { return self._s[2938]! } - public var Settings_About_Title: String { return self._s[2939]! } - public var Settings_NotificationsAndSounds: String { return self._s[2940]! } - public var ChannelInfo_DeleteGroup: String { return self._s[2941]! } - public var Settings_BlockedUsers: String { return self._s[2942]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2935]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[2936]! } + public var ContactInfo_BirthdayLabel: String { return self._s[2937]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[2938]! } + public var AutoDownloadSettings_Channels: String { return self._s[2939]! } + public var Passport_Language_mn: String { return self._s[2940]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[2943]! } + public var Passport_Language_ja: String { return self._s[2945]! } + public var Settings_About_Title: String { return self._s[2946]! } + public var Settings_NotificationsAndSounds: String { return self._s[2947]! } + public var ChannelInfo_DeleteGroup: String { return self._s[2948]! } + public var Settings_BlockedUsers: String { return self._s[2949]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2943]!, self._r[2943]!, [_0]) + return formatWithArgumentRanges(self._s[2950]!, self._r[2950]!, [_0]) } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[2944]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[2945]! } - public var Channel_Username_Title: String { return self._s[2946]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[2951]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[2952]! } + public var Channel_Username_Title: String { return self._s[2953]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2947]!, self._r[2947]!, [_0]) + return formatWithArgumentRanges(self._s[2954]!, self._r[2954]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[2949]! } - public var AppleWatch_Title: String { return self._s[2950]! } - public var Activity_RecordingVideoMessage: String { return self._s[2951]! } + public var AttachmentMenu_File: String { return self._s[2956]! } + public var AppleWatch_Title: String { return self._s[2957]! } + public var Activity_RecordingVideoMessage: String { return self._s[2958]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2952]!, self._r[2952]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2959]!, self._r[2959]!, [_1, _2]) } - public var Weekday_Saturday: String { return self._s[2953]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[2954]! } - public var Profile_CreateEncryptedChatError: String { return self._s[2955]! } - public var Common_Next: String { return self._s[2957]! } - public var Channel_Stickers_YourStickers: String { return self._s[2959]! } - public var Call_AudioRouteHeadphones: String { return self._s[2960]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2962]! } - public var Watch_Contacts_NoResults: String { return self._s[2964]! } - public var PhotoEditor_TintTool: String { return self._s[2967]! } - public var LoginPassword_ResetAccount: String { return self._s[2969]! } - public var Settings_SavedMessages: String { return self._s[2970]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[2971]! } - public var Bot_GenericSupportStatus: String { return self._s[2972]! } - public var StickerPack_Add: String { return self._s[2973]! } - public var Checkout_TotalAmount: String { return self._s[2974]! } - public var Your_cards_number_is_invalid: String { return self._s[2975]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[2976]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[2977]! } + public var Weekday_Saturday: String { return self._s[2960]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[2961]! } + public var Profile_CreateEncryptedChatError: String { return self._s[2962]! } + public var Common_Next: String { return self._s[2964]! } + public var Channel_Stickers_YourStickers: String { return self._s[2966]! } + public var Call_AudioRouteHeadphones: String { return self._s[2967]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[2969]! } + public var Watch_Contacts_NoResults: String { return self._s[2971]! } + public var PhotoEditor_TintTool: String { return self._s[2974]! } + public var LoginPassword_ResetAccount: String { return self._s[2976]! } + public var Settings_SavedMessages: String { return self._s[2977]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[2978]! } + public var Bot_GenericSupportStatus: String { return self._s[2979]! } + public var StickerPack_Add: String { return self._s[2980]! } + public var Checkout_TotalAmount: String { return self._s[2981]! } + public var Your_cards_number_is_invalid: String { return self._s[2982]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[2983]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[2984]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2978]!, self._r[2978]!, [_0]) + return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2979]!, self._r[2979]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2980]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[2987]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2982]!, self._r[2982]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2989]!, self._r[2989]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2983]!, self._r[2983]!, [_0]) + return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[2984]! } - public var StickerPack_Share: String { return self._s[2985]! } - public var Passport_DeleteAddress: String { return self._s[2986]! } - public var Settings_Passport: String { return self._s[2987]! } - public var SharedMedia_EmptyFilesText: String { return self._s[2988]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[2989]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2990]! } - public var Contacts_PermissionsText: String { return self._s[2991]! } - public var Group_Setup_HistoryVisible: String { return self._s[2992]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[2994]! } - public var SocksProxySetup_Title: String { return self._s[2995]! } - public var Notification_Mute1h: String { return self._s[2996]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[2991]! } + public var StickerPack_Share: String { return self._s[2992]! } + public var Passport_DeleteAddress: String { return self._s[2993]! } + public var Settings_Passport: String { return self._s[2994]! } + public var SharedMedia_EmptyFilesText: String { return self._s[2995]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[2996]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[2997]! } + public var Contacts_PermissionsText: String { return self._s[2998]! } + public var Group_Setup_HistoryVisible: String { return self._s[2999]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3001]! } + public var SocksProxySetup_Title: String { return self._s[3002]! } + public var Notification_Mute1h: String { return self._s[3003]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2997]!, self._r[2997]!, [_0]) + return formatWithArgumentRanges(self._s[3004]!, self._r[3004]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[2998]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3005]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2999]!, self._r[2999]!, [_1]) + return formatWithArgumentRanges(self._s[3006]!, self._r[3006]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3000]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3003]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3005]! } - public var DialogList_NoMessagesText: String { return self._s[3006]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3007]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3008]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3010]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3011]! } - public var Common_TakePhotoOrVideo: String { return self._s[3012]! } - public var Call_StatusBusy: String { return self._s[3013]! } - public var Conversation_PinnedMessage: String { return self._s[3014]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3015]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3016]! } - public var Undo_ChatCleared: String { return self._s[3017]! } - public var AppleWatch_ReplyPresets: String { return self._s[3018]! } - public var Passport_DiscardMessageDescription: String { return self._s[3020]! } - public var Login_NetworkError: String { return self._s[3021]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3007]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3010]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3012]! } + public var DialogList_NoMessagesText: String { return self._s[3013]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3014]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3015]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3017]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3018]! } + public var Common_TakePhotoOrVideo: String { return self._s[3019]! } + public var Call_StatusBusy: String { return self._s[3020]! } + public var Conversation_PinnedMessage: String { return self._s[3021]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3022]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3023]! } + public var Undo_ChatCleared: String { return self._s[3024]! } + public var AppleWatch_ReplyPresets: String { return self._s[3025]! } + public var Passport_DiscardMessageDescription: String { return self._s[3027]! } + public var Login_NetworkError: String { return self._s[3028]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3022]!, self._r[3022]!, [_0]) + return formatWithArgumentRanges(self._s[3029]!, self._r[3029]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3023]!, self._r[3023]!, [_0]) + return formatWithArgumentRanges(self._s[3030]!, self._r[3030]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3024]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3026]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3031]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3033]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3028]!, self._r[3028]!, [_0]) + return formatWithArgumentRanges(self._s[3035]!, self._r[3035]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3029]! } - public var VoiceOver_Chat_Music: String { return self._s[3030]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3031]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3033]! } - public var ConversationMedia_Title: String { return self._s[3034]! } - public var EncryptionKey_Title: String { return self._s[3036]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3037]! } - public var Notification_Exceptions_AddException: String { return self._s[3038]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3039]! } - public var Profile_MessageLifetime1m: String { return self._s[3040]! } + public var Call_ConnectionErrorMessage: String { return self._s[3036]! } + public var VoiceOver_Chat_Music: String { return self._s[3037]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3038]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3040]! } + public var ConversationMedia_Title: String { return self._s[3041]! } + public var EncryptionKey_Title: String { return self._s[3043]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3044]! } + public var Notification_Exceptions_AddException: String { return self._s[3045]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3046]! } + public var Profile_MessageLifetime1m: String { return self._s[3047]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3041]!, self._r[3041]!, [_1]) + return formatWithArgumentRanges(self._s[3048]!, self._r[3048]!, [_1]) } - public var Month_GenMay: String { return self._s[3042]! } + public var Month_GenMay: String { return self._s[3049]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3043]!, self._r[3043]!, [_0]) + return formatWithArgumentRanges(self._s[3050]!, self._r[3050]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3044]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3045]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3046]! } - public var Conversation_EmptyPlaceholder: String { return self._s[3048]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3049]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3050]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3051]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3052]! } - public var Channel_JoinChannel: String { return self._s[3054]! } - public var Appearance_Animations: String { return self._s[3057]! } + public var PeopleNearby_Users: String { return self._s[3051]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3052]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3053]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3055]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3056]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3057]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3058]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3059]! } + public var Channel_JoinChannel: String { return self._s[3061]! } + public var Appearance_Animations: String { return self._s[3064]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3058]!, self._r[3058]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3065]!, self._r[3065]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3060]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3062]! } - public var Passport_Address_Street: String { return self._s[3063]! } - public var Conversation_AddContact: String { return self._s[3064]! } - public var Login_PhonePlaceholder: String { return self._s[3065]! } - public var Channel_Members_InviteLink: String { return self._s[3067]! } - public var Bot_Stop: String { return self._s[3068]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3070]! } - public var Notification_PassportValueAddress: String { return self._s[3071]! } - public var Month_ShortJuly: String { return self._s[3072]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3073]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3074]! } - public var Passport_Identity_ReverseSide: String { return self._s[3075]! } - public var Watch_Stickers_Recents: String { return self._s[3078]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3080]! } - public var Map_SendThisLocation: String { return self._s[3081]! } + public var Stickers_GroupStickers: String { return self._s[3067]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3069]! } + public var Passport_Address_Street: String { return self._s[3070]! } + public var Conversation_AddContact: String { return self._s[3071]! } + public var Login_PhonePlaceholder: String { return self._s[3072]! } + public var Channel_Members_InviteLink: String { return self._s[3074]! } + public var Bot_Stop: String { return self._s[3075]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3077]! } + public var Notification_PassportValueAddress: String { return self._s[3078]! } + public var Month_ShortJuly: String { return self._s[3079]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3080]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3081]! } + public var Passport_Identity_ReverseSide: String { return self._s[3082]! } + public var Watch_Stickers_Recents: String { return self._s[3085]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3087]! } + public var Map_SendThisLocation: String { return self._s[3088]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3082]!, self._r[3082]!, [_0]) + return formatWithArgumentRanges(self._s[3089]!, self._r[3089]!, [_0]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3083]!, self._r[3083]!, [_0]) + return formatWithArgumentRanges(self._s[3090]!, self._r[3090]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3084]! } + public var ConvertToSupergroup_Note: String { return self._s[3091]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3085]!, self._r[3085]!, [_0]) + return formatWithArgumentRanges(self._s[3092]!, self._r[3092]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3086]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3093]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3087]!, self._r[3087]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3094]!, self._r[3094]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3089]! } - public var Wallpaper_SearchShort: String { return self._s[3090]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3092]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3093]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3094]! } + public var Login_CallRequestState3: String { return self._s[3096]! } + public var Wallpaper_SearchShort: String { return self._s[3097]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3099]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3100]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3101]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3095]!, self._r[3095]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3102]!, self._r[3102]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3096]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3100]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3103]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3107]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3101]!, self._r[3101]!, [_0]) + return formatWithArgumentRanges(self._s[3108]!, self._r[3108]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3102]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3103]! } + public var Passport_CorrectErrors: String { return self._s[3109]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3110]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3104]!, self._r[3104]!, [_0]) + return formatWithArgumentRanges(self._s[3111]!, self._r[3111]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3105]! } - public var Channel_DiscussionGroup: String { return self._s[3106]! } + public var Map_SendMyCurrentLocation: String { return self._s[3112]! } + public var Channel_DiscussionGroup: String { return self._s[3113]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3107]!, self._r[3107]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3114]!, self._r[3114]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3108]! } - public var Permissions_NotificationsText_v0: String { return self._s[3109]! } - public var Appearance_AppIcon: String { return self._s[3110]! } - public var LoginPassword_FloodError: String { return self._s[3111]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3113]! } + public var SharedMedia_SearchNoResults: String { return self._s[3115]! } + public var Permissions_NotificationsText_v0: String { return self._s[3116]! } + public var Appearance_AppIcon: String { return self._s[3117]! } + public var LoginPassword_FloodError: String { return self._s[3118]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3120]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3114]!, self._r[3114]!, [_0]) + return formatWithArgumentRanges(self._s[3121]!, self._r[3121]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3115]! } + public var Passport_Language_bn: String { return self._s[3122]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3116]!, self._r[3116]!, [_0]) + return formatWithArgumentRanges(self._s[3123]!, self._r[3123]!, [_0]) } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3117]!, self._r[3117]!, [_0]) + return formatWithArgumentRanges(self._s[3124]!, self._r[3124]!, [_0]) } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3118]!, self._r[3118]!, [_0]) + return formatWithArgumentRanges(self._s[3125]!, self._r[3125]!, [_0]) } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3121]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3123]! } - public var Contacts_PermissionsAllow: String { return self._s[3124]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3125]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3126]! } - public var WallpaperPreview_Pattern: String { return self._s[3127]! } - public var Paint_Duplicate: String { return self._s[3128]! } - public var Passport_Address_Country: String { return self._s[3129]! } - public var Notification_RenamedChannel: String { return self._s[3131]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3132]! } - public var Group_MessagePhotoUpdated: String { return self._s[3133]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3134]! } - public var Conversation_ContextMenuBan: String { return self._s[3135]! } - public var TwoStepAuth_EmailSent: String { return self._s[3136]! } - public var MessagePoll_NoVotes: String { return self._s[3137]! } - public var Passport_Language_is: String { return self._s[3138]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3140]! } - public var Tour_Text5: String { return self._s[3141]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3128]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3130]! } + public var Contacts_PermissionsAllow: String { return self._s[3131]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3132]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3133]! } + public var WallpaperPreview_Pattern: String { return self._s[3134]! } + public var Paint_Duplicate: String { return self._s[3135]! } + public var Passport_Address_Country: String { return self._s[3136]! } + public var Notification_RenamedChannel: String { return self._s[3138]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3139]! } + public var Group_MessagePhotoUpdated: String { return self._s[3140]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3141]! } + public var Conversation_ContextMenuBan: String { return self._s[3142]! } + public var TwoStepAuth_EmailSent: String { return self._s[3143]! } + public var MessagePoll_NoVotes: String { return self._s[3144]! } + public var Passport_Language_is: String { return self._s[3145]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3147]! } + public var Tour_Text5: String { return self._s[3148]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3143]!, self._r[3143]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3150]!, self._r[3150]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3144]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3145]! } + public var Undo_SecretChatDeleted: String { return self._s[3151]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3152]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3146]!, self._r[3146]!, [_0]) + return formatWithArgumentRanges(self._s[3153]!, self._r[3153]!, [_0]) } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3147]! } - public var Paint_Edit: String { return self._s[3149]! } - public var Undo_DeletedGroup: String { return self._s[3152]! } - public var LoginPassword_ForgotPassword: String { return self._s[3153]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3154]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3154]! } + public var Paint_Edit: String { return self._s[3156]! } + public var Undo_DeletedGroup: String { return self._s[3159]! } + public var LoginPassword_ForgotPassword: String { return self._s[3160]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3161]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3155]!, self._r[3155]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_0, _1]) } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3156]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3157]! } - public var Passport_Language_uz: String { return self._s[3158]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3159]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3160]! } - public var Map_StopLiveLocation: String { return self._s[3162]! } - public var VoiceOver_MessageContextSend: String { return self._s[3164]! } - public var PasscodeSettings_Help: String { return self._s[3165]! } - public var NotificationsSound_Input: String { return self._s[3166]! } - public var Share_Title: String { return self._s[3169]! } - public var LogoutOptions_Title: String { return self._s[3170]! } - public var Login_TermsOfServiceAgree: String { return self._s[3171]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3172]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3173]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3174]! } - public var EnterPasscode_EnterTitle: String { return self._s[3175]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3163]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3164]! } + public var Passport_Language_uz: String { return self._s[3165]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3166]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3167]! } + public var Map_StopLiveLocation: String { return self._s[3169]! } + public var VoiceOver_MessageContextSend: String { return self._s[3171]! } + public var PasscodeSettings_Help: String { return self._s[3172]! } + public var NotificationsSound_Input: String { return self._s[3173]! } + public var Share_Title: String { return self._s[3176]! } + public var LogoutOptions_Title: String { return self._s[3177]! } + public var Login_TermsOfServiceAgree: String { return self._s[3178]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3179]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3180]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3181]! } + public var EnterPasscode_EnterTitle: String { return self._s[3182]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3176]!, self._r[3176]!, [_0]) + return formatWithArgumentRanges(self._s[3183]!, self._r[3183]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3177]! } - public var Conversation_AddToContacts: String { return self._s[3178]! } + public var Settings_CopyPhoneNumber: String { return self._s[3184]! } + public var Conversation_AddToContacts: String { return self._s[3185]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3179]!, self._r[3179]!, [_0]) + return formatWithArgumentRanges(self._s[3186]!, self._r[3186]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3180]! } + public var NotificationsSound_Keys: String { return self._s[3187]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3181]!, self._r[3181]!, [_0]) - } - public var Notification_MessageLifetime1w: String { return self._s[3182]! } - public var Message_Video: String { return self._s[3183]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3184]! } - public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3185]!, self._r[3185]!, [_1]) - } - public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3188]!, self._r[3188]!, [_0]) } - public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3189]!, self._r[3189]!, [_0]) + public var Notification_MessageLifetime1w: String { return self._s[3189]! } + public var Message_Video: String { return self._s[3190]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3191]! } + public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3192]!, self._r[3192]!, [_1]) } - public var Passport_Language_mk: String { return self._s[3190]! } - public var CreatePoll_CancelConfirmation: String { return self._s[3191]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3193]! } - public var PrivacyPolicy_Decline: String { return self._s[3194]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3195]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3196]! } - public var Permissions_SiriAllow_v0: String { return self._s[3198]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3199]! } + public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3195]!, self._r[3195]!, [_0]) + } + public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3196]!, self._r[3196]!, [_0]) + } + public var Passport_Language_mk: String { return self._s[3197]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3198]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3200]! } + public var PrivacyPolicy_Decline: String { return self._s[3201]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3202]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3203]! } + public var Permissions_SiriAllow_v0: String { return self._s[3205]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3206]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3200]!, self._r[3200]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3207]!, self._r[3207]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3201]!, self._r[3201]!, [_0]) + return formatWithArgumentRanges(self._s[3208]!, self._r[3208]!, [_0]) } - public var Paint_Regular: String { return self._s[3202]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3203]! } - public var SocksProxySetup_ShareLink: String { return self._s[3204]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3205]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3207]! } - public var GroupInfo_InviteByLink: String { return self._s[3208]! } - public var MessageTimer_Custom: String { return self._s[3209]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3210]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3212]! } - public var VoiceOver_Chat_Selected: String { return self._s[3213]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3214]! } - public var Channel_Username_InvalidTaken: String { return self._s[3215]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3216]! } - public var Settings_ChatBackground: String { return self._s[3217]! } - public var Channel_Subscribers_Title: String { return self._s[3218]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3219]! } - public var Watch_ConnectionDescription: String { return self._s[3220]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3224]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3225]! } - public var EditProfile_Title: String { return self._s[3226]! } - public var NotificationsSound_Bamboo: String { return self._s[3228]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3230]! } - public var Login_SmsRequestState2: String { return self._s[3231]! } - public var Passport_Language_ar: String { return self._s[3232]! } + public var Paint_Regular: String { return self._s[3209]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3210]! } + public var SocksProxySetup_ShareLink: String { return self._s[3211]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3212]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3214]! } + public var GroupInfo_InviteByLink: String { return self._s[3215]! } + public var MessageTimer_Custom: String { return self._s[3216]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3217]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3219]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3220]! } + public var VoiceOver_Chat_Selected: String { return self._s[3221]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3222]! } + public var Channel_Username_InvalidTaken: String { return self._s[3223]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3224]! } + public var Settings_ChatBackground: String { return self._s[3225]! } + public var Channel_Subscribers_Title: String { return self._s[3226]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3227]! } + public var Watch_ConnectionDescription: String { return self._s[3228]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3232]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3233]! } + public var EditProfile_Title: String { return self._s[3234]! } + public var NotificationsSound_Bamboo: String { return self._s[3236]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3238]! } + public var Login_SmsRequestState2: String { return self._s[3239]! } + public var Passport_Language_ar: String { return self._s[3240]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3233]!, self._r[3233]!, [_0]) + return formatWithArgumentRanges(self._s[3241]!, self._r[3241]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3234]! } - public var Conversation_MessageDialogEdit: String { return self._s[3235]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3236]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3242]! } + public var Conversation_MessageDialogEdit: String { return self._s[3243]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3244]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3237]!, self._r[3237]!, [_1]) + return formatWithArgumentRanges(self._s[3245]!, self._r[3245]!, [_1]) } - public var Common_Close: String { return self._s[3238]! } - public var GroupInfo_PublicLink: String { return self._s[3239]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3240]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3241]! } + public var Common_Close: String { return self._s[3246]! } + public var GroupInfo_PublicLink: String { return self._s[3247]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3248]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3249]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3245]!, self._r[3245]!, [_0]) + return formatWithArgumentRanges(self._s[3253]!, self._r[3253]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3246]! } + public var UserInfo_About_Placeholder: String { return self._s[3254]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3247]!, self._r[3247]!, [_0]) + return formatWithArgumentRanges(self._s[3255]!, self._r[3255]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3248]! } - public var Channel_Info_Banned: String { return self._s[3250]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3256]! } + public var Channel_Info_Banned: String { return self._s[3258]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3251]!, self._r[3251]!, [_0]) + return formatWithArgumentRanges(self._s[3259]!, self._r[3259]!, [_0]) } - public var Appearance_Other: String { return self._s[3252]! } - public var Passport_Language_my: String { return self._s[3253]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3254]! } + public var Appearance_Other: String { return self._s[3260]! } + public var Passport_Language_my: String { return self._s[3261]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3262]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3255]!, self._r[3255]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3263]!, self._r[3263]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3256]! } - public var Preview_CopyAddress: String { return self._s[3257]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3264]! } + public var Preview_CopyAddress: String { return self._s[3265]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3258]!, self._r[3258]!, [_0]) + return formatWithArgumentRanges(self._s[3266]!, self._r[3266]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3259]! } - public var UserInfo_BotSettings: String { return self._s[3260]! } - public var LiveLocation_MenuStopAll: String { return self._s[3262]! } - public var Passport_PasswordCreate: String { return self._s[3263]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3264]! } - public var Message_PinnedLocationMessage: String { return self._s[3265]! } - public var Map_Satellite: String { return self._s[3266]! } - public var Watch_Message_Unsupported: String { return self._s[3267]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3268]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3269]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3267]! } + public var UserInfo_BotSettings: String { return self._s[3268]! } + public var LiveLocation_MenuStopAll: String { return self._s[3270]! } + public var Passport_PasswordCreate: String { return self._s[3271]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3272]! } + public var Message_PinnedLocationMessage: String { return self._s[3273]! } + public var Map_Satellite: String { return self._s[3274]! } + public var Watch_Message_Unsupported: String { return self._s[3275]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3276]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3277]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3270]!, self._r[3270]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3278]!, self._r[3278]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3271]!, self._r[3271]!, [_0]) + return formatWithArgumentRanges(self._s[3279]!, self._r[3279]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3272]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3273]! } - public var NotificationsSound_None: String { return self._s[3274]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3276]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3277]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3280]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3281]! } + public var NotificationsSound_None: String { return self._s[3282]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3284]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3285]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3278]!, self._r[3278]!, [_1]) + return formatWithArgumentRanges(self._s[3286]!, self._r[3286]!, [_1]) } - public var Cache_Indexing: String { return self._s[3279]! } - public var DialogList_RecentTitlePeople: String { return self._s[3281]! } - public var DialogList_EncryptionRejected: String { return self._s[3282]! } - public var GroupInfo_Administrators: String { return self._s[3283]! } - public var Passport_ScanPassportHelp: String { return self._s[3284]! } - public var Application_Name: String { return self._s[3285]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3286]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3288]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3289]! } + public var Cache_Indexing: String { return self._s[3287]! } + public var DialogList_RecentTitlePeople: String { return self._s[3289]! } + public var DialogList_EncryptionRejected: String { return self._s[3290]! } + public var GroupInfo_Administrators: String { return self._s[3291]! } + public var Passport_ScanPassportHelp: String { return self._s[3292]! } + public var Application_Name: String { return self._s[3293]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3294]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3296]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3297]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3290]!, self._r[3290]!, [_0]) + return formatWithArgumentRanges(self._s[3298]!, self._r[3298]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3291]!, self._r[3291]!, [_0]) + return formatWithArgumentRanges(self._s[3299]!, self._r[3299]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3292]!, self._r[3292]!, [_0]) + return formatWithArgumentRanges(self._s[3300]!, self._r[3300]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3293]! } - public var Privacy_ChatsTitle: String { return self._s[3294]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3295]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3296]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3297]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3298]! } - public var Group_LinkedChannel: String { return self._s[3299]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3300]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3301]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3302]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3303]! } - public var Channel_Setup_TypePublic: String { return self._s[3306]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3301]! } + public var Privacy_ChatsTitle: String { return self._s[3302]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3303]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3304]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3305]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3306]! } + public var Group_LinkedChannel: String { return self._s[3307]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3308]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3309]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3310]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3311]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3313]! } + public var Channel_Setup_TypePublic: String { return self._s[3315]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3307]!, self._r[3307]!, [_0]) + return formatWithArgumentRanges(self._s[3316]!, self._r[3316]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3309]! } - public var Map_OpenInMaps: String { return self._s[3311]! } + public var Channel_TypeSetup_Title: String { return self._s[3318]! } + public var Map_OpenInMaps: String { return self._s[3320]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3312]!, self._r[3312]!, [_1]) + return formatWithArgumentRanges(self._s[3321]!, self._r[3321]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3314]! } + public var NotificationsSound_Tremolo: String { return self._s[3323]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3324]!, self._r[3324]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3316]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3317]! } - public var Passport_PasswordHelp: String { return self._s[3318]! } - public var Login_CodeExpiredError: String { return self._s[3319]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3320]! } - public var Conversation_TitleUnmute: String { return self._s[3321]! } - public var Passport_Identity_ScansHelp: String { return self._s[3322]! } - public var Passport_Language_lo: String { return self._s[3323]! } - public var Camera_FlashAuto: String { return self._s[3324]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3325]! } - public var Common_Cancel: String { return self._s[3326]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3327]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3328]! } - public var Appearance_TintAllColors: String { return self._s[3329]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3325]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3326]! } + public var Passport_PasswordHelp: String { return self._s[3327]! } + public var Login_CodeExpiredError: String { return self._s[3328]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3329]! } + public var Conversation_TitleUnmute: String { return self._s[3330]! } + public var Passport_Identity_ScansHelp: String { return self._s[3331]! } + public var Passport_Language_lo: String { return self._s[3332]! } + public var Camera_FlashAuto: String { return self._s[3333]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3334]! } + public var Common_Cancel: String { return self._s[3335]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3336]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3337]! } + public var Appearance_TintAllColors: String { return self._s[3338]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3330]!, self._r[3330]!, [_1]) + return formatWithArgumentRanges(self._s[3339]!, self._r[3339]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3331]! } - public var ChatSettings_Title: String { return self._s[3333]! } - public var Passport_PasswordReset: String { return self._s[3334]! } - public var SocksProxySetup_TypeNone: String { return self._s[3335]! } - public var PhoneNumberHelp_Help: String { return self._s[3337]! } - public var Checkout_EnterPassword: String { return self._s[3338]! } - public var Share_AuthTitle: String { return self._s[3340]! } - public var Activity_UploadingDocument: String { return self._s[3341]! } - public var State_Connecting: String { return self._s[3342]! } - public var Profile_MessageLifetime1w: String { return self._s[3343]! } - public var Conversation_ContextMenuReport: String { return self._s[3344]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3345]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3346]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3340]! } + public var ChatSettings_Title: String { return self._s[3342]! } + public var Passport_PasswordReset: String { return self._s[3343]! } + public var SocksProxySetup_TypeNone: String { return self._s[3344]! } + public var PhoneNumberHelp_Help: String { return self._s[3346]! } + public var Checkout_EnterPassword: String { return self._s[3347]! } + public var Share_AuthTitle: String { return self._s[3349]! } + public var Activity_UploadingDocument: String { return self._s[3350]! } + public var State_Connecting: String { return self._s[3351]! } + public var Profile_MessageLifetime1w: String { return self._s[3352]! } + public var Conversation_ContextMenuReport: String { return self._s[3353]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3354]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3355]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3347]!, self._r[3347]!, [_0]) + return formatWithArgumentRanges(self._s[3356]!, self._r[3356]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3348]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3349]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3350]! } - public var PhotoEditor_Set: String { return self._s[3351]! } - public var EmptyGroupInfo_Title: String { return self._s[3352]! } - public var Login_PadPhoneHelp: String { return self._s[3353]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3355]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3357]! } - public var NotificationsSound_Complete: String { return self._s[3358]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3359]! } - public var Group_Info_AdminLog: String { return self._s[3360]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3361]! } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3362]! } - public var Conversation_Admin: String { return self._s[3364]! } - public var Conversation_GifTooltip: String { return self._s[3365]! } - public var Passport_NotLoggedInMessage: String { return self._s[3366]! } + public var AuthSessions_Terminate: String { return self._s[3357]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3358]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3359]! } + public var PhotoEditor_Set: String { return self._s[3360]! } + public var EmptyGroupInfo_Title: String { return self._s[3361]! } + public var Login_PadPhoneHelp: String { return self._s[3362]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3364]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3366]! } + public var NotificationsSound_Complete: String { return self._s[3367]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3368]! } + public var Group_Info_AdminLog: String { return self._s[3369]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3370]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3371]! } + public var Conversation_Admin: String { return self._s[3373]! } + public var Conversation_GifTooltip: String { return self._s[3374]! } + public var Passport_NotLoggedInMessage: String { return self._s[3375]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3367]!, self._r[3367]!, [_0]) + return formatWithArgumentRanges(self._s[3376]!, self._r[3376]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3368]! } - public var SharedMedia_EmptyTitle: String { return self._s[3370]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3372]! } - public var Username_Help: String { return self._s[3373]! } - public var DialogList_LanguageTooltip: String { return self._s[3375]! } - public var Map_LoadError: String { return self._s[3376]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3377]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3378]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3379]! } - public var Notification_Exceptions_NewException: String { return self._s[3380]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3381]! } - public var WatchRemote_AlertText: String { return self._s[3382]! } - public var ChatSettings_ConnectionType_Title: String { return self._s[3385]! } + public var Profile_MessageLifetimeForever: String { return self._s[3377]! } + public var SharedMedia_EmptyTitle: String { return self._s[3379]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3381]! } + public var Username_Help: String { return self._s[3382]! } + public var DialogList_LanguageTooltip: String { return self._s[3384]! } + public var Map_LoadError: String { return self._s[3385]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3386]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3387]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3388]! } + public var Notification_Exceptions_NewException: String { return self._s[3389]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3390]! } + public var WatchRemote_AlertText: String { return self._s[3391]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[3394]! } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3386]!, self._r[3386]!, [_0]) + return formatWithArgumentRanges(self._s[3395]!, self._r[3395]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3387]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3388]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3396]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3397]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3389]!, self._r[3389]!, [_0]) + return formatWithArgumentRanges(self._s[3398]!, self._r[3398]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3390]!, self._r[3390]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3399]!, self._r[3399]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3391]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3392]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[3394]! } - public var ChatList_UndoArchiveText1: String { return self._s[3395]! } - public var AccessDenied_VideoMicrophone: String { return self._s[3396]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3397]! } - public var Cache_ClearNone: String { return self._s[3398]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[3399]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[3400]! } + public var Group_AdminLog_EmptyText: String { return self._s[3400]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3401]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[3403]! } + public var ChatList_UndoArchiveText1: String { return self._s[3404]! } + public var AccessDenied_VideoMicrophone: String { return self._s[3405]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3406]! } + public var Cache_ClearNone: String { return self._s[3407]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[3408]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[3409]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3401]!, self._r[3401]!, [_0]) + return formatWithArgumentRanges(self._s[3410]!, self._r[3410]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[3402]! } + public var Passport_Identity_Country: String { return self._s[3411]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3403]!, self._r[3403]!, [_0]) + return formatWithArgumentRanges(self._s[3412]!, self._r[3412]!, [_0]) } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3404]!, self._r[3404]!, [_0]) + return formatWithArgumentRanges(self._s[3413]!, self._r[3413]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[3405]! } - public var AccessDenied_Settings: String { return self._s[3406]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3407]! } - public var Month_ShortMay: String { return self._s[3408]! } - public var Compose_NewGroup: String { return self._s[3409]! } - public var Group_Setup_TypePrivate: String { return self._s[3411]! } - public var Login_PadPhoneHelpTitle: String { return self._s[3413]! } - public var Appearance_ThemeDayClassic: String { return self._s[3414]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3415]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[3416]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3417]! } - public var Conversation_typing: String { return self._s[3419]! } - public var Paint_Masks: String { return self._s[3420]! } - public var Contacts_DeselectAll: String { return self._s[3421]! } - public var Username_InvalidTaken: String { return self._s[3422]! } - public var Call_StatusNoAnswer: String { return self._s[3423]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[3424]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3425]! } - public var Passport_Identity_Selfie: String { return self._s[3426]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[3427]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3428]! } - public var Conversation_ClearSecretHistory: String { return self._s[3429]! } - public var PeopleNearby_Description: String { return self._s[3431]! } - public var NetworkUsageSettings_Title: String { return self._s[3432]! } - public var Your_cards_security_code_is_invalid: String { return self._s[3434]! } + public var Exceptions_AddToExceptions: String { return self._s[3414]! } + public var AccessDenied_Settings: String { return self._s[3415]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3416]! } + public var Month_ShortMay: String { return self._s[3417]! } + public var Compose_NewGroup: String { return self._s[3418]! } + public var Group_Setup_TypePrivate: String { return self._s[3420]! } + public var Login_PadPhoneHelpTitle: String { return self._s[3422]! } + public var Appearance_ThemeDayClassic: String { return self._s[3423]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3424]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[3425]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3426]! } + public var Conversation_typing: String { return self._s[3428]! } + public var Paint_Masks: String { return self._s[3429]! } + public var Contacts_DeselectAll: String { return self._s[3430]! } + public var Username_InvalidTaken: String { return self._s[3431]! } + public var Call_StatusNoAnswer: String { return self._s[3432]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[3433]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3434]! } + public var Passport_Identity_Selfie: String { return self._s[3435]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[3436]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3437]! } + public var Conversation_ClearSecretHistory: String { return self._s[3438]! } + public var PeopleNearby_Description: String { return self._s[3440]! } + public var NetworkUsageSettings_Title: String { return self._s[3441]! } + public var Your_cards_security_code_is_invalid: String { return self._s[3443]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_0]) + return formatWithArgumentRanges(self._s[3445]!, self._r[3445]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3437]!, self._r[3437]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3446]!, self._r[3446]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[3439]! } - public var VoiceOver_Navigation_Search: String { return self._s[3440]! } - public var Map_LiveLocationTitle: String { return self._s[3441]! } - public var Login_InfoAvatarAdd: String { return self._s[3442]! } - public var Passport_Identity_FilesView: String { return self._s[3443]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[3444]! } - public var Privacy_Calls_NeverAllow: String { return self._s[3445]! } - public var VoiceOver_Chat_File: String { return self._s[3446]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[3448]! } + public var VoiceOver_Navigation_Search: String { return self._s[3449]! } + public var Map_LiveLocationTitle: String { return self._s[3450]! } + public var Login_InfoAvatarAdd: String { return self._s[3451]! } + public var Passport_Identity_FilesView: String { return self._s[3452]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[3453]! } + public var Privacy_Calls_NeverAllow: String { return self._s[3454]! } + public var VoiceOver_Chat_File: String { return self._s[3455]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3447]!, self._r[3447]!, [_0]) + return formatWithArgumentRanges(self._s[3456]!, self._r[3456]!, [_0]) } - public var ContactInfo_PhoneNumberHidden: String { return self._s[3448]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[3449]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3450]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[3457]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[3458]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3459]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3451]!, self._r[3451]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3460]!, self._r[3460]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3452]! } - public var Tour_Title2: String { return self._s[3453]! } - public var Conversation_FileOpenIn: String { return self._s[3454]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3455]! } - public var Wallpaper_Set: String { return self._s[3456]! } - public var Passport_Identity_Translations: String { return self._s[3458]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3461]! } + public var Tour_Title2: String { return self._s[3462]! } + public var Conversation_FileOpenIn: String { return self._s[3463]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3464]! } + public var Wallpaper_Set: String { return self._s[3465]! } + public var Passport_Identity_Translations: String { return self._s[3467]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3459]!, self._r[3459]!, [_0]) + return formatWithArgumentRanges(self._s[3468]!, self._r[3468]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[3460]! } + public var Channel_LeaveChannel: String { return self._s[3469]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3461]!, self._r[3461]!, [_1]) + return formatWithArgumentRanges(self._s[3470]!, self._r[3470]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3462]! } - public var PhotoEditor_HighlightsTint: String { return self._s[3463]! } - public var Passport_Email_Delete: String { return self._s[3464]! } - public var Conversation_Mute: String { return self._s[3466]! } - public var Channel_AddBotAsAdmin: String { return self._s[3467]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[3469]! } - public var Channel_Management_LabelOwner: String { return self._s[3471]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3471]! } + public var PhotoEditor_HighlightsTint: String { return self._s[3472]! } + public var Passport_Email_Delete: String { return self._s[3473]! } + public var Conversation_Mute: String { return self._s[3475]! } + public var Channel_AddBotAsAdmin: String { return self._s[3476]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[3478]! } + public var Channel_Management_LabelOwner: String { return self._s[3480]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3472]!, self._r[3472]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3481]!, self._r[3481]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[3473]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[3474]! } - public var Common_No: String { return self._s[3475]! } - public var Weekday_Sunday: String { return self._s[3476]! } - public var Notification_Reply: String { return self._s[3477]! } - public var Conversation_ViewMessage: String { return self._s[3478]! } + public var Calls_CallTabDescription: String { return self._s[3482]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[3483]! } + public var Common_No: String { return self._s[3484]! } + public var Weekday_Sunday: String { return self._s[3485]! } + public var Notification_Reply: String { return self._s[3486]! } + public var Conversation_ViewMessage: String { return self._s[3487]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_0]) + return formatWithArgumentRanges(self._s[3488]!, self._r[3488]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3480]!, self._r[3480]!, [_0]) + return formatWithArgumentRanges(self._s[3489]!, self._r[3489]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3481]! } - public var Message_PinnedDocumentMessage: String { return self._s[3482]! } - public var DialogList_TabTitle: String { return self._s[3484]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[3485]! } - public var Passport_FieldEmail: String { return self._s[3486]! } - public var Conversation_UnpinMessageAlert: String { return self._s[3487]! } - public var Passport_Address_TypeBankStatement: String { return self._s[3488]! } - public var Passport_Identity_ExpiryDate: String { return self._s[3489]! } - public var Privacy_Calls_P2P: String { return self._s[3490]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3490]! } + public var Message_PinnedDocumentMessage: String { return self._s[3491]! } + public var DialogList_TabTitle: String { return self._s[3493]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[3494]! } + public var Passport_FieldEmail: String { return self._s[3495]! } + public var Conversation_UnpinMessageAlert: String { return self._s[3496]! } + public var Passport_Address_TypeBankStatement: String { return self._s[3497]! } + public var Passport_Identity_ExpiryDate: String { return self._s[3498]! } + public var Privacy_Calls_P2P: String { return self._s[3499]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3492]!, self._r[3492]!, [_0]) + return formatWithArgumentRanges(self._s[3501]!, self._r[3501]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[3493]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[3502]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3494]!, self._r[3494]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3503]!, self._r[3503]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[3495]! } - public var EnterPasscode_ChangeTitle: String { return self._s[3496]! } - public var Passport_InfoText: String { return self._s[3497]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3498]! } + public var Stickers_ClearRecent: String { return self._s[3504]! } + public var EnterPasscode_ChangeTitle: String { return self._s[3505]! } + public var Passport_InfoText: String { return self._s[3506]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3507]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3499]!, self._r[3499]!, [_0]) + return formatWithArgumentRanges(self._s[3508]!, self._r[3508]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3500]!, self._r[3500]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3509]!, self._r[3509]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3501]! } - public var VoiceOver_Navigation_Compose: String { return self._s[3502]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[3503]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[3505]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3506]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3510]! } + public var VoiceOver_Navigation_Compose: String { return self._s[3511]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[3512]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[3514]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[3515]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3507]!, self._r[3507]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3516]!, self._r[3516]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3509]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3518]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3511]!, self._r[3511]!, [_0]) + return formatWithArgumentRanges(self._s[3520]!, self._r[3520]!, [_0]) } - public var DialogList_Unread: String { return self._s[3512]! } + public var DialogList_Unread: String { return self._s[3521]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3522]!, self._r[3522]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[3514]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[3515]! } + public var User_DeletedAccount: String { return self._s[3523]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[3524]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3516]!, self._r[3516]!, [_0]) + return formatWithArgumentRanges(self._s[3525]!, self._r[3525]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[3517]! } - public var SharedMedia_CategoryMedia: String { return self._s[3518]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[3519]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[3520]! } - public var Watch_ChatList_Compose: String { return self._s[3521]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[3522]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[3523]! } - public var Watch_Microphone_Access: String { return self._s[3524]! } - public var Group_Setup_HistoryHeader: String { return self._s[3525]! } - public var Map_SetThisLocation: String { return self._s[3526]! } - public var Activity_UploadingPhoto: String { return self._s[3527]! } - public var Conversation_Edit: String { return self._s[3529]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[3530]! } - public var Login_TermsOfServiceDecline: String { return self._s[3531]! } - public var Message_PinnedContactMessage: String { return self._s[3532]! } + public var UserInfo_NotificationsDefault: String { return self._s[3526]! } + public var SharedMedia_CategoryMedia: String { return self._s[3527]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[3528]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[3529]! } + public var Watch_ChatList_Compose: String { return self._s[3530]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[3531]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[3532]! } + public var Watch_Microphone_Access: String { return self._s[3533]! } + public var Group_Setup_HistoryHeader: String { return self._s[3534]! } + public var Map_SetThisLocation: String { return self._s[3535]! } + public var Activity_UploadingPhoto: String { return self._s[3536]! } + public var Conversation_Edit: String { return self._s[3538]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[3539]! } + public var Login_TermsOfServiceDecline: String { return self._s[3540]! } + public var Message_PinnedContactMessage: String { return self._s[3541]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3533]!, self._r[3533]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3542]!, self._r[3542]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3534]!, self._r[3534]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[3543]!, self._r[3543]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[3535]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[3537]! } + public var Appearance_LargeEmoji: String { return self._s[3544]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[3546]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3538]!, self._r[3538]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3547]!, self._r[3547]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[3539]! } - public var Message_PinnedPhotoMessage: String { return self._s[3540]! } - public var Passport_FieldPhone: String { return self._s[3541]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3542]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[3543]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[3545]! } - public var Conversation_Call: String { return self._s[3546]! } - public var Common_TakePhoto: String { return self._s[3548]! } - public var Group_EditAdmin_RankTitle: String { return self._s[3549]! } - public var Channel_NotificationLoading: String { return self._s[3550]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[3548]! } + public var Message_PinnedPhotoMessage: String { return self._s[3549]! } + public var Passport_FieldPhone: String { return self._s[3550]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[3551]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[3552]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[3554]! } + public var Conversation_Call: String { return self._s[3555]! } + public var Common_TakePhoto: String { return self._s[3557]! } + public var Group_EditAdmin_RankTitle: String { return self._s[3558]! } + public var Channel_NotificationLoading: String { return self._s[3559]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3551]!, self._r[3551]!, [_0]) + return formatWithArgumentRanges(self._s[3560]!, self._r[3560]!, [_0]) + } + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3561]!, self._r[3561]!, [_0]) } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3552]!, self._r[3552]!, [_1]) + return formatWithArgumentRanges(self._s[3562]!, self._r[3562]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[3553]! } + public var Permissions_SiriTitle_v0: String { return self._s[3563]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3554]!, self._r[3554]!, [_0]) + return formatWithArgumentRanges(self._s[3564]!, self._r[3564]!, [_0]) } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3555]!, self._r[3555]!, [_0]) + return formatWithArgumentRanges(self._s[3565]!, self._r[3565]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[3556]! } - public var Common_edit: String { return self._s[3557]! } - public var PrivacySettings_AuthSessions: String { return self._s[3558]! } - public var Month_ShortJune: String { return self._s[3559]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3560]! } - public var Call_ReportSend: String { return self._s[3561]! } - public var Watch_LastSeen_JustNow: String { return self._s[3562]! } - public var Notifications_MessageNotifications: String { return self._s[3563]! } - public var WallpaperSearch_ColorGreen: String { return self._s[3564]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[3566]! } - public var Group_Status: String { return self._s[3567]! } + public var Channel_MessagePhotoRemoved: String { return self._s[3566]! } + public var Common_edit: String { return self._s[3567]! } + public var PrivacySettings_AuthSessions: String { return self._s[3568]! } + public var Month_ShortJune: String { return self._s[3569]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[3570]! } + public var Call_ReportSend: String { return self._s[3571]! } + public var Watch_LastSeen_JustNow: String { return self._s[3572]! } + public var Notifications_MessageNotifications: String { return self._s[3573]! } + public var WallpaperSearch_ColorGreen: String { return self._s[3574]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[3576]! } + public var Group_Status: String { return self._s[3577]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3568]!, self._r[3568]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3578]!, self._r[3578]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[3569]! } - public var ShareMenu_ShareTo: String { return self._s[3570]! } - public var Conversation_Moderate_Ban: String { return self._s[3571]! } + public var TextFormat_AddLinkTitle: String { return self._s[3579]! } + public var ShareMenu_ShareTo: String { return self._s[3580]! } + public var Conversation_Moderate_Ban: String { return self._s[3581]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3572]!, self._r[3572]!, [_0]) + return formatWithArgumentRanges(self._s[3582]!, self._r[3582]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[3573]! } - public var Map_LiveLocationFor8Hours: String { return self._s[3574]! } + public var SharedMedia_ViewInChat: String { return self._s[3583]! } + public var Map_LiveLocationFor8Hours: String { return self._s[3584]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3575]!, self._r[3575]!, [_1]) + return formatWithArgumentRanges(self._s[3585]!, self._r[3585]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3576]!, self._r[3576]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3586]!, self._r[3586]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3578]!, self._r[3578]!, [_0]) + return formatWithArgumentRanges(self._s[3588]!, self._r[3588]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[3579]! } - public var Appearance_ReduceMotion: String { return self._s[3580]! } + public var Map_OpenInHereMaps: String { return self._s[3589]! } + public var Appearance_ReduceMotion: String { return self._s[3590]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3581]!, self._r[3581]!, [_1, _2]) - } - public var Channel_Setup_TypePublicHelp: String { return self._s[3582]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[3583]! } - public var PhotoEditor_Skip: String { return self._s[3584]! } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Invitation_Members(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Seconds(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Days(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) - } - public func UserCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedPhotos(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_Exceptions(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Contacts_ImportersCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Map_ETAMinutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortSeconds(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Generic(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_SelectedChats(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_File(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Days(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusOnline(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Passport_Scans(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Years(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Video(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Hours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Hours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Minutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortMinutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedLocations(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Seconds(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) - } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAudios(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Minutes(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func Conversation_StatusMembers(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, _1, _2) + return formatWithArgumentRanges(self._s[3591]!, self._r[3591]!, [_1, _2]) } + public var Channel_Setup_TypePublicHelp: String { return self._s[3592]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[3593]! } + public var PhotoEditor_Skip: String { return self._s[3594]! } public func Media_ShareVideo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSimple(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedVideoMessages(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Map_ETAHours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) - } - public func InviteText_ContactsCountText(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedGifs(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_HoursAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Photo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func ForwardedMessages(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedContacts(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Months(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) - } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func StickerPack_StickerCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_SharePhoto(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Days(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, _2, _1, _3) } public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, _2, _1, _3) + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func Media_ShareItem(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_File(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func Media_SharePhoto(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_ShortSeconds(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, _1, _2) } public func QuickSend_Photos(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Video(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_Months(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_StickerCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Hours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessagePoll_VotedCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Minutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func UserCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteFor_Days(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Link(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAHours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortDays(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_AddStickerCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Passport_Scans(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideoMessages(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Days(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Contacts_ImportersCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_Minutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedLocations(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedStickers(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func ForwardedPolls(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedGifs(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Weeks(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Years(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteFor_Hours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusMembers(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) } public func Notification_GameScoreExtended(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) } public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedPhotos(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Map_ETAMinutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortHours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideos(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_Seconds(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LastSeen_HoursAgo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Invitation_Members(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Seconds(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + public func SharedMedia_Generic(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, _1, _2) + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, _1, _2) + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) } public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, selector) return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, _1, _2) } - public func ForwardedVideos(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, _1, _2) } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, _1, _2) } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { + public func InviteText_ContactsCountText(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, _1, _2) + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareItem(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func Conversation_StatusSubscribers(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessagePoll_VotedCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortHours(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_Minutes(_ value: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, _1, _2) + public func Call_ShortMinutes(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, _2, _1, _3) + public func Conversation_StatusOnline(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedStickers(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + public func Notifications_Exceptions(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, _1, _2) + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + public func ForwardedAudios(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Weeks(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, _1, _2) } - public func ForwardedPolls(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteFor_Hours(_ value: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, selector) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = presentationStringsPluralizationForm(self.lc, selector) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, _2, _1, _3) + public func ForwardedFiles(_ value: Int32) -> String { + let form = presentationStringsPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Link(_ value: Int32) -> String { + public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = presentationStringsPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramPresentationData/Sources/PresentationThemeEssentialGraphics.swift b/submodules/TelegramPresentationData/Sources/PresentationThemeEssentialGraphics.swift index 083b4c66a5..5afc057a33 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationThemeEssentialGraphics.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationThemeEssentialGraphics.swift @@ -202,6 +202,10 @@ public final class PrincipalThemeEssentialGraphics { let emptyImage = UIImage() if preview { self.chatMessageBackgroundIncomingImage = messageBubbleImage(incoming: true, fillColor: incoming.fill, strokeColor: incoming.stroke, neighbors: .none, theme: theme, wallpaper: wallpaper, knockout: incomingKnockout) + self.chatMessageBackgroundOutgoingImage = messageBubbleImage(incoming: false, fillColor: outgoing.fill, strokeColor: outgoing.stroke, neighbors: .none, theme: theme, wallpaper: wallpaper, knockout: outgoingKnockout) + self.checkBubbleFullImage = generateCheckImage(partial: false, color: theme.message.outgoingCheckColor)! + self.checkBubblePartialImage = generateCheckImage(partial: true, color: theme.message.outgoingCheckColor)! + self.chatMessageBackgroundIncomingHighlightedImage = emptyImage self.chatMessageBackgroundIncomingMergedTopImage = emptyImage self.chatMessageBackgroundIncomingMergedTopHighlightedImage = emptyImage @@ -213,7 +217,6 @@ public final class PrincipalThemeEssentialGraphics { self.chatMessageBackgroundIncomingMergedBothHighlightedImage = emptyImage self.chatMessageBackgroundIncomingMergedSideImage = emptyImage self.chatMessageBackgroundIncomingMergedSideHighlightedImage = emptyImage - self.chatMessageBackgroundOutgoingImage = messageBubbleImage(incoming: false, fillColor: outgoing.fill, strokeColor: outgoing.stroke, neighbors: .none, theme: theme, wallpaper: wallpaper, knockout: outgoingKnockout) self.chatMessageBackgroundOutgoingHighlightedImage = emptyImage self.chatMessageBackgroundOutgoingMergedTopImage = emptyImage self.chatMessageBackgroundOutgoingMergedTopHighlightedImage = emptyImage @@ -225,8 +228,6 @@ public final class PrincipalThemeEssentialGraphics { self.chatMessageBackgroundOutgoingMergedBothHighlightedImage = emptyImage self.chatMessageBackgroundOutgoingMergedSideImage = emptyImage self.chatMessageBackgroundOutgoingMergedSideHighlightedImage = emptyImage - self.checkBubbleFullImage = emptyImage - self.checkBubblePartialImage = emptyImage self.checkMediaFullImage = emptyImage self.checkMediaPartialImage = emptyImage self.checkFreeFullImage = emptyImage diff --git a/submodules/TelegramPresentationData/Sources/Resources/PresentationResourceKey.swift b/submodules/TelegramPresentationData/Sources/Resources/PresentationResourceKey.swift index dfe1325e08..cbca01ce42 100644 --- a/submodules/TelegramPresentationData/Sources/Resources/PresentationResourceKey.swift +++ b/submodules/TelegramPresentationData/Sources/Resources/PresentationResourceKey.swift @@ -143,6 +143,7 @@ public enum PresentationResourceKey: Int32 { case chatInputTextFieldClearImage case chatInputPanelSendButtonImage case chatInputPanelApplyButtonImage + case chatInputPanelScheduleButtonImage case chatInputPanelVoiceButtonImage case chatInputPanelVideoButtonImage case chatInputPanelExpandButtonImage @@ -159,6 +160,7 @@ public enum PresentationResourceKey: Int32 { case chatInputTextFieldSilentPostOnImage case chatInputTextFieldSilentPostOffImage case chatInputTextFieldTimerImage + case chatInputTextFieldScheduleImage case chatInputSearchPanelUpImage case chatInputSearchPanelUpDisabledImage diff --git a/submodules/TelegramPresentationData/Sources/Resources/PresentationResourcesChat.swift b/submodules/TelegramPresentationData/Sources/Resources/PresentationResourcesChat.swift index d325381591..065cd1fadd 100644 --- a/submodules/TelegramPresentationData/Sources/Resources/PresentationResourcesChat.swift +++ b/submodules/TelegramPresentationData/Sources/Resources/PresentationResourcesChat.swift @@ -362,6 +362,25 @@ public struct PresentationResourcesChat { }) } + public static func chatInputPanelScheduleButtonImage(_ theme: PresentationTheme) -> UIImage? { + return theme.image(PresentationResourceKey.chatInputPanelScheduleButtonImage.rawValue, { theme in + return generateImage(CGSize(width: 33.0, height: 33.0), rotatedContext: { size, context in + context.clear(CGRect(origin: CGPoint(), size: size)) + context.setFillColor(theme.chat.inputPanel.actionControlFillColor.cgColor) + context.fillEllipse(in: CGRect(origin: CGPoint(), size: size)) + + let imageRect = CGRect(origin: CGPoint(), size: size) + context.translateBy(x: imageRect.midX, y: imageRect.midY) + context.scaleBy(x: 1.0, y: -1.0) + context.translateBy(x: -imageRect.midX, y: -imageRect.midY) + + if let image = generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/ScheduleIcon"), color: theme.chat.inputPanel.actionControlForegroundColor) { + context.draw(image.cgImage!, in: CGRect(origin: CGPoint(x: floorToScreenPixels((size.width - image.size.width) / 2.0), y: floorToScreenPixels((size.height - image.size.height) / 2.0)), size: image.size)) + } + }) + }) + } + public static func chatInputPanelVoiceButtonImage(_ theme: PresentationTheme) -> UIImage? { return theme.image(PresentationResourceKey.chatInputPanelVoiceButtonImage.rawValue, { theme in return generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Text/IconMicrophone"), color: theme.chat.inputPanel.panelControlColor) @@ -499,6 +518,12 @@ public struct PresentationResourcesChat { }) } + public static func chatInputTextFieldScheduleImage(_ theme: PresentationTheme) -> UIImage? { + return theme.image(PresentationResourceKey.chatInputTextFieldScheduleImage.rawValue, { theme in + return generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Text/AccessoryIconSchedule"), color: theme.chat.inputPanel.inputControlColor) + }) + } + public static func chatHistoryNavigationButtonImage(_ theme: PresentationTheme) -> UIImage? { return theme.image(PresentationResourceKey.chatHistoryNavigationButtonImage.rawValue, { theme in return generateImage(CGSize(width: 38.0, height: 38.0), contextGenerator: { size, context in diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/Contents.json deleted file mode 100644 index 7e7946ae1b..0000000000 --- a/submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/Contents.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "images" : [ - { - "idiom" : "universal", - "filename" : "telegram_plane_flat.pdf" - } - ], - "info" : { - "version" : 1, - "author" : "xcode" - } -} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/telegram_plane_flat.pdf b/submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/telegram_plane_flat.pdf deleted file mode 100644 index 7c0cc207989976edc8eb1ca2c6c845010e530727..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6186 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 diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Contents.json new file mode 100644 index 0000000000..69aa9981a3 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Contents.json @@ -0,0 +1,22 @@ +{ + "images" : [ + { + "idiom" : "universal", + "scale" : "1x" + }, + { + "idiom" : "universal", + "filename" : "Schedule@2x.png", + "scale" : "2x" + }, + { + "idiom" : "universal", + "filename" : "Schedule@3x.png", + "scale" : "3x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@2x.png b/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..2829293819e4a9149270f3a4c0b139939d1963bc GIT binary patch literal 1004 zcmV@82B$$v-p)+cq7q>VawC}q%GAG1636H7t zI@BCk5~svzaan8}yJX?9*y|1CO=Pb+Cd7r5j)!Uwij9Iuz7}or*tLGb1# z#YNHd&8a>rHUe_>ooL2hsJ>rh()KLv04W4RIH1lqqUpei+TX+mDShOOJatC$9AM(? zOzGW8kJezjo;(rF3DOChwc)BXnevyaZ*!XS9LRg_L|0XD!oP_tt9mOmMkM=H!~yb^ zwDHJ`bXf<`Njlk@pd@W8)^+PIm=9vmPu-gf- zsQL}=5QY(}q|1;4eh;piK8MnV3$(ohoWU{?a^Sa<*y!p-tK_g9kFTqKv8Z5~aUll^ zMIc~oUVWEDK1yr|oLb8`;iK;7A~nUp!m%$R-+)*!Y2F07D2qCQO|$RQS&xf@^FB&A zI#)rA6WGKybBG2PaEk&rsVXSr1h&jBbBM;cBu&vow3Zb??*yB~*h<%`8n(?UyM;;r4Vj~!pR__FBf<+gzJ0XLttuLaFZfrD)A!+yNgkiQ=_U8mD4U{I)L0{==fd~oy3xU|cnUvAZiJ?P>f_6!v2r-a~BCp!>JGtn+FKeH(&%SHzy>6@*p0n55 zd+qmq*0cBe+-GK{T2-JbP!*^OR0XO6Re`ENRiG-+uL4gg+D{wwEGG8y;&_=!Ec4h*hphpx}F>5<7&w!h6D}!WE&( zA2I$GXnMph+GfS>dm$!FI5$b4rV4J+g%54IB1*`2706b4 zk21Vf!KXbk`t7uZOGv*V688m5lr$ahej&9$ayhbh^?OV3ap7`cRHA^NH^t$1!IS(_ z=bm}OFPA{L-z;1be0)S2{7rgMBz}pI`%LGowGk+cV$5|&Ph)FT_;bOFL~|RgPg!#o%9O<|R8Qo4t$b8aJt2P3)DbwJ7$?4de#1x=cdqvR} zh47R(UJzCZF=Krd%94&*DuHNjek#B`X?rYau5(|>ai}my+WMw3!C2IW@}y&yN+5jG zar@DY8Fw#62O26Hj*~i7mL*4@fOO1K3WR^A0D&Jz{P(hUqtmm2d7DyLYJuS72a)*{ zM92Bqri->B2=(f?8>YBs{gO^$%((5tB%O7umoGW%1sb<3>RgXMbf+B&)_3+4ztN6j#5o)<*6Hj<-DSBq zEtoqw4>#e|1|eulV}4@&KTtlENWBPj*HvIgN_FJx9RX2thy+*bm%1c3wlr*zy~!i| z`^MxD39gnqb!lbObkYmX;|ngIBFkRU5n<6dW4rVVVL8psbM?1VQaRdZw3Z@E*KU={+rpF1MH$sf|Ez z^L(>zxl+k_7c_TgP0V04D}(_D!^ts6xLJYVp56F#;@3@lVkylA`|N`d=LGv?n3?ji zt`r;e!yzK@8JEwwRwO#ZHNwyahf9Lx23I)uYJNn65PuvP+TdWtAr05wjWv@0$_km| zy)*eQAhEqTaD?k1#-Ee?Dj$M8#Xg%Gv0`ry+y?stm12)JT8P;LojfCaEG)(flz5JcG2`~jlJK-s9Pv#IVy#$X?KUr@ z5XAbxC%*qT#x?^pTEFRLD?KUAz4*w!WuX`&%h3k~-{X#Ry0}l+E$~NzSz(j#w1E94 zFjOxHH-ziLcLF0+wW>f>pej%ms0vgCssdGksz6nscm@6e(-FB)yp37_00000NkvXX Hu0mjfpX;>3 literal 0 HcmV?d00001 diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/Contents.json new file mode 100644 index 0000000000..1806465436 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/Contents.json @@ -0,0 +1,22 @@ +{ + "images" : [ + { + "idiom" : "universal", + "scale" : "1x" + }, + { + "idiom" : "universal", + "filename" : "ScheduleSendButton@2x.png", + "scale" : "2x" + }, + { + "idiom" : "universal", + "filename" : "ScheduleSendButton@3x.png", + "scale" : "3x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@2x.png b/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..69fecc9a3ba0f24cfcde7f21d7d1dfb431c74a17 GIT binary patch literal 1114 zcmV-g1f~0lP)7NO7>0XGLxR@7sJqaWO^JjRO)MJSva%py*+@66h}c+2 z8XIeEEJR|%f}|3uh!R#L;%7-LP{dE@hKQ=?y`3}OnL9Ig?rrr;-h009e82acGiT13 zN}JKl%uFZZY0zWcY4#@_7b}&@L{OODTKXmf!)6728l6V82!lP~Ja|QM!(e42C+RD0gj3d3ZpLOiSnRg&Ri;VP z)n^a1|3$zn?v7Bb*706xpvNX0cCIgGBD zlh`L<1K2IWC@zdXjj*0fLF+V^(D#5Bz-c7cK?*F7x;6Y`uqx6O73SN;xxyr~dGtq~ zr*aKu`eC#Vd^6*Z@bTUQzr%E5M0GbKTMLe@(1|Avo=7aMI-36t1V*Um(!6gne<0Up zDU8@*48xN#1D~usM4{!MPMJ6#>_5b|g}$xkK`oCjVEKTrZTp{g$qONRVS4fRsW82G15GltZ-TH;Ejizk%g=39 z6&CMD@C#m){dwP-Hl_>ns?Db!^uoGT*t9uoep?}JmVvgw+-|YB5TmwT zBr1(H%`s;&e{3#0;hQZke*NJ)sS$f`0bOa`#Vm{WI~IGvT#EDDlR8oC15VZAGV-+q zSqai-Imv}<4!ushPWx2Y8lc-uprQQKjWqn>VH=rfN!u^|S!j5-a(%KyZWOqUa<;ks04wJvnL4WwglPo3dBbtpE- zJz6KyU^obzbYZAFu_l~a5EK)nZ%Wyhkq{q;QQ)NF=56E@3n-@3Xvm-2V%-6B33bwt z&w0%$2Jq=qj&c`XRgAGV-E?sZG6tI7O5_vy(j-VZbUP|fIB4Y3)2gWYK%xy%yLImC zOS;HLwpkxlM(7V0pz?(UOPuvU_|uA*pifB8z^w@4)t5(#RlLwc@I1JtcA@+EY;1J#i zX24l+19Y=F8VnSP(X}mvd%#k+$f^B>l1vMLV<(sb-=_GiODdDD%ok`SZ9sG>(niNjne6idK>mDzSeV#?Vu!SHv$%b9`q_l zTmqpbeGUP|w`?wyr`ZmM*DV%&mw|5iEu$WqR1iD@tkdEz z{Ezu0_(GGsN!zsD^tnRokm!h78dvdmA2879U0~UyC4z=u7>(O*1nh4ZZR83W09avl zFVHn=*}U1oIqC6~)eGO7u8m)^PY?05oio}*Pf{@mYTb3$@VD+6z7}=*GOae*)^#|T zX`FJf|3&Z)cmr%p?P_k~t1C%80j%d}=7)Ad4${H0SA5Y$>yXxxq;$Zo0fS}P*ECwa zWwiVXU+L?{{TSjfxaEq$t&x#61U&8HH%l6A2Y&$HUTtewvI1#sNlFs@Q@(KOdLD1g zFi?5PXtaWFXUV+Uy1`R-k{Z-oZ!gU!f_rJsp1*y4XLxVB)~0rgRuY}o;NqwxyCe@8 z`ad#!TiNx#A?`@i$6?+EtkJ_Bqf;qY-KVQW5o0&dBwE^3AJmb20{A2N%bWt2)cJNX z^!|p{A3eRgdygu~d%Yd1X69#%He1nk!4S1yN#0}ZxMKKj2bX^&rFnR>lN^ow%W3Js zw;?5Ym+z(ir{OE@;(A%9v(`U+Tja(NGtujQ0P5S7i%Cais1QIc9d^G!3`QH@jfI|vVhIuo^YU)4kO0Pt-YF|`zdBP_lH!e>D10-( zx8|Tm*Q9LmR?+tN`LU^Wf*I45Hv5*p!Zq&cb^%MZW?Nh-Z#yi^w*GAhLSi| zqFs-q^nvbkJV}xhG`8$mMo~=;g6{(hAb7omw&AmNNuv4)!8groS|f>?QVpk-E)YKN znj|?+C(S_nR?ixJcs^!JL>8YxPZFK?Gfe8!W~5DWqG>uuXXmw$BuRZApw%JYG!JA= zc=bF@=>XQelyry9P0=v#6EUp|?(KP2sepmg!WPc0WijO2q@#DJp&Cz8R2kI`0C@V#zVx-D-Wjh#y#YQ71|I+7^8a|L72m zfli6)Ii&}3)RB?+5?<>$$gZYISGDhW+%E!=j%ePg+l;;nW`d-bzcr*OBKbPPCc-O9p?ppef(s?Rzz%jQNf zO-23yG_$Q`2Thu3+EBAOUr8dOWhANr!#r36y)ea@2VoETmeL3t z1l3sA8r0*CX5t@@Ah#L?A|`;|N39oc+=Wd%(Y`?sxekJV0fcFd{#kGo909uCLSpFJ z)pffFJ^>#x2lO{(6blhhIuJ?g2BUe@{lI;aEuU^ax(W5<|3dx;ae{%q zdwX}c?Y8zNn=@x-&dk?y=KRc*DfD&qx^1NOM$#M$iSk|68BO$cd!qS^Jd@~1I$fI? z9@|UAOCZ0@_>uAk6!FiyocJHM?o?^m%6~^wXP+F)jQyDBl%~`?eyVkA{0F1e)#G+* zt=}^Jf|mJLrOBmv+TFD!evz5+w@m(1lUI$<9H-?G+-R28k9nkbdt>x{vZwDNR&H&y zVl=nPX76w|{R9K;6PBK7A!%BrNiVkbiRodxAFG|W4@(c0UWw_d!<^NjEgU0K(yPd$ z@2~>rm|`8RiRXW@?L^T9OCP0>>~&wma(<{a)r94WxurD`?+NqmzU#URZ;a9gfNKWm z2B5s(mJ{FO&Zci&)- z_Dq;*=FYZlO}i1hUX+>0813)xuRk9t@)#x*uC|z_W{P` zL22EAuuI7VMcIpFUixR`Gb~k0Fo5}LOsjSHi{B1-6%dZI?nYZ8-a#?mjAg$Wn9{VR ztGDm{pl=ZqfFADYd)1yvoQap`SE*-qwlscgjf*6csng32A9K&iPv}S`i`nkP`;*PmB@*cqkU5XSZ){{N3T3id+)w7d6oGmehuj4fu>*`8?p#`J@hc{k3_YXIC=qw33sLoluk z;fDe90i%XZwb8y5f&<_4y!VU}mVAI8sNQG#cH5R{`V@Wn&G=WN?%6+@x%Fajba^CK z@@iR0e@2tXUAc7-pV^NUzuUTgeXzuaKijRG20*mm_>mi|`-Hn%`aV$Hzb_dfmi5L0 zez4>%5$MhW@zBEg2Z7;wV0w(>Li<3m;~E2j=3|btW;E#k&xBkG2)(p%>oH}4%6W%4 z2p$(Wj?NgRxoWXdPX)g5>grCp%N2Rv8pD*Jt)}V=raxEhq8j?j_KoM^3M{>@x0ruB z&W3ANe@@7FJU)V19W>76xu{4h>yV}^MmX24W<6jqcv>w*I%7SCSq~Xu#Vyl{lPCKN z-=0%2iVbzysDrLU8p9dGKwCVavy_UGOn(^}Hs~Y6w};PH0@m1)7C`gJLD$*BsnT+@ zAhv>JPY&$qg0-;-MpZDy2->NFv-Ra>sa;UJZYIFW1~RqW)x{|gOSV{6q*)G5U zY=Y6h>-`EwZX~9>p`4*oPHb5*uvc&1ZLsxhT6_xz!!y`?pi*Wr0?E52r49NO5);Al z?Qpo+E_~m1?w`Yk4TVcoYnC#L94FETb4XHJ*~QYIiBD!qW>P@f>5XkWl{&u&59dG4 zMv~K`HPPfhoc$NRJVx;B?~pQ!3>3vt@83NjJ8VOh(DHo4_>-k_OnCp9zcS|l~@~ah%O6M^m73(RSR=;h0Mq~$AgkSz@Yy!$Bdyg&P#ELESaF3V_=DAt~72t z@oPa+X35=Pwrnc2|6avmj(F^!?6^tIsBKJw-!HSEf`J)q#*89(0`d@>5)Eo1K87eofp5~!}f~x{{ue`<3*yUiEjV^002ov JPDHLkV1i3uX>I@j literal 0 HcmV?d00001 diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@3x.png b/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..c238786991b13e5abf66e85570e26787b895ba93 GIT binary patch literal 2664 zcmV-u3YYbXP)j{00004XF*Lt006O% z3;baP000UfNkl%E8X+}-Q!oteA7>+WuB?!(SK-klW=vmq6-+ULYxjkqJzY&NTi0(2_cj94dQTbEcSkhgk`BzS+UEA z4C6mjM)Zv&(1R<4H@-557G1T;hka?6H4PE-_vJ>SK zM2Va|MA`ELso?|3W4~XyzyUD^aRPl z(KbisGC{rY-MTkgU-xApWy+R6uQ1N6{NusF7q{E=IyNtPEG=6c z%B8W~H0X&jK}{$rd*eM@_ZYe=0Xw&Ec@Gm@FUsvgB}^H`5G~6Q9Znt{{)VB`fRf~s zsnK<4ZH#d;W^}anTgzzKSK>V}Yb$8wR9r;4&&xV-9~$8AM&_^=JzyAf)MpJ{5fC`$ zd5e2_n$DobjSU5ezuCOJ`Mcg89Ltl$mencB*L@8d^J8OU%P(HKvQJ3*CYHE2ZeQK} z^o9)^uIlN-$j_zItFlvc+`1}Y5^Pi}?+;o90$cv0X*ysdj+#E%(kQ;;5f5Xa9_Qlt z=Wf%qr;m+cCx?HRa^Ul2{+9*40LjV=rJ&;QC3Sm43`QyjOT5u?NQjdwQ zeg!Mc_IO*{$A(TyLdDD!m(@XDce@qAU|>K z%8$_!x9UZM%%0sno8Q&(BKg&#cYYny;ylNX#HcTpbW;|f3V+vNvOzU!Lh5S;Z?x84l?-XV$Am5w|&z;fN!?xYK=vsksoDeW_ivk-U*_ibNr3rQO};amgiF(M&l!% z!V58+pQ+>r1TWuehP)9HLK!DL9Ebakq|>)~WzUhv@pT6#qDD`_A$Q@MZ;Jf97+Wgu z^`DYY<|k>N#nG8*vC~85$YX{#$EcKt+S}XBEu@!v5r=#hz!LN;(?p7Um`fhV#II?<|fuEQgn+S#%+rb@9Wr-mPx#$+wbI5s}hbd$fN18KmR{^Bz>r}!GzwdNSZB= zrms2q#efoW4-ZZ&C&&zM9L7vs@%Zl}I&>s~NiO;k1PbQNw zyt9nBH3ZnfiS1(h^kSJukZ-P)JZHeZtmyt{^~`w3^skATvBlB@*p7>rCQjIPa%{iL zLnl#?1Ie@d7W=YdoxP-|<$`9W>GX}B1Gs#)!$usF-Un=dkQ*9v3M9`;cH&iav<($- zjb-11E=IHBwHvhxaJgK*t*f)W?1MX>6EZ4j{wFas+=;KehcKBKW1V+jsQE#51*yeG z$lbv3zJsX8YB`8Uq};iyd+Q5UeGwRnJjZ8WR(9z`p{tA1&%I(|nITfYVUGxQ446|? z=p~HTH4jnlsbRgYLz8C??8^#&dn_m7?jTO=3c?-{>=?lJ<3aJl;)}xH-ZOS+=u`u{ zbfT}DyC^SGAwW?qCg1@|M-Ma|@e)Sz|sZ)4XS6ZXf%( zA&!2U3QD#R9KA;!;?tRaNLff`6(R2x%np8eKR1eFPFUyRpETr8PdIN>{2!GSC0|UE z-Mw6|CpiCL9{?X1D&s&@oBz^QjeK!M@H_j!uqz0AM6hFkdp|CnMu*fCTK0zgi~4^s W7de~twk`4i0000 deliverOnMainQueue).start(next: { [weak self] data in if let strongSelf = self, data.complete { strongSelf.cachedData = try? Data(contentsOf: URL(fileURLWithPath: data.path), options: [.mappedRead]) diff --git a/submodules/TelegramUI/TelegramUI/AnimatedStickerUtils.swift b/submodules/TelegramUI/TelegramUI/AnimatedStickerUtils.swift index 1d15924e11..3b481b80c1 100644 --- a/submodules/TelegramUI/TelegramUI/AnimatedStickerUtils.swift +++ b/submodules/TelegramUI/TelegramUI/AnimatedStickerUtils.swift @@ -4,68 +4,69 @@ import SwiftSignalKit import Postbox import Display import TelegramCore -import AVFoundation -import Lottie import TelegramUIPrivateModule import Compression import GZip import RLottie +import MediaResources import MobileCoreServices -public struct LocalBundleResourceId: MediaResourceId { - public let name: String - public let ext: String - - public var uniqueId: String { - return "local-bundle-\(self.name)-\(self.ext)" - } - - public var hashValue: Int { - return self.name.hashValue - } - - public func isEqual(to: MediaResourceId) -> Bool { - if let to = to as? LocalBundleResourceId { - return self.name == to.name && self.ext == to.ext - } else { - return false +private func transformedWithFitzModifier(data: Data, fitzModifier: EmojiFitzModifier?) -> Data { + if let fitzModifier = fitzModifier, var string = String(data: data, encoding: .utf8) { + let color1: UIColor + let color2: UIColor + let color3: UIColor + let color4: UIColor + switch fitzModifier { + case .type12: + color1 = UIColor(rgb: 0xca907a) + color2 = UIColor(rgb: 0xedc5a5) + color3 = UIColor(rgb: 0xf7e3c3) + color4 = UIColor(rgb: 0xfbefd6) + case .type3: + color1 = UIColor(rgb: 0xaa7c60) + color2 = UIColor(rgb: 0xc8a987) + color3 = UIColor(rgb: 0xddc89f) + color4 = UIColor(rgb: 0xe6d6b2) + case .type4: + color1 = UIColor(rgb: 0x8c6148) + color2 = UIColor(rgb: 0xad8562) + color3 = UIColor(rgb: 0xc49e76) + color4 = UIColor(rgb: 0xd4b188) + case .type5: + color1 = UIColor(rgb: 0x6e3c2c) + color2 = UIColor(rgb: 0x925a34) + color3 = UIColor(rgb: 0xa16e46) + color4 = UIColor(rgb: 0xac7a52) + case .type6: + color1 = UIColor(rgb: 0x291c12) + color2 = UIColor(rgb: 0x472a22) + color3 = UIColor(rgb: 0x573b30) + color4 = UIColor(rgb: 0x68493c) } + + func colorToString(_ color: UIColor) -> String { + var r: CGFloat = 0.0 + var g: CGFloat = 0.0 + var b: CGFloat = 0.0 + if color.getRed(&r, green: &g, blue: &b, alpha: nil) { + return "\(r),\(g),\(b)" + } + return "" + } + + string = string.replacingOccurrences(of: "0.96862745285,0.494117647409,0.254901975393", with: colorToString(color1)) + string = string.replacingOccurrences(of: "1,0.694117665291,0.223529413342", with: colorToString(color2)) + string = string.replacingOccurrences(of: "1,0.819607853889,0.250980407", with: colorToString(color3)) + string = string.replacingOccurrences(of: "1,0.874509811401,0.474509805441", with: colorToString(color4)) + + return string.data(using: .utf8) ?? data + } else { + return data } } -public class LocalBundleResource: TelegramMediaResource { - public let name: String - public let ext: String - - public init(name: String, ext: String) { - self.name = name - self.ext = ext - } - - public required init(decoder: PostboxDecoder) { - self.name = decoder.decodeStringForKey("n", orElse: "") - self.ext = decoder.decodeStringForKey("e", orElse: "") - } - - public func encode(_ encoder: PostboxEncoder) { - encoder.encodeString(self.name, forKey: "n") - encoder.encodeString(self.ext, forKey: "e") - } - - public var id: MediaResourceId { - return LocalBundleResourceId(name: self.name, ext: self.ext) - } - - public func isEqual(to: MediaResource) -> Bool { - if let to = to as? LocalBundleResource { - return self.name == to.name && self.ext == to.ext - } else { - return false - } - } -} - -func fetchCompressedLottieFirstFrameAJpeg(data: Data, size: CGSize, cacheKey: String) -> Signal { +func fetchCompressedLottieFirstFrameAJpeg(data: Data, size: CGSize, fitzModifier: EmojiFitzModifier? = nil, cacheKey: String) -> Signal { return Signal({ subscriber in let queue = Queue() @@ -77,72 +78,75 @@ func fetchCompressedLottieFirstFrameAJpeg(data: Data, size: CGSize, cacheKey: St } let decompressedData = TGGUnzipData(data, 8 * 1024 * 1024) - if let decompressedData = decompressedData, let player = LottieInstance(data: decompressedData, cacheKey: cacheKey) { - if cancelled.with({ $0 }) { - return - } - - let context = DrawingContext(size: size, scale: 1.0, clear: true) - player.renderFrame(with: 0, into: context.bytes.assumingMemoryBound(to: UInt8.self), width: Int32(size.width), height: Int32(size.height), bytesPerRow: Int32(context.bytesPerRow)) - - let yuvaPixelsPerAlphaRow = (Int(size.width) + 1) & (~1) - assert(yuvaPixelsPerAlphaRow % 2 == 0) - - let yuvaLength = Int(size.width) * Int(size.height) * 2 + yuvaPixelsPerAlphaRow * Int(size.height) / 2 - var yuvaFrameData = malloc(yuvaLength)! - memset(yuvaFrameData, 0, yuvaLength) - - defer { - free(yuvaFrameData) - } - - encodeRGBAToYUVA(yuvaFrameData.assumingMemoryBound(to: UInt8.self), context.bytes.assumingMemoryBound(to: UInt8.self), Int32(size.width), Int32(size.height), Int32(context.bytesPerRow)) - decodeYUVAToRGBA(yuvaFrameData.assumingMemoryBound(to: UInt8.self), context.bytes.assumingMemoryBound(to: UInt8.self), Int32(size.width), Int32(size.height), Int32(context.bytesPerRow)) - - if let colorSourceImage = context.generateImage(), let alphaImage = generateGrayscaleAlphaMaskImage(image: colorSourceImage) { - let colorContext = DrawingContext(size: size, scale: 1.0, clear: false) - colorContext.withFlippedContext { c in - c.setFillColor(UIColor.black.cgColor) - c.fill(CGRect(origin: CGPoint(), size: size)) - c.draw(colorSourceImage.cgImage!, in: CGRect(origin: CGPoint(), size: size)) - } - guard let colorImage = colorContext.generateImage() else { + if let decompressedData = decompressedData { + let decompressedData = transformedWithFitzModifier(data: decompressedData, fitzModifier: fitzModifier) + if let player = LottieInstance(data: decompressedData, cacheKey: cacheKey) { + if cancelled.with({ $0 }) { return } - let colorData = NSMutableData() - let alphaData = NSMutableData() + let context = DrawingContext(size: size, scale: 1.0, clear: true) + player.renderFrame(with: 0, into: context.bytes.assumingMemoryBound(to: UInt8.self), width: Int32(size.width), height: Int32(size.height), bytesPerRow: Int32(context.bytesPerRow)) - if let colorDestination = CGImageDestinationCreateWithData(colorData as CFMutableData, kUTTypeJPEG, 1, nil), let alphaDestination = CGImageDestinationCreateWithData(alphaData as CFMutableData, kUTTypeJPEG, 1, nil) { - CGImageDestinationSetProperties(colorDestination, [:] as CFDictionary) - CGImageDestinationSetProperties(alphaDestination, [:] as CFDictionary) + let yuvaPixelsPerAlphaRow = (Int(size.width) + 1) & (~1) + assert(yuvaPixelsPerAlphaRow % 2 == 0) + + let yuvaLength = Int(size.width) * Int(size.height) * 2 + yuvaPixelsPerAlphaRow * Int(size.height) / 2 + var yuvaFrameData = malloc(yuvaLength)! + memset(yuvaFrameData, 0, yuvaLength) + + defer { + free(yuvaFrameData) + } + + encodeRGBAToYUVA(yuvaFrameData.assumingMemoryBound(to: UInt8.self), context.bytes.assumingMemoryBound(to: UInt8.self), Int32(size.width), Int32(size.height), Int32(context.bytesPerRow)) + decodeYUVAToRGBA(yuvaFrameData.assumingMemoryBound(to: UInt8.self), context.bytes.assumingMemoryBound(to: UInt8.self), Int32(size.width), Int32(size.height), Int32(context.bytesPerRow)) + + if let colorSourceImage = context.generateImage(), let alphaImage = generateGrayscaleAlphaMaskImage(image: colorSourceImage) { + let colorContext = DrawingContext(size: size, scale: 1.0, clear: false) + colorContext.withFlippedContext { c in + c.setFillColor(UIColor.black.cgColor) + c.fill(CGRect(origin: CGPoint(), size: size)) + c.draw(colorSourceImage.cgImage!, in: CGRect(origin: CGPoint(), size: size)) + } + guard let colorImage = colorContext.generateImage() else { + return + } - let colorQuality: Float - let alphaQuality: Float - colorQuality = 0.5 - alphaQuality = 0.4 + let colorData = NSMutableData() + let alphaData = NSMutableData() - let options = NSMutableDictionary() - options.setObject(colorQuality as NSNumber, forKey: kCGImageDestinationLossyCompressionQuality as NSString) - - let optionsAlpha = NSMutableDictionary() - optionsAlpha.setObject(alphaQuality as NSNumber, forKey: kCGImageDestinationLossyCompressionQuality as NSString) - - CGImageDestinationAddImage(colorDestination, colorImage.cgImage!, options as CFDictionary) - CGImageDestinationAddImage(alphaDestination, alphaImage.cgImage!, optionsAlpha as CFDictionary) - if CGImageDestinationFinalize(colorDestination) && CGImageDestinationFinalize(alphaDestination) { - let finalData = NSMutableData() - var colorSize: Int32 = Int32(colorData.length) - finalData.append(&colorSize, length: 4) - finalData.append(colorData as Data) - var alphaSize: Int32 = Int32(alphaData.length) - finalData.append(&alphaSize, length: 4) - finalData.append(alphaData as Data) + if let colorDestination = CGImageDestinationCreateWithData(colorData as CFMutableData, kUTTypeJPEG, 1, nil), let alphaDestination = CGImageDestinationCreateWithData(alphaData as CFMutableData, kUTTypeJPEG, 1, nil) { + CGImageDestinationSetProperties(colorDestination, [:] as CFDictionary) + CGImageDestinationSetProperties(alphaDestination, [:] as CFDictionary) - let tempFile = TempBox.shared.tempFile(fileName: "image.ajpg") - let _ = try? finalData.write(to: URL(fileURLWithPath: tempFile.path), options: []) - subscriber.putNext(tempFile) - subscriber.putCompletion() + let colorQuality: Float + let alphaQuality: Float + colorQuality = 0.5 + alphaQuality = 0.4 + + let options = NSMutableDictionary() + options.setObject(colorQuality as NSNumber, forKey: kCGImageDestinationLossyCompressionQuality as NSString) + + let optionsAlpha = NSMutableDictionary() + optionsAlpha.setObject(alphaQuality as NSNumber, forKey: kCGImageDestinationLossyCompressionQuality as NSString) + + CGImageDestinationAddImage(colorDestination, colorImage.cgImage!, options as CFDictionary) + CGImageDestinationAddImage(alphaDestination, alphaImage.cgImage!, optionsAlpha as CFDictionary) + if CGImageDestinationFinalize(colorDestination) && CGImageDestinationFinalize(alphaDestination) { + let finalData = NSMutableData() + var colorSize: Int32 = Int32(colorData.length) + finalData.append(&colorSize, length: 4) + finalData.append(colorData as Data) + var alphaSize: Int32 = Int32(alphaData.length) + finalData.append(&alphaSize, length: 4) + finalData.append(alphaData as Data) + + let tempFile = TempBox.shared.tempFile(fileName: "image.ajpg") + let _ = try? finalData.write(to: URL(fileURLWithPath: tempFile.path), options: []) + subscriber.putNext(tempFile) + subscriber.putCompletion() + } } } } @@ -159,7 +163,7 @@ private let threadPool: ThreadPool = { }() @available(iOS 9.0, *) -func experimentalConvertCompressedLottieToCombinedMp4(data: Data, size: CGSize, cacheKey: String) -> Signal { +func experimentalConvertCompressedLottieToCombinedMp4(data: Data, size: CGSize, fitzModifier: EmojiFitzModifier? = nil, cacheKey: String) -> Signal { return Signal({ subscriber in let cancelled = Atomic(value: false) @@ -176,125 +180,128 @@ func experimentalConvertCompressedLottieToCombinedMp4(data: Data, size: CGSize, var compressionTime: Double = 0 let decompressedData = TGGUnzipData(data, 8 * 1024 * 1024) - if let decompressedData = decompressedData, let player = LottieInstance(data: decompressedData, cacheKey: cacheKey) { - let endFrame = Int(player.frameCount) - - if cancelled.with({ $0 }) { - //print("cancelled 2") - return - } - - var randomId: Int64 = 0 - arc4random_buf(&randomId, 8) - let path = NSTemporaryDirectory() + "\(randomId).lz4v" - guard let fileContext = ManagedFile(queue: nil, path: path, mode: .readwrite) else { - return - } - - let bytesPerRow = (4 * Int(size.width) + 15) & (~15) - - var currentFrame: Int32 = 0 - - var fps: Int32 = player.frameRate - var frameCount: Int32 = player.frameCount - let _ = fileContext.write(&fps, count: 4) - let _ = fileContext.write(&frameCount, count: 4) - var widthValue: Int32 = Int32(size.width) - var heightValue: Int32 = Int32(size.height) - var bytesPerRowValue: Int32 = Int32(bytesPerRow) - let _ = fileContext.write(&widthValue, count: 4) - let _ = fileContext.write(&heightValue, count: 4) - let _ = fileContext.write(&bytesPerRowValue, count: 4) - - let frameLength = bytesPerRow * Int(size.height) - assert(frameLength % 16 == 0) - - let currentFrameData = malloc(frameLength)! - memset(currentFrameData, 0, frameLength) - - let yuvaPixelsPerAlphaRow = (Int(size.width) + 1) & (~1) - assert(yuvaPixelsPerAlphaRow % 2 == 0) - - let yuvaLength = Int(size.width) * Int(size.height) * 2 + yuvaPixelsPerAlphaRow * Int(size.height) / 2 - var yuvaFrameData = malloc(yuvaLength)! - memset(yuvaFrameData, 0, yuvaLength) - - var previousYuvaFrameData = malloc(yuvaLength)! - memset(previousYuvaFrameData, 0, yuvaLength) - - defer { - free(currentFrameData) - free(previousYuvaFrameData) - free(yuvaFrameData) - } - - var compressedFrameData = Data(count: frameLength) - let compressedFrameDataLength = compressedFrameData.count - - let scratchData = malloc(compression_encode_scratch_buffer_size(COMPRESSION_LZFSE))! - defer { - free(scratchData) - } - - while currentFrame < endFrame { + if let decompressedData = decompressedData { + let decompressedData = transformedWithFitzModifier(data: decompressedData, fitzModifier: fitzModifier) + if let player = LottieInstance(data: decompressedData, cacheKey: cacheKey) { + let endFrame = Int(player.frameCount) + if cancelled.with({ $0 }) { - //print("cancelled 3") + //print("cancelled 2") return } - let drawStartTime = CACurrentMediaTime() + var randomId: Int64 = 0 + arc4random_buf(&randomId, 8) + let path = NSTemporaryDirectory() + "\(randomId).lz4v" + guard let fileContext = ManagedFile(queue: nil, path: path, mode: .readwrite) else { + return + } + + let bytesPerRow = (4 * Int(size.width) + 15) & (~15) + + var currentFrame: Int32 = 0 + + var fps: Int32 = player.frameRate + var frameCount: Int32 = player.frameCount + let _ = fileContext.write(&fps, count: 4) + let _ = fileContext.write(&frameCount, count: 4) + var widthValue: Int32 = Int32(size.width) + var heightValue: Int32 = Int32(size.height) + var bytesPerRowValue: Int32 = Int32(bytesPerRow) + let _ = fileContext.write(&widthValue, count: 4) + let _ = fileContext.write(&heightValue, count: 4) + let _ = fileContext.write(&bytesPerRowValue, count: 4) + + let frameLength = bytesPerRow * Int(size.height) + assert(frameLength % 16 == 0) + + let currentFrameData = malloc(frameLength)! memset(currentFrameData, 0, frameLength) - player.renderFrame(with: Int32(currentFrame), into: currentFrameData.assumingMemoryBound(to: UInt8.self), width: Int32(size.width), height: Int32(size.height), bytesPerRow: Int32(bytesPerRow)) - drawingTime += CACurrentMediaTime() - drawStartTime - let appendStartTime = CACurrentMediaTime() + let yuvaPixelsPerAlphaRow = (Int(size.width) + 1) & (~1) + assert(yuvaPixelsPerAlphaRow % 2 == 0) - encodeRGBAToYUVA(yuvaFrameData.assumingMemoryBound(to: UInt8.self), currentFrameData.assumingMemoryBound(to: UInt8.self), Int32(size.width), Int32(size.height), Int32(bytesPerRow)) + let yuvaLength = Int(size.width) * Int(size.height) * 2 + yuvaPixelsPerAlphaRow * Int(size.height) / 2 + var yuvaFrameData = malloc(yuvaLength)! + memset(yuvaFrameData, 0, yuvaLength) - appendingTime += CACurrentMediaTime() - appendStartTime + var previousYuvaFrameData = malloc(yuvaLength)! + memset(previousYuvaFrameData, 0, yuvaLength) - let deltaStartTime = CACurrentMediaTime() - var lhs = previousYuvaFrameData.assumingMemoryBound(to: UInt64.self) - var rhs = yuvaFrameData.assumingMemoryBound(to: UInt64.self) - for _ in 0 ..< yuvaLength / 8 { - lhs.pointee = rhs.pointee ^ lhs.pointee - lhs = lhs.advanced(by: 1) - rhs = rhs.advanced(by: 1) - } - var lhsRest = previousYuvaFrameData.assumingMemoryBound(to: UInt8.self).advanced(by: (yuvaLength / 8) * 8) - var rhsRest = yuvaFrameData.assumingMemoryBound(to: UInt8.self).advanced(by: (yuvaLength / 8) * 8) - for _ in (yuvaLength / 8) * 8 ..< yuvaLength { - lhsRest.pointee = rhsRest.pointee ^ lhsRest.pointee - lhsRest = lhsRest.advanced(by: 1) - rhsRest = rhsRest.advanced(by: 1) - } - deltaTime += CACurrentMediaTime() - deltaStartTime - - let compressionStartTime = CACurrentMediaTime() - compressedFrameData.withUnsafeMutableBytes { (bytes: UnsafeMutablePointer) -> Void in - let length = compression_encode_buffer(bytes, compressedFrameDataLength, previousYuvaFrameData.assumingMemoryBound(to: UInt8.self), yuvaLength, scratchData, COMPRESSION_LZFSE) - var frameLengthValue: Int32 = Int32(length) - let _ = fileContext.write(&frameLengthValue, count: 4) - let _ = fileContext.write(bytes, count: length) + defer { + free(currentFrameData) + free(previousYuvaFrameData) + free(yuvaFrameData) } - let tmp = previousYuvaFrameData - previousYuvaFrameData = yuvaFrameData - yuvaFrameData = tmp + var compressedFrameData = Data(count: frameLength) + let compressedFrameDataLength = compressedFrameData.count - compressionTime += CACurrentMediaTime() - compressionStartTime + let scratchData = malloc(compression_encode_scratch_buffer_size(COMPRESSION_LZFSE))! + defer { + free(scratchData) + } - currentFrame += 1 + while currentFrame < endFrame { + if cancelled.with({ $0 }) { + //print("cancelled 3") + return + } + + let drawStartTime = CACurrentMediaTime() + memset(currentFrameData, 0, frameLength) + player.renderFrame(with: Int32(currentFrame), into: currentFrameData.assumingMemoryBound(to: UInt8.self), width: Int32(size.width), height: Int32(size.height), bytesPerRow: Int32(bytesPerRow)) + drawingTime += CACurrentMediaTime() - drawStartTime + + let appendStartTime = CACurrentMediaTime() + + encodeRGBAToYUVA(yuvaFrameData.assumingMemoryBound(to: UInt8.self), currentFrameData.assumingMemoryBound(to: UInt8.self), Int32(size.width), Int32(size.height), Int32(bytesPerRow)) + + appendingTime += CACurrentMediaTime() - appendStartTime + + let deltaStartTime = CACurrentMediaTime() + var lhs = previousYuvaFrameData.assumingMemoryBound(to: UInt64.self) + var rhs = yuvaFrameData.assumingMemoryBound(to: UInt64.self) + for _ in 0 ..< yuvaLength / 8 { + lhs.pointee = rhs.pointee ^ lhs.pointee + lhs = lhs.advanced(by: 1) + rhs = rhs.advanced(by: 1) + } + var lhsRest = previousYuvaFrameData.assumingMemoryBound(to: UInt8.self).advanced(by: (yuvaLength / 8) * 8) + var rhsRest = yuvaFrameData.assumingMemoryBound(to: UInt8.self).advanced(by: (yuvaLength / 8) * 8) + for _ in (yuvaLength / 8) * 8 ..< yuvaLength { + lhsRest.pointee = rhsRest.pointee ^ lhsRest.pointee + lhsRest = lhsRest.advanced(by: 1) + rhsRest = rhsRest.advanced(by: 1) + } + deltaTime += CACurrentMediaTime() - deltaStartTime + + let compressionStartTime = CACurrentMediaTime() + compressedFrameData.withUnsafeMutableBytes { (bytes: UnsafeMutablePointer) -> Void in + let length = compression_encode_buffer(bytes, compressedFrameDataLength, previousYuvaFrameData.assumingMemoryBound(to: UInt8.self), yuvaLength, scratchData, COMPRESSION_LZFSE) + var frameLengthValue: Int32 = Int32(length) + let _ = fileContext.write(&frameLengthValue, count: 4) + let _ = fileContext.write(bytes, count: length) + } + + let tmp = previousYuvaFrameData + previousYuvaFrameData = yuvaFrameData + yuvaFrameData = tmp + + compressionTime += CACurrentMediaTime() - compressionStartTime + + currentFrame += 1 + } + + subscriber.putNext(path) + subscriber.putCompletion() + print("animation render time \(CACurrentMediaTime() - startTime)") + print("of which drawing time \(drawingTime)") + print("of which appending time \(appendingTime)") + print("of which delta time \(deltaTime)") + + print("of which compression time \(compressionTime)") } - - subscriber.putNext(path) - subscriber.putCompletion() - print("animation render time \(CACurrentMediaTime() - startTime)") - print("of which drawing time \(drawingTime)") - print("of which appending time \(appendingTime)") - print("of which delta time \(deltaTime)") - - print("of which compression time \(compressionTime)") } })) return ActionDisposable { @@ -302,28 +309,3 @@ func experimentalConvertCompressedLottieToCombinedMp4(data: Data, size: CGSize, } }) } - -private final class LocalBundleResourceCopyFile : MediaResourceDataFetchCopyLocalItem { - let path: String - init(path: String) { - self.path = path - } - func copyTo(url: URL) -> Bool { - do { - try FileManager.default.copyItem(at: URL(fileURLWithPath: self.path), to: url) - return true - } catch { - return false - } - } -} - -func fetchLocalBundleResource(postbox: Postbox, resource: LocalBundleResource) -> Signal { - return Signal { subscriber in - if let path = frameworkBundle.path(forResource: resource.name, ofType: resource.ext), let _ = try? Data(contentsOf: URL(fileURLWithPath: path), options: [.mappedRead]) { - subscriber.putNext(.copyLocalItem(LocalBundleResourceCopyFile(path: path))) - subscriber.putCompletion() - } - return EmptyDisposable - } -} diff --git a/submodules/TelegramUI/TelegramUI/AppDelegate.swift b/submodules/TelegramUI/TelegramUI/AppDelegate.swift index a49b99e764..7fb3660173 100644 --- a/submodules/TelegramUI/TelegramUI/AppDelegate.swift +++ b/submodules/TelegramUI/TelegramUI/AppDelegate.swift @@ -1121,13 +1121,13 @@ final class SharedApplicationContext { Logger.shared.log("App \(self.episodeId)", "isActive = \(value)") }) - /*if let url = launchOptions?[.url] { - if let url = url as? URL, url.scheme == "tg" { + if let url = launchOptions?[.url] { + if let url = url as? URL, url.scheme == "tg" || url.scheme == buildConfig.appSpecificUrlScheme { self.openUrlWhenReady(url: url.absoluteString) - } else if let url = url as? String, url.lowercased().hasPrefix("tg://") { + } else if let url = url as? String, url.lowercased().hasPrefix("tg:") || url.lowercased().hasPrefix("\(buildConfig.appSpecificUrlScheme):") { self.openUrlWhenReady(url: url) } - }*/ + } if application.applicationState == .active { self.isInForegroundValue = true diff --git a/submodules/TelegramUI/TelegramUI/ApplicationContext.swift b/submodules/TelegramUI/TelegramUI/ApplicationContext.swift index 993633800c..589094da34 100644 --- a/submodules/TelegramUI/TelegramUI/ApplicationContext.swift +++ b/submodules/TelegramUI/TelegramUI/ApplicationContext.swift @@ -487,7 +487,7 @@ final class AuthorizedApplicationContext { if let strongSelf = self, let botName = botName { strongSelf.termsOfServiceProceedToBotDisposable.set((resolvePeerByName(account: strongSelf.context.account, name: botName, ageLimit: 10) |> take(1) |> deliverOnMainQueue).start(next: { peerId in if let strongSelf = self, let peerId = peerId { - self?.rootController.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(peerId), messageId: nil)) + self?.rootController.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(peerId))) } })) } diff --git a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift index 40c388239e..edb4817fb7 100644 --- a/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/AuthorizationSequenceAwaitingAccountResetControllerNode.swift @@ -6,8 +6,6 @@ import SwiftSignalKit import TelegramPresentationData private func timerValueString(days: Int32, hours: Int32, minutes: Int32, color: UIColor, strings: PresentationStrings) -> NSAttributedString { - var string = NSMutableAttributedString() - var daysString = "" if days > 0 { daysString = strings.MessageTimer_Days(days) + " " @@ -15,7 +13,7 @@ private func timerValueString(days: Int32, hours: Int32, minutes: Int32, color: var hoursString = "" if hours > 0 || days > 0 { - daysString = strings.MessageTimer_Hours(hours) + " " + hoursString = strings.MessageTimer_Hours(hours) + " " } let minutesString = strings.MessageTimer_Minutes(minutes) diff --git a/submodules/TelegramUI/TelegramUI/BundleResource.swift b/submodules/TelegramUI/TelegramUI/BundleResource.swift new file mode 100644 index 0000000000..cb09193ee0 --- /dev/null +++ b/submodules/TelegramUI/TelegramUI/BundleResource.swift @@ -0,0 +1,82 @@ +import Foundation +import SwiftSignalKit +import Postbox +import TelegramCore + +public struct LocalBundleResourceId: MediaResourceId { + public let name: String + public let ext: String + + public var uniqueId: String { + return "local-bundle-\(self.name)-\(self.ext)" + } + + public var hashValue: Int { + return self.name.hashValue + } + + public func isEqual(to: MediaResourceId) -> Bool { + if let to = to as? LocalBundleResourceId { + return self.name == to.name && self.ext == to.ext + } else { + return false + } + } +} + +public class LocalBundleResource: TelegramMediaResource { + public let name: String + public let ext: String + + public init(name: String, ext: String) { + self.name = name + self.ext = ext + } + + public required init(decoder: PostboxDecoder) { + self.name = decoder.decodeStringForKey("n", orElse: "") + self.ext = decoder.decodeStringForKey("e", orElse: "") + } + + public func encode(_ encoder: PostboxEncoder) { + encoder.encodeString(self.name, forKey: "n") + encoder.encodeString(self.ext, forKey: "e") + } + + public var id: MediaResourceId { + return LocalBundleResourceId(name: self.name, ext: self.ext) + } + + public func isEqual(to: MediaResource) -> Bool { + if let to = to as? LocalBundleResource { + return self.name == to.name && self.ext == to.ext + } else { + return false + } + } +} + +private final class LocalBundleResourceCopyFile : MediaResourceDataFetchCopyLocalItem { + let path: String + init(path: String) { + self.path = path + } + func copyTo(url: URL) -> Bool { + do { + try FileManager.default.copyItem(at: URL(fileURLWithPath: self.path), to: url) + return true + } catch { + return false + } + } +} + +func fetchLocalBundleResource(postbox: Postbox, resource: LocalBundleResource) -> Signal { + return Signal { subscriber in + if let path = frameworkBundle.path(forResource: resource.name, ofType: resource.ext), let _ = try? Data(contentsOf: URL(fileURLWithPath: path), options: [.mappedRead]) { + subscriber.putNext(.copyLocalItem(LocalBundleResourceCopyFile(path: path))) + subscriber.putCompletion() + } + return EmptyDisposable + } +} diff --git a/submodules/TelegramUI/TelegramUI/ChatAnimationGalleryItem.swift b/submodules/TelegramUI/TelegramUI/ChatAnimationGalleryItem.swift index be9f81d49b..f179391722 100644 --- a/submodules/TelegramUI/TelegramUI/ChatAnimationGalleryItem.swift +++ b/submodules/TelegramUI/TelegramUI/ChatAnimationGalleryItem.swift @@ -137,7 +137,7 @@ final class ChatAnimationGalleryItemNode: ZoomableContentGalleryItemNode { func setFile(context: AccountContext, fileReference: FileMediaReference) { if self.contextAndMedia == nil || !self.contextAndMedia!.1.media.isEqual(to: fileReference.media) { - let signal = chatMessageAnimatedStrickerBackingData(postbox: context.account.postbox, fileReference: fileReference, synchronousLoad: false) + let signal = chatMessageAnimatedStickerBackingData(postbox: context.account.postbox, fileReference: fileReference, synchronousLoad: false) |> mapToSignal { value -> Signal in if value._1, let data = value._0 { return .single(data) diff --git a/submodules/TelegramUI/TelegramUI/ChatController.swift b/submodules/TelegramUI/TelegramUI/ChatController.swift index 9a3585c9e1..65d0c67092 100644 --- a/submodules/TelegramUI/TelegramUI/ChatController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatController.swift @@ -108,6 +108,11 @@ private func calculateSlowmodeActiveUntilTimestamp(account: Account, untilTimest let ChatControllerCount = Atomic(value: 0) +public enum ChatControllerSubject { + case message(MessageId) + case scheduledMessages +} + public final class ChatController: TelegramBaseController, GalleryHiddenMediaTarget, UIDropInteractionDelegate { private var validLayout: ContainerViewLayout? @@ -118,7 +123,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar private let context: AccountContext public let chatLocation: ChatLocation - private let messageId: MessageId? + private let subject: ChatControllerSubject? private let botStart: ChatControllerInitialBotStart? private let peerDisposable = MetaDisposable() @@ -257,6 +262,8 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar private var reportIrrelvantGeoNotice: Bool? private var reportIrrelvantGeoDisposable: Disposable? + private var hasScheduledMessages: Bool = false + private var volumeButtonsListener: VolumeButtonsListener? private var beginMediaRecordingRequestId: Int = 0 @@ -271,14 +278,14 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar var purposefulAction: (() -> Void)? - public init(context: AccountContext, chatLocation: ChatLocation, messageId: MessageId? = nil, botStart: ChatControllerInitialBotStart? = nil, mode: ChatControllerPresentationMode = .standard(previewing: false)) { + public init(context: AccountContext, chatLocation: ChatLocation, subject: ChatControllerSubject? = nil, botStart: ChatControllerInitialBotStart? = nil, mode: ChatControllerPresentationMode = .standard(previewing: false)) { let _ = ChatControllerCount.modify { value in return value + 1 } self.context = context self.chatLocation = chatLocation - self.messageId = messageId + self.subject = subject self.botStart = botStart var locationBroadcastPanelSource: LocationBroadcastPanelSource @@ -297,7 +304,12 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar self.stickerSettings = ChatInterfaceStickerSettings(loopAnimatedStickers: false) - self.presentationInterfaceState = ChatPresentationInterfaceState(chatWallpaper: self.presentationData.chatWallpaper, theme: self.presentationData.theme, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameDisplayOrder: self.presentationData.nameDisplayOrder, limitsConfiguration: context.currentLimitsConfiguration.with { $0 }, fontSize: self.presentationData.fontSize, accountPeerId: context.account.peerId, mode: mode, chatLocation: chatLocation) + var isScheduledMessages = false + if let subject = subject, case .scheduledMessages = subject { + isScheduledMessages = true + } + + self.presentationInterfaceState = ChatPresentationInterfaceState(chatWallpaper: self.presentationData.chatWallpaper, theme: self.presentationData.theme, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameDisplayOrder: self.presentationData.nameDisplayOrder, limitsConfiguration: context.currentLimitsConfiguration.with { $0 }, fontSize: self.presentationData.fontSize, accountPeerId: context.account.peerId, mode: mode, chatLocation: chatLocation, isScheduledMessages: isScheduledMessages) var mediaAccessoryPanelVisibility = MediaAccessoryPanelVisibility.none if case .standard = mode { @@ -673,7 +685,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar if let strongSelf = self { strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { return $0.updatedTitlePanelContext { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .requestInProgress: return true @@ -740,7 +752,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar if let strongSelf = self { strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { return $0.updatedTitlePanelContext { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .requestInProgress: return true @@ -789,7 +801,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar if let strongSelf = self { strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { return $0.updatedTitlePanelContext { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .requestInProgress: return true @@ -1338,6 +1350,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar strongSelf.present(c, in: .window(.root), with: a) } }) + strongSelf.chatDisplayNode.dismissInput() strongSelf.present(controller, in: .window(.root)) } }, requestSelectMessagePollOption: { [weak self] id, opaqueIdentifier in @@ -1422,6 +1435,20 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar let _ = strongSelf.controllerInteraction?.openMessage(message, .timecode(Double(timestamp))) } } + }, scheduleCurrentMessage: { [weak self] in + if let strongSelf = self { + let controller = ChatScheduleTimeController(context: strongSelf.context, completion: { [weak self] time in + if let strongSelf = self { + strongSelf.chatDisplayNode.sendCurrentMessage(scheduleTime: time) + if !strongSelf.presentationInterfaceState.isScheduledMessages { + let controller = ChatController(context: strongSelf.context, chatLocation: strongSelf.chatLocation, subject: .scheduledMessages) + (strongSelf.navigationController as? NavigationController)?.pushViewController(controller) + } + } + }) + strongSelf.chatDisplayNode.dismissInput() + strongSelf.present(controller, in: .window(.root)) + } }, requestMessageUpdate: { [weak self] id in if let strongSelf = self { strongSelf.chatDisplayNode.historyNode.requestMessageUpdate(id) @@ -1442,7 +1469,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar } else { strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { return $0.updatedTitlePanelContext { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .chatInfo: return true @@ -1491,6 +1518,8 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar if case let .peer(peerView) = self.chatLocationInfoData { peerView.set(context.account.viewTracker.peerView(peerId)) var onlineMemberCount: Signal = .single(nil) + var hasScheduledMessages: Signal = .single(false) + if peerId.namespace == Namespaces.Peer.CloudChannel { let recentOnlineSignal: Signal = context.account.viewTracker.peerView(peerId) |> map { view -> Bool in @@ -1522,19 +1551,27 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar self.reportIrrelvantGeoNoticePromise.set(.single(nil)) } - self.peerDisposable.set((combineLatest(queue: Queue.mainQueue(), peerView.get(), onlineMemberCount, self.reportIrrelvantGeoNoticePromise.get()) - |> deliverOnMainQueue).start(next: { [weak self] peerView, onlineMemberCount, peerReportNotice in + if !isScheduledMessages { + hasScheduledMessages = context.account.viewTracker.aroundMessageHistoryViewForLocation(chatLocation, index: .upperBound, anchorIndex: .upperBound, count: 100, fixedCombinedReadStates: nil, tagMask: nil, excludeNamespaces: [Namespaces.Message.Cloud, Namespaces.Message.Local], orderStatistics: []) + |> map { view, _, _ in + return !view.entries.isEmpty + } + } + + self.peerDisposable.set((combineLatest(queue: Queue.mainQueue(), peerView.get(), onlineMemberCount, hasScheduledMessages, self.reportIrrelvantGeoNoticePromise.get()) + |> deliverOnMainQueue).start(next: { [weak self] peerView, onlineMemberCount, hasScheduledMessages, peerReportNotice in if let strongSelf = self { if let peer = peerViewMainPeer(peerView) { - strongSelf.chatTitleView?.titleContent = .peer(peerView: peerView, onlineMemberCount: onlineMemberCount) + strongSelf.chatTitleView?.titleContent = .peer(peerView: peerView, onlineMemberCount: onlineMemberCount, isScheduledMessages: isScheduledMessages) (strongSelf.chatInfoNavigationButton?.buttonItem.customDisplayNode as? ChatAvatarNavigationNode)?.avatarNode.setPeer(account: strongSelf.context.account, theme: strongSelf.presentationData.theme, peer: peer, overrideImage: peer.isDeleted ? .deletedIcon : .none) } - if strongSelf.peerView === peerView && strongSelf.reportIrrelvantGeoNotice == peerReportNotice { + if strongSelf.peerView === peerView && strongSelf.reportIrrelvantGeoNotice == peerReportNotice && strongSelf.hasScheduledMessages == hasScheduledMessages { return } strongSelf.reportIrrelvantGeoNotice = peerReportNotice + strongSelf.hasScheduledMessages = hasScheduledMessages var upgradedToPeerId: PeerId? if let previous = strongSelf.peerView, let group = previous.peers[previous.peerId] as? TelegramGroup, group.migrationReference == nil, let updatedGroup = peerView.peers[peerView.peerId] as? TelegramGroup, let migrationReference = updatedGroup.migrationReference { @@ -1701,7 +1738,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar strongSelf.updateChatPresentationInterfaceState(animated: animated, interactive: false, { return $0.updatedPeer { _ in return renderedPeer - }.updatedIsNotAccessible(isNotAccessible).updatedContactStatus(contactStatus).updatedHasBots(hasBots).updatedIsArchived(isArchived).updatedPeerIsMuted(peerIsMuted).updatedPeerDiscussionId(peerDiscussionId).updatedPeerGeoLocation(peerGeoLocation).updatedExplicitelyCanPinMessages(explicitelyCanPinMessages) + }.updatedIsNotAccessible(isNotAccessible).updatedContactStatus(contactStatus).updatedHasBots(hasBots).updatedIsArchived(isArchived).updatedPeerIsMuted(peerIsMuted).updatedPeerDiscussionId(peerDiscussionId).updatedPeerGeoLocation(peerGeoLocation).updatedExplicitelyCanPinMessages(explicitelyCanPinMessages).updatedHasScheduledMessages(hasScheduledMessages) }) if !strongSelf.didSetChatLocationInfoReady { strongSelf.didSetChatLocationInfoReady = true @@ -1711,7 +1748,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar if let upgradedToPeerId = upgradedToPeerId { if let navigationController = strongSelf.navigationController as? NavigationController { var viewControllers = navigationController.viewControllers - if let index = viewControllers.index(where: { $0 === strongSelf }) { + if let index = viewControllers.firstIndex(where: { $0 === strongSelf }) { viewControllers[index] = ChatController(context: strongSelf.context, chatLocation: .peer(upgradedToPeerId)) navigationController.setViewControllers(viewControllers, animated: false) } @@ -1728,7 +1765,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: false, { return $0.updatedTitlePanelContext { if let message = message { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .toastAlert: return true @@ -1749,7 +1786,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar return updatedContexts.sorted() } } else { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .toastAlert: return true @@ -2047,7 +2084,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar } override public func loadDisplayNode() { - self.displayNode = ChatControllerNode(context: self.context, chatLocation: self.chatLocation, messageId: self.messageId, controllerInteraction: self.controllerInteraction!, chatPresentationInterfaceState: self.presentationInterfaceState, automaticMediaDownloadSettings: self.automaticMediaDownloadSettings, navigationBar: self.navigationBar, controller: self) + 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) self.chatDisplayNode.peerView = self.peerView @@ -2114,7 +2151,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar return context } } else { - if let index = context.index(where: { + if let index = context.firstIndex(where: { switch $0 { case .pinnedMessage: return true @@ -2262,7 +2299,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar return context } } else { - if let index = context.index(where: { + if let index = context.firstIndex(where: { switch $0 { case .pinnedMessage: return true @@ -2692,7 +2729,14 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar } else if (messages.first?.flags.isSending ?? false) { let _ = deleteMessagesInteractively(postbox: strongSelf.context.account.postbox, messageIds: Array(messageIds), type: .forEveryone, deleteAllInGroup: true).start() } else { - strongSelf.presentDeleteMessageOptions(messageIds: messageIds, options: actions.options) + var isScheduled = false + for id in messageIds { + if id.namespace == Namespaces.Message.CloudScheduled { + isScheduled = true + break + } + } + strongSelf.presentDeleteMessageOptions(messageIds: messageIds, options: isScheduled ? [.deleteLocally] : actions.options) } } } @@ -2835,7 +2879,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar if let strongSelf = self { strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { current in return current.updatedTitlePanelContext { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .chatInfo: return true @@ -2875,7 +2919,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar var navigateIndex: MessageIndex? strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { current in if let data = current.search, let resultsState = data.resultsState { - if let currentId = resultsState.currentId, let index = resultsState.messageIndices.index(where: { $0.id == currentId }) { + if let currentId = resultsState.currentId, let index = resultsState.messageIndices.firstIndex(where: { $0.id == currentId }) { var updatedIndex: Int? switch action { case .earlier: @@ -3668,6 +3712,11 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar strongSelf.sendMessageActionsController = controller strongSelf.presentInGlobalOverlay(controller, with: nil) } + }, openScheduledMessages: { [weak self] in + if let strongSelf = self { + let controller = ChatController(context: strongSelf.context, chatLocation: strongSelf.chatLocation, subject: .scheduledMessages) + (strongSelf.navigationController as? NavigationController)?.pushViewController(controller) + } }, statuses: ChatPanelInterfaceInteractionStatuses(editingMessage: self.editingMessage.get(), startingBot: self.startingBot.get(), unblockingPeer: self.unblockingPeer.get(), searching: self.searching.get(), loadingMessage: self.loadingMessage.get())) switch self.chatLocation { @@ -4059,7 +4108,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar self.updateChatPresentationInterfaceState(animated: false, interactive: false, { $0.updatedTitlePanelContext { - if let index = $0.index(where: { + if let index = $0.firstIndex(where: { switch $0 { case .chatInfo: return true @@ -5497,7 +5546,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar guard let resultsState = resultsState, let currentId = resultsState.currentId else { return nil } - if let index = resultsState.messageIndices.index(where: { $0.id == currentId }) { + if let index = resultsState.messageIndices.firstIndex(where: { $0.id == currentId }) { if index <= limit / 2 { return resultsState.state } @@ -5810,7 +5859,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar strongSelf.chatDisplayNode.historyNode.scrollToMessage(from: fromIndex, to: index, animated: animated, scrollPosition: scrollPosition) completion?() } else { - (strongSelf.navigationController as? NavigationController)?.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(messageLocation.peerId), messageId: messageLocation.messageId)) + (strongSelf.navigationController as? NavigationController)?.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(messageLocation.peerId), subject: messageLocation.messageId.flatMap { .message($0) })) completion?() } } @@ -5966,10 +6015,10 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar } }) } else { - (self.navigationController as? NavigationController)?.pushViewController(ChatController(context: self.context, chatLocation: .peer(peerId), messageId: messageId)) + (self.navigationController as? NavigationController)?.pushViewController(ChatController(context: self.context, chatLocation: .peer(peerId), subject: messageId.flatMap({ .message($0) }))) } case let .withBotStartPayload(botStart): - (self.navigationController as? NavigationController)?.pushViewController(ChatController(context: self.context, chatLocation: .peer(peerId), messageId: nil, botStart: botStart)) + (self.navigationController as? NavigationController)?.pushViewController(ChatController(context: self.context, chatLocation: .peer(peerId), botStart: botStart)) default: break } @@ -6694,7 +6743,7 @@ public final class ChatController: TelegramBaseController, GalleryHiddenMediaTar self.navigationActionDisposable.set((fetchChannelParticipant(account: self.context.account, peerId: peerId, participantId: author.id) |> deliverOnMainQueue).start(next: { [weak self] participant in if let strongSelf = self { - var canBan = participant?.canBeBannedBy(peerId: accountPeerId) ?? true + let canBan = participant?.canBeBannedBy(peerId: accountPeerId) ?? true let actionSheet = ActionSheetController(presentationTheme: strongSelf.presentationData.theme) var items: [ActionSheetItem] = [] diff --git a/submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift b/submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift index de290327bd..5b027911cf 100644 --- a/submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift +++ b/submodules/TelegramUI/TelegramUI/ChatControllerInteraction.swift @@ -86,6 +86,7 @@ public final class ChatControllerInteraction { let openAppStorePage: () -> Void let displayMessageTooltip: (MessageId, String, ASDisplayNode?, CGRect?) -> Void let seekToTimecode: (Message, Double, Bool) -> Void + let scheduleCurrentMessage: () -> Void let requestMessageUpdate: (MessageId) -> Void let cancelInteractiveKeyboardGestures: () -> Void @@ -100,7 +101,7 @@ public final class ChatControllerInteraction { var searchTextHighightState: String? 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) -> Void, navigateToMessage: @escaping (MessageId, MessageId) -> 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, requestMessageActionCallback: @escaping (MessageId, MemoryBuffer?, Bool) -> Void, requestMessageActionUrlAuth: @escaping (String, MessageId, Int32) -> Void, activateSwitchInline: @escaping (PeerId?, String) -> Void, openUrl: @escaping (String, Bool, Bool?) -> Void, shareCurrentLocation: @escaping () -> Void, shareAccountContact: @escaping () -> Void, sendBotCommand: @escaping (MessageId?, String) -> Void, openInstantPage: @escaping (Message, ChatMessageItemAssociatedData?) -> Void, openWallpaper: @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?, 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) -> Bool, navigateToFirstDateMessage: @escaping(Int32) ->Void, requestRedeliveryOfFailedMessages: @escaping (MessageId) -> Void, addContact: @escaping (String) -> Void, rateCall: @escaping (Message, CallId) -> Void, requestSelectMessagePollOption: @escaping (MessageId, Data) -> Void, openAppStorePage: @escaping () -> Void, displayMessageTooltip: @escaping (MessageId, String, ASDisplayNode?, CGRect?) -> Void, seekToTimecode: @escaping (Message, Double, Bool) -> 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) -> Void, navigateToMessage: @escaping (MessageId, MessageId) -> 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, requestMessageActionCallback: @escaping (MessageId, MemoryBuffer?, Bool) -> Void, requestMessageActionUrlAuth: @escaping (String, MessageId, Int32) -> Void, activateSwitchInline: @escaping (PeerId?, String) -> Void, openUrl: @escaping (String, Bool, Bool?) -> Void, shareCurrentLocation: @escaping () -> Void, shareAccountContact: @escaping () -> Void, sendBotCommand: @escaping (MessageId?, String) -> Void, openInstantPage: @escaping (Message, ChatMessageItemAssociatedData?) -> Void, openWallpaper: @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?, 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) -> Bool, navigateToFirstDateMessage: @escaping(Int32) ->Void, requestRedeliveryOfFailedMessages: @escaping (MessageId) -> Void, addContact: @escaping (String) -> Void, rateCall: @escaping (Message, CallId) -> Void, requestSelectMessagePollOption: @escaping (MessageId, Data) -> Void, openAppStorePage: @escaping () -> Void, displayMessageTooltip: @escaping (MessageId, String, ASDisplayNode?, CGRect?) -> Void, seekToTimecode: @escaping (Message, Double, Bool) -> Void, scheduleCurrentMessage: @escaping () -> Void, requestMessageUpdate: @escaping (MessageId) -> Void, cancelInteractiveKeyboardGestures: @escaping () -> Void, automaticMediaDownloadSettings: MediaAutoDownloadSettings, pollActionState: ChatInterfacePollActionState, stickerSettings: ChatInterfaceStickerSettings) { self.openMessage = openMessage self.openPeer = openPeer self.openPeerMention = openPeerMention @@ -142,6 +143,7 @@ public final class ChatControllerInteraction { self.openAppStorePage = openAppStorePage self.displayMessageTooltip = displayMessageTooltip self.seekToTimecode = seekToTimecode + self.scheduleCurrentMessage = scheduleCurrentMessage self.requestMessageUpdate = requestMessageUpdate self.cancelInteractiveKeyboardGestures = cancelInteractiveKeyboardGestures @@ -168,6 +170,7 @@ public final class ChatControllerInteraction { }, openAppStorePage: { }, displayMessageTooltip: { _, _, _, _ in }, seekToTimecode: { _, _, _ in + }, scheduleCurrentMessage: { }, requestMessageUpdate: { _ in }, cancelInteractiveKeyboardGestures: { }, automaticMediaDownloadSettings: MediaAutoDownloadSettings.defaultSettings, diff --git a/submodules/TelegramUI/TelegramUI/ChatControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatControllerNode.swift index 42728f2785..9cc42740a4 100644 --- a/submodules/TelegramUI/TelegramUI/ChatControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatControllerNode.swift @@ -188,7 +188,7 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { } }*/ - init(context: AccountContext, chatLocation: ChatLocation, messageId: MessageId?, controllerInteraction: ChatControllerInteraction, chatPresentationInterfaceState: ChatPresentationInterfaceState, automaticMediaDownloadSettings: MediaAutoDownloadSettings, navigationBar: NavigationBar?, controller: ChatController?) { + init(context: AccountContext, chatLocation: ChatLocation, subject: ChatControllerSubject?, controllerInteraction: ChatControllerInteraction, chatPresentationInterfaceState: ChatPresentationInterfaceState, automaticMediaDownloadSettings: MediaAutoDownloadSettings, navigationBar: NavigationBar?, controller: ChatController?) { self.context = context self.chatLocation = chatLocation self.controllerInteraction = controllerInteraction @@ -203,7 +203,7 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { self.titleAccessoryPanelContainer = ChatControllerTitlePanelNodeContainer() self.titleAccessoryPanelContainer.clipsToBounds = true - self.historyNode = ChatHistoryListNode(context: context, chatLocation: chatLocation, tagMask: nil, messageId: messageId, controllerInteraction: controllerInteraction, selectedMessages: self.selectedMessagesPromise.get()) + self.historyNode = ChatHistoryListNode(context: context, chatLocation: chatLocation, tagMask: nil, subject: subject, controllerInteraction: controllerInteraction, selectedMessages: self.selectedMessagesPromise.get()) self.historyNode.rotated = true self.historyNodeContainer = ASDisplayNode() self.historyNodeContainer.addSubnode(self.historyNode) @@ -284,7 +284,11 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { self.textInputPanelNode?.sendMessage = { [weak self] in if let strongSelf = self { - strongSelf.sendCurrentMessage() + if strongSelf.chatPresentationInterfaceState.isScheduledMessages { + strongSelf.controllerInteraction.scheduleCurrentMessage() + } else { + strongSelf.sendCurrentMessage() + } } } @@ -2003,7 +2007,7 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { } } - func sendCurrentMessage(silentPosting: Bool? = nil) { + func sendCurrentMessage(silentPosting: Bool? = nil, scheduleTime: Int32? = nil) { if let textInputPanelNode = self.inputPanelNode as? ChatTextInputPanelNode { if textInputPanelNode.textInputNode?.isFirstResponder() ?? false { Keyboard.applyAutocorrection() @@ -2045,8 +2049,11 @@ class ChatControllerNode: ASDisplayNode, UIScrollViewDelegate { } var webpage: TelegramMediaWebpage? if self.chatPresentationInterfaceState.interfaceState.composeDisableUrlPreview != nil { - attributes.append(OutgoingContentInfoMessageAttribute(flags: [.disableLinkPreviews])) + attributes.append(OutgoingContentInfoMessageAttribute(flags: [.disableLinkPreviews], scheduleTime: scheduleTime)) } else { + if let scheduleTime = scheduleTime { + attributes.append(OutgoingContentInfoMessageAttribute(flags: [], scheduleTime: scheduleTime)) + } webpage = self.chatPresentationInterfaceState.urlPreview?.1 } messages.append(.message(text: text.string, attributes: attributes, mediaReference: webpage.flatMap(AnyMediaReference.standalone), replyToMessageId: self.chatPresentationInterfaceState.interfaceState.replyMessageId, localGroupingKey: nil)) diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift index 4c4d62bd62..48e2834d17 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistoryEntriesForView.swift @@ -40,7 +40,7 @@ func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, var contentTypeHint: ChatMessageEntryContentType = .generic if presentationData.largeEmoji { - if let _ = associatedData.animatedEmojiStickers[entry.message.text.trimmedEmoji] { + if let _ = associatedData.animatedEmojiStickers[entry.message.text.basicEmoji.0] { contentTypeHint = .animatedEmoji } else if messageIsElligibleForLargeEmoji(entry.message) { contentTypeHint = .largeEmoji diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift index 927b56aca1..b3fe6cf67e 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift @@ -256,7 +256,7 @@ private final class ChatHistoryTransactionOpaqueState { } } -private func extractAssociatedData(chatLocation: ChatLocation, view: MessageHistoryView, automaticDownloadNetworkType: MediaAutoDownloadNetworkType, animatedEmojiStickers: [String: StickerPackItem]) -> ChatMessageItemAssociatedData { +private func extractAssociatedData(chatLocation: ChatLocation, view: MessageHistoryView, automaticDownloadNetworkType: MediaAutoDownloadNetworkType, animatedEmojiStickers: [String: StickerPackItem], isScheduledMessages: Bool) -> ChatMessageItemAssociatedData { var automaticMediaDownloadPeerType: MediaAutoDownloadPeerType = .channel var contactsPeerIds: Set = Set() if case let .peer(peerId) = chatLocation { @@ -295,7 +295,7 @@ private func extractAssociatedData(chatLocation: ChatLocation, view: MessageHist } } } - let associatedData = ChatMessageItemAssociatedData(automaticDownloadPeerType: automaticMediaDownloadPeerType, automaticDownloadNetworkType: automaticDownloadNetworkType, isRecentActions: false, contactsPeerIds: contactsPeerIds, animatedEmojiStickers: animatedEmojiStickers) + let associatedData = ChatMessageItemAssociatedData(automaticDownloadPeerType: automaticMediaDownloadPeerType, automaticDownloadNetworkType: automaticDownloadNetworkType, isRecentActions: false, isScheduledMessages: isScheduledMessages, contactsPeerIds: contactsPeerIds, animatedEmojiStickers: animatedEmojiStickers) return associatedData } @@ -335,7 +335,7 @@ private struct ChatHistoryAnimatedEmojiConfiguration { public final class ChatHistoryListNode: ListView, ChatHistoryNode { private let context: AccountContext private let chatLocation: ChatLocation - private let messageId: MessageId? + private let subject: ChatControllerSubject? private let tagMask: MessageTags? private let controllerInteraction: ChatControllerInteraction private let mode: ChatHistoryListMode @@ -443,10 +443,10 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { private var loadedMessagesFromCachedDataDisposable: Disposable? - public init(context: AccountContext, chatLocation: ChatLocation, tagMask: MessageTags?, messageId: MessageId?, controllerInteraction: ChatControllerInteraction, selectedMessages: Signal?, NoError>, mode: ChatHistoryListMode = .bubbles) { + public init(context: AccountContext, chatLocation: ChatLocation, tagMask: MessageTags?, subject: ChatControllerSubject?, controllerInteraction: ChatControllerInteraction, selectedMessages: Signal?, NoError>, mode: ChatHistoryListMode = .bubbles) { self.context = context self.chatLocation = chatLocation - self.messageId = messageId + self.subject = subject self.tagMask = tagMask self.controllerInteraction = controllerInteraction self.mode = mode @@ -548,7 +548,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { var animatedEmojiStickers: [String: StickerPackItem] = [:] for case let item as StickerPackItem in items { if let emoji = item.getStringRepresentationsOfIndexKeys().first { - animatedEmojiStickers[emoji.trimmedEmoji] = item + animatedEmojiStickers[emoji.basicEmoji.0] = item } } return animatedEmojiStickers @@ -572,8 +572,14 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { strongSelf.chatHistoryLocationValue = ChatHistoryLocationInput(content: .Navigation(index: .message(lastEntry.index), anchorIndex: .message(lastEntry.index), count: historyMessageCount), id: (strongSelf.chatHistoryLocationValue?.id).flatMap({ $0 + 1 }) ?? 0) } else { - if let messageId = messageId { - strongSelf.chatHistoryLocationValue = ChatHistoryLocationInput(content: .InitialSearch(location: .id(messageId), count: 60), id: (strongSelf.chatHistoryLocationValue?.id).flatMap({ $0 + 1 }) ?? 0) + if let subject = subject { + switch subject { + case let .message(messageId): + strongSelf.chatHistoryLocationValue = ChatHistoryLocationInput(content: .InitialSearch(location: .id(messageId), count: 60), id: (strongSelf.chatHistoryLocationValue?.id).flatMap({ $0 + 1 }) ?? 0) + case .scheduledMessages: + strongSelf.chatHistoryLocationValue = ChatHistoryLocationInput(content: .Scheduled, id: (strongSelf.chatHistoryLocationValue?.id).flatMap({ $0 + 1 }) ?? 0) + } + } else { strongSelf.chatHistoryLocationValue = ChatHistoryLocationInput(content: .Initial(count: 60), id: (strongSelf.chatHistoryLocationValue?.id).flatMap({ $0 + 1 }) ?? 0) } @@ -630,7 +636,12 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { reverse = reverseValue } - let associatedData = extractAssociatedData(chatLocation: chatLocation, view: view, automaticDownloadNetworkType: networkType, animatedEmojiStickers: animatedEmojiStickers) + var isScheduledMessages = false + if let subject = subject, case .scheduledMessages = subject { + isScheduledMessages = true + } + + let associatedData = extractAssociatedData(chatLocation: chatLocation, view: view, automaticDownloadNetworkType: networkType, animatedEmojiStickers: animatedEmojiStickers, isScheduledMessages: isScheduledMessages) let processedView = ChatHistoryView(originalView: view, filteredEntries: chatHistoryEntriesForView(location: chatLocation, view: view, includeUnreadEntry: mode == .bubbles, includeEmptyEntry: mode == .bubbles && tagMask == nil, includeChatInfoEntry: mode == .bubbles, includeSearchEntry: includeSearchEntry && tagMask != nil, reverse: reverse, groupMessages: mode == .bubbles, selectedMessages: selectedMessages, presentationData: chatPresentationData, historyAppearsCleared: historyAppearsCleared, associatedData: associatedData), associatedData: associatedData, id: id) let previousValueAndVersion = previousView.swap((processedView, update.1)) @@ -666,19 +677,19 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { updatedScrollPosition = nil } else { switch type { - case let .Initial(fadeIn): - reason = ChatHistoryViewTransitionReason.Initial(fadeIn: fadeIn) - case let .Generic(genericType): - switch genericType { - case .InitialUnread, .Initial: - reason = ChatHistoryViewTransitionReason.Initial(fadeIn: false) - case .Generic: - reason = ChatHistoryViewTransitionReason.InteractiveChanges - case .UpdateVisible: - reason = ChatHistoryViewTransitionReason.Reload - case .FillHole: - reason = ChatHistoryViewTransitionReason.HoleReload - } + case let .Initial(fadeIn): + reason = ChatHistoryViewTransitionReason.Initial(fadeIn: fadeIn) + case let .Generic(genericType): + switch genericType { + case .InitialUnread, .Initial: + reason = ChatHistoryViewTransitionReason.Initial(fadeIn: false) + case .Generic: + reason = ChatHistoryViewTransitionReason.InteractiveChanges + case .UpdateVisible: + reason = ChatHistoryViewTransitionReason.Reload + case .FillHole: + reason = ChatHistoryViewTransitionReason.HoleReload + } } } let rawTransition = preparedChatHistoryViewTransition(from: previous, to: processedView, reason: reason, reverse: reverse, chatLocation: chatLocation, controllerInteraction: controllerInteraction, scrollPosition: updatedScrollPosition, initialData: initialData?.initialData, keyboardButtonsMessage: view.topTaggedMessages.first, cachedData: initialData?.cachedData, cachedDataMessages: initialData?.cachedDataMessages, readStateData: initialData?.readStateData, flashIndicators: flashIndicators) @@ -731,8 +742,13 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { } }) - if let messageId = messageId { - self.chatHistoryLocationValue = ChatHistoryLocationInput(content: .InitialSearch(location: .id(messageId), count: 60), id: 0) + if let subject = subject { + switch subject { + case let .message(messageId): + self.chatHistoryLocationValue = ChatHistoryLocationInput(content: .InitialSearch(location: .id(messageId), count: 60), id: 0) + case .scheduledMessages: + self.chatHistoryLocationValue = ChatHistoryLocationInput(content: .Scheduled, id: 0) + } } else { self.chatHistoryLocationValue = ChatHistoryLocationInput(content: .Initial(count: 60), id: 0) } diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift index 7e95433d3c..b19ecb061d 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistoryViewForLocation.swift @@ -187,6 +187,75 @@ func chatHistoryViewForLocation(_ location: ChatHistoryLocationInput, account: A } return .HistoryView(view: view, type: .Generic(type: genericType), scrollPosition: scrollPosition, flashIndicators: animated, originalScrollPosition: chatScrollPosition, initialData: ChatHistoryCombinedInitialData(initialData: initialData, buttonKeyboardMessage: view.topTaggedMessages.first, cachedData: cachedData, cachedDataMessages: cachedDataMessages, readStateData: readStateData), id: location.id) } + case .Scheduled: + var preloaded = false + var fadeIn = false + let count = 100 + let signal = account.viewTracker.aroundMessageHistoryViewForLocation(chatLocation, index: .upperBound, anchorIndex: .upperBound, count: count, fixedCombinedReadStates: nil, tagMask: tagMask, excludeNamespaces: [Namespaces.Message.Cloud, Namespaces.Message.Local], orderStatistics: orderStatistics) + return signal + |> map { view, updateType, initialData -> ChatHistoryViewUpdate in + let (cachedData, cachedDataMessages, readStateData) = extractAdditionalData(view: view, chatLocation: chatLocation) + + let combinedInitialData = ChatHistoryCombinedInitialData(initialData: initialData, buttonKeyboardMessage: view.topTaggedMessages.first, cachedData: cachedData, cachedDataMessages: cachedDataMessages, readStateData: readStateData) + + if preloaded { + return .HistoryView(view: view, type: .Generic(type: updateType), scrollPosition: nil, flashIndicators: false, originalScrollPosition: nil, initialData: combinedInitialData, id: location.id) + } else { + if view.isLoading { + return .Loading(initialData: combinedInitialData, type: .Generic(type: updateType)) + } + var scrollPosition: ChatHistoryViewScrollPosition? + + if let maxReadIndex = view.maxReadIndex, tagMask == nil { + let aroundIndex = maxReadIndex + scrollPosition = .unread(index: maxReadIndex) + + var targetIndex = 0 + for i in 0 ..< view.entries.count { + if view.entries[i].index >= aroundIndex { + targetIndex = i + break + } + } + + let maxIndex = targetIndex + count / 2 + let minIndex = targetIndex - count / 2 + if minIndex <= 0 && view.holeEarlier { + fadeIn = true + return .Loading(initialData: combinedInitialData, type: .Generic(type: updateType)) + } + if maxIndex >= targetIndex { + if view.holeLater { + fadeIn = true + return .Loading(initialData: combinedInitialData, type: .Generic(type: updateType)) + } + if view.holeEarlier { + var incomingCount: Int32 = 0 + inner: for entry in view.entries.reversed() { + if entry.message.flags.contains(.Incoming) { + incomingCount += 1 + } + } + if case let .peer(peerId) = chatLocation, let combinedReadStates = view.fixedReadStates, case let .peer(readStates) = combinedReadStates, let readState = readStates[peerId], readState.count == incomingCount { + } else { + fadeIn = true + return .Loading(initialData: combinedInitialData, type: .Generic(type: updateType)) + } + } + } + } else if let historyScrollState = (initialData?.chatInterfaceState as? ChatInterfaceState)?.historyScrollState, tagMask == nil { + scrollPosition = .positionRestoration(index: historyScrollState.messageIndex, relativeOffset: CGFloat(historyScrollState.relativeOffset)) + } else { + if view.entries.isEmpty && (view.holeEarlier || view.holeLater) { + fadeIn = true + return .Loading(initialData: combinedInitialData, type: .Generic(type: updateType)) + } + } + + preloaded = true + return .HistoryView(view: view, type: .Initial(fadeIn: fadeIn), scrollPosition: scrollPosition, flashIndicators: false, originalScrollPosition: nil, initialData: ChatHistoryCombinedInitialData(initialData: initialData, buttonKeyboardMessage: view.topTaggedMessages.first, cachedData: cachedData, cachedDataMessages: cachedDataMessages, readStateData: readStateData), id: location.id) + } + } } } diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift index bdfdebc011..3886c3ea5f 100644 --- a/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift +++ b/submodules/TelegramUI/TelegramUI/ChatInterfaceInputContexts.swift @@ -177,7 +177,7 @@ func inputContextQueriesForChatPresentationIntefaceState(_ chatPresentationInter for (possibleQueryRange, possibleTypes, additionalStringRange) in textInputStateContextQueryRangeAndType(inputState) { let query = inputString.substring(with: possibleQueryRange) if possibleTypes == [.emoji] { - result.append(.emoji(query.basicEmoji)) + result.append(.emoji(query.basicEmoji.0)) } else if possibleTypes == [.hashtag] { result.append(.hashtag(query)) } else if possibleTypes == [.mention] { @@ -258,6 +258,10 @@ func inputTextPanelStateForChatPresentationInterfaceState(_ chatPresentationInte } } if chatPresentationInterfaceState.interfaceState.composeInputState.inputText.length == 0 { + if chatPresentationInterfaceState.hasScheduledMessages { + accessoryItems.append(.scheduledMessages) + } + var stickersEnabled = true if let peer = chatPresentationInterfaceState.renderedPeer?.peer as? TelegramChannel { if case .broadcast = peer.info, canSendMessagesToPeer(peer) { diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift index 9d5ec25225..2f1b4de3ba 100644 --- a/submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift +++ b/submodules/TelegramUI/TelegramUI/ChatInterfaceTitlePanelNodes.swift @@ -30,7 +30,7 @@ func titlePanelForChatPresentationInterfaceState(_ chatPresentationInterfaceStat } var displayActionsPanel = false - if !chatPresentationInterfaceState.peerIsBlocked, let contactStatus = chatPresentationInterfaceState.contactStatus, let peerStatusSettings = contactStatus.peerStatusSettings { + if !chatPresentationInterfaceState.peerIsBlocked && !chatPresentationInterfaceState.isScheduledMessages, let contactStatus = chatPresentationInterfaceState.contactStatus, let peerStatusSettings = contactStatus.peerStatusSettings { if !peerStatusSettings.isEmpty { if contactStatus.canAddContact && peerStatusSettings.contains(.canAddContact) { displayActionsPanel = true diff --git a/submodules/TelegramUI/TelegramUI/ChatListController.swift b/submodules/TelegramUI/TelegramUI/ChatListController.swift index 290af94f6f..8fe817c176 100644 --- a/submodules/TelegramUI/TelegramUI/ChatListController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatListController.swift @@ -1223,7 +1223,7 @@ public class ChatListController: TelegramBaseController, UIViewControllerPreview sourceRect = CGRect(x: sourceRect.minX, y: sourceRect.minY + bounds.minY, width: bounds.width, height: bounds.height) sourceRect.size.height -= UIScreenPixel - let chatController = ChatController(context: self.context, chatLocation: .peer(messageId.peerId), messageId: messageId, mode: .standard(previewing: true)) + let chatController = ChatController(context: self.context, chatLocation: .peer(messageId.peerId), subject: .message(messageId), mode: .standard(previewing: true)) chatController.canReadHistory.set(false) chatController.containerLayoutUpdated(ContainerViewLayout(size: contentSize, metrics: LayoutMetrics(), intrinsicInsets: UIEdgeInsets(), safeInsets: UIEdgeInsets(), statusBarHeight: nil, inputHeight: nil, standardInputHeight: 216.0, inputHeightIsInteractivellyChanging: false, inVoiceOver: false), transition: .immediate) return (chatController, sourceRect) diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift index 2fa6428596..87b96d1493 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageAnimatedStickerItemNode.swift @@ -10,6 +10,7 @@ import TelegramPresentationData import Compression import TextFormat import AccountContext +import MediaResources import StickerResources private let nameFont = Font.medium(14.0) @@ -233,12 +234,17 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { break } } - - if self.telegramFile == nil, let emojiFile = item.associatedData.animatedEmojiStickers[item.message.text.trimmedEmoji]?.file { + + let (emoji, fitz) = item.message.text.basicEmoji + if self.telegramFile == nil, let emojiFile = item.associatedData.animatedEmojiStickers[emoji]?.file { if self.emojiFile?.id != emojiFile.id { self.emojiFile = emojiFile let dimensions = emojiFile.dimensions ?? CGSize(width: 512.0, height: 512.0) - self.imageNode.setSignal(chatMessageAnimatedSticker(postbox: item.context.account.postbox, file: emojiFile, small: false, size: dimensions.aspectFilled(CGSize(width: 384.0, height: 384.0)), thumbnail: false)) + var fitzModifier: EmojiFitzModifier? + if let fitz = fitz { + fitzModifier = EmojiFitzModifier(emoji: fitz) + } + self.imageNode.setSignal(chatMessageAnimatedSticker(postbox: item.context.account.postbox, file: emojiFile, small: false, size: dimensions.aspectFilled(CGSize(width: 384.0, height: 384.0)), fitzModifier: fitzModifier, thumbnail: false)) self.disposable.set(freeMediaFileInteractiveFetched(account: item.context.account, fileReference: .message(message: MessageReference(item.message), media: emojiFile)).start()) self.updateVisibility() } @@ -272,6 +278,7 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { var file: TelegramMediaFile? var playbackMode: AnimatedStickerPlaybackMode = .loop var isEmoji = false + var fitzModifier: EmojiFitzModifier? if let telegramFile = self.telegramFile { file = telegramFile @@ -282,12 +289,16 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { isEmoji = true file = emojiFile playbackMode = .once + let (_, fitz) = item.message.text.basicEmoji + if let fitz = fitz { + fitzModifier = EmojiFitzModifier(emoji: fitz) + } } if let file = file { let dimensions = file.dimensions ?? CGSize(width: 512.0, height: 512.0) let fittedSize = isEmoji ? dimensions.aspectFilled(CGSize(width: 384.0, height: 384.0)) : dimensions.aspectFitted(CGSize(width: 384.0, height: 384.0)) - self.animationNode.setup(account: item.context.account, resource: file.resource, width: Int(fittedSize.width), height: Int(fittedSize.height), playbackMode: playbackMode, mode: .cached) + self.animationNode.setup(account: item.context.account, resource: file.resource, fitzModifier: fitzModifier, width: Int(fittedSize.width), height: Int(fittedSize.height), playbackMode: playbackMode, mode: .cached) } } } diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift b/submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift index 3ea4bdb968..2f59548bcf 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageDateHeader.swift @@ -19,14 +19,16 @@ private let granularity: Int32 = 60 * 60 * 24 final class ChatMessageDateHeader: ListViewItemHeader { private let timestamp: Int32 private let roundedTimestamp: Int32 + private let scheduled: Bool let id: Int64 let presentationData: ChatPresentationData let context: AccountContext let action: ((Int32) -> Void)? - init(timestamp: Int32, presentationData: ChatPresentationData, context: AccountContext, action: ((Int32) -> Void)? = nil) { + init(timestamp: Int32, scheduled: Bool, presentationData: ChatPresentationData, context: AccountContext, action: ((Int32) -> Void)? = nil) { self.timestamp = timestamp + self.scheduled = scheduled self.presentationData = presentationData self.context = context self.action = action @@ -43,7 +45,7 @@ final class ChatMessageDateHeader: ListViewItemHeader { let height: CGFloat = 34.0 func node() -> ListViewItemHeaderNode { - return ChatMessageDateHeaderNode(localTimestamp: self.roundedTimestamp, presentationData: self.presentationData, context: self.context, action: self.action) + return ChatMessageDateHeaderNode(localTimestamp: self.roundedTimestamp, scheduled: self.scheduled, presentationData: self.presentationData, context: self.context, action: self.action) } } @@ -93,7 +95,7 @@ final class ChatMessageDateHeaderNode: ListViewItemHeaderNode { private var stickDistanceFactor: CGFloat = 0.0 private var action: ((Int32) -> Void)? = nil - init(localTimestamp: Int32, presentationData: ChatPresentationData, context: AccountContext, action: ((Int32) -> Void)? = nil) { + init(localTimestamp: Int32, scheduled: Bool, presentationData: ChatPresentationData, context: AccountContext, action: ((Int32) -> Void)? = nil) { self.presentationData = presentationData self.context = context @@ -137,7 +139,7 @@ final class ChatMessageDateHeaderNode: ListViewItemHeaderNode { var timeinfoNow: tm = tm() localtime_r(&now, &timeinfoNow) - let text: String + var text: String if timeinfo.tm_year == timeinfoNow.tm_year { if timeinfo.tm_yday == timeinfoNow.tm_yday { text = presentationData.strings.Weekday_Today @@ -148,6 +150,10 @@ final class ChatMessageDateHeaderNode: ListViewItemHeaderNode { text = presentationData.strings.Date_ChatDateHeaderYear(monthAtIndex(Int(timeinfo.tm_mon), strings: presentationData.strings), "\(timeinfo.tm_mday)", "\(1900 + timeinfo.tm_year)").0 } + if scheduled { + text = presentationData.strings.ScheduledMessages_ScheduledDate(text).0 + } + let attributedString = NSAttributedString(string: text, font: titleFont, textColor: bubbleVariableColor(variableColor: presentationData.theme.theme.chat.serviceMessage.dateTextColor, wallpaper: presentationData.theme.wallpaper)) let labelLayout = TextNode.asyncLayout(self.labelNode) diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift b/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift index 155a64cb8f..ae825912ff 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageItem.swift @@ -212,14 +212,16 @@ public final class ChatMessageItemAssociatedData: Equatable { let automaticDownloadPeerType: MediaAutoDownloadPeerType let automaticDownloadNetworkType: MediaAutoDownloadNetworkType let isRecentActions: Bool + let isScheduledMessages: Bool let contactsPeerIds: Set let animatedEmojiStickers: [String: StickerPackItem] let forcedResourceStatus: FileMediaResourceStatus? - init(automaticDownloadPeerType: MediaAutoDownloadPeerType, automaticDownloadNetworkType: MediaAutoDownloadNetworkType, isRecentActions: Bool, contactsPeerIds: Set = Set(), animatedEmojiStickers: [String: StickerPackItem] = [:], forcedResourceStatus: FileMediaResourceStatus? = nil) { + init(automaticDownloadPeerType: MediaAutoDownloadPeerType, automaticDownloadNetworkType: MediaAutoDownloadNetworkType, isRecentActions: Bool = false, isScheduledMessages: Bool = false, contactsPeerIds: Set = Set(), animatedEmojiStickers: [String: StickerPackItem] = [:], forcedResourceStatus: FileMediaResourceStatus? = nil) { self.automaticDownloadPeerType = automaticDownloadPeerType self.automaticDownloadNetworkType = automaticDownloadNetworkType self.isRecentActions = isRecentActions + self.isScheduledMessages = isScheduledMessages self.contactsPeerIds = contactsPeerIds self.animatedEmojiStickers = animatedEmojiStickers self.forcedResourceStatus = forcedResourceStatus @@ -235,9 +237,15 @@ public final class ChatMessageItemAssociatedData: Equatable { if lhs.isRecentActions != rhs.isRecentActions { return false } + if lhs.isScheduledMessages != rhs.isScheduledMessages { + return false + } if lhs.contactsPeerIds != rhs.contactsPeerIds { return false } + if lhs.animatedEmojiStickers != rhs.animatedEmojiStickers { + return false + } if lhs.forcedResourceStatus != rhs.forcedResourceStatus { return false } @@ -320,7 +328,13 @@ public final class ChatMessageItem: ListViewItem, CustomStringConvertible { self.effectiveAuthorId = effectiveAuthor?.id - self.header = ChatMessageDateHeader(timestamp: content.index.timestamp, presentationData: presentationData, context: context, action: { timestamp in + let timestamp: Int32 + if let scheduleTime = content.firstMessage.scheduleTime { + timestamp = scheduleTime + } else { + timestamp = content.index.timestamp + } + self.header = ChatMessageDateHeader(timestamp: timestamp, scheduled: associatedData.isScheduledMessages, presentationData: presentationData, context: context, action: { timestamp in var calendar = NSCalendar.current calendar.timeZone = TimeZone(abbreviation: "UTC")! let date = Date(timeIntervalSince1970: TimeInterval(timestamp)) @@ -388,7 +402,7 @@ public final class ChatMessageItem: ListViewItem, CustomStringConvertible { } if viewClassName == ChatMessageBubbleItemNode.self && self.presentationData.largeEmoji && messageIsElligibleForLargeEmoji(self.message) { - if let _ = self.associatedData.animatedEmojiStickers[self.message.text.trimmedEmoji] { + if let _ = self.associatedData.animatedEmojiStickers[self.message.text.basicEmoji.0] { viewClassName = ChatMessageAnimatedStickerItemNode.self } else { viewClassName = ChatMessageStickerItemNode.self diff --git a/submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift b/submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift index babac77bb7..9ea7384296 100644 --- a/submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift +++ b/submodules/TelegramUI/TelegramUI/ChatPanelInterfaceInteraction.swift @@ -108,9 +108,10 @@ final class ChatPanelInterfaceInteraction { let reportPeerIrrelevantGeoLocation: () -> Void let displaySlowmodeTooltip: (ASDisplayNode, CGRect) -> Void let displaySendMessageOptions: () -> Void + let openScheduledMessages: () -> Void let statuses: ChatPanelInterfaceInteractionStatuses? - init(setupReplyMessage: @escaping (MessageId) -> Void, setupEditMessage: @escaping (MessageId?) -> Void, beginMessageSelection: @escaping ([MessageId]) -> Void, deleteSelectedMessages: @escaping () -> Void, reportSelectedMessages: @escaping () -> Void, reportMessages: @escaping ([Message]) -> Void, deleteMessages: @escaping ([Message]) -> 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, navigateMessageSearch: @escaping (ChatPanelSearchNavigationAction) -> Void, openCalendarSearch: @escaping () -> Void, toggleMembersSearch: @escaping (Bool) -> Void, navigateToMessage: @escaping (MessageId) -> Void, navigateToChat: @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 () -> Void, statuses: ChatPanelInterfaceInteractionStatuses?) { + init(setupReplyMessage: @escaping (MessageId) -> Void, setupEditMessage: @escaping (MessageId?) -> Void, beginMessageSelection: @escaping ([MessageId]) -> Void, deleteSelectedMessages: @escaping () -> Void, reportSelectedMessages: @escaping () -> Void, reportMessages: @escaping ([Message]) -> Void, deleteMessages: @escaping ([Message]) -> 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, navigateMessageSearch: @escaping (ChatPanelSearchNavigationAction) -> Void, openCalendarSearch: @escaping () -> Void, toggleMembersSearch: @escaping (Bool) -> Void, navigateToMessage: @escaping (MessageId) -> Void, navigateToChat: @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 () -> Void, openScheduledMessages: @escaping () -> Void, statuses: ChatPanelInterfaceInteractionStatuses?) { self.setupReplyMessage = setupReplyMessage self.setupEditMessage = setupEditMessage self.beginMessageSelection = beginMessageSelection @@ -175,6 +176,7 @@ final class ChatPanelInterfaceInteraction { self.reportPeerIrrelevantGeoLocation = reportPeerIrrelevantGeoLocation self.displaySlowmodeTooltip = displaySlowmodeTooltip self.displaySendMessageOptions = displaySendMessageOptions + self.openScheduledMessages = openScheduledMessages self.statuses = statuses } } diff --git a/submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift b/submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift index 2853ee69c3..6043b75b44 100644 --- a/submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift +++ b/submodules/TelegramUI/TelegramUI/ChatPresentationInterfaceState.swift @@ -389,8 +389,10 @@ final class ChatPresentationInterfaceState: Equatable { let fontSize: PresentationFontSize let accountPeerId: PeerId let mode: ChatControllerPresentationMode + let hasScheduledMessages: Bool + let isScheduledMessages: Bool - init(chatWallpaper: TelegramWallpaper, theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, limitsConfiguration: LimitsConfiguration, fontSize: PresentationFontSize, accountPeerId: PeerId, mode: ChatControllerPresentationMode, chatLocation: ChatLocation) { + init(chatWallpaper: TelegramWallpaper, theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, limitsConfiguration: LimitsConfiguration, fontSize: PresentationFontSize, accountPeerId: PeerId, mode: ChatControllerPresentationMode, chatLocation: ChatLocation, isScheduledMessages: Bool) { self.interfaceState = ChatInterfaceState() self.inputTextPanelState = ChatTextInputPanelState() self.editMessageState = nil @@ -430,9 +432,11 @@ final class ChatPresentationInterfaceState: Equatable { self.fontSize = fontSize self.accountPeerId = accountPeerId self.mode = mode + self.hasScheduledMessages = false + self.isScheduledMessages = isScheduledMessages } - init(interfaceState: ChatInterfaceState, chatLocation: ChatLocation, renderedPeer: RenderedPeer?, isNotAccessible: Bool, explicitelyCanPinMessages: Bool, contactStatus: ChatContactStatus?, hasBots: Bool, isArchived: Bool, inputTextPanelState: ChatTextInputPanelState, editMessageState: ChatEditInterfaceMessageState?, recordedMediaPreview: ChatRecordedMediaPreview?, inputQueryResults: [ChatPresentationInputQueryKind: ChatPresentationInputQueryResult], inputMode: ChatInputMode, titlePanelContexts: [ChatTitlePanelContext], keyboardButtonsMessage: Message?, pinnedMessageId: MessageId?, pinnedMessage: Message?, peerIsBlocked: Bool, peerIsMuted: Bool, peerDiscussionId: PeerId?, peerGeoLocation: PeerGeoLocation?, callsAvailable: Bool, callsPrivate: Bool, slowmodeState: ChatSlowmodeState?, chatHistoryState: ChatHistoryNodeHistoryState?, botStartPayload: String?, urlPreview: (String, TelegramMediaWebpage)?, editingUrlPreview: (String, TelegramMediaWebpage)?, search: ChatSearchData?, searchQuerySuggestionResult: ChatPresentationInputQueryResult?, chatWallpaper: TelegramWallpaper, theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, limitsConfiguration: LimitsConfiguration, fontSize: PresentationFontSize, accountPeerId: PeerId, mode: ChatControllerPresentationMode) { + init(interfaceState: ChatInterfaceState, chatLocation: ChatLocation, renderedPeer: RenderedPeer?, isNotAccessible: Bool, explicitelyCanPinMessages: Bool, contactStatus: ChatContactStatus?, hasBots: Bool, isArchived: Bool, inputTextPanelState: ChatTextInputPanelState, editMessageState: ChatEditInterfaceMessageState?, recordedMediaPreview: ChatRecordedMediaPreview?, inputQueryResults: [ChatPresentationInputQueryKind: ChatPresentationInputQueryResult], inputMode: ChatInputMode, titlePanelContexts: [ChatTitlePanelContext], keyboardButtonsMessage: Message?, pinnedMessageId: MessageId?, pinnedMessage: Message?, peerIsBlocked: Bool, peerIsMuted: Bool, peerDiscussionId: PeerId?, peerGeoLocation: PeerGeoLocation?, callsAvailable: Bool, callsPrivate: Bool, slowmodeState: ChatSlowmodeState?, chatHistoryState: ChatHistoryNodeHistoryState?, botStartPayload: String?, urlPreview: (String, TelegramMediaWebpage)?, editingUrlPreview: (String, TelegramMediaWebpage)?, search: ChatSearchData?, searchQuerySuggestionResult: ChatPresentationInputQueryResult?, chatWallpaper: TelegramWallpaper, theme: PresentationTheme, strings: PresentationStrings, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, limitsConfiguration: LimitsConfiguration, fontSize: PresentationFontSize, accountPeerId: PeerId, mode: ChatControllerPresentationMode, hasScheduledMessages: Bool, isScheduledMessages: Bool) { self.interfaceState = interfaceState self.chatLocation = chatLocation self.renderedPeer = renderedPeer @@ -472,6 +476,8 @@ final class ChatPresentationInterfaceState: Equatable { self.fontSize = fontSize self.accountPeerId = accountPeerId self.mode = mode + self.hasScheduledMessages = hasScheduledMessages + self.isScheduledMessages = isScheduledMessages } static func ==(lhs: ChatPresentationInterfaceState, rhs: ChatPresentationInterfaceState) -> Bool { @@ -611,35 +617,41 @@ final class ChatPresentationInterfaceState: Equatable { if lhs.mode != rhs.mode { return false } + if lhs.hasScheduledMessages != rhs.hasScheduledMessages { + return false + } + if lhs.isScheduledMessages != rhs.isScheduledMessages { + return false + } return true } func updatedInterfaceState(_ f: (ChatInterfaceState) -> ChatInterfaceState) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: f(self.interfaceState), chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: f(self.interfaceState), chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedPeer(_ f: (RenderedPeer?) -> RenderedPeer?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: f(self.renderedPeer), isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: f(self.renderedPeer), isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedIsNotAccessible(_ isNotAccessible: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedExplicitelyCanPinMessages(_ explicitelyCanPinMessages: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedContactStatus(_ contactStatus: ChatContactStatus?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedHasBots(_ hasBots: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedIsArchived(_ isArchived: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedInputQueryResult(queryKind: ChatPresentationInputQueryKind, _ f: (ChatPresentationInputQueryResult?) -> ChatPresentationInputQueryResult?) -> ChatPresentationInterfaceState { @@ -650,111 +662,115 @@ final class ChatPresentationInterfaceState: Equatable { } else { inputQueryResults.removeValue(forKey: queryKind) } - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedInputTextPanelState(_ f: (ChatTextInputPanelState) -> ChatTextInputPanelState) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: f(self.inputTextPanelState), editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: f(self.inputTextPanelState), editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedEditMessageState(_ editMessageState: ChatEditInterfaceMessageState?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedRecordedMediaPreview(_ recordedMediaPreview: ChatRecordedMediaPreview?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedInputMode(_ f: (ChatInputMode) -> ChatInputMode) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: f(self.inputMode), titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: f(self.inputMode), titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedTitlePanelContext(_ f: ([ChatTitlePanelContext]) -> [ChatTitlePanelContext]) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: f(self.titlePanelContexts), keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: f(self.titlePanelContexts), keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedKeyboardButtonsMessage(_ message: Message?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: message, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: message, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedPinnedMessageId(_ pinnedMessageId: MessageId?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedPinnedMessage(_ pinnedMessage: Message?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedPeerIsBlocked(_ peerIsBlocked: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedPeerIsMuted(_ peerIsMuted: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedPeerDiscussionId(_ peerDiscussionId: PeerId?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedPeerGeoLocation(_ peerGeoLocation: PeerGeoLocation?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedCallsAvailable(_ callsAvailable: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedCallsPrivate(_ callsPrivate: Bool) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedSlowmodeState(_ slowmodeState: ChatSlowmodeState?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedBotStartPayload(_ botStartPayload: String?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedChatHistoryState(_ chatHistoryState: ChatHistoryNodeHistoryState?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedUrlPreview(_ urlPreview: (String, TelegramMediaWebpage)?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedEditingUrlPreview(_ editingUrlPreview: (String, TelegramMediaWebpage)?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedSearch(_ search: ChatSearchData?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedSearchQuerySuggestionResult(_ f: (ChatPresentationInputQueryResult?) -> ChatPresentationInputQueryResult?) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: f(self.searchQuerySuggestionResult), chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: f(self.searchQuerySuggestionResult), chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedMode(_ mode: ChatControllerPresentationMode) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedTheme(_ theme: PresentationTheme) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedStrings(_ strings: PresentationStrings) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedDateTimeFormat(_ dateTimeFormat: PresentationDateTimeFormat) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } func updatedChatWallpaper(_ chatWallpaper: TelegramWallpaper) -> ChatPresentationInterfaceState { - return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode) + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: self.hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) + } + + func updatedHasScheduledMessages(_ hasScheduledMessages: Bool) -> ChatPresentationInterfaceState { + return ChatPresentationInterfaceState(interfaceState: self.interfaceState, chatLocation: self.chatLocation, renderedPeer: self.renderedPeer, isNotAccessible: self.isNotAccessible, explicitelyCanPinMessages: self.explicitelyCanPinMessages, contactStatus: self.contactStatus, hasBots: self.hasBots, isArchived: self.isArchived, inputTextPanelState: self.inputTextPanelState, editMessageState: self.editMessageState, recordedMediaPreview: self.recordedMediaPreview, inputQueryResults: self.inputQueryResults, inputMode: self.inputMode, titlePanelContexts: self.titlePanelContexts, keyboardButtonsMessage: self.keyboardButtonsMessage, pinnedMessageId: self.pinnedMessageId, pinnedMessage: self.pinnedMessage, peerIsBlocked: self.peerIsBlocked, peerIsMuted: self.peerIsMuted, peerDiscussionId: self.peerDiscussionId, peerGeoLocation: self.peerGeoLocation, callsAvailable: self.callsAvailable, callsPrivate: self.callsPrivate, slowmodeState: self.slowmodeState, chatHistoryState: self.chatHistoryState, botStartPayload: self.botStartPayload, urlPreview: self.urlPreview, editingUrlPreview: self.editingUrlPreview, search: self.search, searchQuerySuggestionResult: self.searchQuerySuggestionResult, chatWallpaper: self.chatWallpaper, theme: self.theme, strings: self.strings, dateTimeFormat: self.dateTimeFormat, nameDisplayOrder: self.nameDisplayOrder, limitsConfiguration: self.limitsConfiguration, fontSize: self.fontSize, accountPeerId: self.accountPeerId, mode: self.mode, hasScheduledMessages: hasScheduledMessages, isScheduledMessages: self.isScheduledMessages) } } diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift index 005efebfd9..a2a7526a50 100644 --- a/submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatRecentActionsController.swift @@ -108,6 +108,7 @@ final class ChatRecentActionsController: TelegramBaseController { }, reportPeerIrrelevantGeoLocation: { }, displaySlowmodeTooltip: { _, _ in }, displaySendMessageOptions: { + }, openScheduledMessages: { }, statuses: nil) self.navigationItem.titleView = self.titleView diff --git a/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift index 651448a985..0adedee643 100644 --- a/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatRecentActionsControllerNode.swift @@ -394,6 +394,7 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { } }, displayMessageTooltip: { _, _, _, _ in }, seekToTimecode: { _, _, _ in + }, scheduleCurrentMessage: { }, requestMessageUpdate: { _ in }, cancelInteractiveKeyboardGestures: { }, automaticMediaDownloadSettings: self.automaticMediaDownloadSettings, diff --git a/submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift new file mode 100644 index 0000000000..bc17b7b225 --- /dev/null +++ b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeController.swift @@ -0,0 +1,71 @@ +import Foundation +import UIKit +import Display +import AsyncDisplayKit +import Postbox +import TelegramCore +import SwiftSignalKit +import AccountContext + +final class ChatScheduleTimeController: ViewController { + private var controllerNode: ChatScheduleTimeControllerNode { + return self.displayNode as! ChatScheduleTimeControllerNode + } + + private var animatedIn = false + + private let context: AccountContext + private let completion: (Int32) -> Void + + init(context: AccountContext, completion: @escaping (Int32) -> Void) { + self.context = context + self.completion = completion + + super.init(navigationBarPresentationData: nil) + + self.statusBar.statusBarStyle = .Ignore + } + + required init(coder aDecoder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } + + override public func loadDisplayNode() { + self.displayNode = ChatScheduleTimeControllerNode(context: self.context) + self.controllerNode.completion = { [weak self] time in + self?.completion(time + 5) + self?.dismiss() + } + self.controllerNode.dismiss = { [weak self] in + self?.presentingViewController?.dismiss(animated: false, completion: nil) + } + self.controllerNode.cancel = { [weak self] in + self?.dismiss() + } + } + + override public func loadView() { + super.loadView() + + self.statusBar.removeFromSupernode() + } + + override public func viewDidAppear(_ animated: Bool) { + super.viewDidAppear(animated) + + if !self.animatedIn { + self.animatedIn = true + self.controllerNode.animateIn() + } + } + + override public func dismiss(completion: (() -> Void)? = nil) { + self.controllerNode.animateOut(completion: completion) + } + + override public func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { + super.containerLayoutUpdated(layout, transition: transition) + + self.controllerNode.containerLayoutUpdated(layout, navigationBarHeight: self.navigationHeight, transition: transition) + } +} diff --git a/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift new file mode 100644 index 0000000000..ff9dbdda14 --- /dev/null +++ b/submodules/TelegramUI/TelegramUI/ChatScheduleTimeControllerNode.swift @@ -0,0 +1,245 @@ +import Foundation +import UIKit +import Display +import AsyncDisplayKit +import Postbox +import TelegramCore +import TelegramPresentationData +import TelegramStringFormatting +import AccountContext +import ShareController + +class ChatScheduleTimeControllerNode: ViewControllerTracingNode, UIScrollViewDelegate { + private let context: AccountContext + private var presentationData: PresentationData + + private let dimNode: ASDisplayNode + private let wrappingScrollNode: ASScrollNode + private let contentContainerNode: ASDisplayNode + private let contentBackgroundNode: ASImageNode + private let titleNode: ASTextNode + private let separatorNode: ASDisplayNode + private let cancelButton: HighlightableButtonNode + private let doneButton: SolidRoundedButtonNode + + private let pickerView: UIDatePicker + private let dateFormatter: DateFormatter + + private var containerLayout: (ContainerViewLayout, CGFloat)? + + var completion: ((Int32) -> Void)? + var dismiss: (() -> Void)? + var cancel: (() -> Void)? + + init(context: AccountContext) { + self.context = context + self.presentationData = context.sharedContext.currentPresentationData.with { $0 } + + self.wrappingScrollNode = ASScrollNode() + self.wrappingScrollNode.view.alwaysBounceVertical = true + self.wrappingScrollNode.view.delaysContentTouches = false + self.wrappingScrollNode.view.canCancelContentTouches = true + + self.dimNode = ASDisplayNode() + self.dimNode.backgroundColor = UIColor(white: 0.0, alpha: 0.5) + + let roundedBackground = generateStretchableFilledCircleImage(radius: 16.0, color: self.presentationData.theme.actionSheet.opaqueItemBackgroundColor) + + self.contentContainerNode = ASDisplayNode() + self.contentContainerNode.isOpaque = false + self.contentContainerNode.clipsToBounds = true + + self.contentBackgroundNode = ASImageNode() + self.contentBackgroundNode.displaysAsynchronously = false + self.contentBackgroundNode.displayWithoutProcessing = true + self.contentBackgroundNode.image = roundedBackground + + self.titleNode = ASTextNode() + self.titleNode.attributedText = NSAttributedString(string: self.presentationData.strings.Conversation_ScheduleMessage_Title, font: Font.bold(17.0), textColor: self.presentationData.theme.actionSheet.primaryTextColor) + + self.separatorNode = ASDisplayNode() + //self.separatorNode.backgroundColor = self.theme.controlColor + + self.cancelButton = HighlightableButtonNode() + self.cancelButton.setTitle(self.presentationData.strings.Common_Cancel, with: Font.regular(17.0), with: self.presentationData.theme.actionSheet.controlAccentColor, for: .normal) + + self.doneButton = SolidRoundedButtonNode(theme: self.presentationData.theme, height: 52.0, cornerRadius: 11.0, gloss: false) + + self.pickerView = UIDatePicker() + self.pickerView.timeZone = TimeZone(secondsFromGMT: 0) + self.pickerView.datePickerMode = .dateAndTime + self.pickerView.date = Date() //Date(timeIntervalSince1970: Double(roundDateToDays(currentValue))) + self.pickerView.locale = localeWithStrings(self.presentationData.strings) + + self.dateFormatter = DateFormatter() + self.dateFormatter.timeStyle = .none + self.dateFormatter.dateStyle = .short + self.dateFormatter.timeZone = TimeZone.current + + super.init() + + self.backgroundColor = nil + self.isOpaque = false + + self.dimNode.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.dimTapGesture(_:)))) + self.addSubnode(self.dimNode) + + self.wrappingScrollNode.view.delegate = self + self.addSubnode(self.wrappingScrollNode) + + self.wrappingScrollNode.addSubnode(self.contentBackgroundNode) + self.wrappingScrollNode.addSubnode(self.contentContainerNode) + + self.contentContainerNode.addSubnode(self.titleNode) + self.contentContainerNode.addSubnode(self.cancelButton) + self.contentContainerNode.addSubnode(self.doneButton) + + self.pickerView.timeZone = TimeZone.current + self.pickerView.minuteInterval = 5 + self.pickerView.minimumDate = Date() + self.pickerView.maximumDate = Date(timeIntervalSince1970: Double(Int32.max - 1)) + + self.pickerView.setValue(self.presentationData.theme.actionSheet.primaryTextColor, forKey: "textColor") + + self.contentContainerNode.view.addSubview(self.pickerView) + self.pickerView.addTarget(self, action: #selector(self.datePickerUpdated), for: .valueChanged) + + self.cancelButton.addTarget(self, action: #selector(self.cancelButtonPressed), forControlEvents: .touchUpInside) + self.doneButton.pressed = { [weak self] in + if let strongSelf = self { + strongSelf.completion?(Int32(strongSelf.pickerView.date.timeIntervalSince1970)) + } + } + + self.updateButtonTitle() + } + + override func didLoad() { + super.didLoad() + + if #available(iOSApplicationExtension 11.0, iOS 11.0, *) { + self.wrappingScrollNode.view.contentInsetAdjustmentBehavior = .never + } + } + + private func updateButtonTitle() { + let calendar = Calendar.current + let date = self.pickerView.date + + let time = stringForMessageTimestamp(timestamp: Int32(date.timeIntervalSince1970), dateTimeFormat: self.presentationData.dateTimeFormat) + if calendar.isDateInToday(date) { + self.doneButton.title = self.presentationData.strings.Conversation_ScheduleMessage_SendToday(time).0 + } else { + self.doneButton.title = self.presentationData.strings.Conversation_ScheduleMessage_SendOn(self.dateFormatter.string(from: date), time).0 + } + } + + @objc private func datePickerUpdated() { + self.updateButtonTitle() + } + + @objc func cancelButtonPressed() { + self.cancel?() + } + + @objc func dimTapGesture(_ recognizer: UITapGestureRecognizer) { + if case .ended = recognizer.state { + self.cancelButtonPressed() + } + } + + func animateIn() { + self.dimNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.4) + + let offset = self.bounds.size.height - self.contentBackgroundNode.frame.minY + + let dimPosition = self.dimNode.layer.position + self.dimNode.layer.animatePosition(from: CGPoint(x: dimPosition.x, y: dimPosition.y - offset), to: dimPosition, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) + self.layer.animateBoundsOriginYAdditive(from: -offset, to: 0.0, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) + } + + func animateOut(completion: (() -> Void)? = nil) { + var dimCompleted = false + var offsetCompleted = false + + let internalCompletion: () -> Void = { [weak self] in + if let strongSelf = self, dimCompleted && offsetCompleted { + strongSelf.dismiss?() + } + completion?() + } + + self.dimNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.3, removeOnCompletion: false, completion: { _ in + dimCompleted = true + internalCompletion() + }) + + let offset = self.bounds.size.height - self.contentBackgroundNode.frame.minY + let dimPosition = self.dimNode.layer.position + self.dimNode.layer.animatePosition(from: dimPosition, to: CGPoint(x: dimPosition.x, y: dimPosition.y - offset), duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false) + self.layer.animateBoundsOriginYAdditive(from: 0.0, to: -offset, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false, completion: { _ in + offsetCompleted = true + internalCompletion() + }) + } + + override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { + if self.bounds.contains(point) { + if !self.contentBackgroundNode.bounds.contains(self.convert(point, to: self.contentBackgroundNode)) { + return self.dimNode.view + } + } + return super.hitTest(point, with: event) + } + + func scrollViewDidEndDragging(_ scrollView: UIScrollView, willDecelerate decelerate: Bool) { + let contentOffset = scrollView.contentOffset + let additionalTopHeight = max(0.0, -contentOffset.y) + + if additionalTopHeight >= 30.0 { + self.cancelButtonPressed() + } + } + + func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { + self.containerLayout = (layout, navigationBarHeight) + + var insets = layout.insets(options: [.statusBar, .input]) + let cleanInsets = layout.insets(options: [.statusBar]) + insets.top = max(10.0, insets.top) + + let bottomInset: CGFloat = 10.0 + cleanInsets.bottom + let titleAreaHeight: CGFloat = 54.0 + let contentHeight = titleAreaHeight + bottomInset + 285.0 + let width = horizontalContainerFillingSizeForLayout(layout: layout, sideInset: layout.safeInsets.left) + + let sideInset = floor((layout.size.width - width) / 2.0) + let contentContainerFrame = CGRect(origin: CGPoint(x: sideInset, y: layout.size.height - contentHeight), size: CGSize(width: width, height: contentHeight)) + let contentFrame = contentContainerFrame + + var backgroundFrame = CGRect(origin: CGPoint(x: contentFrame.minX, y: contentFrame.minY), size: CGSize(width: contentFrame.width, height: contentFrame.height + 2000.0)) + if backgroundFrame.minY < contentFrame.minY { + backgroundFrame.origin.y = contentFrame.minY + } + transition.updateFrame(node: self.contentBackgroundNode, frame: backgroundFrame) + transition.updateFrame(node: self.wrappingScrollNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + transition.updateFrame(node: self.dimNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + + let titleSize = self.titleNode.measure(CGSize(width: width, height: titleAreaHeight)) + let titleFrame = CGRect(origin: CGPoint(x: floor((contentFrame.width - titleSize.width) / 2.0), y: 16.0), size: titleSize) + transition.updateFrame(node: self.titleNode, frame: titleFrame) + + let cancelSize = self.cancelButton.measure(CGSize(width: width, height: titleAreaHeight)) + let cancelFrame = CGRect(origin: CGPoint(x: 16.0, y: 16.0), size: cancelSize) + transition.updateFrame(node: self.cancelButton, frame: cancelFrame) + + let buttonInset: CGFloat = 16.0 + let buttonHeight = self.doneButton.updateLayout(width: contentFrame.width - buttonInset * 2.0, transition: transition) + transition.updateFrame(node: self.doneButton, frame: CGRect(x: buttonInset, y: contentHeight - buttonHeight - insets.bottom - 10.0, width: contentFrame.width, height: buttonHeight)) + + self.pickerView.frame = CGRect(origin: CGPoint(x: 0.0, y: 54.0), size: CGSize(width: contentFrame.width, height: 216.0)) + + transition.updateFrame(node: self.contentContainerNode, frame: contentContainerFrame) + transition.updateFrame(node: self.separatorNode, frame: CGRect(origin: CGPoint(x: 0.0, y: titleAreaHeight), size: CGSize(width: contentContainerFrame.size.width, height: UIScreenPixel))) + } +} diff --git a/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift b/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift index a34fa006fd..453551662b 100644 --- a/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetController.swift @@ -67,6 +67,9 @@ final class ChatSendMessageActionSheetController: ViewController { }, sendSilently: { [weak self] in self?.controllerInteraction?.sendCurrentMessage(true) self?.dismiss(cancel: false) + }, schedule: { [weak self] in + self?.controllerInteraction?.scheduleCurrentMessage() + self?.dismiss(cancel: false) }, cancel: { [weak self] in self?.dismiss(cancel: true) }) diff --git a/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift b/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift index 0a2be8b93e..81a6f5a00d 100644 --- a/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatSendMessageActionSheetControllerNode.swift @@ -11,8 +11,25 @@ import AccountContext private let leftInset: CGFloat = 16.0 private let rightInset: CGFloat = 46.0 +private enum ChatSendMessageActionIcon { + case sendWithoutSound + case schedule + + func image(theme: PresentationTheme) -> UIImage? { + let imageName: String + switch self { + case .sendWithoutSound: + imageName = "Chat/Input/Menu/SilentIcon" + case .schedule: + imageName = "Chat/Input/Menu/ScheduleIcon" + } + return generateTintedImage(image: UIImage(bundleImageName: imageName), color: theme.actionSheet.primaryTextColor) + } +} + private final class ActionSheetItemNode: ASDisplayNode { private let title: String + private let icon: ChatSendMessageActionIcon private let action: () -> Void private let separatorNode: ASDisplayNode @@ -23,8 +40,9 @@ private final class ActionSheetItemNode: ASDisplayNode { private var maxWidth: CGFloat? - init(theme: PresentationTheme, title: String, action: @escaping () -> Void) { + init(theme: PresentationTheme, title: String, icon: ChatSendMessageActionIcon, hasSeparator: Bool, action: @escaping () -> Void) { self.title = title + self.icon = icon self.action = action self.separatorNode = ASDisplayNode() @@ -41,7 +59,7 @@ private final class ActionSheetItemNode: ASDisplayNode { self.titleNode.attributedText = NSAttributedString(string: title, font: Font.regular(17.0), textColor: theme.actionSheet.primaryTextColor) self.iconNode = ASImageNode() - self.iconNode.image = generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Menu/SilentIcon"), color: theme.actionSheet.primaryTextColor) + self.iconNode.image = icon.image(theme: theme) self.iconNode.contentMode = .center super.init() @@ -50,6 +68,9 @@ private final class ActionSheetItemNode: ASDisplayNode { self.addSubnode(self.titleNode) self.addSubnode(self.iconNode) self.addSubnode(self.buttonNode) + if hasSeparator { + self.addSubnode(self.separatorNode) + } self.buttonNode.addTarget(self, action: #selector(self.buttonPressed), forControlEvents: .touchUpInside) self.buttonNode.highligthedChanged = { [weak self] highlighted in @@ -69,7 +90,7 @@ private final class ActionSheetItemNode: ASDisplayNode { self.separatorNode.backgroundColor = theme.actionSheet.opaqueItemSeparatorColor self.highlightedBackgroundNode.backgroundColor = theme.actionSheet.opaqueItemHighlightedBackgroundColor self.titleNode.attributedText = NSAttributedString(string: self.title, font: Font.regular(17.0), textColor: theme.actionSheet.primaryTextColor) - self.iconNode.image = generateTintedImage(image: UIImage(bundleImageName: "Chat/Input/Menu/SilentIcon"), color: theme.actionSheet.primaryTextColor) + self.iconNode.image = self.icon.image(theme: theme) if let maxWidth = self.maxWidth { let _ = self.titleNode.updateLayout(CGSize(width: maxWidth - leftInset - rightInset, height: .greatestFiniteMagnitude)) @@ -130,7 +151,7 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, private var validLayout: ContainerViewLayout? - init(context: AccountContext, sendButtonFrame: CGRect, textInputNode: EditableTextNode, forwardedCount: Int?, send: (() -> Void)?, sendSilently: (() -> Void)?, cancel: (() -> Void)?) { + init(context: AccountContext, sendButtonFrame: CGRect, textInputNode: EditableTextNode, forwardedCount: Int?, send: (() -> Void)?, sendSilently: (() -> Void)?, schedule: (() -> Void)?, cancel: (() -> Void)?) { self.context = context self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.sendButtonFrame = sendButtonFrame @@ -188,9 +209,12 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, self.contentContainerNode.clipsToBounds = true var contentNodes: [ActionSheetItemNode] = [] - contentNodes.append(ActionSheetItemNode(theme: self.presentationData.theme, title: self.presentationData.strings.Conversation_SendMessage_SendSilently, action: { + contentNodes.append(ActionSheetItemNode(theme: self.presentationData.theme, title: self.presentationData.strings.Conversation_SendMessage_SendSilently, icon: .sendWithoutSound, hasSeparator: true, action: { sendSilently?() })) + contentNodes.append(ActionSheetItemNode(theme: self.presentationData.theme, title: self.presentationData.strings.Conversation_SendMessage_ScheduleMessage, icon: .schedule, hasSeparator: false, action: { + schedule?() + })) self.contentNodes = contentNodes super.init() @@ -218,8 +242,8 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, } self.messageBackgroundNode.contentMode = .scaleToFill - let graphics = PresentationResourcesChat.principalGraphics(mediaBox: self.context.account.postbox.mediaBox, knockoutWallpaper: self.context.sharedContext.immediateExperimentalUISettings.knockoutWallpaper, theme: self.presentationData.theme, wallpaper: self.presentationData.chatWallpaper) - self.messageBackgroundNode.image = graphics.chatMessageBackgroundOutgoingImage + let outgoing: PresentationThemeBubbleColorComponents = self.presentationData.chatWallpaper.isEmpty ? self.presentationData.theme.chat.message.outgoing.bubble.withoutWallpaper : self.presentationData.theme.chat.message.outgoing.bubble.withWallpaper + self.messageBackgroundNode.image = messageBubbleImage(incoming: false, fillColor: outgoing.fill, strokeColor: outgoing.stroke, neighbors: .none, theme: self.presentationData.theme.chat, wallpaper: self.presentationData.chatWallpaper, knockout: false) self.view.addSubview(self.effectView) self.addSubnode(self.dimNode) @@ -264,6 +288,9 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, } func updatePresentationData(_ presentationData: PresentationData) { + guard presentationData.theme !== self.presentationData.theme else { + return + } self.presentationData = presentationData if self.presentationData.theme.chatList.searchBarKeyboardColor == .dark { @@ -288,8 +315,8 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, self.toMessageTextNode.attributedText = toAttributedText } - let graphics = PresentationResourcesChat.principalGraphics(mediaBox: self.context.account.postbox.mediaBox, knockoutWallpaper: self.context.sharedContext.immediateExperimentalUISettings.knockoutWallpaper, theme: self.presentationData.theme, wallpaper: self.presentationData.chatWallpaper) - self.messageBackgroundNode.image = graphics.chatMessageBackgroundOutgoingImage + let outgoing: PresentationThemeBubbleColorComponents = self.presentationData.chatWallpaper.isEmpty ? self.presentationData.theme.chat.message.outgoing.bubble.withoutWallpaper : self.presentationData.theme.chat.message.outgoing.bubble.withWallpaper + self.messageBackgroundNode.image = messageBubbleImage(incoming: false, fillColor: outgoing.fill, strokeColor: outgoing.stroke, neighbors: .none, theme: self.presentationData.theme.chat, wallpaper: self.presentationData.chatWallpaper, knockout: false) for node in self.contentNodes { node.updateTheme(presentationData.theme) @@ -355,7 +382,7 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, let inputHeight = layout.inputHeight ?? 0.0 var clipDelta = delta if inputHeight.isZero { - clipDelta -= 60.0 + clipDelta -= self.contentContainerNode.frame.height + 16.0 } self.messageClipNode.layer.animateBounds(from: fromFrame, to: self.messageClipNode.bounds, duration: duration, timingFunction: kCAMediaTimingFunctionSpring) @@ -449,7 +476,7 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, let inputHeight = layout.inputHeight ?? 0.0 var clipDelta = delta if inputHeight.isZero { - clipDelta -= 60.0 + clipDelta -= self.contentContainerNode.frame.height + 16.0 } if cancel { @@ -501,6 +528,8 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, contentSize.height += height } + let menuHeightWithInset = contentSize.height + 16.0 + let insets = layout.insets(options: [.statusBar, .input]) let inputHeight = layout.inputHeight ?? 0.0 @@ -508,7 +537,7 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, var contentOrigin = CGPoint(x: layout.size.width - sideInset - contentSize.width - layout.safeInsets.right, y: layout.size.height - 6.0 - insets.bottom - contentSize.height) if inputHeight > 0.0 { - contentOrigin.y += 60.0 + contentOrigin.y += menuHeightWithInset } contentOrigin.y = min(contentOrigin.y + contentOffset, layout.size.height - 6.0 - layout.intrinsicInsets.bottom - contentSize.height) @@ -523,7 +552,7 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, let initialSendButtonFrame = self.sendButtonFrame var sendButtonFrame = CGRect(origin: CGPoint(x: layout.size.width - initialSendButtonFrame.width + 1.0 - UIScreenPixel - layout.safeInsets.right, y: layout.size.height - insets.bottom - initialSendButtonFrame.height), size: initialSendButtonFrame.size) if inputHeight.isZero { - sendButtonFrame.origin.y -= 60.0 + sendButtonFrame.origin.y -= menuHeightWithInset } sendButtonFrame.origin.y = min(sendButtonFrame.origin.y + contentOffset, layout.size.height - layout.intrinsicInsets.bottom - initialSendButtonFrame.height) transition.updateFrame(node: self.sendButtonNode, frame: sendButtonFrame) @@ -533,7 +562,7 @@ final class ChatSendMessageActionSheetControllerNode: ViewControllerTracingNode, messageFrame.origin.x -= 13.0 messageFrame.origin.y = layout.size.height - messageFrame.origin.y - messageFrame.size.height - 1.0 if inputHeight.isZero { - messageFrame.origin.y += 60.0 + messageFrame.origin.y += menuHeightWithInset } if self.textInputNode.textView.attributedText.string.isEmpty { diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift index baf7a8546c..6b08831f42 100644 --- a/submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift +++ b/submodules/TelegramUI/TelegramUI/ChatTextInputAccessoryItem.swift @@ -7,4 +7,5 @@ enum ChatTextInputAccessoryItem: Equatable { case commands case silentPost(Bool) case messageAutoremoveTimeout(Int32?) + case scheduledMessages } diff --git a/submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift b/submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift index f6c727c1c7..916ac17ee7 100644 --- a/submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatTextInputPanelNode.swift @@ -111,12 +111,14 @@ private final class AccessoryItemIconButton: HighlightTrackingButton { } else { return (PresentationResourcesChat.chatInputTextFieldTimerImage(theme), nil, 1.0, UIEdgeInsets(top: 0.0, left: 0.0, bottom: 1.0, right: 0.0)) } + case .scheduledMessages: + return (PresentationResourcesChat.chatInputTextFieldScheduleImage(theme), nil, 1.0, UIEdgeInsets()) } } static func calculateWidth(item: ChatTextInputAccessoryItem, image: UIImage?, text: String?, strings: PresentationStrings) -> CGFloat { switch item { - case .keyboard, .stickers, .inputButtons, .silentPost, .commands: + case .keyboard, .stickers, .inputButtons, .silentPost, .commands, .scheduledMessages: return (image?.size.width ?? 0.0) + CGFloat(8.0) case let .messageAutoremoveTimeout(timeout): var imageWidth = (image?.size.width ?? 0.0) + CGFloat(8.0) @@ -796,7 +798,11 @@ class ChatTextInputPanelNode: ChatInputPanelNode, ASEditableTextNodeDelegate { if self.actionButtons.sendButtonHasApplyIcon { self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelApplyButtonImage(interfaceState.theme), for: []) } else { - self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelSendButtonImage(interfaceState.theme), for: []) + if interfaceState.isScheduledMessages { + self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelScheduleButtonImage(interfaceState.theme), for: []) + } else { + self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelSendButtonImage(interfaceState.theme), for: []) + } } } } @@ -1411,7 +1417,11 @@ class ChatTextInputPanelNode: ChatInputPanelNode, ASEditableTextNodeDelegate { if self.actionButtons.sendButtonHasApplyIcon { self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelApplyButtonImage(interfaceState.theme), for: []) } else { - self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelSendButtonImage(interfaceState.theme), for: []) + if interfaceState.isScheduledMessages { + self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelScheduleButtonImage(interfaceState.theme), for: []) + } else { + self.actionButtons.sendButton.setImage(PresentationResourcesChat.chatInputPanelSendButtonImage(interfaceState.theme), for: []) + } } } } @@ -1702,6 +1712,8 @@ class ChatTextInputPanelNode: ChatInputPanelNode, ASEditableTextNodeDelegate { self.interfaceInteraction?.toggleSilentPost() case .messageAutoremoveTimeout: self.interfaceInteraction?.setupMessageAutoremoveTimeout() + case .scheduledMessages: + self.interfaceInteraction?.openScheduledMessages() } break } diff --git a/submodules/TelegramUI/TelegramUI/ChatTitleView.swift b/submodules/TelegramUI/TelegramUI/ChatTitleView.swift index 73046b280e..b7940177b8 100644 --- a/submodules/TelegramUI/TelegramUI/ChatTitleView.swift +++ b/submodules/TelegramUI/TelegramUI/ChatTitleView.swift @@ -13,7 +13,7 @@ import TelegramStringFormatting import PeerPresenceStatusManager enum ChatTitleContent { - case peer(peerView: PeerView, onlineMemberCount: Int32?) + case peer(peerView: PeerView, onlineMemberCount: Int32?, isScheduledMessages: Bool) case group([Peer]) } @@ -177,26 +177,36 @@ final class ChatTitleView: UIView, NavigationBarTitleView { var titleLeftIcon: ChatTitleIcon = .none var titleRightIcon: ChatTitleIcon = .none var titleScamIcon = false + var isEnabled = true switch titleContent { - case let .peer(peerView, _): - 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) + case let .peer(peerView, _, isScheduledMessages): + if isScheduledMessages { + if let peer = peerViewMainPeer(peerView), peerView.peerId == self.account.peerId { + string = NSAttributedString(string: self.strings.ScheduledMessages_RemindersTitle, font: Font.medium(17.0), textColor: self.theme.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) - } 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: self.strings.ScheduledMessages_Title, font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) } - titleScamIcon = peer.isScam - } - if peerView.peerId.namespace == Namespaces.Peer.SecretChat { - titleLeftIcon = .lock - } - if let notificationSettings = peerView.notificationSettings as? TelegramPeerNotificationSettings { - if case let .muted(until) = notificationSettings.muteState, until >= Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970) { - titleRightIcon = .mute + 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) + } 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) + } else { + string = NSAttributedString(string: peer.displayTitle(strings: self.strings, displayOrder: self.nameDisplayOrder), font: Font.medium(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + } + } + titleScamIcon = peer.isScam + } + if peerView.peerId.namespace == Namespaces.Peer.SecretChat { + titleLeftIcon = .lock + } + if let notificationSettings = peerView.notificationSettings as? TelegramPeerNotificationSettings { + if case let .muted(until) = notificationSettings.muteState, until >= Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970) { + titleRightIcon = .mute + } } } case .group: @@ -235,7 +245,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } self.setNeedsLayout() } - + self.isUserInteractionEnabled = isEnabled self.updateStatus() } } @@ -245,7 +255,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { var inputActivitiesAllowed = true if let titleContent = self.titleContent { switch titleContent { - case let .peer(peerView, _): + case let .peer(peerView, _, _): if let peer = peerViewMainPeer(peerView) { if peer.id == self.account.peerId { inputActivitiesAllowed = false @@ -316,10 +326,10 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } else { if let titleContent = self.titleContent { switch titleContent { - case let .peer(peerView, onlineMemberCount): + case let .peer(peerView, onlineMemberCount, isScheduledMessages): if let peer = peerViewMainPeer(peerView) { let servicePeer = isServicePeer(peer) - if peer.id == self.account.peerId { + if peer.id == self.account.peerId || isScheduledMessages { let string = NSAttributedString(string: "", font: Font.regular(13.0), textColor: self.theme.rootController.navigationBar.secondaryTextColor) state = .info(string, .generic) } else if let user = peer as? TelegramUser { @@ -537,7 +547,6 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } func updateLayout(size: CGSize, clearBounds: CGRect, transition: ContainedViewLayoutTransition) { - var clearBounds = clearBounds self.validLayout = (size, clearBounds) let transition: ContainedViewLayoutTransition = .immediate diff --git a/submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift b/submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift index 4d78f52459..a0c2bc6fb7 100644 --- a/submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift +++ b/submodules/TelegramUI/TelegramUI/ChatUnreadItem.swift @@ -17,7 +17,7 @@ class ChatUnreadItem: ListViewItem { init(index: MessageIndex, presentationData: ChatPresentationData, context: AccountContext) { self.index = index self.presentationData = presentationData - self.header = ChatMessageDateHeader(timestamp: index.timestamp, presentationData: presentationData, context: context) + self.header = ChatMessageDateHeader(timestamp: index.timestamp, scheduled: false, presentationData: presentationData, context: context) } func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { diff --git a/submodules/TelegramUI/TelegramUI/EmojiUtils.swift b/submodules/TelegramUI/TelegramUI/EmojiUtils.swift index 37388e101e..32c3535f45 100644 --- a/submodules/TelegramUI/TelegramUI/EmojiUtils.swift +++ b/submodules/TelegramUI/TelegramUI/EmojiUtils.swift @@ -129,7 +129,7 @@ extension String { return string } - var basicEmoji: String { + var basicEmoji: (String, String?) { let fitzCodes: [UInt32] = [ 0x1f3fb, 0x1f3fc, @@ -139,13 +139,18 @@ extension String { ] var string = "" + var fitzModifier: String? for scalar in self.unicodeScalars { if fitzCodes.contains(scalar.value) { + fitzModifier = String(scalar) continue } string.unicodeScalars.append(scalar) + if scalar.value == 0x2764, self.unicodeScalars.count > 1, self.emojis.count == 1 { + break + } } - return string + return (string, fitzModifier) } var trimmedEmoji: String { diff --git a/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift b/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift index 84ec4e6c29..0c1cb692a3 100644 --- a/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift +++ b/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift @@ -113,19 +113,7 @@ public func fetchCachedResourceRepresentation(account: Account, resource: MediaR } else if let representation = representation as? CachedEmojiRepresentation { return fetchEmojiRepresentation(account: account, resource: resource, representation: representation) } else if let representation = representation as? CachedAnimatedStickerRepresentation { - let data: Signal -// if let resource = resource as? LocalBundleResource { -// data = Signal { subscriber in -// if let path = frameworkBundle.path(forResource: resource.name, ofType: resource.ext), let data = try? Data(contentsOf: URL(fileURLWithPath: path), options: [.mappedRead]) { -// subscriber.putNext(MediaResourceData(path: path, offset: 0, size: data.count, complete: true)) -// subscriber.putCompletion() -// } -// return EmptyDisposable -// } -// } else { - data = account.postbox.mediaBox.resourceData(resource, option: .complete(waitUntilFetchStatus: false)) -// } - return data + return account.postbox.mediaBox.resourceData(resource, option: .complete(waitUntilFetchStatus: false)) |> mapToSignal { data -> Signal in if !data.complete { return .complete() @@ -909,7 +897,7 @@ private func fetchEmojiRepresentation(account: Account, resource: MediaResource, private func fetchAnimatedStickerFirstFrameRepresentation(account: Account, resource: MediaResource, resourceData: MediaResourceData, representation: CachedAnimatedStickerFirstFrameRepresentation) -> Signal { return Signal({ subscriber in if let data = try? Data(contentsOf: URL(fileURLWithPath: resourceData.path), options: [.mappedIfSafe]) { - return fetchCompressedLottieFirstFrameAJpeg(data: data, size: CGSize(width: CGFloat(representation.width), height: CGFloat(representation.height)), cacheKey: "\(resource.id.uniqueId)-\(representation.uniqueId)").start(next: { file in + return fetchCompressedLottieFirstFrameAJpeg(data: data, size: CGSize(width: CGFloat(representation.width), height: CGFloat(representation.height)), fitzModifier: representation.fitzModifier, cacheKey: "\(resource.id.uniqueId)-\(representation.uniqueId)").start(next: { file in subscriber.putNext(.tempFile(file)) subscriber.putCompletion() }) @@ -917,14 +905,14 @@ private func fetchAnimatedStickerFirstFrameRepresentation(account: Account, reso return EmptyDisposable } }) - |> runOn(Queue.concurrentDefaultQueue()) + |> runOn(Queue.concurrentDefaultQueue()) } private func fetchAnimatedStickerRepresentation(account: Account, resource: MediaResource, resourceData: MediaResourceData, representation: CachedAnimatedStickerRepresentation) -> Signal { return Signal({ subscriber in if let data = try? Data(contentsOf: URL(fileURLWithPath: resourceData.path), options: [.mappedIfSafe]) { if #available(iOS 9.0, *) { - return experimentalConvertCompressedLottieToCombinedMp4(data: data, size: CGSize(width: CGFloat(representation.width), height: CGFloat(representation.height)), cacheKey: "\(resource.id.uniqueId)-\(representation.uniqueId)").start(next: { path in + return experimentalConvertCompressedLottieToCombinedMp4(data: data, size: CGSize(width: CGFloat(representation.width), height: CGFloat(representation.height)), fitzModifier: representation.fitzModifier, cacheKey: "\(resource.id.uniqueId)-\(representation.uniqueId)").start(next: { path in subscriber.putNext(.temporaryPath(path)) subscriber.putCompletion() }) diff --git a/submodules/TelegramUI/TelegramUI/GalleryController.swift b/submodules/TelegramUI/TelegramUI/GalleryController.swift index b30a9b5866..cab874c13a 100644 --- a/submodules/TelegramUI/TelegramUI/GalleryController.swift +++ b/submodules/TelegramUI/TelegramUI/GalleryController.swift @@ -365,7 +365,7 @@ class GalleryController: ViewController { switch source { case .peerMessagesAtId: if let tags = tagsForMessage(message!) { - let view = context.account.postbox.aroundMessageHistoryViewForLocation(.peer(message!.id.peerId), anchor: .index(message!.index), count: 50, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tags, orderStatistics: [.combinedLocation]) + let view = context.account.postbox.aroundMessageHistoryViewForLocation(.peer(message!.id.peerId), anchor: .index(message!.index), count: 50, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tags, excludeNamespaces: [Namespaces.Message.CloudScheduled], orderStatistics: [.combinedLocation]) return view |> mapToSignal { (view, _, _) -> Signal in diff --git a/submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift b/submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift index 3e3012006a..d92a6aa5a6 100644 --- a/submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift +++ b/submodules/TelegramUI/TelegramUI/GifPaneSearchContentNode.swift @@ -235,7 +235,7 @@ final class GifPaneSearchContentNode: ASDisplayNode & PaneSearchContentNode { self.addSubnode(multiplexedNode) multiplexedNode.fileSelected = { [weak self] fileReference, sourceNode, sourceRect in - self?.controllerInteraction.sendGif(fileReference, sourceNode, sourceRect) + let _ = self?.controllerInteraction.sendGif(fileReference, sourceNode, sourceRect) } multiplexedNode.didScroll = { [weak self] offset, height in diff --git a/submodules/TelegramUI/TelegramUI/GroupInfoController.swift b/submodules/TelegramUI/TelegramUI/GroupInfoController.swift index 20b969b0c7..4b02b84877 100644 --- a/submodules/TelegramUI/TelegramUI/GroupInfoController.swift +++ b/submodules/TelegramUI/TelegramUI/GroupInfoController.swift @@ -2293,7 +2293,7 @@ public func groupInfoController(context: AccountContext, peerId originalPeerId: let infoController = groupInfoController(context: context, peerId: upgradedPeerId, membersLoaded: { f() }) - let chatController = ChatController(context: context, chatLocation: .peer(upgradedPeerId), messageId: nil, botStart: nil, mode: .standard(previewing: false)) + let chatController = ChatController(context: context, chatLocation: .peer(upgradedPeerId), mode: .standard(previewing: false)) var viewControllers: [UIViewController] = [] if let first = navigationController.viewControllers.first { viewControllers.append(first) diff --git a/submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift b/submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift index 3f1869e979..aedfdb11bf 100644 --- a/submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift +++ b/submodules/TelegramUI/TelegramUI/HashtagChatInputPanelItem.swift @@ -119,7 +119,7 @@ final class HashtagChatInputPanelItemNode: ListViewItemNode { let leftInset: CGFloat = 15.0 + params.leftInset let rightInset: CGFloat = 10.0 + params.rightInset - let (textLayout, textApply) = makeTextLayout(TextNodeLayoutArguments(attributedString: NSAttributedString(string: "#\(item.text)", font: textFont, textColor: item.theme.list.itemPrimaryTextColor), backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - rightInset, height: 100.0), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let (textLayout, textApply) = makeTextLayout(TextNodeLayoutArguments(attributedString: NSAttributedString(string: "#\(item.text)", font: textFont, textColor: item.theme.list.itemPrimaryTextColor), backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: baseWidth, height: 100.0), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) let nodeLayout = ListViewItemNodeLayout(contentSize: CGSize(width: params.width, height: HashtagChatInputPanelItemNode.itemHeight), insets: UIEdgeInsets()) diff --git a/submodules/TelegramUI/TelegramUI/HashtagSearchControllerNode.swift b/submodules/TelegramUI/TelegramUI/HashtagSearchControllerNode.swift index 2ff9dc7e45..69cdd9d042 100644 --- a/submodules/TelegramUI/TelegramUI/HashtagSearchControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/HashtagSearchControllerNode.swift @@ -39,7 +39,7 @@ final class HashtagSearchControllerNode: ASDisplayNode { self.segmentedControl.selectedSegmentIndex = 0 if let peer = peer { - self.chatController = ChatController(context: context, chatLocation: .peer(peer.id), messageId: nil, botStart: nil, mode: .inline) + self.chatController = ChatController(context: context, chatLocation: .peer(peer.id), botStart: nil, mode: .inline) } else { self.chatController = nil } diff --git a/submodules/TelegramUI/TelegramUI/InstalledStickerPacksController.swift b/submodules/TelegramUI/TelegramUI/InstalledStickerPacksController.swift index 69ac4a5c2f..2a3e24e09a 100644 --- a/submodules/TelegramUI/TelegramUI/InstalledStickerPacksController.swift +++ b/submodules/TelegramUI/TelegramUI/InstalledStickerPacksController.swift @@ -44,6 +44,7 @@ private enum InstalledStickerPacksSection: Int32 { public enum InstalledStickerPacksEntryTag: ItemListItemTag { case suggestOptions + case loopAnimatedStickers public func isEqual(to other: ItemListItemTag) -> Bool { if let other = other as? InstalledStickerPacksEntryTag, self == other { diff --git a/submodules/TelegramUI/TelegramUI/InstantPageAudioNode.swift b/submodules/TelegramUI/TelegramUI/InstantPageAudioNode.swift index 06a061f61c..47257e0f98 100644 --- a/submodules/TelegramUI/TelegramUI/InstantPageAudioNode.swift +++ b/submodules/TelegramUI/TelegramUI/InstantPageAudioNode.swift @@ -227,12 +227,8 @@ final class InstantPageAudioNode: ASDisplayNode, InstantPageNode { self.titleNode.attributedText = titleString(media: self.media, theme: theme) - var backgroundAlpha: CGFloat = 0.1 var brightness: CGFloat = 0.0 theme.textCategories.paragraph.color.getHue(nil, saturation: nil, brightness: &brightness, alpha: nil) - if brightness > 0.5 { - backgroundAlpha = 0.4 - } self.setNeedsLayout() } diff --git a/submodules/TelegramUI/TelegramUI/InstantPageMediaPlaylist.swift b/submodules/TelegramUI/TelegramUI/InstantPageMediaPlaylist.swift index c96a674d9c..c8837589a1 100644 --- a/submodules/TelegramUI/TelegramUI/InstantPageMediaPlaylist.swift +++ b/submodules/TelegramUI/TelegramUI/InstantPageMediaPlaylist.swift @@ -169,7 +169,7 @@ final class InstantPageMediaPlaylist: SharedMediaPlaylist { switch action { case .next, .previous: - if let currentItem = self.currentItem, let currentIndex = self.items.index(where: { $0.index == currentItem.index }) { + if let currentItem = self.currentItem, let currentIndex = self.items.firstIndex(where: { $0.index == currentItem.index }) { let selectedIndex: Int? switch self.order { case .regular: diff --git a/submodules/TelegramUI/TelegramUI/InstantPageReferenceControllerNode.swift b/submodules/TelegramUI/TelegramUI/InstantPageReferenceControllerNode.swift index e8b7dd9917..e0902973ce 100644 --- a/submodules/TelegramUI/TelegramUI/InstantPageReferenceControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/InstantPageReferenceControllerNode.swift @@ -66,7 +66,7 @@ class InstantPageReferenceControllerNode: ViewControllerTracingNode, UIScrollVie self.contentBackgroundNode.image = roundedBackground self.titleNode = ASTextNode() - self.titleNode.attributedText = NSAttributedString(string: self.presentationData.strings.InstantPage_Reference, font: Font.medium(17.0), textColor: self.theme.panelSecondaryColor) + self.titleNode.attributedText = NSAttributedString(string: self.presentationData.strings.InstantPage_Reference, font: Font.bold(17.0), textColor: self.theme.panelSecondaryColor) self.separatorNode = ASDisplayNode() self.separatorNode.backgroundColor = self.theme.controlColor diff --git a/submodules/TelegramUI/TelegramUI/LegacyFileImport.swift b/submodules/TelegramUI/TelegramUI/LegacyFileImport.swift index ebc8e6d67c..416f65365a 100644 --- a/submodules/TelegramUI/TelegramUI/LegacyFileImport.swift +++ b/submodules/TelegramUI/TelegramUI/LegacyFileImport.swift @@ -2,7 +2,6 @@ import Foundation import TelegramCore import SwiftSignalKit import Postbox -import TelegramUI import LegacyComponents diff --git a/submodules/TelegramUI/TelegramUI/NavigateToChatController.swift b/submodules/TelegramUI/TelegramUI/NavigateToChatController.swift index 12a873d391..931c63f992 100644 --- a/submodules/TelegramUI/TelegramUI/NavigateToChatController.swift +++ b/submodules/TelegramUI/TelegramUI/NavigateToChatController.swift @@ -60,7 +60,7 @@ public func navigateToChatController(navigationController: NavigationController, } } } else { - controller = ChatController(context: context, chatLocation: chatLocation, messageId: messageId, botStart: botStart) + controller = ChatController(context: context, chatLocation: chatLocation, subject: messageId.flatMap({ .message($0) }), botStart: botStart) } controller.purposefulAction = purposefulAction let resolvedKeepStack: Bool diff --git a/submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift b/submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift index 002161aa5c..fe63674bab 100644 --- a/submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift +++ b/submodules/TelegramUI/TelegramUI/OpenResolvedUrl.swift @@ -169,7 +169,7 @@ func openResolvedUrl(_ resolvedUrl: ResolvedUrl, context: AccountContext, urlCon }) }) |> deliverOnMainQueue).start(completed: { - navigationController?.pushViewController(ChatController(context: context, chatLocation: .peer(peerId), messageId: nil)) + navigationController?.pushViewController(ChatController(context: context, chatLocation: .peer(peerId))) }) } } diff --git a/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift b/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift index 9cf8307f7d..366d985223 100644 --- a/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift @@ -38,7 +38,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu private var presentationDataDisposable: Disposable? private let replacementHistoryNodeReadyDisposable = MetaDisposable() - init(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, requestDismiss: @escaping () -> Void, requestShare: @escaping (MessageId) -> Void) { + init(context: AccountContext, peerId: PeerId, type: MediaManagerPlayerType, initialMessageId: MessageId, initialOrder: MusicPlaybackSettingsOrder, requestDismiss: @escaping () -> Void, requestShare: @escaping (MessageId) -> Void) { self.context = context self.peerId = peerId self.presentationData = context.sharedContext.currentPresentationData.with { $0 } @@ -103,6 +103,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu }, openAppStorePage: { }, displayMessageTooltip: { _, _, _, _ in }, seekToTimecode: { _, _, _ in + }, scheduleCurrentMessage: { }, requestMessageUpdate: { _ in }, cancelInteractiveKeyboardGestures: { }, automaticMediaDownloadSettings: MediaAutoDownloadSettings.defaultSettings, pollActionState: ChatInterfacePollActionState(), stickerSettings: ChatInterfaceStickerSettings(loopAnimatedStickers: false)) @@ -131,7 +132,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu tagMask = .voiceOrInstantVideo } - self.historyNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: tagMask, messageId: initialMessageId, controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: currentIsReversed)) + self.historyNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: tagMask, subject: .message(initialMessageId), controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: currentIsReversed)) super.init() @@ -450,7 +451,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu tagMask = .voiceOrInstantVideo } - let historyNode = ChatHistoryListNode(context: self.context, chatLocation: .peer(self.peerId), tagMask: tagMask, messageId: messageId, controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: self.currentIsReversed)) + let historyNode = ChatHistoryListNode(context: self.context, chatLocation: .peer(self.peerId), tagMask: tagMask, subject: .message(messageId), controllerInteraction: self.controllerInteraction, selectedMessages: .single(nil), mode: .list(search: false, reversed: self.currentIsReversed)) historyNode.preloadPages = true historyNode.stackFromBottom = true historyNode.updateFloatingHeaderOffset = { [weak self] offset, _ in diff --git a/submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift b/submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift index 394de12832..fa98dde0af 100644 --- a/submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift +++ b/submodules/TelegramUI/TelegramUI/OverlayPlayerControlsNode.swift @@ -248,7 +248,6 @@ final class OverlayPlayerControlsNode: ASDisplayNode { displayData = value.item.displayData - let baseColor = strongSelf.theme.list.itemSecondaryTextColor if value.order != strongSelf.currentOrder { strongSelf.updateOrder?(value.order) strongSelf.currentOrder = value.order diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift index 3a8078a77f..b479294f47 100644 --- a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift +++ b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionController.swift @@ -175,7 +175,7 @@ public class PeerMediaCollectionController: TelegramBaseController { } }*/ } else { - (strongSelf.navigationController as? NavigationController)?.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(id.peerId), messageId: id)) + (strongSelf.navigationController as? NavigationController)?.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(id.peerId), subject: .message(id))) } } }, clickThroughMessage: { [weak self] in @@ -276,6 +276,7 @@ public class PeerMediaCollectionController: TelegramBaseController { }, openAppStorePage: { }, displayMessageTooltip: { _, _, _, _ in }, seekToTimecode: { _, _, _ in + }, scheduleCurrentMessage: { }, requestMessageUpdate: { _ in }, cancelInteractiveKeyboardGestures: { }, automaticMediaDownloadSettings: MediaAutoDownloadSettings.defaultSettings, @@ -385,6 +386,7 @@ public class PeerMediaCollectionController: TelegramBaseController { }, reportPeerIrrelevantGeoLocation: { }, displaySlowmodeTooltip: { _, _ in }, displaySendMessageOptions: { + }, openScheduledMessages: { }, statuses: nil) self.updateInterfaceState(animated: false, { return $0 }) diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift index fbdb4b4385..4b2a3167c4 100644 --- a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift @@ -25,7 +25,7 @@ private func historyNodeImplForMode(_ mode: PeerMediaCollectionMode, context: Ac } return node case .file: - let node = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: .file, messageId: messageId, controllerInteraction: controllerInteraction, selectedMessages: selectedMessages, mode: .list(search: true, reversed: false)) + let node = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: .file, subject: messageId.flatMap { .message($0) }, controllerInteraction: controllerInteraction, selectedMessages: selectedMessages, mode: .list(search: true, reversed: false)) node.verticalScrollIndicatorColor = theme.list.scrollIndicatorColor node.didEndScrolling = { [weak node] in guard let node = node else { @@ -36,7 +36,7 @@ private func historyNodeImplForMode(_ mode: PeerMediaCollectionMode, context: Ac node.preloadPages = true return node case .music: - let node = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: .music, messageId: messageId, controllerInteraction: controllerInteraction, selectedMessages: selectedMessages, mode: .list(search: true, reversed: false)) + let node = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: .music, subject: messageId.flatMap { .message($0) }, controllerInteraction: controllerInteraction, selectedMessages: selectedMessages, mode: .list(search: true, reversed: false)) node.verticalScrollIndicatorColor = theme.list.scrollIndicatorColor node.didEndScrolling = { [weak node] in guard let node = node else { @@ -47,7 +47,7 @@ private func historyNodeImplForMode(_ mode: PeerMediaCollectionMode, context: Ac node.preloadPages = true return node case .webpage: - let node = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: .webPage, messageId: messageId, controllerInteraction: controllerInteraction, selectedMessages: selectedMessages, mode: .list(search: true, reversed: false)) + let node = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: .webPage, subject: messageId.flatMap { .message($0) }, controllerInteraction: controllerInteraction, selectedMessages: selectedMessages, mode: .list(search: true, reversed: false)) node.verticalScrollIndicatorColor = theme.list.scrollIndicatorColor node.didEndScrolling = { [weak node] in guard let node = node else { @@ -151,7 +151,7 @@ class PeerMediaCollectionControllerNode: ASDisplayNode { self.historyEmptyNode = PeerMediaCollectionEmptyNode(mode: self.mediaCollectionInterfaceState.mode, theme: self.presentationData.theme, strings: self.presentationData.strings) self.historyEmptyNode.isHidden = true - self.chatPresentationInterfaceState = ChatPresentationInterfaceState(chatWallpaper: self.presentationData.chatWallpaper, theme: self.presentationData.theme, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameDisplayOrder: self.presentationData.nameDisplayOrder, limitsConfiguration: .defaultValue, fontSize: self.presentationData.fontSize, accountPeerId: context.account.peerId, mode: .standard(previewing: false), chatLocation: .peer(self.peerId)) + self.chatPresentationInterfaceState = ChatPresentationInterfaceState(chatWallpaper: self.presentationData.chatWallpaper, theme: self.presentationData.theme, strings: self.presentationData.strings, dateTimeFormat: self.presentationData.dateTimeFormat, nameDisplayOrder: self.presentationData.nameDisplayOrder, limitsConfiguration: .defaultValue, fontSize: self.presentationData.fontSize, accountPeerId: context.account.peerId, mode: .standard(previewing: false), chatLocation: .peer(self.peerId), isScheduledMessages: false) super.init() diff --git a/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift b/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift index 62fa04f0b1..ae3ed49fe8 100644 --- a/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift +++ b/submodules/TelegramUI/TelegramUI/PeerMessagesMediaPlaylist.swift @@ -485,7 +485,7 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { guard let message = message else { return .single(nil) } - return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(message.index), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, orderStatistics: []) + return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(message.index), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, excludeNamespaces: [Namespaces.Message.CloudScheduled], orderStatistics: []) |> mapToSignal { view -> Signal<(Message, [Message])?, NoError> in if let (message, aroundMessages, _) = navigatedMessageFromView(view.0, anchorIndex: message.index, position: .exact) { return .single((message, aroundMessages)) @@ -559,7 +559,7 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { } let historySignal = inputIndex |> mapToSignal { inputIndex -> Signal<(Message, [Message])?, NoError> in - return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(inputIndex), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, orderStatistics: []) + return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: .index(inputIndex), count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, excludeNamespaces: [Namespaces.Message.CloudScheduled], orderStatistics: []) |> mapToSignal { view -> Signal<(Message, [Message])?, NoError> in let position: NavigatedMessageFromViewPosition switch navigation { @@ -589,7 +589,7 @@ final class PeerMessagesMediaPlaylist: SharedMediaPlaylist { } else { viewIndex = .lowerBound } - return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: viewIndex, count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, orderStatistics: []) + return self.postbox.aroundMessageHistoryViewForLocation(.peer(peerId), anchor: viewIndex, count: 10, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, excludeNamespaces: [Namespaces.Message.CloudScheduled], orderStatistics: []) |> mapToSignal { view -> Signal<(Message, [Message])?, NoError> in let position: NavigatedMessageFromViewPosition switch navigation { diff --git a/submodules/TelegramUI/TelegramUI/PermissionContentNode.swift b/submodules/TelegramUI/TelegramUI/PermissionContentNode.swift index 8ac2896056..eba8cf859a 100644 --- a/submodules/TelegramUI/TelegramUI/PermissionContentNode.swift +++ b/submodules/TelegramUI/TelegramUI/PermissionContentNode.swift @@ -80,7 +80,7 @@ final class PermissionContentNode: ASDisplayNode { self.textNode.maximumNumberOfLines = 0 self.textNode.displaysAsynchronously = false - self.actionButton = SolidRoundedButtonNode(theme: theme, height: 48.0, cornerRadius: 9.0) + self.actionButton = SolidRoundedButtonNode(theme: theme, height: 48.0, cornerRadius: 9.0, gloss: true) self.footerNode = ImmediateTextNode() self.footerNode.textAlignment = .center @@ -178,7 +178,8 @@ final class PermissionContentNode: ASDisplayNode { let titleSize = self.titleNode.updateLayout(CGSize(width: size.width - sidePadding * 2.0, height: .greatestFiniteMagnitude)) let subtitleSize = self.subtitleNode.updateLayout(CGSize(width: size.width - smallerSidePadding * 2.0, height: .greatestFiniteMagnitude)) let textSize = self.textNode.updateLayout(CGSize(width: size.width - sidePadding * 2.0, height: .greatestFiniteMagnitude)) - let buttonWidth = min(size.width, size.height) + let buttonInset: CGFloat = 38.0 + let buttonWidth = min(size.width, size.height) - buttonInset * 2.0 let buttonHeight = self.actionButton.updateLayout(width: buttonWidth, transition: transition) let footerSize = self.footerNode.updateLayout(CGSize(width: size.width - smallerSidePadding * 2.0, height: .greatestFiniteMagnitude)) let privacyButtonSize = self.privacyPolicyButton.measure(CGSize(width: size.width - sidePadding * 2.0, height: .greatestFiniteMagnitude)) diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping index 53117500dc86bd564cffeede97c1384bdd3d9ff1..fc2bbb43e6a74ababfab41bf4bcf83447aaa8887 100644 GIT binary patch delta 30970 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 delta 30726 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 CGFloat { self.validLayout = width - let inset: CGFloat = 38.0 - let buttonSize = CGSize(width: width - inset * 2.0, height: self.buttonHeight) - let buttonFrame = CGRect(origin: CGPoint(x: inset, y: 0.0), size: buttonSize) + let buttonSize = CGSize(width: width, height: self.buttonHeight) + let buttonFrame = CGRect(origin: CGPoint(), size: buttonSize) transition.updateFrame(node: self.buttonBackgroundNode, frame: buttonFrame) transition.updateFrame(node: self.buttonGlossNode, frame: buttonFrame) transition.updateFrame(node: self.buttonNode, frame: buttonFrame) diff --git a/submodules/TelegramUI/TelegramUI/StickerPackPreviewController.swift b/submodules/TelegramUI/TelegramUI/StickerPackPreviewController.swift index ba26977ccf..484c49d325 100644 --- a/submodules/TelegramUI/TelegramUI/StickerPackPreviewController.swift +++ b/submodules/TelegramUI/TelegramUI/StickerPackPreviewController.swift @@ -127,7 +127,7 @@ final class StickerPackPreviewController: ViewController { } if let peer = peer { strongSelf.dismiss() - strongSelf.parentNavigationController?.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(peer.id), messageId: nil)) + strongSelf.parentNavigationController?.pushViewController(ChatController(context: strongSelf.context, chatLocation: .peer(peer.id))) } })) }) diff --git a/submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift b/submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift index d0b08152fa..8b198fe8a9 100644 --- a/submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift +++ b/submodules/TelegramUI/TelegramUI/StringForMessageTimestampStatus.swift @@ -12,7 +12,13 @@ enum MessageTimestampStatusFormat { } func stringForMessageTimestampStatus(accountPeerId: PeerId, message: Message, dateTimeFormat: PresentationDateTimeFormat, nameDisplayOrder: PresentationPersonNameOrder, strings: PresentationStrings, format: MessageTimestampStatusFormat = .regular) -> String { - var dateText = stringForMessageTimestamp(timestamp: message.timestamp, dateTimeFormat: dateTimeFormat) + let timestamp: Int32 + if let scheduleTime = message.scheduleTime { + timestamp = scheduleTime + } else { + timestamp = message.timestamp + } + var dateText = stringForMessageTimestamp(timestamp: timestamp, dateTimeFormat: dateTimeFormat) var authorTitle: String? if let author = message.author as? TelegramUser { diff --git a/submodules/TelegramUI/TelegramUI/VolumeButtons.swift b/submodules/TelegramUI/TelegramUI/VolumeButtons.swift index 64e2e28ed5..87f905d543 100644 --- a/submodules/TelegramUI/TelegramUI/VolumeButtons.swift +++ b/submodules/TelegramUI/TelegramUI/VolumeButtons.swift @@ -21,7 +21,7 @@ class VolumeButtonsListener: NSObject { super.init() - impl = { [weak self] in + impl = { valueChanged() } diff --git a/submodules/TelegramUI/TelegramUI_Xcode.xcodeproj/project.pbxproj b/submodules/TelegramUI/TelegramUI_Xcode.xcodeproj/project.pbxproj index ab44500ca3..8a51bf33f6 100644 --- a/submodules/TelegramUI/TelegramUI_Xcode.xcodeproj/project.pbxproj +++ b/submodules/TelegramUI/TelegramUI_Xcode.xcodeproj/project.pbxproj @@ -57,6 +57,9 @@ 094735192277483C00EA2312 /* anim_infotip.json in Resources */ = {isa = PBXBuildFile; fileRef = 094735182277483B00EA2312 /* anim_infotip.json */; }; 0947FCAE224043450086741C /* SettingsSearchRecentItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0947FCAD224043450086741C /* SettingsSearchRecentItem.swift */; }; 0947FCB0224055990086741C /* StringHash.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0947FCAF224055990086741C /* StringHash.swift */; }; + 09510B0F22F9347E0078CAB7 /* BundleResource.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09510B0E22F9347E0078CAB7 /* BundleResource.swift */; }; + 09510B1322F96E5B0078CAB7 /* ChatScheduleTimeController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09510B1222F96E5B0078CAB7 /* ChatScheduleTimeController.swift */; }; + 09510B1522F96E6C0078CAB7 /* ChatScheduleTimeControllerNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09510B1422F96E6C0078CAB7 /* ChatScheduleTimeControllerNode.swift */; }; 0952D1752176DEB500194860 /* NotificationMuteSettingsController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0952D1742176DEB500194860 /* NotificationMuteSettingsController.swift */; }; 0957DE2322DE28FB001B4D57 /* ThemePreviewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0957DE2222DE28FB001B4D57 /* ThemePreviewController.swift */; }; 0957DE2522DE2909001B4D57 /* ThemePreviewControllerNode.swift in Sources */ = {isa = PBXBuildFile; fileRef = 0957DE2422DE2909001B4D57 /* ThemePreviewControllerNode.swift */; }; @@ -151,6 +154,7 @@ 09E4A803223B833B0038140F /* ForwardPrivacyChatPreviewItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09E4A802223B833B0038140F /* ForwardPrivacyChatPreviewItem.swift */; }; 09E4A805223D4A5A0038140F /* OpenSettings.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09E4A804223D4A5A0038140F /* OpenSettings.swift */; }; 09E4A807223D4B860038140F /* AccountUtils.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09E4A806223D4B860038140F /* AccountUtils.swift */; }; + 09E719F722F9F99E00494136 /* MediaResources.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 09E719F622F9F99E00494136 /* MediaResources.framework */; }; 09EC0DED22CB583C00E7185B /* TextLinkHandling.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09EC0DEC22CB583C00E7185B /* TextLinkHandling.swift */; }; 09EC5CDC22CBD33D00292E42 /* NumberFormat.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09EC5CDB22CBD33D00292E42 /* NumberFormat.swift */; }; 09EDAD26220D30980012A50B /* AutodownloadConnectionTypeController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 09EDAD25220D30980012A50B /* AutodownloadConnectionTypeController.swift */; }; @@ -1205,6 +1209,9 @@ 094735182277483B00EA2312 /* anim_infotip.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; path = anim_infotip.json; sourceTree = ""; }; 0947FCAD224043450086741C /* SettingsSearchRecentItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SettingsSearchRecentItem.swift; sourceTree = ""; }; 0947FCAF224055990086741C /* StringHash.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = StringHash.swift; sourceTree = ""; }; + 09510B0E22F9347E0078CAB7 /* BundleResource.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BundleResource.swift; sourceTree = ""; }; + 09510B1222F96E5B0078CAB7 /* ChatScheduleTimeController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatScheduleTimeController.swift; sourceTree = ""; }; + 09510B1422F96E6C0078CAB7 /* ChatScheduleTimeControllerNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ChatScheduleTimeControllerNode.swift; sourceTree = ""; }; 0952D1742176DEB500194860 /* NotificationMuteSettingsController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NotificationMuteSettingsController.swift; sourceTree = ""; }; 0957DE2222DE28FB001B4D57 /* ThemePreviewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ThemePreviewController.swift; sourceTree = ""; }; 0957DE2422DE2909001B4D57 /* ThemePreviewControllerNode.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ThemePreviewControllerNode.swift; sourceTree = ""; }; @@ -1299,6 +1306,7 @@ 09E4A802223B833B0038140F /* ForwardPrivacyChatPreviewItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ForwardPrivacyChatPreviewItem.swift; sourceTree = ""; }; 09E4A804223D4A5A0038140F /* OpenSettings.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = OpenSettings.swift; sourceTree = ""; }; 09E4A806223D4B860038140F /* AccountUtils.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AccountUtils.swift; sourceTree = ""; }; + 09E719F622F9F99E00494136 /* MediaResources.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; path = MediaResources.framework; sourceTree = BUILT_PRODUCTS_DIR; }; 09EC0DEC22CB583C00E7185B /* TextLinkHandling.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TextLinkHandling.swift; sourceTree = ""; }; 09EC5CDB22CBD33D00292E42 /* NumberFormat.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = NumberFormat.swift; sourceTree = ""; }; 09EDAD25220D30980012A50B /* AutodownloadConnectionTypeController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AutodownloadConnectionTypeController.swift; sourceTree = ""; }; @@ -2344,6 +2352,7 @@ isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; files = ( + 09E719F722F9F99E00494136 /* MediaResources.framework in Frameworks */, D038AC5322F88A3600320981 /* ImageBlur.framework in Frameworks */, D0879CCC22F876DD00C4D6B3 /* ChatListSearchRecentPeersNode.framework in Frameworks */, D0879C9622F875C000C4D6B3 /* PeerPresenceStatusManager.framework in Frameworks */, @@ -3427,6 +3436,7 @@ D08D45281D5E340200A7428A /* Frameworks */ = { isa = PBXGroup; children = ( + 09E719F622F9F99E00494136 /* MediaResources.framework */, D038AC5222F88A3600320981 /* ImageBlur.framework */, D0879CCB22F876DD00C4D6B3 /* ChatListSearchRecentPeersNode.framework */, D0879C9522F875C000C4D6B3 /* PeerPresenceStatusManager.framework */, @@ -4484,6 +4494,8 @@ D025402622E1F23000AC0195 /* ChatSendButtonRadialStatusNode.swift */, D025402822E1F7F500AC0195 /* ChatTextInputSlowmodePlaceholderNode.swift */, D06018B422F3659900796784 /* ChatTextFormat.swift */, + 09510B1222F96E5B0078CAB7 /* ChatScheduleTimeController.swift */, + 09510B1422F96E6C0078CAB7 /* ChatScheduleTimeControllerNode.swift */, ); name = Chat; sourceTree = ""; @@ -4736,6 +4748,7 @@ 0910B0EE21FA532D00F8F87D /* WallpaperResources.swift */, D0CCD61A222E8B4500EE1E08 /* TimeBasedVideoPreload.swift */, 09E2D9F0226F214000EA0AA4 /* EmojiResources.swift */, + 09510B0E22F9347E0078CAB7 /* BundleResource.swift */, ); name = Resources; sourceTree = ""; @@ -5344,6 +5357,7 @@ D0E9BAE01F0574D800F079A4 /* STPDispatchFunctions.m in Sources */, D0EC6D2B1EB9F58800EBF1C3 /* FileMediaResourceStatus.swift in Sources */, D0EC6D2C1EB9F58800EBF1C3 /* TouchDownGestureRecognizer.swift in Sources */, + 09510B0F22F9347E0078CAB7 /* BundleResource.swift in Sources */, 09DD88FA21BFD70B000766BC /* ThemedTextAlertController.swift in Sources */, D0FA08C020483F9600DD23FC /* ExtractVideoData.swift in Sources */, D025402522E1E00100AC0195 /* ChatSlowmodeHintController.swift in Sources */, @@ -5900,6 +5914,7 @@ D02F4AE91FCF370B004DFBAE /* ChatMessageInteractiveMediaBadge.swift in Sources */, D00817CF22B47A14008A895F /* LegacyFileImport.swift in Sources */, D01A21AF1F39EA2E00DDA104 /* InstantPageTheme.swift in Sources */, + 09510B1322F96E5B0078CAB7 /* ChatScheduleTimeController.swift in Sources */, D0EC6E471EB9F58900EBF1C3 /* ItemListTextEmptyStateItem.swift in Sources */, D0E412C62069B60600BEE4A2 /* FormControllerHeaderItem.swift in Sources */, D0E412D5206A842900BEE4A2 /* SecureIdVerificationDocument.swift in Sources */, @@ -5995,6 +6010,7 @@ D0471B621EFEB5B70074D609 /* BotPaymentSwitchItemNode.swift in Sources */, D0E8175B201254FA00B82BBB /* ChatRecentActionsEmptyNode.swift in Sources */, D0C44B641FC64D0500227BE0 /* SwipeToDismissGestureRecognizer.swift in Sources */, + 09510B1522F96E6C0078CAB7 /* ChatScheduleTimeControllerNode.swift in Sources */, D0EC6E7D1EB9F58900EBF1C3 /* ChangePhoneNumberIntroController.swift in Sources */, 09F215AB2264ABA600AEDF6D /* PasscodeBackground.swift in Sources */, D0EC6E7E1EB9F58900EBF1C3 /* ChangePhoneNumberController.swift in Sources */, diff --git a/submodules/TelegramVoip/Sources/OngoingCallContext.swift b/submodules/TelegramVoip/Sources/OngoingCallContext.swift index ef378a70eb..440bb59fda 100644 --- a/submodules/TelegramVoip/Sources/OngoingCallContext.swift +++ b/submodules/TelegramVoip/Sources/OngoingCallContext.swift @@ -149,6 +149,8 @@ public final class OngoingCallContext { return .connected case .failed: return .failed + default: + return .failed } } }