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 7c0cc20798..0000000000 Binary files a/submodules/TelegramUI/Images.xcassets/Chat/Empty Chat/Chat.imageset/telegram_plane_flat.pdf and /dev/null differ 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 0000000000..2829293819 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@2x.png differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@3x.png b/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@3x.png new file mode 100644 index 0000000000..f4eb832ef8 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat/Input/Menu/ScheduleIcon.imageset/Schedule@3x.png differ 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 0000000000..69fecc9a3b Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@2x.png differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@3x.png b/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@3x.png new file mode 100644 index 0000000000..9ad5160195 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat/Input/ScheduleIcon.imageset/ScheduleSendButton@3x.png differ diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/Contents.json new file mode 100644 index 0000000000..3572e6fcaa --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/Contents.json @@ -0,0 +1,22 @@ +{ + "images" : [ + { + "idiom" : "universal", + "scale" : "1x" + }, + { + "idiom" : "universal", + "filename" : "ScheduleInput@2x.png", + "scale" : "2x" + }, + { + "idiom" : "universal", + "filename" : "ScheduleInput@3x.png", + "scale" : "3x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@2x.png b/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@2x.png new file mode 100644 index 0000000000..678cba5609 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@2x.png differ 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 0000000000..c238786991 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Chat/Input/Text/AccessoryIconSchedule.imageset/ScheduleInput@3x.png differ diff --git a/submodules/TelegramUI/TelegramUI/AnimatedStickerNode.swift b/submodules/TelegramUI/TelegramUI/AnimatedStickerNode.swift index be875994d8..08ed27ec57 100644 --- a/submodules/TelegramUI/TelegramUI/AnimatedStickerNode.swift +++ b/submodules/TelegramUI/TelegramUI/AnimatedStickerNode.swift @@ -8,6 +8,7 @@ import AsyncDisplayKit import RLottie import GZip import Tuples +import MediaResources import StickerResources private final class AnimationFrameCache { @@ -404,7 +405,7 @@ final class AnimatedStickerNode: ASDisplayNode { self.addSubnode(self.renderer!) } - func setup(account: Account, resource: MediaResource, width: Int, height: Int, playbackMode: AnimatedStickerPlaybackMode = .loop, mode: AnimatedStickerMode) { + func setup(account: Account, resource: MediaResource, fitzModifier: EmojiFitzModifier? = nil, width: Int, height: Int, playbackMode: AnimatedStickerPlaybackMode = .loop, mode: AnimatedStickerMode) { if width < 2 || height < 2 { return } @@ -424,7 +425,7 @@ final class AnimatedStickerNode: ASDisplayNode { } })) case .cached: - self.disposable.set((chatMessageAnimationData(postbox: account.postbox, resource: resource, width: width, height: height, synchronousLoad: false) + self.disposable.set((chatMessageAnimationData(postbox: account.postbox, resource: resource, fitzModifier: fitzModifier, width: width, height: height, synchronousLoad: false) |> 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 53117500dc..fc2bbb43e6 100644 Binary files a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TelegramUI/TelegramUI/SecureIdAuthPasswordSetupContentNode.swift b/submodules/TelegramUI/TelegramUI/SecureIdAuthPasswordSetupContentNode.swift index 394940ab8a..0680a66849 100644 --- a/submodules/TelegramUI/TelegramUI/SecureIdAuthPasswordSetupContentNode.swift +++ b/submodules/TelegramUI/TelegramUI/SecureIdAuthPasswordSetupContentNode.swift @@ -95,7 +95,7 @@ final class SecureIdAuthPasswordSetupContentNode: ASDisplayNode, SecureIdAuthCon self.buttonTextNode.attributedText = NSAttributedString(string: self.strings.Passport_PasswordCompleteSetup, font: buttonFont, textColor: self.theme.list.itemAccentColor) } if let width = self.validLayout { - self.updateLayout(width: width, transition: .immediate) + let _ = self.updateLayout(width: width, transition: .immediate) } } diff --git a/submodules/TelegramUI/TelegramUI/SettingsSearchableItems.swift b/submodules/TelegramUI/TelegramUI/SettingsSearchableItems.swift index d46956f1e6..b9a1018b38 100644 --- a/submodules/TelegramUI/TelegramUI/SettingsSearchableItems.swift +++ b/submodules/TelegramUI/TelegramUI/SettingsSearchableItems.swift @@ -247,15 +247,18 @@ private func stickerSearchableItems(context: AccountContext, archivedStickerPack items.append(SettingsSearchableItem(id: .stickers(1), title: strings.Stickers_SuggestStickers, alternate: synonyms(strings.SettingsSearch_Synonyms_Stickers_SuggestStickers), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in presentStickerSettings(context, present, .suggestOptions) })) - items.append(SettingsSearchableItem(id: .stickers(2), title: strings.StickerPacksSettings_FeaturedPacks, alternate: synonyms(strings.SettingsSearch_Synonyms_Stickers_FeaturedPacks), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in + items.append(SettingsSearchableItem(id: .stickers(2), title: strings.StickerPacksSettings_AnimatedStickers, alternate: synonyms(strings.StickerPacksSettings_AnimatedStickers), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in + presentStickerSettings(context, present, .loopAnimatedStickers) + })) + items.append(SettingsSearchableItem(id: .stickers(3), title: strings.StickerPacksSettings_FeaturedPacks, alternate: synonyms(strings.SettingsSearch_Synonyms_Stickers_FeaturedPacks), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in present(.push, featuredStickerPacksController(context: context)) })) if !(archivedStickerPacks?.isEmpty ?? true) { - items.append(SettingsSearchableItem(id: .stickers(3), title: strings.StickerPacksSettings_ArchivedPacks, alternate: synonyms(strings.SettingsSearch_Synonyms_Stickers_ArchivedPacks), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in + items.append(SettingsSearchableItem(id: .stickers(4), title: strings.StickerPacksSettings_ArchivedPacks, alternate: synonyms(strings.SettingsSearch_Synonyms_Stickers_ArchivedPacks), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in present(.push, archivedStickerPacksController(context: context, mode: .stickers, archived: archivedStickerPacks, updatedPacks: { _ in })) })) } - items.append(SettingsSearchableItem(id: .stickers(4), title: strings.MaskStickerSettings_Title, alternate: synonyms(strings.SettingsSearch_Synonyms_Stickers_Masks), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in + items.append(SettingsSearchableItem(id: .stickers(5), title: strings.MaskStickerSettings_Title, alternate: synonyms(strings.SettingsSearch_Synonyms_Stickers_Masks), icon: icon, breadcrumbs: [strings.ChatSettings_Stickers], present: { context, _, present in present(.push, installedStickerPacksController(context: context, mode: .masks, archivedPacks: nil, updatedPacks: { _ in })) })) return items diff --git a/submodules/TelegramUI/TelegramUI/SolidRoundedButtonNode.swift b/submodules/TelegramUI/TelegramUI/SolidRoundedButtonNode.swift index 0c5f953a35..e1d6ab9c23 100644 --- a/submodules/TelegramUI/TelegramUI/SolidRoundedButtonNode.swift +++ b/submodules/TelegramUI/TelegramUI/SolidRoundedButtonNode.swift @@ -28,7 +28,7 @@ final class SolidRoundedButtonNode: ASDisplayNode { } } - init(title: String? = nil, theme: PresentationTheme, height: CGFloat = 48.0, cornerRadius: CGFloat = 24.0) { + init(title: String? = nil, theme: PresentationTheme, height: CGFloat = 48.0, cornerRadius: CGFloat = 24.0, gloss: Bool = false) { self.theme = theme self.buttonHeight = height self.buttonCornerRadius = cornerRadius @@ -50,7 +50,9 @@ final class SolidRoundedButtonNode: ASDisplayNode { super.init() self.addSubnode(self.buttonBackgroundNode) - self.addSubnode(self.buttonGlossNode) + if gloss { + self.addSubnode(self.buttonGlossNode) + } self.addSubnode(self.buttonNode) self.addSubnode(self.labelNode) @@ -79,9 +81,8 @@ final class SolidRoundedButtonNode: ASDisplayNode { func updateLayout(width: CGFloat, transition: ContainedViewLayoutTransition) -> 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 } } }