diff --git a/Makefile b/Makefile index f2e612c7c4..d8a8f39a01 100644 --- a/Makefile +++ b/Makefile @@ -3,7 +3,7 @@ include Utils.makefile BUCK_OPTIONS=\ - --config custom.appVersion="5.15" \ + --config custom.appVersion="5.15.1" \ --config custom.developmentCodeSignIdentity="${DEVELOPMENT_CODE_SIGN_IDENTITY}" \ --config custom.distributionCodeSignIdentity="${DISTRIBUTION_CODE_SIGN_IDENTITY}" \ --config custom.developmentTeam="${DEVELOPMENT_TEAM}" \ diff --git a/Telegram-iOS/en.lproj/Localizable.strings b/Telegram-iOS/en.lproj/Localizable.strings index 8338a6be74..061741053b 100644 --- a/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram-iOS/en.lproj/Localizable.strings @@ -5330,3 +5330,17 @@ Any member of this group will be able to see messages in the channel."; "PeerInfo.ButtonUnmute" = "Unmute"; "PeerInfo.ButtonMore" = "More"; "PeerInfo.ButtonAddMember" = "Add Members"; +"PeerInfo.ButtonSearch" = "Search"; +"PeerInfo.ButtonLeave" = "Leave"; + +"PeerInfo.PaneMedia" = "Media"; +"PeerInfo.PaneFiles" = "Files"; +"PeerInfo.PaneLinks" = "Links"; +"PeerInfo.PaneVoice" = "Voice Messages"; +"PeerInfo.PaneAudio" = "Audio"; +"PeerInfo.PaneGroups" = "Groups"; +"PeerInfo.PaneMembers" = "Members"; + +"PeerInfo.AddToContacts" = "Add to Contacts"; + +"PeerInfo.BioExpand" = "more"; diff --git a/submodules/ContextUI/Sources/ContextControllerSourceNode.swift b/submodules/ContextUI/Sources/ContextControllerSourceNode.swift index 51b7fca583..e375015ece 100644 --- a/submodules/ContextUI/Sources/ContextControllerSourceNode.swift +++ b/submodules/ContextUI/Sources/ContextControllerSourceNode.swift @@ -14,6 +14,12 @@ public final class ContextControllerSourceNode: ASDisplayNode { public var shouldBegin: ((CGPoint) -> Bool)? public var customActivationProgress: ((CGFloat, ContextGestureTransition) -> Void)? + public func cancelGesture() { + self.contextGesture?.cancel() + self.contextGesture?.isEnabled = false + self.contextGesture?.isEnabled = self.isGestureEnabled + } + override public func didLoad() { super.didLoad() diff --git a/submodules/Display/Display/ImmediateTextNode.swift b/submodules/Display/Display/ImmediateTextNode.swift index 25d8fb69e7..f7e8dfc340 100644 --- a/submodules/Display/Display/ImmediateTextNode.swift +++ b/submodules/Display/Display/ImmediateTextNode.swift @@ -15,6 +15,7 @@ public class ImmediateTextNode: TextNode { public var insets: UIEdgeInsets = UIEdgeInsets() public var textShadowColor: UIColor? public var textStroke: (UIColor, CGFloat)? + public var cutout: TextNodeCutout? private var tapRecognizer: TapLongTapOrDoubleTapGestureRecognizer? private var linkHighlightingNode: LinkHighlightingNode? @@ -57,7 +58,7 @@ public class ImmediateTextNode: TextNode { public func updateLayout(_ constrainedSize: CGSize) -> CGSize { let makeLayout = TextNode.asyncLayout(self) - let (layout, apply) = makeLayout(TextNodeLayoutArguments(attributedString: self.attributedText, backgroundColor: nil, maximumNumberOfLines: self.maximumNumberOfLines, truncationType: self.truncationType, constrainedSize: constrainedSize, alignment: self.textAlignment, lineSpacing: self.lineSpacing, cutout: nil, insets: self.insets, textShadowColor: self.textShadowColor, textStroke: self.textStroke)) + let (layout, apply) = makeLayout(TextNodeLayoutArguments(attributedString: self.attributedText, backgroundColor: nil, maximumNumberOfLines: self.maximumNumberOfLines, truncationType: self.truncationType, constrainedSize: constrainedSize, alignment: self.textAlignment, lineSpacing: self.lineSpacing, cutout: self.cutout, insets: self.insets, textShadowColor: self.textShadowColor, textStroke: self.textStroke)) let _ = apply() if layout.numberOfLines > 1 { self.trailingLineWidth = layout.trailingLineWidth @@ -69,7 +70,7 @@ public class ImmediateTextNode: TextNode { public func updateLayoutInfo(_ constrainedSize: CGSize) -> ImmediateTextNodeLayoutInfo { let makeLayout = TextNode.asyncLayout(self) - let (layout, apply) = makeLayout(TextNodeLayoutArguments(attributedString: self.attributedText, backgroundColor: nil, maximumNumberOfLines: self.maximumNumberOfLines, truncationType: self.truncationType, constrainedSize: constrainedSize, alignment: self.textAlignment, lineSpacing: self.lineSpacing, cutout: nil, insets: self.insets)) + let (layout, apply) = makeLayout(TextNodeLayoutArguments(attributedString: self.attributedText, backgroundColor: nil, maximumNumberOfLines: self.maximumNumberOfLines, truncationType: self.truncationType, constrainedSize: constrainedSize, alignment: self.textAlignment, lineSpacing: self.lineSpacing, cutout: self.cutout, insets: self.insets)) let _ = apply() return ImmediateTextNodeLayoutInfo(size: layout.size, truncated: layout.truncated) } diff --git a/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift b/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift index 507899560a..6462a0d325 100644 --- a/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift +++ b/submodules/Display/Display/InteractiveTransitionGestureRecognizer.swift @@ -31,27 +31,42 @@ private func hasHorizontalGestures(_ view: UIView, point: CGPoint?) -> Bool { } } -class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { - var validatedGesture = false - var firstLocation: CGPoint = CGPoint() - private let canBegin: () -> Bool +public struct InteractiveTransitionGestureRecognizerDirections: OptionSet { + public var rawValue: Int - init(target: Any?, action: Selector?, canBegin: @escaping () -> Bool) { - self.canBegin = canBegin + public init(rawValue: Int) { + self.rawValue = rawValue + } + + public static let left = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 0) + public static let right = InteractiveTransitionGestureRecognizerDirections(rawValue: 1 << 1) +} + +public class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { + private let allowedDirections: () -> InteractiveTransitionGestureRecognizerDirections + + private var validatedGesture = false + private var firstLocation: CGPoint = CGPoint() + private var currentAllowedDirections: InteractiveTransitionGestureRecognizerDirections = [] + + public init(target: Any?, action: Selector?, allowedDirections: @escaping () -> InteractiveTransitionGestureRecognizerDirections) { + self.allowedDirections = allowedDirections super.init(target: target, action: action) self.maximumNumberOfTouches = 1 } - override func reset() { + override public func reset() { super.reset() - validatedGesture = false + self.validatedGesture = false + self.currentAllowedDirections = [] } - override func touchesBegan(_ touches: Set, with event: UIEvent) { - if !self.canBegin() { + override public func touchesBegan(_ touches: Set, with event: UIEvent) { + self.currentAllowedDirections = self.allowedDirections() + if self.currentAllowedDirections.isEmpty { self.state = .failed return } @@ -68,22 +83,24 @@ class InteractiveTransitionGestureRecognizer: UIPanGestureRecognizer { } } - override func touchesMoved(_ touches: Set, with event: UIEvent) { + override public func touchesMoved(_ touches: Set, with event: UIEvent) { let location = touches.first!.location(in: self.view) let translation = CGPoint(x: location.x - firstLocation.x, y: location.y - firstLocation.y) let absTranslationX: CGFloat = abs(translation.x) let absTranslationY: CGFloat = abs(translation.y) - if !validatedGesture { - if self.firstLocation.x < 16.0 { - validatedGesture = true - } else if translation.x < 0.0 { + if !self.validatedGesture { + if self.currentAllowedDirections.contains(.right) && self.firstLocation.x < 16.0 { + self.validatedGesture = true + } else if !self.currentAllowedDirections.contains(.left) && translation.x < 0.0 { + self.state = .failed + } else if !self.currentAllowedDirections.contains(.right) && translation.x > 0.0 { self.state = .failed } else if absTranslationY > 2.0 && absTranslationY > absTranslationX * 2.0 { self.state = .failed } else if absTranslationX > 2.0 && absTranslationY * 2.0 < absTranslationX { - validatedGesture = true + self.validatedGesture = true } } diff --git a/submodules/Display/Display/Navigation/NavigationContainer.swift b/submodules/Display/Display/Navigation/NavigationContainer.swift index 282101e452..c45e446656 100644 --- a/submodules/Display/Display/Navigation/NavigationContainer.swift +++ b/submodules/Display/Display/Navigation/NavigationContainer.swift @@ -111,11 +111,11 @@ final class NavigationContainer: ASDisplayNode, UIGestureRecognizerDelegate { override func didLoad() { super.didLoad() - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), canBegin: { [weak self] in - guard let strongSelf = self else { - return false + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + guard let strongSelf = self, strongSelf.controllers.count > 1 else { + return [] } - return strongSelf.controllers.count > 1 + return .right }) panRecognizer.delegate = self panRecognizer.delaysTouchesBegan = false diff --git a/submodules/Display/Display/Navigation/NavigationModalContainer.swift b/submodules/Display/Display/Navigation/NavigationModalContainer.swift index 0f3f0dee97..1798a9c436 100644 --- a/submodules/Display/Display/Navigation/NavigationModalContainer.swift +++ b/submodules/Display/Display/Navigation/NavigationModalContainer.swift @@ -90,11 +90,11 @@ final class NavigationModalContainer: ASDisplayNode, UIScrollViewDelegate, UIGes self.scrollNode.view.clipsToBounds = false self.scrollNode.view.delegate = self - let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), canBegin: { [weak self] in - guard let strongSelf = self else { - return false + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + guard let strongSelf = self, !strongSelf.isDismissed else { + return [] } - return !strongSelf.isDismissed + return .right }) self.panRecognizer = panRecognizer if let layout = self.validLayout { diff --git a/submodules/Display/Display/NavigationBar.swift b/submodules/Display/Display/NavigationBar.swift index ff66977045..9aaa5d5b01 100644 --- a/submodules/Display/Display/NavigationBar.swift +++ b/submodules/Display/Display/NavigationBar.swift @@ -1190,14 +1190,14 @@ open class NavigationBar: ASDisplayNode { } override open func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { - if self.bounds.contains(point) { + /*if self.bounds.contains(point) { if self.backButtonNode.supernode != nil && !self.backButtonNode.isHidden { let effectiveBackButtonRect = CGRect(origin: CGPoint(), size: CGSize(width: self.backButtonNode.frame.maxX + 20.0, height: self.bounds.height)) if effectiveBackButtonRect.contains(point) { return self.backButtonNode.internalHitTest(self.view.convert(point, to: self.backButtonNode.view), with: event) } } - } + }*/ guard let result = super.hitTest(point, with: event) else { return nil diff --git a/submodules/Display/Display/TextNode.swift b/submodules/Display/Display/TextNode.swift index 1e7268cdde..2cbb4708ca 100644 --- a/submodules/Display/Display/TextNode.swift +++ b/submodules/Display/Display/TextNode.swift @@ -929,7 +929,12 @@ public class TextNode: ASDisplayNode { let coreTextLine: CTLine let originalLine = CTTypesetterCreateLineWithOffset(typesetter, lineRange, 0.0) - if CTLineGetTypographicBounds(originalLine, nil, nil, nil) - CTLineGetTrailingWhitespaceWidth(originalLine) < Double(constrainedSize.width) { + var lineConstrainedSize = constrainedSize + if bottomCutoutEnabled { + lineConstrainedSize.width -= bottomCutoutSize.width + } + + if CTLineGetTypographicBounds(originalLine, nil, nil, nil) - CTLineGetTrailingWhitespaceWidth(originalLine) < Double(lineConstrainedSize.width) { coreTextLine = originalLine } else { var truncationTokenAttributes: [NSAttributedString.Key : AnyObject] = [:] @@ -939,7 +944,7 @@ public class TextNode: ASDisplayNode { let truncatedTokenString = NSAttributedString(string: tokenString, attributes: truncationTokenAttributes) let truncationToken = CTLineCreateWithAttributedString(truncatedTokenString) - coreTextLine = CTLineCreateTruncatedLine(originalLine, Double(constrainedSize.width), truncationType, truncationToken) ?? truncationToken + coreTextLine = CTLineCreateTruncatedLine(originalLine, Double(lineConstrainedSize.width), truncationType, truncationToken) ?? truncationToken truncated = true } @@ -956,7 +961,7 @@ public class TextNode: ASDisplayNode { } } - let lineWidth = min(constrainedSize.width, ceil(CGFloat(CTLineGetTypographicBounds(coreTextLine, nil, nil, nil) - CTLineGetTrailingWhitespaceWidth(coreTextLine)))) + let lineWidth = min(lineConstrainedSize.width, ceil(CGFloat(CTLineGetTypographicBounds(coreTextLine, nil, nil, nil) - CTLineGetTrailingWhitespaceWidth(coreTextLine)))) let lineFrame = CGRect(x: lineCutoutOffset + headIndent, y: lineOriginY, width: lineWidth, height: fontLineHeight) layoutSize.height += fontLineHeight + fontLineSpacing layoutSize.width = max(layoutSize.width, lineWidth + lineAdditionalWidth) @@ -1032,7 +1037,7 @@ public class TextNode: ASDisplayNode { if !lines.isEmpty && bottomCutoutEnabled { let proposedWidth = lines[lines.count - 1].frame.width + bottomCutoutSize.width if proposedWidth > layoutSize.width { - if proposedWidth < constrainedSize.width { + if proposedWidth <= constrainedSize.width + .ulpOfOne { layoutSize.width = proposedWidth } else { layoutSize.height += bottomCutoutSize.height diff --git a/submodules/Display/Display/TransformImageNode.swift b/submodules/Display/Display/TransformImageNode.swift index 163b0ce437..311ce62ee1 100644 --- a/submodules/Display/Display/TransformImageNode.swift +++ b/submodules/Display/Display/TransformImageNode.swift @@ -81,7 +81,7 @@ open class TransformImageNode: ASDisplayNode { let apply: () -> Void = { if let strongSelf = self { if strongSelf.contents == nil { - if strongSelf.contentAnimations.contains(.firstUpdate) { + if strongSelf.contentAnimations.contains(.firstUpdate) && !attemptSynchronously { strongSelf.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.15) } } else if strongSelf.contentAnimations.contains(.subsequentUpdates) { diff --git a/submodules/GalleryUI/Sources/GalleryController.swift b/submodules/GalleryUI/Sources/GalleryController.swift index 11e4215545..6d5d0a7067 100644 --- a/submodules/GalleryUI/Sources/GalleryController.swift +++ b/submodules/GalleryUI/Sources/GalleryController.swift @@ -253,6 +253,33 @@ private enum GalleryMessageHistoryView { return [entry] } } + + var tagMask: MessageTags? { + switch self { + case .single: + return nil + case let .view(view): + return view.tagMask + } + } + + var hasEarlier: Bool { + switch self { + case .single: + return false + case let .view(view): + return view.earlierId != nil + } + } + + var hasLater: Bool { + switch self { + case .single: + return false + case let .view(view): + return view.laterId != nil + } + } } public enum GalleryControllerItemSource { @@ -304,6 +331,7 @@ public class GalleryController: ViewController, StandalonePresentableController private let context: AccountContext private var presentationData: PresentationData private let source: GalleryControllerItemSource + private let invertItemOrder: Bool private let streamVideos: Bool @@ -324,6 +352,9 @@ public class GalleryController: ViewController, StandalonePresentableController private let disposable = MetaDisposable() private var entries: [MessageHistoryEntry] = [] + private var hasLeftEntries: Bool = false + private var hasRightEntries: Bool = false + private var tagMask: MessageTags? private var centralEntryStableId: UInt32? private var configuration: GalleryConfiguration? @@ -346,9 +377,12 @@ public class GalleryController: ViewController, StandalonePresentableController private var performAction: (GalleryControllerInteractionTapAction) -> Void private var openActionOptions: (GalleryControllerInteractionTapAction) -> Void + private let updateVisibleDisposable = MetaDisposable() + public init(context: AccountContext, source: GalleryControllerItemSource, invertItemOrder: Bool = false, streamSingleVideo: Bool = false, fromPlayingVideo: Bool = false, landscape: Bool = false, timecode: Double? = nil, synchronousLoad: Bool = false, replaceRootController: @escaping (ViewController, ValuePromise?) -> Void, baseNavigationController: NavigationController?, actionInteraction: GalleryControllerActionInteraction? = nil) { self.context = context self.source = source + self.invertItemOrder = invertItemOrder self.replaceRootController = replaceRootController self.baseNavigationController = baseNavigationController self.actionInteraction = actionInteraction @@ -444,13 +478,19 @@ public class GalleryController: ViewController, StandalonePresentableController } } + strongSelf.tagMask = view.tagMask + if invertItemOrder { strongSelf.entries = entries.reversed() + strongSelf.hasLeftEntries = view.hasLater + strongSelf.hasRightEntries = view.hasEarlier if let centralEntryStableId = centralEntryStableId { strongSelf.centralEntryStableId = centralEntryStableId } } else { strongSelf.entries = entries + strongSelf.hasLeftEntries = view.hasEarlier + strongSelf.hasRightEntries = view.hasLater strongSelf.centralEntryStableId = centralEntryStableId } if strongSelf.isViewLoaded { @@ -774,6 +814,7 @@ public class GalleryController: ViewController, StandalonePresentableController if let hiddenMediaManagerIndex = self.hiddenMediaManagerIndex { self.context.sharedContext.mediaManager.galleryHiddenMediaManager.removeSource(hiddenMediaManagerIndex) } + self.updateVisibleDisposable.dispose() } @objc private func donePressed() { @@ -898,6 +939,7 @@ public class GalleryController: ViewController, StandalonePresentableController var hiddenItem: (MessageId, Media)? if let index = index { let message = strongSelf.entries[index].message + strongSelf.centralEntryStableId = message.stableId if let (media, _) = mediaForMessage(message: message) { hiddenItem = (message.id, media) } @@ -910,6 +952,69 @@ public class GalleryController: ViewController, StandalonePresentableController strongSelf.centralItemNavigationStyle.set(node.navigationStyle()) strongSelf.centralItemFooterContentNode.set(node.footerContent()) } + + switch strongSelf.source { + case let .peerMessagesAtId(initialMessageId): + var reloadAroundIndex: MessageIndex? + if index <= 2 && strongSelf.hasLeftEntries { + reloadAroundIndex = strongSelf.entries.first?.index + } else if index >= strongSelf.entries.count - 3 && strongSelf.hasRightEntries { + reloadAroundIndex = strongSelf.entries.last?.index + } + if let reloadAroundIndex = reloadAroundIndex, let tagMask = strongSelf.tagMask { + let namespaces: MessageIdNamespaces + if Namespaces.Message.allScheduled.contains(message.id.namespace) { + namespaces = .just(Namespaces.Message.allScheduled) + } else { + namespaces = .not(Namespaces.Message.allScheduled) + } + let signal = strongSelf.context.account.postbox.aroundMessageHistoryViewForLocation(.peer(initialMessageId.peerId), anchor: .index(reloadAroundIndex), count: 50, clipHoles: false, fixedCombinedReadStates: nil, topTaggedMessageIdNamespaces: [], tagMask: tagMask, namespaces: namespaces, orderStatistics: [.combinedLocation]) + |> mapToSignal { (view, _, _) -> Signal in + let mapped = GalleryMessageHistoryView.view(view) + return .single(mapped) + } + |> take(1) + + strongSelf.updateVisibleDisposable.set((signal + |> deliverOnMainQueue).start(next: { view in + guard let strongSelf = self, let view = view else { + return + } + + let entries = view.entries + + if strongSelf.invertItemOrder { + strongSelf.entries = entries.reversed() + strongSelf.hasLeftEntries = view.hasLater + strongSelf.hasRightEntries = view.hasEarlier + } else { + strongSelf.entries = entries + strongSelf.hasLeftEntries = view.hasEarlier + strongSelf.hasRightEntries = view.hasLater + } + if strongSelf.isViewLoaded { + var items: [GalleryItem] = [] + var centralItemIndex: Int? + for entry in strongSelf.entries { + var isCentral = false + if entry.message.stableId == strongSelf.centralEntryStableId { + isCentral = true + } + if let item = galleryItemForEntry(context: strongSelf.context, presentationData: strongSelf.presentationData, entry: entry, isCentral: isCentral, streamVideos: false, fromPlayingVideo: isCentral && strongSelf.fromPlayingVideo, landscape: isCentral && strongSelf.landscape, timecode: isCentral ? strongSelf.timecode : nil, configuration: strongSelf.configuration, performAction: strongSelf.performAction, openActionOptions: strongSelf.openActionOptions, storeMediaPlaybackState: strongSelf.actionInteraction?.storeMediaPlaybackState ?? { _, _ in }) { + if isCentral { + centralItemIndex = items.count + } + items.append(item) + } + } + + strongSelf.galleryNode.pager.replaceItems(items, centralItemIndex: centralItemIndex) + } + })) + } + default: + break + } } if strongSelf.didSetReady { strongSelf._hiddenMedia.set(.single(hiddenItem)) diff --git a/submodules/GalleryUI/Sources/GalleryItem.swift b/submodules/GalleryUI/Sources/GalleryItem.swift index 89cfa918e5..c0b41d8194 100644 --- a/submodules/GalleryUI/Sources/GalleryItem.swift +++ b/submodules/GalleryUI/Sources/GalleryItem.swift @@ -21,6 +21,8 @@ public struct GalleryItemIndexData: Equatable { } public protocol GalleryItem { + var id: AnyHashable { get } + func node() -> GalleryItemNode func updateNode(node: GalleryItemNode) func thumbnailItem() -> (Int64, GalleryThumbnailItem)? diff --git a/submodules/GalleryUI/Sources/GalleryPagerNode.swift b/submodules/GalleryUI/Sources/GalleryPagerNode.swift index e71b3d496e..ce16fd64f4 100644 --- a/submodules/GalleryUI/Sources/GalleryPagerNode.swift +++ b/submodules/GalleryUI/Sources/GalleryPagerNode.swift @@ -246,16 +246,27 @@ public final class GalleryPagerNode: ASDisplayNode, UIScrollViewDelegate, UIGest } public func replaceItems(_ items: [GalleryItem], centralItemIndex: Int?, keepFirst: Bool = false) { + var items = items + if keepFirst && !self.items.isEmpty && !items.isEmpty { + items[0] = self.items[0] + } + var updateItems: [GalleryPagerUpdateItem] = [] - let deleteItems: [Int] = [] + var deleteItems: [Int] = [] var insertItems: [GalleryPagerInsertItem] = [] - for i in 0 ..< items.count { - if i == 0 && keepFirst { - updateItems.append(GalleryPagerUpdateItem(index: 0, previousIndex: 0, item: items[i])) - } else { - insertItems.append(GalleryPagerInsertItem(index: i, item: items[i], previousIndex: nil)) + var previousIndexById: [AnyHashable: Int] = [:] + var validIds = Set(items.map { $0.id }) + + for i in 0 ..< self.items.count { + previousIndexById[self.items[i].id] = i + if !validIds.contains(self.items[i].id) { + deleteItems.append(i) } } + + for i in 0 ..< items.count { + insertItems.append(GalleryPagerInsertItem(index: i, item: items[i], previousIndex: previousIndexById[items[i].id])) + } self.transaction(GalleryPagerTransaction(deleteItems: deleteItems, insertItems: insertItems, updateItems: updateItems, focusOnItem: centralItemIndex)) } @@ -263,6 +274,7 @@ public final class GalleryPagerNode: ASDisplayNode, UIScrollViewDelegate, UIGest for updatedItem in transaction.updateItems { self.items[updatedItem.previousIndex] = updatedItem.item if let itemNode = self.visibleItemNode(at: updatedItem.previousIndex) { + //print("update visible node at \(updatedItem.previousIndex)") updatedItem.item.updateNode(node: itemNode) } } @@ -274,55 +286,52 @@ public final class GalleryPagerNode: ASDisplayNode, UIScrollViewDelegate, UIGest self.items.remove(at: deleteItemIndex) for i in 0 ..< self.itemNodes.count { if self.itemNodes[i].index == deleteItemIndex { + //print("delete visible node at \(deleteItemIndex)") self.removeVisibleItemNode(internalIndex: i) break } } } - for itemNode in self.itemNodes { - var indexOffset = 0 - for deleteIndex in deleteItems { - if deleteIndex < itemNode.index { - indexOffset += 1 - } else { - break - } - } - - itemNode.index = itemNode.index - indexOffset - } - let insertItems = transaction.insertItems.sorted(by: { $0.index < $1.index }) - if self.items.count == 0 && !insertItems.isEmpty { - if insertItems[0].index != 0 { - fatalError("transaction: invalid insert into empty list") - } + + if transaction.updateItems.isEmpty && !insertItems.isEmpty { + self.items.removeAll() } for insertedItem in insertItems { - self.items.insert(insertedItem.item, at: insertedItem.index) + self.items.append(insertedItem.item) + //self.items.insert(insertedItem.item, at: insertedItem.index) } - let sortedInsertItems = transaction.insertItems.sorted(by: { $0.index < $1.index }) + let visibleIndices: [Int] = self.itemNodes.map { $0.index } + + var remapIndices: [Int: Int] = [:] + for i in 0 ..< insertItems.count { + if let previousIndex = insertItems[i].previousIndex, visibleIndices.contains(previousIndex) { + remapIndices[previousIndex] = i + } + } for itemNode in self.itemNodes { - var indexOffset = 0 - for insertedItem in sortedInsertItems { - if insertedItem.index <= itemNode.index + indexOffset { - indexOffset += 1 - } + if let remappedIndex = remapIndices[itemNode.index] { + //print("remap visible node \(itemNode.index) -> \(remappedIndex)") + itemNode.index = remappedIndex } - - itemNode.index = itemNode.index + indexOffset } + self.itemNodes.sort(by: { $0.index < $1.index }) + + //print("visible indices before update \(self.itemNodes.map { $0.index })") + self.invalidatedItems = true if let focusOnItem = transaction.focusOnItem { self.centralItemIndex = focusOnItem } self.updateItemNodes(transition: .immediate) + + //print("visible indices after update \(self.itemNodes.map { $0.index })") } else if let focusOnItem = transaction.focusOnItem { self.ignoreCentralItemIndexUpdate = true diff --git a/submodules/GalleryUI/Sources/Items/ChatAnimationGalleryItem.swift b/submodules/GalleryUI/Sources/Items/ChatAnimationGalleryItem.swift index 834d6758d1..6c5288df31 100644 --- a/submodules/GalleryUI/Sources/Items/ChatAnimationGalleryItem.swift +++ b/submodules/GalleryUI/Sources/Items/ChatAnimationGalleryItem.swift @@ -15,6 +15,10 @@ import StickerResources import AppBundle class ChatAnimationGalleryItem: GalleryItem { + var id: AnyHashable { + return self.message.stableId + } + let context: AccountContext let presentationData: PresentationData let message: Message diff --git a/submodules/GalleryUI/Sources/Items/ChatDocumentGalleryItem.swift b/submodules/GalleryUI/Sources/Items/ChatDocumentGalleryItem.swift index 2be4d488cc..cb04f53db0 100644 --- a/submodules/GalleryUI/Sources/Items/ChatDocumentGalleryItem.swift +++ b/submodules/GalleryUI/Sources/Items/ChatDocumentGalleryItem.swift @@ -12,6 +12,10 @@ import AccountContext import RadialStatusNode class ChatDocumentGalleryItem: GalleryItem { + var id: AnyHashable { + return self.message.stableId + } + let context: AccountContext let presentationData: PresentationData let message: Message diff --git a/submodules/GalleryUI/Sources/Items/ChatExternalFileGalleryItem.swift b/submodules/GalleryUI/Sources/Items/ChatExternalFileGalleryItem.swift index 753b5cc904..bfcdf0fb42 100644 --- a/submodules/GalleryUI/Sources/Items/ChatExternalFileGalleryItem.swift +++ b/submodules/GalleryUI/Sources/Items/ChatExternalFileGalleryItem.swift @@ -13,6 +13,10 @@ import RadialStatusNode import ShareController class ChatExternalFileGalleryItem: GalleryItem { + var id: AnyHashable { + return self.message.stableId + } + let context: AccountContext let presentationData: PresentationData let message: Message diff --git a/submodules/GalleryUI/Sources/Items/ChatImageGalleryItem.swift b/submodules/GalleryUI/Sources/Items/ChatImageGalleryItem.swift index a6c6c9b502..de6f4894e9 100644 --- a/submodules/GalleryUI/Sources/Items/ChatImageGalleryItem.swift +++ b/submodules/GalleryUI/Sources/Items/ChatImageGalleryItem.swift @@ -79,6 +79,10 @@ final class ChatMediaGalleryThumbnailItem: GalleryThumbnailItem { } class ChatImageGalleryItem: GalleryItem { + var id: AnyHashable { + return self.message.stableId + } + let context: AccountContext let presentationData: PresentationData let message: Message diff --git a/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift b/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift index f0b6c51d16..ba3a583887 100644 --- a/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift +++ b/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift @@ -19,6 +19,10 @@ public enum UniversalVideoGalleryItemContentInfo { } public class UniversalVideoGalleryItem: GalleryItem { + public var id: AnyHashable { + return self.content.id + } + let context: AccountContext let presentationData: PresentationData let content: UniversalVideoContent @@ -921,7 +925,7 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { copyView.layer.animate(from: NSValue(caTransform3D: CATransform3DIdentity), to: NSValue(caTransform3D: CATransform3DMakeScale(scale.width, scale.height, 1.0)), keyPath: "transform", timingFunction: kCAMediaTimingFunctionSpring, duration: 0.25, removeOnCompletion: false) if let transformedSurfaceFrame = transformedSurfaceFrame, let transformedSurfaceFinalFrame = transformedSurfaceFinalFrame { - surfaceCopyView.layer.animatePosition(from: CGPoint(x: transformedSurfaceFrame.midX, y: transformedSurfaceFrame.midY), to: CGPoint(x: transformedCopyViewFinalFrame.midX, y: transformedCopyViewFinalFrame.midY), duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false, completion: { [weak surfaceCopyView] _ in + surfaceCopyView.layer.animatePosition(from: CGPoint(x: transformedSurfaceFrame.midX, y: transformedSurfaceFrame.midY), to: CGPoint(x: transformedSurfaceFinalFrame.midX, y: transformedSurfaceFinalFrame.midY), duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false, completion: { [weak surfaceCopyView] _ in surfaceCopyView?.removeFromSuperview() }) let scale = CGSize(width: transformedSurfaceFinalFrame.size.width / transformedSurfaceFrame.size.width, height: transformedSurfaceFinalFrame.size.height / transformedSurfaceFrame.size.height) diff --git a/submodules/InstantPageUI/Sources/InstantImageGalleryItem.swift b/submodules/InstantPageUI/Sources/InstantImageGalleryItem.swift index 1d0c082ae5..087b35790e 100644 --- a/submodules/InstantPageUI/Sources/InstantImageGalleryItem.swift +++ b/submodules/InstantPageUI/Sources/InstantImageGalleryItem.swift @@ -35,6 +35,12 @@ private struct InstantImageGalleryThumbnailItem: GalleryThumbnailItem { } class InstantImageGalleryItem: GalleryItem { + var id: AnyHashable { + return self.itemId + } + + let itemId: AnyHashable + let context: AccountContext let presentationData: PresentationData let imageReference: ImageMediaReference @@ -44,7 +50,8 @@ class InstantImageGalleryItem: GalleryItem { let openUrl: (InstantPageUrlItem) -> Void let openUrlOptions: (InstantPageUrlItem) -> Void - init(context: AccountContext, presentationData: PresentationData, imageReference: ImageMediaReference, caption: NSAttributedString, credit: NSAttributedString, location: InstantPageGalleryEntryLocation?, openUrl: @escaping (InstantPageUrlItem) -> Void, openUrlOptions: @escaping (InstantPageUrlItem) -> Void) { + init(context: AccountContext, presentationData: PresentationData, itemId: AnyHashable, imageReference: ImageMediaReference, caption: NSAttributedString, credit: NSAttributedString, location: InstantPageGalleryEntryLocation?, openUrl: @escaping (InstantPageUrlItem) -> Void, openUrlOptions: @escaping (InstantPageUrlItem) -> Void) { + self.itemId = itemId self.context = context self.presentationData = presentationData self.imageReference = imageReference diff --git a/submodules/InstantPageUI/Sources/InstantPageGalleryController.swift b/submodules/InstantPageUI/Sources/InstantPageGalleryController.swift index d50fc2b478..6c7ef95f88 100644 --- a/submodules/InstantPageUI/Sources/InstantPageGalleryController.swift +++ b/submodules/InstantPageUI/Sources/InstantPageGalleryController.swift @@ -98,7 +98,7 @@ public struct InstantPageGalleryEntry: Equatable { } if let image = self.media.media as? TelegramMediaImage { - return InstantImageGalleryItem(context: context, presentationData: presentationData, imageReference: .webPage(webPage: WebpageReference(webPage), media: image), caption: caption, credit: credit, location: self.location, openUrl: openUrl, openUrlOptions: openUrlOptions) + return InstantImageGalleryItem(context: context, presentationData: presentationData, itemId: self.index, imageReference: .webPage(webPage: WebpageReference(webPage), media: image), caption: caption, credit: credit, location: self.location, openUrl: openUrl, openUrlOptions: openUrlOptions) } else if let file = self.media.media as? TelegramMediaFile { if file.isVideo { var indexData: GalleryItemIndexData? @@ -121,7 +121,7 @@ public struct InstantPageGalleryEntry: Equatable { representations.append(TelegramMediaImageRepresentation(dimensions: dimensions, resource: file.resource)) } let image = TelegramMediaImage(imageId: MediaId(namespace: 0, id: 0), representations: representations, immediateThumbnailData: file.immediateThumbnailData, reference: nil, partialReference: nil, flags: []) - return InstantImageGalleryItem(context: context, presentationData: presentationData, imageReference: .webPage(webPage: WebpageReference(webPage), media: image), caption: caption, credit: credit, location: self.location, openUrl: openUrl, openUrlOptions: openUrlOptions) + return InstantImageGalleryItem(context: context, presentationData: presentationData, itemId: self.index, imageReference: .webPage(webPage: WebpageReference(webPage), media: image), caption: caption, credit: credit, location: self.location, openUrl: openUrl, openUrlOptions: openUrlOptions) } } else if let embedWebpage = self.media.media as? TelegramMediaWebpage, case let .Loaded(webpageContent) = embedWebpage.content { if let content = WebEmbedVideoContent(webPage: embedWebpage, webpageContent: webpageContent) { diff --git a/submodules/MtProtoKit/MTBackupAddressSignals.m b/submodules/MtProtoKit/MTBackupAddressSignals.m index 515c1c90f6..6de20c310f 100644 --- a/submodules/MtProtoKit/MTBackupAddressSignals.m +++ b/submodules/MtProtoKit/MTBackupAddressSignals.m @@ -227,6 +227,8 @@ static NSString *makeRandomPadding() { + (MTSignal *)fetchConfigFromAddress:(MTBackupDatacenterAddress *)address currentContext:(MTContext *)currentContext { MTApiEnvironment *apiEnvironment = [currentContext.apiEnvironment copy]; + apiEnvironment = [apiEnvironment withUpdatedSocksProxySettings:nil]; + NSMutableDictionary *datacenterAddressOverrides = [[NSMutableDictionary alloc] init]; datacenterAddressOverrides[@(address.datacenterId)] = [[MTDatacenterAddress alloc] initWithIp:address.ip port:(uint16_t)address.port preferForMedia:false restrictToTcp:false cdn:false preferForProxy:false secret:address.secret]; diff --git a/submodules/PassportUI/Sources/SecureIdDocumentGalleryController.swift b/submodules/PassportUI/Sources/SecureIdDocumentGalleryController.swift index b2604b8881..c7f7ccdf4c 100644 --- a/submodules/PassportUI/Sources/SecureIdDocumentGalleryController.swift +++ b/submodules/PassportUI/Sources/SecureIdDocumentGalleryController.swift @@ -31,7 +31,7 @@ struct SecureIdDocumentGalleryEntry: Equatable { } func item(context: AccountContext, theme: PresentationTheme, strings: PresentationStrings, secureIdContext: SecureIdAccessContext, delete: @escaping (TelegramMediaResource) -> Void) -> GalleryItem { - return SecureIdDocumentGalleryItem(context: context, theme: theme, strings: strings, secureIdContext: secureIdContext, resource: self.resource, caption: self.error, location: self.location, delete: { + return SecureIdDocumentGalleryItem(context: context, theme: theme, strings: strings, secureIdContext: secureIdContext, itemId: self.index, resource: self.resource, caption: self.error, location: self.location, delete: { delete(self.resource) }) } diff --git a/submodules/PassportUI/Sources/SecureIdDocumentImageGalleryItem.swift b/submodules/PassportUI/Sources/SecureIdDocumentImageGalleryItem.swift index 857c233cc3..d1315f41a7 100644 --- a/submodules/PassportUI/Sources/SecureIdDocumentImageGalleryItem.swift +++ b/submodules/PassportUI/Sources/SecureIdDocumentImageGalleryItem.swift @@ -12,6 +12,12 @@ import PhotoResources import GalleryUI class SecureIdDocumentGalleryItem: GalleryItem { + var id: AnyHashable { + return self.itemId + } + + let itemId: AnyHashable + let context: AccountContext let theme: PresentationTheme let strings: PresentationStrings @@ -21,7 +27,8 @@ class SecureIdDocumentGalleryItem: GalleryItem { let location: SecureIdDocumentGalleryEntryLocation let delete: () -> Void - init(context: AccountContext, theme: PresentationTheme, strings: PresentationStrings, secureIdContext: SecureIdAccessContext, resource: TelegramMediaResource, caption: String, location: SecureIdDocumentGalleryEntryLocation, delete: @escaping () -> Void) { + init(context: AccountContext, theme: PresentationTheme, strings: PresentationStrings, secureIdContext: SecureIdAccessContext, itemId: AnyHashable, resource: TelegramMediaResource, caption: String, location: SecureIdDocumentGalleryEntryLocation, delete: @escaping () -> Void) { + self.itemId = itemId self.context = context self.theme = theme self.strings = strings diff --git a/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryController.swift b/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryController.swift index 2e42e1f680..1035a78876 100644 --- a/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryController.swift +++ b/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryController.swift @@ -11,15 +11,29 @@ import TelegramPresentationData import AccountContext import GalleryUI +public enum AvatarGalleryEntryId: Hashable { + case topImage + case image(MediaId) +} + public enum AvatarGalleryEntry: Equatable { case topImage([ImageRepresentationWithReference], GalleryItemIndexData?) - case image(TelegramMediaImageReference?, [ImageRepresentationWithReference], Peer?, Int32, GalleryItemIndexData?, MessageId?) + case image(MediaId, TelegramMediaImageReference?, [ImageRepresentationWithReference], Peer?, Int32, GalleryItemIndexData?, MessageId?) + + public var id: AvatarGalleryEntryId { + switch self { + case .topImage: + return .topImage + case let .image(image): + return .image(image.0) + } + } public var representations: [ImageRepresentationWithReference] { switch self { case let .topImage(representations, _): return representations - case let .image(_, representations, _, _, _, _): + case let .image(_, _, representations, _, _, _, _): return representations } } @@ -28,7 +42,7 @@ public enum AvatarGalleryEntry: Equatable { switch self { case let .topImage(_, indexData): return indexData - case let .image(_, _, _, _, indexData, _): + case let .image(_, _, _, _, _, indexData, _): return indexData } } @@ -41,8 +55,8 @@ public enum AvatarGalleryEntry: Equatable { } else { return false } - case let .image(lhsImageReference, lhsRepresentations, lhsPeer, lhsDate, lhsIndexData, lhsMessageId): - if case let .image(rhsImageReference, rhsRepresentations, rhsPeer, rhsDate, rhsIndexData, rhsMessageId) = rhs, lhsImageReference == rhsImageReference, lhsRepresentations == rhsRepresentations, arePeersEqual(lhsPeer, rhsPeer), lhsDate == rhsDate, lhsIndexData == rhsIndexData, lhsMessageId == rhsMessageId { + case let .image(lhsId, lhsImageReference, lhsRepresentations, lhsPeer, lhsDate, lhsIndexData, lhsMessageId): + if case let .image(rhsId, rhsImageReference, rhsRepresentations, rhsPeer, rhsDate, rhsIndexData, rhsMessageId) = rhs, lhsId == rhsId, lhsImageReference == rhsImageReference, lhsRepresentations == rhsRepresentations, arePeersEqual(lhsPeer, rhsPeer), lhsDate == rhsDate, lhsIndexData == rhsIndexData, lhsMessageId == rhsMessageId { return true } else { return false @@ -84,9 +98,9 @@ public func fetchedAvatarGalleryEntries(account: Account, peer: Peer) -> Signal< for photo in photos { let indexData = GalleryItemIndexData(position: index, totalCount: Int32(photos.count)) if result.isEmpty, let first = initialEntries.first { - result.append(.image(photo.image.reference, first.representations, peer, photo.date, indexData, photo.messageId)) + result.append(.image(photo.image.imageId, photo.image.reference, first.representations, peer, photo.date, indexData, photo.messageId)) } else { - result.append(.image(photo.image.reference, photo.image.representations.map({ ImageRepresentationWithReference(representation: $0, reference: MediaResourceReference.standalone(resource: $0.resource)) }), peer, photo.date, indexData, photo.messageId)) + result.append(.image(photo.image.imageId, photo.image.reference, photo.image.representations.map({ ImageRepresentationWithReference(representation: $0, reference: MediaResourceReference.standalone(resource: $0.resource)) }), peer, photo.date, indexData, photo.messageId)) } index += 1 } @@ -111,9 +125,9 @@ public func fetchedAvatarGalleryEntries(account: Account, peer: Peer, firstEntry for photo in photos { let indexData = GalleryItemIndexData(position: index, totalCount: Int32(photos.count)) if result.isEmpty, let first = initialEntries.first { - result.append(.image(photo.image.reference, first.representations, peer, photo.date, indexData, photo.messageId)) + result.append(.image(photo.image.imageId, photo.image.reference, first.representations, peer, photo.date, indexData, photo.messageId)) } else { - result.append(.image(photo.image.reference, photo.image.representations.map({ ImageRepresentationWithReference(representation: $0, reference: MediaResourceReference.standalone(resource: $0.resource)) }), peer, photo.date, indexData, photo.messageId)) + result.append(.image(photo.image.imageId, photo.image.reference, photo.image.representations.map({ ImageRepresentationWithReference(representation: $0, reference: MediaResourceReference.standalone(resource: $0.resource)) }), peer, photo.date, indexData, photo.messageId)) } index += 1 } @@ -130,6 +144,7 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr private let context: AccountContext private let peer: Peer + private let sourceHasRoundCorners: Bool private var presentationData: PresentationData @@ -159,12 +174,15 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr private let replaceRootController: (ViewController, ValuePromise?) -> Void - public init(context: AccountContext, peer: Peer, remoteEntries: Promise<[AvatarGalleryEntry]>? = nil, replaceRootController: @escaping (ViewController, ValuePromise?) -> Void, synchronousLoad: Bool = false) { + public init(context: AccountContext, peer: Peer, sourceHasRoundCorners: Bool = true, remoteEntries: Promise<[AvatarGalleryEntry]>? = nil, centralEntryIndex: Int? = nil, replaceRootController: @escaping (ViewController, ValuePromise?) -> Void, synchronousLoad: Bool = false) { self.context = context self.peer = peer + self.sourceHasRoundCorners = sourceHasRoundCorners self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.replaceRootController = replaceRootController + self.centralEntryIndex = centralEntryIndex + super.init(navigationBarPresentationData: NavigationBarPresentationData(theme: GalleryController.darkNavigationTheme, strings: NavigationBarStrings(presentationStrings: self.presentationData.strings))) let backItem = UIBarButtonItem(backButtonAppearanceWithTitle: self.presentationData.strings.Common_Back, target: self, action: #selector(self.donePressed)) @@ -196,7 +214,9 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr let f: () -> Void = { if let strongSelf = self { strongSelf.entries = entries - strongSelf.centralEntryIndex = 0 + if strongSelf.centralEntryIndex == nil { + strongSelf.centralEntryIndex = 0 + } if strongSelf.isViewLoaded { let canDelete: Bool if strongSelf.peer.id == strongSelf.context.account.peerId { @@ -213,7 +233,7 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr } else { canDelete = false } - strongSelf.galleryNode.pager.replaceItems(strongSelf.entries.map({ entry in PeerAvatarImageGalleryItem(context: context, peer: peer, presentationData: presentationData, entry: entry, delete: canDelete ? { + strongSelf.galleryNode.pager.replaceItems(strongSelf.entries.map({ entry in PeerAvatarImageGalleryItem(context: context, peer: peer, presentationData: presentationData, entry: entry, sourceHasRoundCorners: sourceHasRoundCorners, delete: canDelete ? { self?.deleteEntry(entry) } : nil) }), centralItemIndex: 0, keepFirst: true) @@ -296,7 +316,7 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr if let centralItemNode = self.galleryNode.pager.centralItemNode(), let presentationArguments = self.presentationArguments as? AvatarGalleryControllerPresentationArguments { if !self.entries.isEmpty { - if centralItemNode.index == 0, let transitionArguments = presentationArguments.transitionArguments(self.entries[centralItemNode.index]), !forceAway { + if (centralItemNode.index == 0 || !self.sourceHasRoundCorners), let transitionArguments = presentationArguments.transitionArguments(self.entries[centralItemNode.index]), !forceAway { animatedOutNode = false centralItemNode.animateOut(to: transitionArguments.transitionNode, addToTransitionSurface: transitionArguments.addToTransitionSurface, completion: { animatedOutNode = true @@ -333,7 +353,7 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr self.galleryNode.transitionDataForCentralItem = { [weak self] in if let strongSelf = self { if let centralItemNode = strongSelf.galleryNode.pager.centralItemNode(), let presentationArguments = strongSelf.presentationArguments as? AvatarGalleryControllerPresentationArguments { - if centralItemNode.index != 0 { + if centralItemNode.index != 0 && strongSelf.sourceHasRoundCorners { return nil } if let transitionArguments = presentationArguments.transitionArguments(strongSelf.entries[centralItemNode.index]) { @@ -365,7 +385,7 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr } let presentationData = self.presentationData - self.galleryNode.pager.replaceItems(self.entries.map({ entry in PeerAvatarImageGalleryItem(context: self.context, peer: peer, presentationData: presentationData, entry: entry, delete: canDelete ? { [weak self] in + self.galleryNode.pager.replaceItems(self.entries.map({ entry in PeerAvatarImageGalleryItem(context: self.context, peer: peer, presentationData: presentationData, entry: entry, sourceHasRoundCorners: self.sourceHasRoundCorners, delete: canDelete ? { [weak self] in self?.deleteEntry(entry) } : nil) }), centralItemIndex: self.centralEntryIndex) @@ -469,7 +489,7 @@ public class AvatarGalleryController: ViewController, StandalonePresentableContr } } } - case let .image(reference, _, _, _, _, messageId): + case let .image(_, reference, _, _, _, _, messageId): if self.peer.id == self.context.account.peerId { if let reference = reference { let _ = removeAccountPhoto(network: self.context.account.network, reference: reference).start() diff --git a/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryItemFooterContentNode.swift b/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryItemFooterContentNode.swift index 01cc3e6394..5bfda46d5a 100644 --- a/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryItemFooterContentNode.swift +++ b/submodules/PeerAvatarGalleryUI/Sources/AvatarGalleryItemFooterContentNode.swift @@ -84,7 +84,7 @@ final class AvatarGalleryItemFooterContentNode: GalleryFooterContentNode { var nameText: String? var dateText: String? switch entry { - case let .image(_, _, peer, date, _, _): + case let .image(_, _, _, peer, date, _, _): nameText = peer?.displayTitle(strings: self.presentationData.strings, displayOrder: self.presentationData.nameDisplayOrder) ?? "" dateText = humanReadableStringForTimestamp(strings: self.strings, dateTimeFormat: self.dateTimeFormat, timestamp: date) default: diff --git a/submodules/PeerAvatarGalleryUI/Sources/PeerAvatarImageGalleryItem.swift b/submodules/PeerAvatarGalleryUI/Sources/PeerAvatarImageGalleryItem.swift index 995ce56263..45415eef19 100644 --- a/submodules/PeerAvatarGalleryUI/Sources/PeerAvatarImageGalleryItem.swift +++ b/submodules/PeerAvatarGalleryUI/Sources/PeerAvatarImageGalleryItem.swift @@ -42,22 +42,28 @@ private struct PeerAvatarImageGalleryThumbnailItem: GalleryThumbnailItem { } class PeerAvatarImageGalleryItem: GalleryItem { + var id: AnyHashable { + return self.entry.id + } + let context: AccountContext let peer: Peer let presentationData: PresentationData let entry: AvatarGalleryEntry + let sourceHasRoundCorners: Bool let delete: (() -> Void)? - init(context: AccountContext, peer: Peer, presentationData: PresentationData, entry: AvatarGalleryEntry, delete: (() -> Void)?) { + init(context: AccountContext, peer: Peer, presentationData: PresentationData, entry: AvatarGalleryEntry, sourceHasRoundCorners: Bool, delete: (() -> Void)?) { self.context = context self.peer = peer self.presentationData = presentationData self.entry = entry + self.sourceHasRoundCorners = sourceHasRoundCorners self.delete = delete } func node() -> GalleryItemNode { - let node = PeerAvatarImageGalleryItemNode(context: self.context, presentationData: self.presentationData, peer: self.peer) + let node = PeerAvatarImageGalleryItemNode(context: self.context, presentationData: self.presentationData, peer: self.peer, sourceHasRoundCorners: self.sourceHasRoundCorners) if let indexData = self.entry.indexData { node._title.set(.single(self.presentationData.strings.Items_NOfM("\(indexData.position + 1)", "\(indexData.totalCount)").0)) @@ -85,7 +91,7 @@ class PeerAvatarImageGalleryItem: GalleryItem { switch self.entry { case let .topImage(representations, _): content = representations - case let .image(_, representations, _, _, _, _): + case let .image(_, _, representations, _, _, _, _): content = representations } @@ -96,6 +102,7 @@ class PeerAvatarImageGalleryItem: GalleryItem { final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { private let context: AccountContext private let peer: Peer + private let sourceHasRoundCorners: Bool private var entry: AvatarGalleryEntry? @@ -110,9 +117,10 @@ final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { private let statusDisposable = MetaDisposable() private var status: MediaResourceStatus? - init(context: AccountContext, presentationData: PresentationData, peer: Peer) { + init(context: AccountContext, presentationData: PresentationData, peer: Peer, sourceHasRoundCorners: Bool) { self.context = context self.peer = peer + self.sourceHasRoundCorners = sourceHasRoundCorners self.imageNode = TransformImageNode() self.footerContentNode = AvatarGalleryItemFooterContentNode(context: context, presentationData: presentationData) @@ -175,7 +183,7 @@ final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { switch entry { case let .topImage(topRepresentations, _): representations = topRepresentations - case let .image(_, imageRepresentations, _, _, _, _): + case let .image(_, _, imageRepresentations, _, _, _, _): representations = imageRepresentations } self.imageNode.setSignal(chatAvatarGalleryPhoto(account: self.context.account, representations: representations), dispatchOnDisplayLink: false) @@ -235,10 +243,44 @@ final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { let transformedSuperFrame = node.0.view.convert(node.0.view.bounds, to: self.imageNode.view.superview) let transformedSelfFrame = node.0.view.convert(node.0.view.bounds, to: self.view) let transformedCopyViewFinalFrame = self.imageNode.view.convert(self.imageNode.view.bounds, to: self.view) + let scaledLocalImageViewBounds = self.imageNode.view.bounds - let copyView = node.2().0! + let copyViewContents = node.2().0! + let copyView = UIView() + copyView.addSubview(copyViewContents) + copyViewContents.frame = CGRect(origin: CGPoint(x: (transformedSelfFrame.width - copyViewContents.frame.width) / 2.0, y: (transformedSelfFrame.height - copyViewContents.frame.height) / 2.0), size: copyViewContents.frame.size) + copyView.layer.sublayerTransform = CATransform3DMakeScale(transformedSelfFrame.width / copyViewContents.frame.width, transformedSelfFrame.height / copyViewContents.frame.height, 1.0) - self.view.insertSubview(copyView, belowSubview: self.scrollNode.view) + let surfaceCopyViewContents = node.2().0! + let surfaceCopyView = UIView() + surfaceCopyView.addSubview(surfaceCopyViewContents) + + addToTransitionSurface(surfaceCopyView) + + var transformedSurfaceFrame: CGRect? + var transformedSurfaceFinalFrame: CGRect? + if let contentSurface = surfaceCopyView.superview { + transformedSurfaceFrame = node.0.view.convert(node.0.view.bounds, to: contentSurface) + transformedSurfaceFinalFrame = self.imageNode.view.convert(scaledLocalImageViewBounds, to: contentSurface) + } + + if let transformedSurfaceFrame = transformedSurfaceFrame, let transformedSurfaceFinalFrame = transformedSurfaceFinalFrame { + surfaceCopyViewContents.frame = CGRect(origin: CGPoint(x: (transformedSurfaceFrame.width - surfaceCopyViewContents.frame.width) / 2.0, y: (transformedSurfaceFrame.height - surfaceCopyViewContents.frame.height) / 2.0), size: surfaceCopyViewContents.frame.size) + surfaceCopyView.layer.sublayerTransform = CATransform3DMakeScale(transformedSurfaceFrame.width / surfaceCopyViewContents.frame.width, transformedSurfaceFrame.height / surfaceCopyViewContents.frame.height, 1.0) + surfaceCopyView.frame = transformedSurfaceFrame + + surfaceCopyView.layer.animatePosition(from: CGPoint(x: transformedSurfaceFrame.midX, y: transformedSurfaceFrame.midY), to: CGPoint(x: transformedSurfaceFinalFrame.midX, y: transformedSurfaceFinalFrame.midY), duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false) + let scale = CGSize(width: transformedSurfaceFinalFrame.size.width / transformedSurfaceFrame.size.width, height: transformedSurfaceFrame.size.height / transformedSelfFrame.size.height) + surfaceCopyView.layer.animate(from: NSValue(caTransform3D: CATransform3DIdentity), to: NSValue(caTransform3D: CATransform3DMakeScale(scale.width, scale.height, 1.0)), keyPath: "transform", timingFunction: kCAMediaTimingFunctionSpring, duration: 0.25, removeOnCompletion: false) + + surfaceCopyView.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.25, removeOnCompletion: false, completion: { [weak surfaceCopyView] _ in + surfaceCopyView?.removeFromSuperview() + }) + } + + if self.sourceHasRoundCorners { + self.view.insertSubview(copyView, belowSubview: self.scrollNode.view) + } copyView.frame = transformedSelfFrame copyView.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.25, removeOnCompletion: false, completion: { [weak copyView] _ in @@ -259,11 +301,13 @@ final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { self.imageNode.layer.animate(from: NSValue(caTransform3D: transform), to: NSValue(caTransform3D: self.imageNode.layer.transform), keyPath: "transform", timingFunction: kCAMediaTimingFunctionSpring, duration: 0.25) self.imageNode.clipsToBounds = true - self.imageNode.layer.animate(from: (self.imageNode.frame.width / 2.0) as NSNumber, to: 0.0 as NSNumber, keyPath: "cornerRadius", timingFunction: CAMediaTimingFunctionName.default.rawValue, duration: 0.18, removeOnCompletion: false, completion: { [weak self] value in - if value { - self?.imageNode.clipsToBounds = false - } - }) + if self.sourceHasRoundCorners { + self.imageNode.layer.animate(from: (self.imageNode.frame.width / 2.0) as NSNumber, to: 0.0 as NSNumber, keyPath: "cornerRadius", timingFunction: CAMediaTimingFunctionName.default.rawValue, duration: 0.18, removeOnCompletion: false, completion: { [weak self] value in + if value { + self?.imageNode.clipsToBounds = false + } + }) + } self.statusNodeContainer.layer.animatePosition(from: CGPoint(x: transformedSuperFrame.midX, y: transformedSuperFrame.midY), to: self.statusNodeContainer.position, duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring) self.statusNodeContainer.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring) @@ -279,20 +323,49 @@ final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { var positionCompleted = false var boundsCompleted = false var copyCompleted = false + var surfaceCopyCompleted = false let copyView = node.2().0! - self.view.insertSubview(copyView, belowSubview: self.scrollNode.view) + if self.sourceHasRoundCorners { + self.view.insertSubview(copyView, belowSubview: self.scrollNode.view) + } copyView.frame = transformedSelfFrame - let intermediateCompletion = { [weak copyView] in + let surfaceCopyView = node.2().0! + if !self.sourceHasRoundCorners { + addToTransitionSurface(surfaceCopyView) + } + + var transformedSurfaceFrame: CGRect? + var transformedSurfaceCopyViewInitialFrame: CGRect? + if let contentSurface = surfaceCopyView.superview { + transformedSurfaceFrame = node.0.view.convert(node.0.view.bounds, to: contentSurface) + transformedSurfaceCopyViewInitialFrame = self.imageNode.view.convert(self.imageNode.view.bounds, to: contentSurface) + } + + let durationFactor = 1.0 + + let intermediateCompletion = { [weak copyView, weak surfaceCopyView] in if positionCompleted && boundsCompleted && copyCompleted { copyView?.removeFromSuperview() + surfaceCopyView?.removeFromSuperview() completion() } } - let durationFactor = 1.0 + if let transformedSurfaceFrame = transformedSurfaceFrame, let transformedSurfaceCopyViewInitialFrame = transformedSurfaceCopyViewInitialFrame { + surfaceCopyView.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.1 * durationFactor, removeOnCompletion: false) + + surfaceCopyView.layer.animatePosition(from: CGPoint(x: transformedSurfaceCopyViewInitialFrame.midX, y: transformedSurfaceCopyViewInitialFrame.midY), to: CGPoint(x: transformedSurfaceFrame.midX, y: transformedSurfaceFrame.midY), duration: 0.25 * durationFactor, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false) + let scale = CGSize(width: transformedSurfaceCopyViewInitialFrame.size.width / transformedSurfaceFrame.size.width, height: transformedSurfaceCopyViewInitialFrame.size.height / transformedSurfaceFrame.size.height) + surfaceCopyView.layer.animate(from: NSValue(caTransform3D: CATransform3DMakeScale(scale.width, scale.height, 1.0)), to: NSValue(caTransform3D: CATransform3DIdentity), keyPath: "transform", timingFunction: kCAMediaTimingFunctionSpring, duration: 0.25 * durationFactor, removeOnCompletion: false, completion: { _ in + surfaceCopyCompleted = true + intermediateCompletion() + }) + } else { + surfaceCopyCompleted = true + } copyView.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.1 * durationFactor, removeOnCompletion: false) @@ -319,7 +392,9 @@ final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { }) self.imageNode.clipsToBounds = true - self.imageNode.layer.animate(from: 0.0 as NSNumber, to: (self.imageNode.frame.width / 2.0) as NSNumber, keyPath: "cornerRadius", timingFunction: CAMediaTimingFunctionName.default.rawValue, duration: 0.18 * durationFactor, removeOnCompletion: false) + if self.sourceHasRoundCorners { + self.imageNode.layer.animate(from: 0.0 as NSNumber, to: (self.imageNode.frame.width / 2.0) as NSNumber, keyPath: "cornerRadius", timingFunction: CAMediaTimingFunctionName.default.rawValue, duration: 0.18 * durationFactor, removeOnCompletion: false) + } self.statusNodeContainer.layer.animatePosition(from: self.statusNodeContainer.position, to: CGPoint(x: transformedSuperFrame.midX, y: transformedSuperFrame.midY), duration: 0.25, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false) self.statusNodeContainer.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15, timingFunction: CAMediaTimingFunctionName.easeIn.rawValue, removeOnCompletion: false) @@ -343,7 +418,7 @@ final class PeerAvatarImageGalleryItemNode: ZoomableContentGalleryItemNode { switch entry { case let .topImage(topRepresentations, _): representations = topRepresentations - case let .image(_, imageRepresentations, _, _, _, _): + case let .image(_, _, imageRepresentations, _, _, _, _): representations = imageRepresentations } diff --git a/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift b/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift index ae1d09dd9c..1364132297 100644 --- a/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift +++ b/submodules/PeerInfoUI/Sources/ItemListCallListItem.swift @@ -11,22 +11,24 @@ import ItemListUI import PresentationDataUtils import TelegramStringFormatting -class ItemListCallListItem: ListViewItem, ItemListItem { +public class ItemListCallListItem: ListViewItem, ItemListItem { let presentationData: ItemListPresentationData let dateTimeFormat: PresentationDateTimeFormat let messages: [Message] - let sectionId: ItemListSectionId + public let sectionId: ItemListSectionId let style: ItemListStyle + let displayDecorations: Bool - init(presentationData: ItemListPresentationData, dateTimeFormat: PresentationDateTimeFormat, messages: [Message], sectionId: ItemListSectionId, style: ItemListStyle) { + public init(presentationData: ItemListPresentationData, dateTimeFormat: PresentationDateTimeFormat, messages: [Message], sectionId: ItemListSectionId, style: ItemListStyle, displayDecorations: Bool = true) { self.presentationData = presentationData self.dateTimeFormat = dateTimeFormat self.messages = messages self.sectionId = sectionId self.style = style + self.displayDecorations = displayDecorations } - func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { + public func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { async { let node = ItemListCallListItemNode() let (layout, apply) = node.asyncLayout()(self, params, itemListNeighbors(item: self, topItem: previousItem as? ItemListItem, bottomItem: nextItem as? ItemListItem)) @@ -42,7 +44,7 @@ class ItemListCallListItem: ListViewItem, ItemListItem { } } - func updateNode(async: @escaping (@escaping () -> Void) -> Void, node: @escaping () -> ListViewItemNode, params: ListViewItemLayoutParams, previousItem: ListViewItem?, nextItem: ListViewItem?, animation: ListViewItemUpdateAnimation, completion: @escaping (ListViewItemNodeLayout, @escaping (ListViewItemApply) -> Void) -> Void) { + public func updateNode(async: @escaping (@escaping () -> Void) -> Void, node: @escaping () -> ListViewItemNode, params: ListViewItemLayoutParams, previousItem: ListViewItem?, nextItem: ListViewItem?, animation: ListViewItemUpdateAnimation, completion: @escaping (ListViewItemNodeLayout, @escaping (ListViewItemApply) -> Void) -> Void) { Queue.mainQueue().async { if let nodeValue = node() as? ItemListCallListItemNode { let makeLayout = nodeValue.asyncLayout() @@ -97,7 +99,7 @@ private func stringForCallType(message: Message, strings: PresentationStrings) - return string } -class ItemListCallListItemNode: ListViewItemNode { +public class ItemListCallListItemNode: ListViewItemNode { private let backgroundNode: ASDisplayNode private let topStripeNode: ASDisplayNode private let bottomStripeNode: ASDisplayNode @@ -109,11 +111,11 @@ class ItemListCallListItemNode: ListViewItemNode { private var item: ItemListCallListItem? - override var canBeSelected: Bool { + override public var canBeSelected: Bool { return false } - init() { + public init() { self.backgroundNode = ASDisplayNode() self.backgroundNode.isLayerBacked = true self.backgroundNode.backgroundColor = .white @@ -138,7 +140,7 @@ class ItemListCallListItemNode: ListViewItemNode { self.addSubnode(self.accessibilityArea) } - func asyncLayout() -> (_ item: ItemListCallListItem, _ params: ListViewItemLayoutParams, _ insets: ItemListNeighbors) -> (ListViewItemNodeLayout, () -> Void) { + public func asyncLayout() -> (_ item: ItemListCallListItem, _ params: ListViewItemLayoutParams, _ insets: ItemListNeighbors) -> (ListViewItemNodeLayout, () -> Void) { let makeTitleLayout = TextNode.asyncLayout(self.titleNode) let currentItem = self.item @@ -185,7 +187,7 @@ class ItemListCallListItemNode: ListViewItemNode { let contentSize: CGSize var contentHeight: CGFloat = 0.0 - let insets: UIEdgeInsets + var insets: UIEdgeInsets let separatorHeight = UIScreenPixel let itemBackgroundColor: UIColor let itemSeparatorColor: UIColor @@ -193,14 +195,18 @@ class ItemListCallListItemNode: ListViewItemNode { let leftInset = 16.0 + params.leftInset switch item.style { - case .plain: - itemBackgroundColor = item.presentationData.theme.list.plainBackgroundColor - itemSeparatorColor = item.presentationData.theme.list.itemPlainSeparatorColor - insets = itemListNeighborsPlainInsets(neighbors) - case .blocks: - itemBackgroundColor = item.presentationData.theme.list.itemBlocksBackgroundColor - itemSeparatorColor = item.presentationData.theme.list.itemBlocksSeparatorColor - insets = itemListNeighborsGroupedInsets(neighbors) + case .plain: + itemBackgroundColor = item.presentationData.theme.list.plainBackgroundColor + itemSeparatorColor = item.presentationData.theme.list.itemPlainSeparatorColor + insets = itemListNeighborsPlainInsets(neighbors) + case .blocks: + itemBackgroundColor = item.presentationData.theme.list.itemBlocksBackgroundColor + itemSeparatorColor = item.presentationData.theme.list.itemBlocksSeparatorColor + insets = itemListNeighborsGroupedInsets(neighbors) + } + + if !item.displayDecorations { + insets = UIEdgeInsets() } let earliestMessage = item.messages.sorted(by: {$0.timestamp < $1.timestamp}).first! @@ -277,8 +283,10 @@ class ItemListCallListItemNode: ListViewItemNode { case .sameSection(false): strongSelf.topStripeNode.isHidden = true default: - strongSelf.topStripeNode.isHidden = false + strongSelf.topStripeNode.isHidden = !item.displayDecorations } + strongSelf.bottomStripeNode.isHidden = !item.displayDecorations + strongSelf.backgroundNode.isHidden = !item.displayDecorations let bottomStripeInset: CGFloat switch neighbors.bottom { case .sameSection(false): @@ -311,15 +319,15 @@ class ItemListCallListItemNode: ListViewItemNode { } } - override func animateInsertion(_ currentTimestamp: Double, duration: Double, short: Bool) { + override public func animateInsertion(_ currentTimestamp: Double, duration: Double, short: Bool) { self.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.4) } - override func animateAdded(_ currentTimestamp: Double, duration: Double) { + override public func animateAdded(_ currentTimestamp: Double, duration: Double) { self.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) } - override func animateRemoved(_ currentTimestamp: Double, duration: Double) { + override public func animateRemoved(_ currentTimestamp: Double, duration: Double) { self.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15, removeOnCompletion: false) } } diff --git a/submodules/PeerInfoUI/Sources/SecretChatKeyController.swift b/submodules/PeerInfoUI/Sources/SecretChatKeyController.swift index baec51f9b6..fb309cd499 100644 --- a/submodules/PeerInfoUI/Sources/SecretChatKeyController.swift +++ b/submodules/PeerInfoUI/Sources/SecretChatKeyController.swift @@ -8,7 +8,7 @@ import Postbox import TelegramPresentationData import AccountContext -final class SecretChatKeyController: ViewController { +public final class SecretChatKeyController: ViewController { private var controllerNode: SecretChatKeyControllerNode { return self.displayNode as! SecretChatKeyControllerNode } @@ -19,7 +19,7 @@ final class SecretChatKeyController: ViewController { private var presentationData: PresentationData - init(context: AccountContext, fingerprint: SecretChatKeyFingerprint, peer: Peer) { + public init(context: AccountContext, fingerprint: SecretChatKeyFingerprint, peer: Peer) { self.context = context self.fingerprint = fingerprint self.peer = peer @@ -34,11 +34,11 @@ final class SecretChatKeyController: ViewController { self.title = self.presentationData.strings.EncryptionKey_Title } - required init(coder aDecoder: NSCoder) { + required public init(coder aDecoder: NSCoder) { fatalError("init(coder:) has not been implemented") } - override func loadDisplayNode() { + override public func loadDisplayNode() { self.displayNode = SecretChatKeyControllerNode(context: self.context, presentationData: self.presentationData, fingerprint: self.fingerprint, peer: self.peer, getNavigationController: { [weak self] in return self?.navigationController as? NavigationController }) diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift index de7ea72d05..0157a7c7ba 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift @@ -297,7 +297,7 @@ public class WallpaperGalleryController: ViewController { var i: Int = 0 var updateItems: [GalleryPagerUpdateItem] = [] for entry in entries { - let item = GalleryPagerUpdateItem(index: i, previousIndex: i, item: WallpaperGalleryItem(context: self.context, entry: entry, arguments: arguments, source: self.source)) + let item = GalleryPagerUpdateItem(index: i, previousIndex: i, item: WallpaperGalleryItem(context: self.context, index: updateItems.count, entry: entry, arguments: arguments, source: self.source)) updateItems.append(item) i += 1 } @@ -660,7 +660,7 @@ public class WallpaperGalleryController: ViewController { colors = true } - self.galleryNode.pager.replaceItems(self.entries.map({ WallpaperGalleryItem(context: self.context, entry: $0, arguments: WallpaperGalleryItemArguments(isColorsList: colors), source: self.source) }), centralItemIndex: self.centralEntryIndex) + self.galleryNode.pager.replaceItems(zip(0 ..< self.entries.count, self.entries).map({ WallpaperGalleryItem(context: self.context, index: $0, entry: $1, arguments: WallpaperGalleryItemArguments(isColorsList: colors), source: self.source) }), centralItemIndex: self.centralEntryIndex) if let initialOptions = self.initialOptions, let itemNode = self.galleryNode.pager.centralItemNode() as? WallpaperGalleryItemNode { itemNode.options = initialOptions diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift index a159690102..07774073d6 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift @@ -32,13 +32,20 @@ struct WallpaperGalleryItemArguments { } class WallpaperGalleryItem: GalleryItem { + var id: AnyHashable { + return self.index + } + + let index: Int + let context: AccountContext let entry: WallpaperGalleryEntry let arguments: WallpaperGalleryItemArguments let source: WallpaperListSource - init(context: AccountContext, entry: WallpaperGalleryEntry, arguments: WallpaperGalleryItemArguments, source: WallpaperListSource) { + init(context: AccountContext, index: Int, entry: WallpaperGalleryEntry, arguments: WallpaperGalleryItemArguments, source: WallpaperListSource) { self.context = context + self.index = index self.entry = entry self.arguments = arguments self.source = source diff --git a/submodules/TelegramCore/Sources/GroupsInCommon.swift b/submodules/TelegramCore/Sources/GroupsInCommon.swift index 2a6d4eb7cf..85e72c3aac 100644 --- a/submodules/TelegramCore/Sources/GroupsInCommon.swift +++ b/submodules/TelegramCore/Sources/GroupsInCommon.swift @@ -66,18 +66,21 @@ private final class GroupsInCommonContextImpl { |> mapToSignal { result -> Signal<([Peer], Int), NoError> in let chats: [Api.Chat] let count: Int? - switch result { - case .none: + if let result = result { + switch result { + case let .chats(apiChats): + chats = apiChats + count = nil + case let .chatsSlice(apiCount, apiChats): + chats = apiChats + count = Int(apiCount) + } + } else { chats = [] count = nil - case let .chats(apiChats): - chats = apiChats - count = nil - case let .chatsSlice(apiCount, apiChats): - chats = apiChats - count = Int(apiCount) } + return postbox.transaction { transaction -> ([Peer], Int) in var peers: [Peer] = [] for chat in chats { diff --git a/submodules/TelegramCore/Sources/Holes.swift b/submodules/TelegramCore/Sources/Holes.swift index 1ebe27461e..89e71dfeef 100644 --- a/submodules/TelegramCore/Sources/Holes.swift +++ b/submodules/TelegramCore/Sources/Holes.swift @@ -366,7 +366,23 @@ 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 = storeMessages.compactMap { message -> MessageId.Id? in + switch message.id { + case let .Id(id): + switch space { + case let .tag(tag): + if !message.tags.contains(tag) { + return nil + } else { + return id.id + } + case .everywhere: + return id.id + } + case .Partial: + return nil + } + } if ids.count == 0 || implicitelyFillHole { filledRange = minMaxRange } else { diff --git a/submodules/TelegramCore/Sources/ManagedChatListHoles.swift b/submodules/TelegramCore/Sources/ManagedChatListHoles.swift index ce36e13ef9..c0a8885162 100644 --- a/submodules/TelegramCore/Sources/ManagedChatListHoles.swift +++ b/submodules/TelegramCore/Sources/ManagedChatListHoles.swift @@ -59,7 +59,9 @@ func managedChatListHoles(network: Network, postbox: Postbox, accountPeerId: Pee let disposable = combineLatest(postbox.chatListHolesView(), topRootHole).start(next: { view, topRootHoleView in var additionalLatestHole: ChatListHole? if let topRootHole = topRootHoleView.views[topRootHoleKey] as? AllChatListHolesView { - //additionalLatestHole = topRootHole.latestHole + #if os(macOS) + additionalLatestHole = topRootHole.latestHole + #endif } let (removed, added, addedAdditionalLatestHole) = state.with { state in diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index acb68d246d..df5ea4620e 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -438,4308 +438,4319 @@ public final class PresentationStrings: Equatable { public func Message_StickerText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[239]!, self._r[239]!, [_0]) } - public var PasscodeSettings_AlphanumericCode: String { return self._s[240]! } - public var Localization_LanguageOther: String { return self._s[241]! } - public var Stickers_SuggestStickers: String { return self._s[242]! } + public var PeerInfo_PaneFiles: String { return self._s[240]! } + public var PasscodeSettings_AlphanumericCode: String { return self._s[241]! } + public var Localization_LanguageOther: String { return self._s[242]! } + public var Stickers_SuggestStickers: String { return self._s[243]! } public func Channel_AdminLog_MessageRemovedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[243]!, self._r[243]!, [_0]) + return formatWithArgumentRanges(self._s[244]!, self._r[244]!, [_0]) } - public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[244]! } - public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[245]! } - public var Conversation_DefaultRestrictedStickers: String { return self._s[246]! } + public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[245]! } + public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[246]! } + public var Conversation_DefaultRestrictedStickers: String { return self._s[247]! } public func Notification_PinnedDeletedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[247]!, self._r[247]!, [_0]) + return formatWithArgumentRanges(self._s[248]!, self._r[248]!, [_0]) } - public var Wallet_TransactionInfo_CopyAddress: String { return self._s[249]! } - public var Group_UpgradeConfirmation: String { return self._s[250]! } - public var DialogList_Unpin: String { return self._s[251]! } - public var Passport_Identity_DateOfBirth: String { return self._s[252]! } - public var Month_ShortOctober: String { return self._s[253]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[254]! } - public var TwoFactorSetup_Done_Text: String { return self._s[255]! } - public var Notification_CallCanceledShort: String { return self._s[256]! } - public var Conversation_StopQuiz: String { return self._s[257]! } - public var Passport_Phone_Help: String { return self._s[258]! } - public var Passport_Language_az: String { return self._s[260]! } - public var CreatePoll_TextPlaceholder: String { return self._s[262]! } - public var VoiceOver_Chat_AnonymousPoll: String { return self._s[263]! } - public var Passport_Identity_DocumentNumber: String { return self._s[264]! } - public var PhotoEditor_CurvesRed: String { return self._s[265]! } - public var PhoneNumberHelp_Alert: String { return self._s[267]! } - public var SocksProxySetup_Port: String { return self._s[268]! } - public var Checkout_PayNone: String { return self._s[269]! } - public var AutoDownloadSettings_WiFi: String { return self._s[270]! } - public var GroupInfo_GroupType: String { return self._s[271]! } - public var StickerSettings_ContextHide: String { return self._s[272]! } - public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[273]! } - public var Group_Setup_HistoryTitle: String { return self._s[275]! } - public var Passport_Identity_FilesUploadNew: String { return self._s[276]! } - public var PasscodeSettings_AutoLock: String { return self._s[277]! } - public var Passport_Title: String { return self._s[278]! } - public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[279]! } - public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[280]! } - public var GroupPermission_NoSendGifs: String { return self._s[281]! } - public var PrivacySettings_PasscodeOn: String { return self._s[282]! } + public var Wallet_TransactionInfo_CopyAddress: String { return self._s[250]! } + public var Group_UpgradeConfirmation: String { return self._s[251]! } + public var DialogList_Unpin: String { return self._s[252]! } + public var Passport_Identity_DateOfBirth: String { return self._s[253]! } + public var Month_ShortOctober: String { return self._s[254]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[255]! } + public var TwoFactorSetup_Done_Text: String { return self._s[256]! } + public var Notification_CallCanceledShort: String { return self._s[257]! } + public var Conversation_StopQuiz: String { return self._s[258]! } + public var Passport_Phone_Help: String { return self._s[259]! } + public var Passport_Language_az: String { return self._s[261]! } + public var CreatePoll_TextPlaceholder: String { return self._s[263]! } + public var VoiceOver_Chat_AnonymousPoll: String { return self._s[264]! } + public var Passport_Identity_DocumentNumber: String { return self._s[265]! } + public var PhotoEditor_CurvesRed: String { return self._s[266]! } + public var PhoneNumberHelp_Alert: String { return self._s[268]! } + public var SocksProxySetup_Port: String { return self._s[269]! } + public var Checkout_PayNone: String { return self._s[270]! } + public var AutoDownloadSettings_WiFi: String { return self._s[271]! } + public var GroupInfo_GroupType: String { return self._s[272]! } + public var StickerSettings_ContextHide: String { return self._s[273]! } + public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[274]! } + public var Group_Setup_HistoryTitle: String { return self._s[276]! } + public var Passport_Identity_FilesUploadNew: String { return self._s[277]! } + public var PasscodeSettings_AutoLock: String { return self._s[278]! } + public var Passport_Title: String { return self._s[279]! } + public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[280]! } + public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[281]! } + public var GroupPermission_NoSendGifs: String { return self._s[282]! } + public var PrivacySettings_PasscodeOn: String { return self._s[283]! } public func Conversation_ScheduleMessage_SendTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[283]!, self._r[283]!, [_0]) + return formatWithArgumentRanges(self._s[284]!, self._r[284]!, [_0]) } - public var State_WaitingForNetwork: String { return self._s[286]! } + public var State_WaitingForNetwork: String { return self._s[287]! } public func Notification_Invited(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[287]!, self._r[287]!, [_0, _1]) + return formatWithArgumentRanges(self._s[288]!, self._r[288]!, [_0, _1]) } - public var Calls_NotNow: String { return self._s[289]! } + public var Calls_NotNow: String { return self._s[290]! } public func Channel_DiscussionGroup_HeaderSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[290]!, self._r[290]!, [_0]) + return formatWithArgumentRanges(self._s[291]!, self._r[291]!, [_0]) } - public var UserInfo_SendMessage: String { return self._s[291]! } - public var TwoStepAuth_PasswordSet: String { return self._s[292]! } - public var Passport_DeleteDocument: String { return self._s[293]! } - public var SocksProxySetup_AddProxyTitle: String { return self._s[294]! } + public var UserInfo_SendMessage: String { return self._s[292]! } + public var TwoStepAuth_PasswordSet: String { return self._s[293]! } + public var Passport_DeleteDocument: String { return self._s[294]! } + public var SocksProxySetup_AddProxyTitle: String { return self._s[295]! } public func PUSH_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[295]!, self._r[295]!, [_1]) + return formatWithArgumentRanges(self._s[296]!, self._r[296]!, [_1]) } - public var AuthSessions_AddedDeviceTitle: String { return self._s[296]! } - public var GroupRemoved_Remove: String { return self._s[297]! } - public var Passport_FieldIdentity: String { return self._s[298]! } - public var Group_Setup_TypePrivateHelp: String { return self._s[299]! } - public var Conversation_Processing: String { return self._s[302]! } - public var Wallet_Settings_BackupWallet: String { return self._s[304]! } - public var ChatSettings_AutoPlayAnimations: String { return self._s[305]! } - public var AuthSessions_LogOutApplicationsHelp: String { return self._s[308]! } - public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[309]! } - public var Month_GenFebruary: String { return self._s[310]! } - public var Wallet_Send_NetworkErrorTitle: String { return self._s[311]! } + public var AuthSessions_AddedDeviceTitle: String { return self._s[297]! } + public var GroupRemoved_Remove: String { return self._s[298]! } + public var Passport_FieldIdentity: String { return self._s[299]! } + public var Group_Setup_TypePrivateHelp: String { return self._s[300]! } + public var Conversation_Processing: String { return self._s[303]! } + public var Wallet_Settings_BackupWallet: String { return self._s[305]! } + public var ChatSettings_AutoPlayAnimations: String { return self._s[306]! } + public var AuthSessions_LogOutApplicationsHelp: String { return self._s[309]! } + public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[310]! } + public var Month_GenFebruary: String { return self._s[311]! } + public var Wallet_Send_NetworkErrorTitle: String { return self._s[312]! } public func Login_InvalidPhoneEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[313]!, self._r[313]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[314]!, self._r[314]!, [_1, _2, _3, _4, _5]) } - public var Passport_Identity_TypeIdentityCard: String { return self._s[314]! } - public var Wallet_Month_ShortJune: String { return self._s[316]! } - public var AutoDownloadSettings_DataUsageMedium: String { return self._s[317]! } - public var GroupInfo_AddParticipant: String { return self._s[318]! } - public var KeyCommand_SendMessage: String { return self._s[319]! } - public var VoiceOver_Chat_YourContact: String { return self._s[321]! } - public var Map_LiveLocationShowAll: String { return self._s[322]! } - public var WallpaperSearch_ColorOrange: String { return self._s[324]! } - public var Appearance_AppIconDefaultX: String { return self._s[325]! } - public var Checkout_Receipt_Title: String { return self._s[326]! } - public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[327]! } - public var WallpaperPreview_PreviewTopText: String { return self._s[328]! } - public var Message_Contact: String { return self._s[329]! } - public var Call_StatusIncoming: String { return self._s[330]! } - public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[331]! } + public var Passport_Identity_TypeIdentityCard: String { return self._s[315]! } + public var Wallet_Month_ShortJune: String { return self._s[317]! } + public var AutoDownloadSettings_DataUsageMedium: String { return self._s[318]! } + public var GroupInfo_AddParticipant: String { return self._s[319]! } + public var KeyCommand_SendMessage: String { return self._s[320]! } + public var VoiceOver_Chat_YourContact: String { return self._s[322]! } + public var Map_LiveLocationShowAll: String { return self._s[323]! } + public var WallpaperSearch_ColorOrange: String { return self._s[325]! } + public var Appearance_AppIconDefaultX: String { return self._s[326]! } + public var Checkout_Receipt_Title: String { return self._s[327]! } + public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[328]! } + public var WallpaperPreview_PreviewTopText: String { return self._s[329]! } + public var Message_Contact: String { return self._s[330]! } + public var Call_StatusIncoming: String { return self._s[331]! } + public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[332]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[332]!, self._r[332]!, [_1]) + return formatWithArgumentRanges(self._s[333]!, self._r[333]!, [_1]) } public func PUSH_ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[334]!, self._r[334]!, [_1]) + return formatWithArgumentRanges(self._s[335]!, self._r[335]!, [_1]) } - public var VoiceOver_Media_PlaybackRate: String { return self._s[335]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[336]! } - public var Conversation_ViewChannel: String { return self._s[337]! } + public var VoiceOver_Media_PlaybackRate: String { return self._s[336]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[337]! } + public var Conversation_ViewChannel: String { return self._s[338]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[338]!, self._r[338]!, [_0]) + return formatWithArgumentRanges(self._s[339]!, self._r[339]!, [_0]) } - public var Theme_Colors_Accent: String { return self._s[339]! } - public var Passport_Language_nl: String { return self._s[341]! } - public var Camera_Retake: String { return self._s[342]! } + public var Theme_Colors_Accent: String { return self._s[340]! } + public var Passport_Language_nl: String { return self._s[342]! } + public var Camera_Retake: String { return self._s[343]! } public func UserInfo_BlockActionTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[343]!, self._r[343]!, [_0]) + return formatWithArgumentRanges(self._s[344]!, self._r[344]!, [_0]) } - public var AuthSessions_LogOutApplications: String { return self._s[344]! } - public var ApplyLanguage_ApplySuccess: String { return self._s[345]! } - public var Tour_Title6: String { return self._s[346]! } - public var Map_ChooseAPlace: String { return self._s[347]! } - public var CallSettings_Never: String { return self._s[349]! } + public var AuthSessions_LogOutApplications: String { return self._s[345]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[346]! } + public var Tour_Title6: String { return self._s[347]! } + public var Map_ChooseAPlace: String { return self._s[348]! } + public var CallSettings_Never: String { return self._s[350]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[350]!, self._r[350]!, [_0]) + return formatWithArgumentRanges(self._s[351]!, self._r[351]!, [_0]) } - public var ChannelRemoved_RemoveInfo: String { return self._s[351]! } + public var ChannelRemoved_RemoveInfo: String { return self._s[352]! } public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[352]!, self._r[352]!, [_0]) + return formatWithArgumentRanges(self._s[353]!, self._r[353]!, [_0]) } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[353]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[354]! } public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[354]!, self._r[354]!, [_0]) + return formatWithArgumentRanges(self._s[355]!, self._r[355]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[355]! } + public var GroupInfo_InviteLink_Title: String { return self._s[356]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[356]!, self._r[356]!, [_1, _2]) + return formatWithArgumentRanges(self._s[357]!, self._r[357]!, [_1, _2]) } - public var KeyCommand_ScrollUp: String { return self._s[357]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[358]! } - public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[359]! } + public var KeyCommand_ScrollUp: String { return self._s[358]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[359]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[360]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[360]!, self._r[360]!, [_0]) + return formatWithArgumentRanges(self._s[361]!, self._r[361]!, [_0]) } - public var TwoFactorSetup_Done_Title: String { return self._s[361]! } + public var TwoFactorSetup_Done_Title: String { return self._s[362]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[362]!, self._r[362]!, [_0]) + return formatWithArgumentRanges(self._s[363]!, self._r[363]!, [_0]) } - public var CallFeedback_ReasonDistortedSpeech: String { return self._s[363]! } - public var Watch_LastSeen_WithinAWeek: String { return self._s[364]! } - public var ContactList_Context_SendMessage: String { return self._s[366]! } - public var Weekday_Tuesday: String { return self._s[367]! } - public var Wallet_Created_Title: String { return self._s[369]! } - public var ScheduledMessages_Delete: String { return self._s[370]! } - public var UserInfo_StartSecretChat: String { return self._s[371]! } - public var Passport_Identity_FilesTitle: String { return self._s[372]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[373]! } - public var DialogList_DeleteConversationConfirmation: String { return self._s[375]! } - public var ChatList_UndoArchiveRevealedTitle: String { return self._s[376]! } + public var CallFeedback_ReasonDistortedSpeech: String { return self._s[364]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[365]! } + public var ContactList_Context_SendMessage: String { return self._s[367]! } + public var Weekday_Tuesday: String { return self._s[368]! } + public var Wallet_Created_Title: String { return self._s[370]! } + public var ScheduledMessages_Delete: String { return self._s[371]! } + public var UserInfo_StartSecretChat: String { return self._s[372]! } + public var Passport_Identity_FilesTitle: String { return self._s[373]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[374]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[376]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[377]! } public func Wallet_Configuration_ApplyErrorTextURLUnreachable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[377]!, self._r[377]!, [_0]) + return formatWithArgumentRanges(self._s[378]!, self._r[378]!, [_0]) } - public var AuthSessions_Sessions: String { return self._s[378]! } + public var AuthSessions_Sessions: String { return self._s[379]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[380]!, self._r[380]!, [_0]) + return formatWithArgumentRanges(self._s[381]!, self._r[381]!, [_0]) } - public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[381]! } - public var Call_StatusWaiting: String { return self._s[382]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[383]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[384]! } - public var WallpaperPreview_CustomColorBottomText: String { return self._s[385]! } - public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[386]! } - public var LogoutOptions_AddAccountText: String { return self._s[387]! } - public var PasscodeSettings_6DigitCode: String { return self._s[388]! } - public var Settings_LogoutConfirmationText: String { return self._s[389]! } - public var Passport_Identity_TypePassport: String { return self._s[391]! } - public var Map_Work: String { return self._s[394]! } + public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[382]! } + public var Call_StatusWaiting: String { return self._s[383]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[384]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[385]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[386]! } + public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[387]! } + public var LogoutOptions_AddAccountText: String { return self._s[388]! } + public var PasscodeSettings_6DigitCode: String { return self._s[389]! } + public var Settings_LogoutConfirmationText: String { return self._s[390]! } + public var Passport_Identity_TypePassport: String { return self._s[392]! } + public var Map_Work: String { return self._s[395]! } public func PUSH_MESSAGE_VIDEOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[395]!, self._r[395]!, [_1, _2]) + return formatWithArgumentRanges(self._s[396]!, self._r[396]!, [_1, _2]) } - public var SocksProxySetup_SaveProxy: String { return self._s[396]! } - public var AccessDenied_SaveMedia: String { return self._s[397]! } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[399]! } - public var CreatePoll_MultipleChoice: String { return self._s[400]! } - public var Settings_Title: String { return self._s[402]! } - public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[403]! } - public var Contacts_InviteSearchLabel: String { return self._s[405]! } - public var PrivacySettings_WebSessions: String { return self._s[406]! } - public var ConvertToSupergroup_Title: String { return self._s[407]! } + public var SocksProxySetup_SaveProxy: String { return self._s[397]! } + public var AccessDenied_SaveMedia: String { return self._s[398]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[400]! } + public var CreatePoll_MultipleChoice: String { return self._s[401]! } + public var Settings_Title: String { return self._s[403]! } + public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[404]! } + public var Contacts_InviteSearchLabel: String { return self._s[406]! } + public var PrivacySettings_WebSessions: String { return self._s[407]! } + public var ConvertToSupergroup_Title: String { return self._s[408]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[408]!, self._r[408]!, [_0]) + return formatWithArgumentRanges(self._s[409]!, self._r[409]!, [_0]) } - public var TwoFactorSetup_Hint_Text: String { return self._s[409]! } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[410]! } + public var TwoFactorSetup_Hint_Text: String { return self._s[410]! } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[411]! } public func PUSH_MESSAGE_CHANNEL_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[411]!, self._r[411]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[412]!, self._r[412]!, [_1, _2, _3]) } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[412]! } - public var UserInfo_BotHelp: String { return self._s[413]! } - public var PrivacySettings_LastSeenEverybody: String { return self._s[414]! } - public var Checkout_Name: String { return self._s[415]! } - public var AutoDownloadSettings_DataUsage: String { return self._s[416]! } - public var Channel_BanUser_BlockFor: String { return self._s[417]! } - public var Checkout_ShippingAddress: String { return self._s[418]! } - public var AutoDownloadSettings_MaxVideoSize: String { return self._s[419]! } - public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[420]! } - public var Privacy_Forwards: String { return self._s[421]! } - public var Channel_BanUser_PermissionSendPolls: String { return self._s[422]! } - public var Appearance_ThemeCarouselNewNight: String { return self._s[423]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[413]! } + public var UserInfo_BotHelp: String { return self._s[414]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[415]! } + public var Checkout_Name: String { return self._s[416]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[417]! } + public var Channel_BanUser_BlockFor: String { return self._s[418]! } + public var Checkout_ShippingAddress: String { return self._s[419]! } + public var AutoDownloadSettings_MaxVideoSize: String { return self._s[420]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[421]! } + public var Privacy_Forwards: String { return self._s[422]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[423]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[424]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[426]!, self._r[426]!, [_0]) + return formatWithArgumentRanges(self._s[427]!, self._r[427]!, [_0]) } - public var Contacts_SortedByName: String { return self._s[427]! } - public var Group_OwnershipTransfer_Title: String { return self._s[428]! } - public var VoiceOver_Chat_OpenHint: String { return self._s[430]! } - public var Group_LeaveGroup: String { return self._s[431]! } - public var Settings_UsernameEmpty: String { return self._s[432]! } + public var Contacts_SortedByName: String { return self._s[428]! } + public var Group_OwnershipTransfer_Title: String { return self._s[429]! } + public var PeerInfo_BioExpand: String { return self._s[431]! } + public var VoiceOver_Chat_OpenHint: String { return self._s[432]! } + public var Group_LeaveGroup: String { return self._s[433]! } + public var Settings_UsernameEmpty: String { return self._s[434]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[433]!, self._r[433]!, [_0]) + return formatWithArgumentRanges(self._s[435]!, self._r[435]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[434]!, self._r[434]!, [_1]) + return formatWithArgumentRanges(self._s[436]!, self._r[436]!, [_1]) } public func Channel_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[435]!, self._r[435]!, [_1, _2]) + return formatWithArgumentRanges(self._s[437]!, self._r[437]!, [_1, _2]) } - public var Message_ImageExpired: String { return self._s[436]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[438]! } - public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[439]! } - public var UserInfo_AddToExisting: String { return self._s[440]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[441]! } - public var Wallet_Send_SyncInProgress: String { return self._s[442]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[443]! } + public var Message_ImageExpired: String { return self._s[438]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[440]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[441]! } + public var UserInfo_AddToExisting: String { return self._s[442]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[443]! } + public var Wallet_Send_SyncInProgress: String { return self._s[444]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[445]! } public func PUSH_CHANNEL_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[444]!, self._r[444]!, [_1]) + return formatWithArgumentRanges(self._s[446]!, self._r[446]!, [_1]) } - public var Notifications_GroupNotificationsAlert: String { return self._s[445]! } - public var Passport_Language_km: String { return self._s[446]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[448]! } - public var VoiceOver_Media_PlaybackPlay: String { return self._s[449]! } - public var Notification_CallMissedShort: String { return self._s[450]! } - public var Wallet_Info_YourBalance: String { return self._s[451]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[453]! } - public var Watch_Compose_Send: String { return self._s[454]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[457]! } - public var TwoFactorSetup_Email_Action: String { return self._s[458]! } - public var Conversation_HoldForVideo: String { return self._s[459]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[460]! } - public var AuthSessions_OtherDevices: String { return self._s[461]! } - public var Wallet_TransactionInfo_CommentHeader: String { return self._s[462]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[464]! } - public var Appearance_AutoNightThemeDisabled: String { return self._s[466]! } - public var Channel_LinkItem: String { return self._s[467]! } + public var Notifications_GroupNotificationsAlert: String { return self._s[447]! } + public var Passport_Language_km: String { return self._s[448]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[450]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[451]! } + public var Notification_CallMissedShort: String { return self._s[452]! } + public var Wallet_Info_YourBalance: String { return self._s[453]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[455]! } + public var Watch_Compose_Send: String { return self._s[456]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[459]! } + public var TwoFactorSetup_Email_Action: String { return self._s[460]! } + public var Conversation_HoldForVideo: String { return self._s[461]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[462]! } + public var AuthSessions_OtherDevices: String { return self._s[463]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[464]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[466]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[468]! } + public var Channel_LinkItem: String { return self._s[469]! } public func PrivacySettings_LastSeenContactsMinusPlus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[468]!, self._r[468]!, [_0, _1]) + return formatWithArgumentRanges(self._s[470]!, self._r[470]!, [_0, _1]) } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[471]!, self._r[471]!, [_0]) + return formatWithArgumentRanges(self._s[473]!, self._r[473]!, [_0]) } - public var VoiceOver_Recording_StopAndPreview: String { return self._s[472]! } - public var Passport_Language_dv: String { return self._s[473]! } - public var Undo_LeftChannel: String { return self._s[474]! } - public var Notifications_ExceptionsMuted: String { return self._s[475]! } - public var ChatList_UnhideAction: String { return self._s[476]! } - public var Conversation_ContextMenuShare: String { return self._s[477]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[478]! } - public var ShareFileTip_Title: String { return self._s[479]! } - public var NotificationsSound_Chord: String { return self._s[480]! } - public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[481]! } + public var VoiceOver_Recording_StopAndPreview: String { return self._s[474]! } + public var Passport_Language_dv: String { return self._s[475]! } + public var Undo_LeftChannel: String { return self._s[476]! } + public var Notifications_ExceptionsMuted: String { return self._s[477]! } + public var ChatList_UnhideAction: String { return self._s[478]! } + public var Conversation_ContextMenuShare: String { return self._s[479]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[480]! } + public var ShareFileTip_Title: String { return self._s[481]! } + public var NotificationsSound_Chord: String { return self._s[482]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[483]! } public func PUSH_CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[482]!, self._r[482]!, [_1, _2]) + return formatWithArgumentRanges(self._s[484]!, self._r[484]!, [_1, _2]) } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[483]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[485]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[484]!, self._r[484]!, [_0]) + return formatWithArgumentRanges(self._s[486]!, self._r[486]!, [_0]) } public func Wallet_Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[485]!, self._r[485]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[487]!, self._r[487]!, [_1, _2, _3]) } - public var Wallet_Settings_ConfigurationInfo: String { return self._s[486]! } - public var Wallpaper_ErrorNotFound: String { return self._s[487]! } - public var Notification_CallOutgoingShort: String { return self._s[489]! } - public var Wallet_WordImport_IncorrectText: String { return self._s[490]! } + public var Wallet_Settings_ConfigurationInfo: String { return self._s[488]! } + public var Wallpaper_ErrorNotFound: String { return self._s[489]! } + public var Notification_CallOutgoingShort: String { return self._s[491]! } + public var Wallet_WordImport_IncorrectText: String { return self._s[492]! } public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[491]!, self._r[491]!, [_1, _2]) + return formatWithArgumentRanges(self._s[493]!, self._r[493]!, [_1, _2]) } - public var Passport_Address_TypeUtilityBill: String { return self._s[492]! } - public var Privacy_Forwards_LinkIfAllowed: String { return self._s[493]! } - public var ReportPeer_Report: String { return self._s[494]! } - public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[495]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[496]! } + public var Passport_Address_TypeUtilityBill: String { return self._s[494]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[495]! } + public var ReportPeer_Report: String { return self._s[496]! } + public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[497]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[498]! } public func VoiceOver_Chat_MusicTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[497]!, self._r[497]!, [_1, _2]) + return formatWithArgumentRanges(self._s[499]!, self._r[499]!, [_1, _2]) } - public var StickerPack_Send: String { return self._s[498]! } - public var Login_CodeSentInternal: String { return self._s[499]! } - public var Wallet_Month_GenJanuary: String { return self._s[500]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[501]! } + public var StickerPack_Send: String { return self._s[500]! } + public var Login_CodeSentInternal: String { return self._s[501]! } + public var Wallet_Month_GenJanuary: String { return self._s[502]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[503]! } public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[502]!, self._r[502]!, [_0]) - } - public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[504]!, self._r[504]!, [_0]) } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[505]! } - public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[506]!, self._r[506]!, [_1]) + public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[506]!, self._r[506]!, [_0]) } - public var ReportPeer_ReasonViolence: String { return self._s[508]! } - public var Appearance_ShareThemeColor: String { return self._s[509]! } - public var Map_Locating: String { return self._s[510]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[507]! } + public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[508]!, self._r[508]!, [_1]) + } + public var ReportPeer_ReasonViolence: String { return self._s[510]! } + public var Appearance_ShareThemeColor: String { return self._s[511]! } + public var Map_Locating: String { return self._s[512]! } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[511]!, self._r[511]!, [_0]) + return formatWithArgumentRanges(self._s[513]!, self._r[513]!, [_0]) } public func PUSH_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[512]!, self._r[512]!, [_1]) + return formatWithArgumentRanges(self._s[514]!, self._r[514]!, [_1]) } - public var AutoDownloadSettings_GroupChats: String { return self._s[514]! } - public var CheckoutInfo_SaveInfo: String { return self._s[515]! } - public var SharedMedia_EmptyLinksText: String { return self._s[517]! } - public var Passport_Address_CityPlaceholder: String { return self._s[518]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[519]! } - public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[520]! } - public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[522]! } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[523]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[516]! } + public var CheckoutInfo_SaveInfo: String { return self._s[517]! } + public var SharedMedia_EmptyLinksText: String { return self._s[519]! } + public var Passport_Address_CityPlaceholder: String { return self._s[520]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[521]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[522]! } + public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[524]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[525]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[524]!, self._r[524]!, [_1]) + return formatWithArgumentRanges(self._s[526]!, self._r[526]!, [_1]) } public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[525]!, self._r[525]!, [_0]) + return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_0]) } - public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[526]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[527]! } - public var ChangePhoneNumberCode_Code: String { return self._s[528]! } - public var Appearance_CreateTheme: String { return self._s[529]! } + public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[528]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[529]! } + public var ChangePhoneNumberCode_Code: String { return self._s[530]! } + public var Appearance_CreateTheme: String { return self._s[531]! } public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[530]!, self._r[530]!, [_0]) + return formatWithArgumentRanges(self._s[532]!, self._r[532]!, [_0]) } - public var TwoStepAuth_SetupEmail: String { return self._s[531]! } - public var HashtagSearch_AllChats: String { return self._s[532]! } - public var MediaPlayer_UnknownTrack: String { return self._s[533]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[535]! } + public var TwoStepAuth_SetupEmail: String { return self._s[533]! } + public var HashtagSearch_AllChats: String { return self._s[534]! } + public var MediaPlayer_UnknownTrack: String { return self._s[535]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[537]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[536]!, self._r[536]!, [_0]) + return formatWithArgumentRanges(self._s[538]!, self._r[538]!, [_0]) } - public var PhotoEditor_QualityHigh: String { return self._s[538]! } + public var PhotoEditor_QualityHigh: String { return self._s[540]! } public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[539]!, self._r[539]!, [_0]) + return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_0]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[540]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[541]! } - public var Message_LiveLocation: String { return self._s[542]! } - public var Cache_LowDiskSpaceText: String { return self._s[543]! } - public var Wallet_Receive_ShareAddress: String { return self._s[544]! } - public var EditTheme_ErrorLinkTaken: String { return self._s[545]! } - public var Conversation_SendMessage: String { return self._s[546]! } - public var AuthSessions_EmptyTitle: String { return self._s[547]! } - public var Privacy_PhoneNumber: String { return self._s[548]! } - public var PeopleNearby_CreateGroup: String { return self._s[549]! } - public var CallSettings_UseLessData: String { return self._s[551]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[552]! } - public var Stickers_AddToFavorites: String { return self._s[553]! } - public var Wallet_WordImport_Title: String { return self._s[554]! } - public var PhotoEditor_QualityLow: String { return self._s[555]! } - public var Watch_UserInfo_Unblock: String { return self._s[556]! } - public var Settings_Logout: String { return self._s[557]! } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[542]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[543]! } + public var Message_LiveLocation: String { return self._s[544]! } + public var Cache_LowDiskSpaceText: String { return self._s[545]! } + public var Wallet_Receive_ShareAddress: String { return self._s[546]! } + public var EditTheme_ErrorLinkTaken: String { return self._s[547]! } + public var Conversation_SendMessage: String { return self._s[548]! } + public var AuthSessions_EmptyTitle: String { return self._s[549]! } + public var Privacy_PhoneNumber: String { return self._s[550]! } + public var PeopleNearby_CreateGroup: String { return self._s[551]! } + public var CallSettings_UseLessData: String { return self._s[553]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[554]! } + public var Stickers_AddToFavorites: String { return self._s[555]! } + public var Wallet_WordImport_Title: String { return self._s[556]! } + public var PhotoEditor_QualityLow: String { return self._s[557]! } + public var Watch_UserInfo_Unblock: String { return self._s[558]! } + public var Settings_Logout: String { return self._s[559]! } public func PUSH_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[558]!, self._r[558]!, [_1]) + return formatWithArgumentRanges(self._s[560]!, self._r[560]!, [_1]) } - public var ContactInfo_PhoneLabelWork: String { return self._s[559]! } - public var ChannelInfo_Stats: String { return self._s[560]! } - public var TextFormat_Link: String { return self._s[561]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[561]! } + public var ChannelInfo_Stats: String { return self._s[562]! } + public var TextFormat_Link: String { return self._s[563]! } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[562]!, self._r[562]!, [_1, _2]) + return formatWithArgumentRanges(self._s[564]!, self._r[564]!, [_1, _2]) } - public var Wallet_TransactionInfo_Title: String { return self._s[563]! } + public var Wallet_TransactionInfo_Title: String { return self._s[565]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[564]!, self._r[564]!, [_0]) + return formatWithArgumentRanges(self._s[566]!, self._r[566]!, [_0]) } - public var Watch_Notification_Joined: String { return self._s[565]! } - public var Group_Setup_TypePublicHelp: String { return self._s[566]! } - public var Passport_Scans_UploadNew: String { return self._s[567]! } - public var Checkout_LiabilityAlertTitle: String { return self._s[568]! } - public var DialogList_Title: String { return self._s[571]! } - public var NotificationSettings_ContactJoined: String { return self._s[572]! } - public var GroupInfo_LabelAdmin: String { return self._s[573]! } - public var KeyCommand_ChatInfo: String { return self._s[574]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[575]! } - public var Call_ReportIncludeLog: String { return self._s[576]! } + public var Watch_Notification_Joined: String { return self._s[567]! } + public var Group_Setup_TypePublicHelp: String { return self._s[568]! } + public var Passport_Scans_UploadNew: String { return self._s[569]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[570]! } + public var DialogList_Title: String { return self._s[573]! } + public var NotificationSettings_ContactJoined: String { return self._s[574]! } + public var GroupInfo_LabelAdmin: String { return self._s[575]! } + public var KeyCommand_ChatInfo: String { return self._s[576]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[577]! } + public var Call_ReportIncludeLog: String { return self._s[578]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[579]!, self._r[579]!, [_0]) + return formatWithArgumentRanges(self._s[581]!, self._r[581]!, [_0]) } - public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[580]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[581]! } - public var LocalGroup_IrrelevantWarning: String { return self._s[582]! } - public var Conversation_DefaultRestrictedInline: String { return self._s[583]! } - public var Message_Sticker: String { return self._s[584]! } - public var LastSeen_JustNow: String { return self._s[586]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[588]! } - public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[589]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[590]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[591]! } - public var TwoStepAuth_Email: String { return self._s[592]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[593]! } - public var PhotoEditor_BlurToolOff: String { return self._s[594]! } - public var Message_PinnedStickerMessage: String { return self._s[595]! } - public var ContactInfo_PhoneLabelPager: String { return self._s[596]! } - public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[597]! } - public var Passport_DiscardMessageTitle: String { return self._s[598]! } - public var Privacy_PaymentsTitle: String { return self._s[599]! } - public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[600]! } - public var ClearCache_StorageCache: String { return self._s[601]! } - public var Appearance_TextSizeSetting: String { return self._s[602]! } - public var Channel_DiscussionGroup_Header: String { return self._s[604]! } - public var VoiceOver_Chat_OptionSelected: String { return self._s[605]! } - public var Appearance_ColorTheme: String { return self._s[606]! } - public var UserInfo_ShareContact: String { return self._s[607]! } - public var Passport_Address_TypePassportRegistration: String { return self._s[608]! } - public var Common_More: String { return self._s[609]! } - public var Watch_Message_Call: String { return self._s[610]! } - public var Profile_EncryptionKey: String { return self._s[613]! } - public var Privacy_TopPeers: String { return self._s[614]! } - public var Conversation_StopPollConfirmation: String { return self._s[615]! } - public var Wallet_Words_NotDoneText: String { return self._s[617]! } - public var Privacy_TopPeersWarning: String { return self._s[619]! } - public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[620]! } - public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[621]! } - public var Wallet_RestoreFailed_EnterWords: String { return self._s[624]! } - public var DialogList_SearchSectionMessages: String { return self._s[625]! } - public var Notifications_ChannelNotifications: String { return self._s[626]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[627]! } - public var Passport_Language_sk: String { return self._s[628]! } - public var Notification_MessageLifetime1h: String { return self._s[629]! } - public var Wallpaper_ResetWallpapersInfo: String { return self._s[630]! } - public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[631]! } - public var Call_ReportSkip: String { return self._s[633]! } - public var Cache_ServiceFiles: String { return self._s[634]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[635]! } - public var VoiceOver_Chat_YourFile: String { return self._s[636]! } - public var Map_Hybrid: String { return self._s[637]! } - public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[639]! } + public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[582]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[583]! } + public var LocalGroup_IrrelevantWarning: String { return self._s[584]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[585]! } + public var Message_Sticker: String { return self._s[586]! } + public var LastSeen_JustNow: String { return self._s[588]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[590]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[591]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[592]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[593]! } + public var TwoStepAuth_Email: String { return self._s[594]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[595]! } + public var PhotoEditor_BlurToolOff: String { return self._s[596]! } + public var Message_PinnedStickerMessage: String { return self._s[597]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[598]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[599]! } + public var Passport_DiscardMessageTitle: String { return self._s[600]! } + public var Privacy_PaymentsTitle: String { return self._s[601]! } + public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[602]! } + public var ClearCache_StorageCache: String { return self._s[603]! } + public var Appearance_TextSizeSetting: String { return self._s[604]! } + public var Channel_DiscussionGroup_Header: String { return self._s[606]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[607]! } + public var Appearance_ColorTheme: String { return self._s[608]! } + public var UserInfo_ShareContact: String { return self._s[609]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[610]! } + public var Common_More: String { return self._s[611]! } + public var Watch_Message_Call: String { return self._s[612]! } + public var Profile_EncryptionKey: String { return self._s[615]! } + public var Privacy_TopPeers: String { return self._s[616]! } + public var Conversation_StopPollConfirmation: String { return self._s[617]! } + public var Wallet_Words_NotDoneText: String { return self._s[619]! } + public var Privacy_TopPeersWarning: String { return self._s[621]! } + public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[622]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[623]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[626]! } + public var DialogList_SearchSectionMessages: String { return self._s[627]! } + public var Notifications_ChannelNotifications: String { return self._s[628]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[629]! } + public var Passport_Language_sk: String { return self._s[630]! } + public var Notification_MessageLifetime1h: String { return self._s[631]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[632]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[633]! } + public var Call_ReportSkip: String { return self._s[635]! } + public var Cache_ServiceFiles: String { return self._s[636]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[637]! } + public var VoiceOver_Chat_YourFile: String { return self._s[638]! } + public var Map_Hybrid: String { return self._s[639]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[641]! } public func PUSH_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[640]!, self._r[640]!, [_1]) + return formatWithArgumentRanges(self._s[642]!, self._r[642]!, [_1]) } - public var ChatSettings_AutoDownloadVideos: String { return self._s[642]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[643]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[644]! } - public var SocksProxySetup_ProxyTelegram: String { return self._s[647]! } + public var ChatSettings_AutoDownloadVideos: String { return self._s[644]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[645]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[646]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[649]! } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[648]!, self._r[648]!, [_1]) + return formatWithArgumentRanges(self._s[650]!, self._r[650]!, [_1]) } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[650]! } - public var ScheduledMessages_ScheduledToday: String { return self._s[651]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[652]! } + public var ScheduledMessages_ScheduledToday: String { return self._s[653]! } public func PUSH_CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[652]!, self._r[652]!, [_1, _2]) + return formatWithArgumentRanges(self._s[654]!, self._r[654]!, [_1, _2]) } - public var Conversation_LiveLocationYou: String { return self._s[653]! } - public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[654]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[655]! } - public var UserInfo_ShareBot: String { return self._s[658]! } + public var Conversation_LiveLocationYou: String { return self._s[655]! } + public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[656]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[657]! } + public var UserInfo_ShareBot: String { return self._s[660]! } public func PUSH_AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[659]!, self._r[659]!, [_1, _2]) + return formatWithArgumentRanges(self._s[661]!, self._r[661]!, [_1, _2]) } - public var Conversation_ClearCache: String { return self._s[660]! } - public var PhotoEditor_ShadowsTint: String { return self._s[661]! } - public var Message_Audio: String { return self._s[662]! } - public var Passport_Language_lt: String { return self._s[663]! } + public var Conversation_ClearCache: String { return self._s[662]! } + public var PhotoEditor_ShadowsTint: String { return self._s[663]! } + public var Message_Audio: String { return self._s[664]! } + public var Passport_Language_lt: String { return self._s[665]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[664]!, self._r[664]!, [_0]) + return formatWithArgumentRanges(self._s[666]!, self._r[666]!, [_0]) } - public var Permissions_SiriText_v0: String { return self._s[665]! } - public var Conversation_FileICloudDrive: String { return self._s[666]! } - public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[667]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[668]! } + public var Permissions_SiriText_v0: String { return self._s[667]! } + public var Conversation_FileICloudDrive: String { return self._s[668]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[669]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[670]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[669]!, self._r[669]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[671]!, self._r[671]!, [_1, _2, _3, _4, _5, _6]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[670]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[672]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[671]!, self._r[671]!, [_0]) + return formatWithArgumentRanges(self._s[673]!, self._r[673]!, [_0]) } - public var Channel_SignMessages: String { return self._s[672]! } + public var Channel_SignMessages: String { return self._s[674]! } public func PUSH_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[673]!, self._r[673]!, [_1]) + return formatWithArgumentRanges(self._s[675]!, self._r[675]!, [_1]) } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[674]! } - public var Passport_ScanPassport: String { return self._s[675]! } - public var Watch_Suggestion_Thanks: String { return self._s[676]! } - public var BlockedUsers_AddNew: String { return self._s[677]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[676]! } + public var Passport_ScanPassport: String { return self._s[677]! } + public var Watch_Suggestion_Thanks: String { return self._s[678]! } + public var BlockedUsers_AddNew: String { return self._s[679]! } public func PUSH_CHAT_MESSAGE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[678]!, self._r[678]!, [_1, _2]) + return formatWithArgumentRanges(self._s[680]!, self._r[680]!, [_1, _2]) } - public var Watch_Message_Invoice: String { return self._s[679]! } - public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[680]! } - public var Month_GenJuly: String { return self._s[681]! } - public var CreatePoll_QuizInfo: String { return self._s[682]! } - public var UserInfo_StartSecretChatStart: String { return self._s[683]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[684]! } - public var IntentsSettings_SuggestByShare: String { return self._s[686]! } - public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[687]! } - public var Notification_ChannelInviterSelf: String { return self._s[688]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[689]! } + public var Watch_Message_Invoice: String { return self._s[681]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[682]! } + public var Month_GenJuly: String { return self._s[683]! } + public var CreatePoll_QuizInfo: String { return self._s[684]! } + public var UserInfo_StartSecretChatStart: String { return self._s[685]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[686]! } + public var IntentsSettings_SuggestByShare: String { return self._s[688]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[689]! } + public var Notification_ChannelInviterSelf: String { return self._s[690]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[691]! } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[690]!, self._r[690]!, [_1, _2]) + return formatWithArgumentRanges(self._s[692]!, self._r[692]!, [_1, _2]) } - public var CheckoutInfo_Title: String { return self._s[691]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[692]! } + public var CheckoutInfo_Title: String { return self._s[693]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[694]! } public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[693]!, self._r[693]!, [_0]) + return formatWithArgumentRanges(self._s[695]!, self._r[695]!, [_0]) } - public var Passport_Identity_MainPage: String { return self._s[694]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[695]! } - public var Passport_Language_de: String { return self._s[696]! } - public var Update_Title: String { return self._s[697]! } - public var ContactInfo_PhoneLabelWorkFax: String { return self._s[698]! } - public var Channel_AdminLog_BanEmbedLinks: String { return self._s[699]! } - public var Passport_Email_UseTelegramEmailHelp: String { return self._s[700]! } - public var Notifications_ChannelNotificationsPreview: String { return self._s[701]! } - public var NotificationsSound_Telegraph: String { return self._s[702]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[703]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[704]! } + public var Passport_Identity_MainPage: String { return self._s[696]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[697]! } + public var Passport_Language_de: String { return self._s[698]! } + public var PeerInfo_PaneVoice: String { return self._s[699]! } + public var Update_Title: String { return self._s[700]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[701]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[702]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[703]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[704]! } + public var NotificationsSound_Telegraph: String { return self._s[705]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[706]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[707]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[705]!, self._r[705]!, [_0]) + return formatWithArgumentRanges(self._s[708]!, self._r[708]!, [_0]) } - public var ClearCache_Description: String { return self._s[706]! } - public var Stickers_SuggestAll: String { return self._s[707]! } - public var Conversation_ForwardTitle: String { return self._s[708]! } - public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[709]! } + public var ClearCache_Description: String { return self._s[709]! } + public var Stickers_SuggestAll: String { return self._s[710]! } + public var Conversation_ForwardTitle: String { return self._s[711]! } + public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[712]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[710]!, self._r[710]!, [_0]) + return formatWithArgumentRanges(self._s[713]!, self._r[713]!, [_0]) } - public var Calls_NewCall: String { return self._s[711]! } - public var Call_StatusEnded: String { return self._s[712]! } - public var AutoDownloadSettings_DataUsageLow: String { return self._s[713]! } - public var Settings_ProxyConnected: String { return self._s[714]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[715]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[716]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[717]! } - public var Passport_PasswordPlaceholder: String { return self._s[718]! } - public var Message_PinnedInvoice: String { return self._s[719]! } - public var Passport_Identity_IssueDate: String { return self._s[720]! } - public var Passport_Language_pl: String { return self._s[721]! } + public var Calls_NewCall: String { return self._s[714]! } + public var Call_StatusEnded: String { return self._s[715]! } + public var AutoDownloadSettings_DataUsageLow: String { return self._s[716]! } + public var Settings_ProxyConnected: String { return self._s[717]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[718]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[719]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[720]! } + public var Passport_PasswordPlaceholder: String { return self._s[721]! } + public var Message_PinnedInvoice: String { return self._s[722]! } + public var Passport_Identity_IssueDate: String { return self._s[723]! } + public var Passport_Language_pl: String { return self._s[724]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[722]!, self._r[722]!, [_0]) - } - public var Call_StatusConnecting: String { return self._s[723]! } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[724]! } - public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[725]!, self._r[725]!, [_0]) } - public var ChatSettings_ConnectionType_UseProxy: String { return self._s[727]! } - public var Common_Edit: String { return self._s[728]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[729]! } + public var Call_StatusConnecting: String { return self._s[726]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[727]! } + public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[728]!, self._r[728]!, [_0]) + } + public var ChatSettings_ConnectionType_UseProxy: String { return self._s[730]! } + public var Common_Edit: String { return self._s[731]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[732]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[730]!, self._r[730]!, [_0]) + return formatWithArgumentRanges(self._s[733]!, self._r[733]!, [_0]) } - public var GroupInfo_ChatAdmins: String { return self._s[731]! } - public var PrivateDataSettings_Title: String { return self._s[732]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[733]! } - public var ChatList_Read: String { return self._s[734]! } - public var Wallet_WordImport_Text: String { return self._s[735]! } - public var Undo_ChatClearedForBothSides: String { return self._s[736]! } - public var GroupPermission_SectionTitle: String { return self._s[737]! } - public var TwoFactorSetup_Intro_Title: String { return self._s[739]! } + public var GroupInfo_ChatAdmins: String { return self._s[734]! } + public var PrivateDataSettings_Title: String { return self._s[735]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[736]! } + public var ChatList_Read: String { return self._s[737]! } + public var Wallet_WordImport_Text: String { return self._s[738]! } + public var Undo_ChatClearedForBothSides: String { return self._s[739]! } + public var GroupPermission_SectionTitle: String { return self._s[740]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[742]! } public func PUSH_CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[740]!, self._r[740]!, [_1, _2]) + return formatWithArgumentRanges(self._s[743]!, self._r[743]!, [_1, _2]) } - public var Checkout_ErrorPaymentFailed: String { return self._s[741]! } - public var Update_UpdateApp: String { return self._s[742]! } - public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[743]! } - public var Settings_Appearance: String { return self._s[744]! } - public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[748]! } - public var Watch_Location_Access: String { return self._s[749]! } - public var ShareMenu_CopyShareLink: String { return self._s[751]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[752]! } - public var Conversation_Theme: String { return self._s[754]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[744]! } + public var Update_UpdateApp: String { return self._s[745]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[746]! } + public var Settings_Appearance: String { return self._s[747]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[751]! } + public var Watch_Location_Access: String { return self._s[752]! } + public var ShareMenu_CopyShareLink: String { return self._s[754]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[755]! } + public var Conversation_Theme: String { return self._s[757]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[755]!, self._r[755]!, [_0]) + return formatWithArgumentRanges(self._s[758]!, self._r[758]!, [_0]) } - public var Notifications_ClassicTones: String { return self._s[756]! } - public var Weekday_ShortWednesday: String { return self._s[757]! } - public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[758]! } - public var Undo_LeftGroup: String { return self._s[761]! } - public var Wallet_RestoreFailed_Text: String { return self._s[762]! } - public var Conversation_LinkDialogCopy: String { return self._s[763]! } - public var Wallet_TransactionInfo_NoAddress: String { return self._s[765]! } - public var Wallet_Navigation_Back: String { return self._s[766]! } - public var KeyCommand_FocusOnInputField: String { return self._s[767]! } - public var Contacts_SelectAll: String { return self._s[768]! } - public var Preview_SaveToCameraRoll: String { return self._s[769]! } - public var PrivacySettings_PasscodeOff: String { return self._s[770]! } - public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[771]! } + public var Notifications_ClassicTones: String { return self._s[759]! } + public var Weekday_ShortWednesday: String { return self._s[760]! } + public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[761]! } + public var Undo_LeftGroup: String { return self._s[764]! } + public var Wallet_RestoreFailed_Text: String { return self._s[765]! } + public var Conversation_LinkDialogCopy: String { return self._s[766]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[768]! } + public var Wallet_Navigation_Back: String { return self._s[769]! } + public var KeyCommand_FocusOnInputField: String { return self._s[770]! } + public var Contacts_SelectAll: String { return self._s[771]! } + public var Preview_SaveToCameraRoll: String { return self._s[772]! } + public var PrivacySettings_PasscodeOff: String { return self._s[773]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[774]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[772]!, self._r[772]!, [_1]) + return formatWithArgumentRanges(self._s[775]!, self._r[775]!, [_1]) } - public var Wallpaper_Title: String { return self._s[773]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[774]! } - public var AccessDenied_Camera: String { return self._s[775]! } - public var Watch_Compose_CurrentLocation: String { return self._s[776]! } - public var PeerInfo_ButtonMessage: String { return self._s[778]! } - public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[779]! } + public var Wallpaper_Title: String { return self._s[776]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[777]! } + public var AccessDenied_Camera: String { return self._s[778]! } + public var Watch_Compose_CurrentLocation: String { return self._s[779]! } + public var PeerInfo_ButtonMessage: String { return self._s[781]! } + public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[782]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[780]!, self._r[780]!, [_0]) + return formatWithArgumentRanges(self._s[783]!, self._r[783]!, [_0]) } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[781]! } - public var Passport_Language_ro: String { return self._s[782]! } - public var EditTheme_UploadNewTheme: String { return self._s[783]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[784]! } - public var Wallet_Intro_Terms: String { return self._s[785]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[784]! } + public var Passport_Language_ro: String { return self._s[785]! } + public var EditTheme_UploadNewTheme: String { return self._s[786]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[787]! } + public var Wallet_Intro_Terms: String { return self._s[788]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[786]!, self._r[786]!, [_0]) + return formatWithArgumentRanges(self._s[789]!, self._r[789]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[787]! } - public var State_ConnectingToProxy: String { return self._s[788]! } - public var Calls_RatingTitle: String { return self._s[789]! } - public var Generic_ErrorMoreInfo: String { return self._s[790]! } - public var ChatList_Search_ShowMore: String { return self._s[791]! } - public var Appearance_PreviewReplyText: String { return self._s[792]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[793]! } + public var Login_CancelPhoneVerification: String { return self._s[790]! } + public var State_ConnectingToProxy: String { return self._s[791]! } + public var Calls_RatingTitle: String { return self._s[792]! } + public var Generic_ErrorMoreInfo: String { return self._s[793]! } + public var ChatList_Search_ShowMore: String { return self._s[794]! } + public var Appearance_PreviewReplyText: String { return self._s[795]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[796]! } public func Wallet_Send_Balance(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[794]!, self._r[794]!, [_0]) + return formatWithArgumentRanges(self._s[797]!, self._r[797]!, [_0]) } - public var IntentsSettings_SuggestedChatsContacts: String { return self._s[795]! } - public var SharedMedia_CategoryLinks: String { return self._s[796]! } - public var Calls_Missed: String { return self._s[797]! } - public var Cache_Photos: String { return self._s[801]! } - public var GroupPermission_NoAddMembers: String { return self._s[802]! } - public var ScheduledMessages_Title: String { return self._s[803]! } + public var IntentsSettings_SuggestedChatsContacts: String { return self._s[798]! } + public var SharedMedia_CategoryLinks: String { return self._s[799]! } + public var Calls_Missed: String { return self._s[800]! } + public var Cache_Photos: String { return self._s[804]! } + public var GroupPermission_NoAddMembers: String { return self._s[805]! } + public var ScheduledMessages_Title: String { return self._s[806]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[804]!, self._r[804]!, [_0]) + return formatWithArgumentRanges(self._s[807]!, self._r[807]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[805]! } - public var Settings_ProxyDisabled: String { return self._s[806]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[808]! } + public var Settings_ProxyDisabled: String { return self._s[809]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[807]!, self._r[807]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[810]!, self._r[810]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[808]!, self._r[808]!, [_0]) + return formatWithArgumentRanges(self._s[811]!, self._r[811]!, [_0]) } - public var ChatList_Context_RemoveFromRecents: String { return self._s[810]! } - public var Appearance_Title: String { return self._s[811]! } + public var ChatList_Context_RemoveFromRecents: String { return self._s[813]! } + public var Appearance_Title: String { return self._s[814]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[813]!, self._r[813]!, [_0]) + return formatWithArgumentRanges(self._s[816]!, self._r[816]!, [_0]) } - public var Conversation_WalletRequiredText: String { return self._s[814]! } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[815]! } - public var OldChannels_NoticeCreateText: String { return self._s[816]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[817]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[818]! } - public var Preview_DeletePhoto: String { return self._s[819]! } - public var Appearance_AppIconFilledX: String { return self._s[820]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[821]! } + public var Conversation_WalletRequiredText: String { return self._s[817]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[818]! } + public var OldChannels_NoticeCreateText: String { return self._s[819]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[820]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[821]! } + public var Preview_DeletePhoto: String { return self._s[822]! } + public var Appearance_AppIconFilledX: String { return self._s[823]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[824]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[822]!, self._r[822]!, [_0]) + return formatWithArgumentRanges(self._s[825]!, self._r[825]!, [_0]) } - public var Coub_TapForSound: String { return self._s[825]! } - public var Map_LocatingError: String { return self._s[826]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[828]! } - public var Conversation_SendMessage_SendSilently: String { return self._s[829]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[830]! } + public var Coub_TapForSound: String { return self._s[828]! } + public var Map_LocatingError: String { return self._s[829]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[831]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[832]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[833]! } public func Wallet_Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[831]!, self._r[831]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[834]!, self._r[834]!, [_1, _2, _3]) } - public var Passport_ForgottenPassword: String { return self._s[832]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[833]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[834]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[836]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[837]! } - public var Message_Location: String { return self._s[838]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[839]! } - public var Channel_Management_Title: String { return self._s[840]! } - public var DialogList_SearchSectionDialogs: String { return self._s[842]! } - public var Compose_NewChannel_Members: String { return self._s[843]! } + public var Passport_ForgottenPassword: String { return self._s[835]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[836]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[837]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[839]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[840]! } + public var Message_Location: String { return self._s[841]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[842]! } + public var Channel_Management_Title: String { return self._s[843]! } + public var DialogList_SearchSectionDialogs: String { return self._s[845]! } + public var Compose_NewChannel_Members: String { return self._s[846]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[844]!, self._r[844]!, [_0]) + return formatWithArgumentRanges(self._s[847]!, self._r[847]!, [_0]) } - public var GroupInfo_Location: String { return self._s[845]! } - public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[846]! } - public var ClearCache_Clear: String { return self._s[847]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[848]! } - public var PhotoEditor_WarmthTool: String { return self._s[849]! } - public var Passport_Language_tr: String { return self._s[850]! } + public var GroupInfo_Location: String { return self._s[848]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[849]! } + public var ClearCache_Clear: String { return self._s[850]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[851]! } + public var PhotoEditor_WarmthTool: String { return self._s[852]! } + public var Passport_Language_tr: String { return self._s[853]! } public func PUSH_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[851]!, self._r[851]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[854]!, self._r[854]!, [_1, _2, _3]) } - public var OldChannels_NoticeUpgradeText: String { return self._s[852]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[854]! } - public var Watch_PhotoView_Title: String { return self._s[855]! } - public var Passport_Phone_Delete: String { return self._s[856]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[857]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[858]! } - public var GroupInfo_Permissions: String { return self._s[859]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[860]! } - public var Profile_ShareContactButton: String { return self._s[861]! } - public var ChatSettings_Other: String { return self._s[862]! } - public var UserInfo_NotificationsDisabled: String { return self._s[863]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[864]! } - public var LastSeen_WithinAMonth: String { return self._s[865]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[866]! } - public var Conversation_ReportGroupLocation: String { return self._s[867]! } - public var Conversation_EncryptionCanceled: String { return self._s[868]! } - public var MediaPicker_GroupDescription: String { return self._s[869]! } - public var WebSearch_Images: String { return self._s[870]! } + public var OldChannels_NoticeUpgradeText: String { return self._s[855]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[857]! } + public var Watch_PhotoView_Title: String { return self._s[858]! } + public var Passport_Phone_Delete: String { return self._s[859]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[860]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[861]! } + public var GroupInfo_Permissions: String { return self._s[862]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[863]! } + public var Profile_ShareContactButton: String { return self._s[864]! } + public var ChatSettings_Other: String { return self._s[865]! } + public var UserInfo_NotificationsDisabled: String { return self._s[866]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[867]! } + public var LastSeen_WithinAMonth: String { return self._s[868]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[869]! } + public var Conversation_ReportGroupLocation: String { return self._s[870]! } + public var Conversation_EncryptionCanceled: String { return self._s[871]! } + public var MediaPicker_GroupDescription: String { return self._s[872]! } + public var WebSearch_Images: String { return self._s[873]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[871]!, self._r[871]!, [_0]) + return formatWithArgumentRanges(self._s[874]!, self._r[874]!, [_0]) } - public var Message_Photo: String { return self._s[872]! } - public var PasscodeSettings_HelpBottom: String { return self._s[873]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[874]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[875]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[876]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[877]! } - public var NotificationsSound_Calypso: String { return self._s[878]! } - public var Map_Map: String { return self._s[879]! } + public var Message_Photo: String { return self._s[875]! } + public var PasscodeSettings_HelpBottom: String { return self._s[876]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[877]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[878]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[879]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[880]! } + public var NotificationsSound_Calypso: String { return self._s[881]! } + public var Map_Map: String { return self._s[882]! } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[880]!, self._r[880]!, [_0]) + return formatWithArgumentRanges(self._s[883]!, self._r[883]!, [_0]) } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[882]! } - public var ChatSettings_TextSizeUnits: String { return self._s[883]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[885]! } + public var ChatSettings_TextSizeUnits: String { return self._s[886]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[884]!, self._r[884]!, [_0]) + return formatWithArgumentRanges(self._s[887]!, self._r[887]!, [_0]) } - public var Common_of: String { return self._s[885]! } - public var Conversation_ForwardContacts: String { return self._s[888]! } - public var IntentsSettings_SuggestByAll: String { return self._s[890]! } + public var Common_of: String { return self._s[888]! } + public var Conversation_ForwardContacts: String { return self._s[891]! } + public var IntentsSettings_SuggestByAll: String { return self._s[893]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[891]!, self._r[891]!, [_0]) + return formatWithArgumentRanges(self._s[894]!, self._r[894]!, [_0]) } - public var Passport_Language_hy: String { return self._s[892]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[893]! } - public var AutoDownloadSettings_Reset: String { return self._s[894]! } - public var Wallet_TransactionInfo_AddressCopied: String { return self._s[895]! } - public var Paint_ClearConfirm: String { return self._s[896]! } - public var Camera_VideoMode: String { return self._s[897]! } + public var Passport_Language_hy: String { return self._s[895]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[896]! } + public var AutoDownloadSettings_Reset: String { return self._s[897]! } + public var Wallet_TransactionInfo_AddressCopied: String { return self._s[898]! } + public var Paint_ClearConfirm: String { return self._s[899]! } + public var Camera_VideoMode: String { return self._s[900]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[898]!, self._r[898]!, [_0]) + return formatWithArgumentRanges(self._s[901]!, self._r[901]!, [_0]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[899]! } - public var Conversation_ViewBackground: String { return self._s[900]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[902]! } + public var Conversation_ViewBackground: String { return self._s[903]! } public func Wallet_Info_TransactionDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[901]!, self._r[901]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[904]!, self._r[904]!, [_1, _2, _3]) } - public var Passport_Language_el: String { return self._s[902]! } - public var PhotoEditor_Original: String { return self._s[903]! } - public var Settings_FAQ_Button: String { return self._s[905]! } - public var Channel_Setup_PublicNoLink: String { return self._s[907]! } - public var Conversation_UnsupportedMedia: String { return self._s[908]! } - public var Conversation_SlideToCancel: String { return self._s[909]! } - public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[910]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[911]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[912]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[913]! } - public var AutoNightTheme_NotAvailable: String { return self._s[914]! } - public var Conversation_Owner: String { return self._s[915]! } - public var Common_Create: String { return self._s[916]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[917]! } - public var ContactList_Context_Call: String { return self._s[918]! } - public var Localization_ChooseLanguage: String { return self._s[920]! } - public var ChatList_Context_AddToContacts: String { return self._s[922]! } - public var OldChannels_NoticeTitle: String { return self._s[923]! } - public var Settings_Proxy: String { return self._s[925]! } - public var Privacy_TopPeersHelp: String { return self._s[926]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[927]! } - public var Chat_UnsendMyMessages: String { return self._s[928]! } + public var Passport_Language_el: String { return self._s[905]! } + public var PhotoEditor_Original: String { return self._s[906]! } + public var Settings_FAQ_Button: String { return self._s[908]! } + public var Channel_Setup_PublicNoLink: String { return self._s[910]! } + public var Conversation_UnsupportedMedia: String { return self._s[911]! } + public var Conversation_SlideToCancel: String { return self._s[912]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[913]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[914]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[915]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[916]! } + public var AutoNightTheme_NotAvailable: String { return self._s[917]! } + public var Conversation_Owner: String { return self._s[918]! } + public var Common_Create: String { return self._s[919]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[920]! } + public var ContactList_Context_Call: String { return self._s[921]! } + public var Localization_ChooseLanguage: String { return self._s[923]! } + public var ChatList_Context_AddToContacts: String { return self._s[925]! } + public var OldChannels_NoticeTitle: String { return self._s[926]! } + public var Settings_Proxy: String { return self._s[928]! } + public var Privacy_TopPeersHelp: String { return self._s[929]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[930]! } + public var Chat_UnsendMyMessages: String { return self._s[931]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[929]!, self._r[929]!, [_0]) - } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[930]! } - public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[932]!, self._r[932]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[933]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[934]! } - public var Cache_Title: String { return self._s[935]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[933]! } + public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[935]!, self._r[935]!, [_0]) + } + public var Contacts_SortedByPresence: String { return self._s[936]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[937]! } + public var Cache_Title: String { return self._s[938]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[936]!, self._r[936]!, [_0]) + return formatWithArgumentRanges(self._s[939]!, self._r[939]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[937]! } - public var Channel_Moderator_Title: String { return self._s[938]! } - public var InstantPage_AutoNightTheme: String { return self._s[940]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[940]! } + public var Channel_Moderator_Title: String { return self._s[941]! } + public var InstantPage_AutoNightTheme: String { return self._s[943]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[943]!, self._r[943]!, [_1]) + return formatWithArgumentRanges(self._s[946]!, self._r[946]!, [_1]) } - public var Passport_Scans_Upload: String { return self._s[944]! } - public var Undo_Undo: String { return self._s[946]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[947]! } - public var TwoStepAuth_RemovePassword: String { return self._s[948]! } - public var Common_Delete: String { return self._s[949]! } - public var Contacts_AddPeopleNearby: String { return self._s[951]! } - public var Conversation_ContextMenuDelete: String { return self._s[952]! } - public var SocksProxySetup_Credentials: String { return self._s[953]! } - public var Appearance_EditTheme: String { return self._s[955]! } - public var ClearCache_StorageOtherApps: String { return self._s[956]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[957]! } - public var Wallet_Send_NetworkErrorText: String { return self._s[958]! } - public var AuthSessions_DevicesTitle: String { return self._s[960]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[962]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[963]! } - public var Passport_Language_id: String { return self._s[965]! } - public var WallpaperSearch_ColorTeal: String { return self._s[966]! } - public var ChannelIntro_Title: String { return self._s[967]! } + public var Passport_Scans_Upload: String { return self._s[947]! } + public var Undo_Undo: String { return self._s[949]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[950]! } + public var TwoStepAuth_RemovePassword: String { return self._s[951]! } + public var Common_Delete: String { return self._s[952]! } + public var Contacts_AddPeopleNearby: String { return self._s[954]! } + public var Conversation_ContextMenuDelete: String { return self._s[955]! } + public var SocksProxySetup_Credentials: String { return self._s[956]! } + public var Appearance_EditTheme: String { return self._s[958]! } + public var ClearCache_StorageOtherApps: String { return self._s[959]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[960]! } + public var Wallet_Send_NetworkErrorText: String { return self._s[961]! } + public var AuthSessions_DevicesTitle: String { return self._s[963]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[965]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[966]! } + public var Passport_Language_id: String { return self._s[968]! } + public var WallpaperSearch_ColorTeal: String { return self._s[969]! } + public var ChannelIntro_Title: String { return self._s[970]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[968]!, self._r[968]!, [_0]) + return formatWithArgumentRanges(self._s[971]!, self._r[971]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[970]! } - public var VoiceOver_Chat_Reply: String { return self._s[971]! } - public var ScheduledMessages_BotActionUnavailable: String { return self._s[972]! } - public var Channel_Info_Description: String { return self._s[973]! } - public var Stickers_FavoriteStickers: String { return self._s[974]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[975]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[976]! } - public var ChatSearch_ResultsTooltip: String { return self._s[977]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[978]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[979]! } - public var Group_PublicLink_Placeholder: String { return self._s[980]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[981]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[973]! } + public var VoiceOver_Chat_Reply: String { return self._s[974]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[975]! } + public var Channel_Info_Description: String { return self._s[976]! } + public var Stickers_FavoriteStickers: String { return self._s[977]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[978]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[979]! } + public var ChatSearch_ResultsTooltip: String { return self._s[980]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[981]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[982]! } + public var Group_PublicLink_Placeholder: String { return self._s[983]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[984]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[982]!, self._r[982]!, [_1]) + return formatWithArgumentRanges(self._s[985]!, self._r[985]!, [_1]) } - public var TextFormat_Underline: String { return self._s[983]! } + public var TextFormat_Underline: String { return self._s[986]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[985]!, self._r[985]!, [_1, _2]) - } - public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[986]!, self._r[986]!, [_0]) - } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[987]! } - public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[988]!, self._r[988]!, [_1, _2]) } - public var Wallet_Intro_ImportExisting: String { return self._s[989]! } - public var GroupPermission_Delete: String { return self._s[990]! } - public var Passport_Language_uk: String { return self._s[991]! } - public var StickerPack_HideStickers: String { return self._s[993]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[994]! } + public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[989]!, self._r[989]!, [_0]) + } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[990]! } + public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[991]!, self._r[991]!, [_1, _2]) + } + public var Wallet_Intro_ImportExisting: String { return self._s[992]! } + public var GroupPermission_Delete: String { return self._s[993]! } + public var Passport_Language_uk: String { return self._s[994]! } + public var StickerPack_HideStickers: String { return self._s[996]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[997]! } public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[995]!, self._r[995]!, [_1, _2]) + return formatWithArgumentRanges(self._s[998]!, self._r[998]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[996]! } + public var Activity_UploadingVideoMessage: String { return self._s[999]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[997]!, self._r[997]!, [_0]) + return formatWithArgumentRanges(self._s[1000]!, self._r[1000]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[998]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[999]! } - public var Settings_CallSettings: String { return self._s[1000]! } - public var Camera_SquareMode: String { return self._s[1001]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1002]! } - public var GroupInfo_SharedMediaNone: String { return self._s[1003]! } + public var Channel_TitleInfo: String { return self._s[1001]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1002]! } + public var Settings_CallSettings: String { return self._s[1003]! } + public var Camera_SquareMode: String { return self._s[1004]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1005]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1006]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1004]!, self._r[1004]!, [_1]) + return formatWithArgumentRanges(self._s[1007]!, self._r[1007]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[1005]! } - public var Application_Update: String { return self._s[1007]! } - public var Month_ShortJanuary: String { return self._s[1008]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[1009]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[1010]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[1011]! } - public var Passport_Address_Street2Placeholder: String { return self._s[1012]! } + public var Bot_GenericBotStatus: String { return self._s[1008]! } + public var Application_Update: String { return self._s[1010]! } + public var Month_ShortJanuary: String { return self._s[1011]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[1012]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[1013]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1014]! } + public var Passport_Address_Street2Placeholder: String { return self._s[1015]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1013]!, self._r[1013]!, [_0]) - } - public var NetworkUsageSettings_Cellular: String { return self._s[1014]! } - public var Appearance_PreviewOutgoingText: String { return self._s[1015]! } - public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1016]!, self._r[1016]!, [_0]) } - public var Notifications_PermissionsAllowInSettings: String { return self._s[1017]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[1019]! } - public var Map_Directions: String { return self._s[1020]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[1022]! } - public var Appearance_ThemeDay: String { return self._s[1023]! } - public var LogoutOptions_LogOut: String { return self._s[1024]! } - public var Group_PublicLink_Title: String { return self._s[1026]! } - public var Channel_AddBotErrorNoRights: String { return self._s[1027]! } - public var ChatList_Search_ShowLess: String { return self._s[1028]! } - public var Passport_Identity_AddPassport: String { return self._s[1029]! } - public var LocalGroup_ButtonTitle: String { return self._s[1030]! } - public var Call_Message: String { return self._s[1031]! } - public var PhotoEditor_ExposureTool: String { return self._s[1032]! } - public var Wallet_Receive_CommentInfo: String { return self._s[1034]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[1035]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[1037]! } - public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1038]! } - public var Appearance_Preview: String { return self._s[1039]! } - public var Compose_ChannelMembers: String { return self._s[1040]! } - public var Conversation_DeleteManyMessages: String { return self._s[1041]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[1042]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1043]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1044]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1047]! } - public var Conversation_UpdateTelegram: String { return self._s[1048]! } - public var EditTheme_Create_TopInfo: String { return self._s[1049]! } + public var NetworkUsageSettings_Cellular: String { return self._s[1017]! } + public var Appearance_PreviewOutgoingText: String { return self._s[1018]! } + public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1019]!, self._r[1019]!, [_0]) + } + public var Notifications_PermissionsAllowInSettings: String { return self._s[1020]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[1022]! } + public var Map_Directions: String { return self._s[1023]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1025]! } + public var Appearance_ThemeDay: String { return self._s[1026]! } + public var LogoutOptions_LogOut: String { return self._s[1027]! } + public var Group_PublicLink_Title: String { return self._s[1029]! } + public var Channel_AddBotErrorNoRights: String { return self._s[1030]! } + public var ChatList_Search_ShowLess: String { return self._s[1031]! } + public var Passport_Identity_AddPassport: String { return self._s[1032]! } + public var LocalGroup_ButtonTitle: String { return self._s[1033]! } + public var Call_Message: String { return self._s[1034]! } + public var PhotoEditor_ExposureTool: String { return self._s[1035]! } + public var Wallet_Receive_CommentInfo: String { return self._s[1037]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1038]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[1040]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1041]! } + public var Appearance_Preview: String { return self._s[1042]! } + public var Compose_ChannelMembers: String { return self._s[1043]! } + public var Conversation_DeleteManyMessages: String { return self._s[1044]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1045]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1046]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1047]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1050]! } + public var Conversation_UpdateTelegram: String { return self._s[1051]! } + public var EditTheme_Create_TopInfo: String { return self._s[1052]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1050]!, self._r[1050]!, [_0]) + return formatWithArgumentRanges(self._s[1053]!, self._r[1053]!, [_0]) } - public var Wallet_WordCheck_Continue: String { return self._s[1051]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[1052]! } - public var IntentsSettings_ResetAll: String { return self._s[1053]! } + public var Wallet_WordCheck_Continue: String { return self._s[1054]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1055]! } + public var IntentsSettings_ResetAll: String { return self._s[1056]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1054]!, self._r[1054]!, [_1]) + return formatWithArgumentRanges(self._s[1057]!, self._r[1057]!, [_1]) } - public var GroupInfo_Administrators_Title: String { return self._s[1055]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[1056]! } + public var GroupInfo_Administrators_Title: String { return self._s[1058]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1059]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1057]!, self._r[1057]!, [_0]) + return formatWithArgumentRanges(self._s[1060]!, self._r[1060]!, [_0]) } - public var Tour_Title3: String { return self._s[1058]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1059]! } - public var Clipboard_SendPhoto: String { return self._s[1063]! } - public var MediaPicker_Videos: String { return self._s[1064]! } - public var Passport_Email_Title: String { return self._s[1065]! } + public var Tour_Title3: String { return self._s[1061]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1062]! } + public var Clipboard_SendPhoto: String { return self._s[1066]! } + public var MediaPicker_Videos: String { return self._s[1067]! } + public var Passport_Email_Title: String { return self._s[1068]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1066]!, self._r[1066]!, [_0]) + return formatWithArgumentRanges(self._s[1069]!, self._r[1069]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[1067]! } - public var Conversation_MessageDialogDelete: String { return self._s[1068]! } - public var Privacy_Calls_CustomHelp: String { return self._s[1070]! } - public var Message_Wallpaper: String { return self._s[1071]! } - public var MemberSearch_BotSection: String { return self._s[1072]! } - public var GroupInfo_SetSound: String { return self._s[1073]! } + public var StickerPacksSettings_Title: String { return self._s[1070]! } + public var Conversation_MessageDialogDelete: String { return self._s[1071]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1073]! } + public var Message_Wallpaper: String { return self._s[1074]! } + public var MemberSearch_BotSection: String { return self._s[1075]! } + public var GroupInfo_SetSound: String { return self._s[1076]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1074]!, self._r[1074]!, [_0]) + return formatWithArgumentRanges(self._s[1077]!, self._r[1077]!, [_0]) } - public var Core_ServiceUserStatus: String { return self._s[1075]! } - public var LiveLocationUpdated_JustNow: String { return self._s[1076]! } - public var Call_StatusFailed: String { return self._s[1077]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[1078]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1079]! } - public var TwoStepAuth_SetPassword: String { return self._s[1080]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[1081]! } + public var Core_ServiceUserStatus: String { return self._s[1078]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1079]! } + public var Call_StatusFailed: String { return self._s[1080]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1081]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1082]! } + public var TwoStepAuth_SetPassword: String { return self._s[1083]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1084]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1083]!, self._r[1083]!, [_0]) + return formatWithArgumentRanges(self._s[1086]!, self._r[1086]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[1084]! } - public var Map_NoPlacesNearby: String { return self._s[1085]! } - public var Profile_Username: String { return self._s[1086]! } - public var Bot_DescriptionTitle: String { return self._s[1087]! } - public var MaskStickerSettings_Title: String { return self._s[1088]! } - public var SharedMedia_CategoryOther: String { return self._s[1089]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1090]! } - public var Common_NotNow: String { return self._s[1091]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[1092]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[1093]! } - public var Map_Location: String { return self._s[1094]! } - public var Invitation_JoinGroup: String { return self._s[1095]! } - public var AutoDownloadSettings_Title: String { return self._s[1097]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1098]! } - public var Channel_ErrorAddBlocked: String { return self._s[1099]! } - public var Conversation_UnblockUser: String { return self._s[1100]! } - public var EditTheme_Edit_TopInfo: String { return self._s[1101]! } - public var Watch_Bot_Restart: String { return self._s[1102]! } - public var TwoStepAuth_Title: String { return self._s[1103]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1104]! } - public var Checkout_ShippingMethod: String { return self._s[1105]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1106]! } + public var Calls_SubmitRating: String { return self._s[1087]! } + public var Map_NoPlacesNearby: String { return self._s[1088]! } + public var Profile_Username: String { return self._s[1089]! } + public var Bot_DescriptionTitle: String { return self._s[1090]! } + public var MaskStickerSettings_Title: String { return self._s[1091]! } + public var SharedMedia_CategoryOther: String { return self._s[1092]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1093]! } + public var Common_NotNow: String { return self._s[1094]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1095]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1096]! } + public var Map_Location: String { return self._s[1097]! } + public var Invitation_JoinGroup: String { return self._s[1098]! } + public var AutoDownloadSettings_Title: String { return self._s[1100]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1101]! } + public var Channel_ErrorAddBlocked: String { return self._s[1102]! } + public var Conversation_UnblockUser: String { return self._s[1103]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1104]! } + public var Watch_Bot_Restart: String { return self._s[1105]! } + public var TwoStepAuth_Title: String { return self._s[1106]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1107]! } + public var Checkout_ShippingMethod: String { return self._s[1108]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1109]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1107]!, self._r[1107]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1110]!, self._r[1110]!, [_1, _2, _3]) } - public var PeerInfo_ButtonDiscuss: String { return self._s[1108]! } - public var EditTheme_ChangeColors: String { return self._s[1110]! } + public var PeerInfo_ButtonDiscuss: String { return self._s[1111]! } + public var EditTheme_ChangeColors: String { return self._s[1113]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1111]!, self._r[1111]!, [_0]) + return formatWithArgumentRanges(self._s[1114]!, self._r[1114]!, [_0]) } public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1112]!, self._r[1112]!, [_0]) + return formatWithArgumentRanges(self._s[1115]!, self._r[1115]!, [_0]) } - public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1113]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1114]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[1115]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[1116]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[1117]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1118]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1119]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[1120]! } - public var Checkout_PaymentMethod_Title: String { return self._s[1121]! } - public var SocksProxySetup_Connection: String { return self._s[1122]! } - public var Group_MessagePhotoRemoved: String { return self._s[1123]! } - public var PeopleNearby_MakeInvisible: String { return self._s[1125]! } - public var Channel_Stickers_NotFound: String { return self._s[1127]! } - public var Group_About_Help: String { return self._s[1128]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[1129]! } - public var PeopleNearby_Title: String { return self._s[1131]! } + public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1116]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1117]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1118]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1119]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1120]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1121]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1122]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1123]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1124]! } + public var SocksProxySetup_Connection: String { return self._s[1125]! } + public var Group_MessagePhotoRemoved: String { return self._s[1126]! } + public var PeopleNearby_MakeInvisible: String { return self._s[1128]! } + public var Channel_Stickers_NotFound: String { return self._s[1130]! } + public var Group_About_Help: String { return self._s[1131]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1132]! } + public var PeopleNearby_Title: String { return self._s[1134]! } public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1132]!, self._r[1132]!, [_1]) + return formatWithArgumentRanges(self._s[1135]!, self._r[1135]!, [_1]) } - public var Map_Home: String { return self._s[1133]! } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1135]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1136]! } - public var SocksProxySetup_Password: String { return self._s[1137]! } - public var Notifications_PermissionsEnable: String { return self._s[1138]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[1140]! } + public var Map_Home: String { return self._s[1136]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1138]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1139]! } + public var SocksProxySetup_Password: String { return self._s[1140]! } + public var Notifications_PermissionsEnable: String { return self._s[1141]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1143]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1141]!, self._r[1141]!, [_1]) + return formatWithArgumentRanges(self._s[1144]!, self._r[1144]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1143]!, self._r[1143]!, [_0]) + return formatWithArgumentRanges(self._s[1146]!, self._r[1146]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[1144]! } - public var ArchivedPacksAlert_Title: String { return self._s[1145]! } - public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1146]! } - public var Map_PlacesNearby: String { return self._s[1147]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[1147]! } + public var ArchivedPacksAlert_Title: String { return self._s[1148]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1149]! } + public var Map_PlacesNearby: String { return self._s[1150]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1148]!, self._r[1148]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1151]!, self._r[1151]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1149]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1151]! } - public var Conversation_StatusTyping: String { return self._s[1152]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[1153]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1154]! } - public var UserInfo_CreateNewContact: String { return self._s[1155]! } - public var Passport_Identity_FrontSide: String { return self._s[1156]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1157]! } - public var Calls_CallTabTitle: String { return self._s[1158]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1159]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1152]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1154]! } + public var Conversation_StatusTyping: String { return self._s[1155]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1156]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1157]! } + public var UserInfo_CreateNewContact: String { return self._s[1158]! } + public var Passport_Identity_FrontSide: String { return self._s[1159]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1160]! } + public var Calls_CallTabTitle: String { return self._s[1161]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1162]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1161]!, self._r[1161]!, [_0]) + return formatWithArgumentRanges(self._s[1164]!, self._r[1164]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[1162]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1163]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1164]! } - public var Wallet_Completed_Text: String { return self._s[1165]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1166]! } - public var Paint_Stickers: String { return self._s[1167]! } - public var Privacy_GroupsAndChannels: String { return self._s[1168]! } - public var ChatList_Context_Delete: String { return self._s[1170]! } - public var UserInfo_AddContact: String { return self._s[1171]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1165]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1166]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1167]! } + public var Wallet_Completed_Text: String { return self._s[1168]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1169]! } + public var Paint_Stickers: String { return self._s[1170]! } + public var Privacy_GroupsAndChannels: String { return self._s[1171]! } + public var ChatList_Context_Delete: String { return self._s[1173]! } + public var UserInfo_AddContact: String { return self._s[1174]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1172]!, self._r[1172]!, [_0]) + return formatWithArgumentRanges(self._s[1175]!, self._r[1175]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1174]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1177]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1176]!, self._r[1176]!, [_0]) + return formatWithArgumentRanges(self._s[1179]!, self._r[1179]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1177]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1178]! } - public var BlockedUsers_BlockUser: String { return self._s[1179]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1180]! } - public var MediaPicker_UngroupDescription: String { return self._s[1182]! } - public var Watch_NoConnection: String { return self._s[1183]! } - public var Month_GenSeptember: String { return self._s[1184]! } - public var Conversation_ViewGroup: String { return self._s[1186]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1189]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1190]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1191]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1192]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1193]! } - public var MediaPicker_CameraRoll: String { return self._s[1195]! } - public var Month_GenAugust: String { return self._s[1196]! } - public var Wallet_Configuration_SourceHeader: String { return self._s[1197]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1198]! } - public var SharedMedia_EmptyText: String { return self._s[1199]! } - public var Map_ShareLiveLocation: String { return self._s[1200]! } - public var Calls_All: String { return self._s[1201]! } - public var Map_SendThisPlace: String { return self._s[1203]! } - public var Appearance_ThemeNight: String { return self._s[1205]! } - public var Conversation_HoldForAudio: String { return self._s[1206]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1209]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1210]! } - public var SocksProxySetup_Secret: String { return self._s[1211]! } + public var DialogList_NoMessagesTitle: String { return self._s[1180]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1181]! } + public var BlockedUsers_BlockUser: String { return self._s[1182]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1183]! } + public var MediaPicker_UngroupDescription: String { return self._s[1185]! } + public var Watch_NoConnection: String { return self._s[1186]! } + public var Month_GenSeptember: String { return self._s[1187]! } + public var Conversation_ViewGroup: String { return self._s[1189]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1192]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1193]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1194]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1195]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1196]! } + public var MediaPicker_CameraRoll: String { return self._s[1198]! } + public var Month_GenAugust: String { return self._s[1199]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1200]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1201]! } + public var SharedMedia_EmptyText: String { return self._s[1202]! } + public var Map_ShareLiveLocation: String { return self._s[1203]! } + public var Calls_All: String { return self._s[1204]! } + public var Map_SendThisPlace: String { return self._s[1206]! } + public var Appearance_ThemeNight: String { return self._s[1208]! } + public var Conversation_HoldForAudio: String { return self._s[1209]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1212]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1213]! } + public var SocksProxySetup_Secret: String { return self._s[1214]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1212]!, self._r[1212]!, [_0]) + return formatWithArgumentRanges(self._s[1215]!, self._r[1215]!, [_0]) } - public var Channel_BanList_RestrictedTitle: String { return self._s[1214]! } - public var Conversation_Location: String { return self._s[1215]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1217]! } + public var Conversation_Location: String { return self._s[1218]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1216]!, self._r[1216]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1219]!, self._r[1219]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1218]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1219]! } - public var Notifications_PermissionsText: String { return self._s[1220]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1221]! } - public var Call_Flip: String { return self._s[1222]! } - public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1224]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1225]! } - public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1226]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1227]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1229]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1231]! } - public var Channel_TooMuchBots: String { return self._s[1233]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1234]! } - public var Login_InvalidCodeError: String { return self._s[1235]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1236]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1221]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1222]! } + public var Notifications_PermissionsText: String { return self._s[1223]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1224]! } + public var Call_Flip: String { return self._s[1225]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1227]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1228]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1229]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1230]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1232]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1234]! } + public var Channel_TooMuchBots: String { return self._s[1236]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1237]! } + public var Login_InvalidCodeError: String { return self._s[1238]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1239]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1237]!, self._r[1237]!, [_0]) + return formatWithArgumentRanges(self._s[1240]!, self._r[1240]!, [_0]) } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1238]!, self._r[1238]!, [_0]) + return formatWithArgumentRanges(self._s[1241]!, self._r[1241]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1239]! } - public var Call_CallInProgressTitle: String { return self._s[1240]! } - public var Month_ShortSeptember: String { return self._s[1241]! } - public var Watch_ChannelInfo_Title: String { return self._s[1242]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1245]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1246]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1247]! } - public var Wallet_Receive_Title: String { return self._s[1248]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1249]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1250]! } - public var PhotoEditor_CropReset: String { return self._s[1251]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1253]! } - public var Channel_Management_LabelEditor: String { return self._s[1254]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1256]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1257]! } - public var Wallet_Info_WalletCreated: String { return self._s[1258]! } - public var UserInfo_Title: String { return self._s[1259]! } - public var ChatList_HideAction: String { return self._s[1260]! } - public var AccessDenied_Title: String { return self._s[1261]! } - public var DialogList_SearchLabel: String { return self._s[1262]! } - public var Group_Setup_HistoryHidden: String { return self._s[1263]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1264]! } - public var State_Updating: String { return self._s[1266]! } - public var Contacts_TabTitle: String { return self._s[1267]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1269]! } - public var GroupInfo_GroupHistory: String { return self._s[1270]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1271]! } - public var Wallpaper_SetColor: String { return self._s[1272]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1273]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1274]! } - public var Chat_AttachmentLimitReached: String { return self._s[1275]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1276]! } - public var Contacts_NotRegisteredSection: String { return self._s[1277]! } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1242]! } + public var Call_CallInProgressTitle: String { return self._s[1243]! } + public var Month_ShortSeptember: String { return self._s[1244]! } + public var Watch_ChannelInfo_Title: String { return self._s[1245]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1248]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1249]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1250]! } + public var Wallet_Receive_Title: String { return self._s[1251]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1252]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1253]! } + public var PhotoEditor_CropReset: String { return self._s[1254]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1256]! } + public var Channel_Management_LabelEditor: String { return self._s[1257]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1259]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1260]! } + public var Wallet_Info_WalletCreated: String { return self._s[1261]! } + public var UserInfo_Title: String { return self._s[1262]! } + public var ChatList_HideAction: String { return self._s[1263]! } + public var AccessDenied_Title: String { return self._s[1264]! } + public var DialogList_SearchLabel: String { return self._s[1265]! } + public var Group_Setup_HistoryHidden: String { return self._s[1266]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1267]! } + public var State_Updating: String { return self._s[1269]! } + public var Contacts_TabTitle: String { return self._s[1270]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1272]! } + public var GroupInfo_GroupHistory: String { return self._s[1273]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1274]! } + public var Wallpaper_SetColor: String { return self._s[1275]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1276]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1277]! } + public var Chat_AttachmentLimitReached: String { return self._s[1278]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1279]! } + public var Contacts_NotRegisteredSection: String { return self._s[1280]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1278]!, self._r[1278]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1281]!, self._r[1281]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1279]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1280]! } - public var SocksProxySetup_Connecting: String { return self._s[1281]! } - public var ExplicitContent_AlertChannel: String { return self._s[1282]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1283]! } - public var Conversation_Contact: String { return self._s[1284]! } - public var Login_CodeExpired: String { return self._s[1285]! } - public var Passport_DiscardMessageAction: String { return self._s[1286]! } - public var ChatList_Context_Unpin: String { return self._s[1287]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1288]! } + public var Paint_Clear: String { return self._s[1282]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1283]! } + public var SocksProxySetup_Connecting: String { return self._s[1284]! } + public var ExplicitContent_AlertChannel: String { return self._s[1285]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1286]! } + public var Conversation_Contact: String { return self._s[1287]! } + public var Login_CodeExpired: String { return self._s[1288]! } + public var Passport_DiscardMessageAction: String { return self._s[1289]! } + public var ChatList_Context_Unpin: String { return self._s[1290]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1291]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1289]!, self._r[1289]!, [_0]) - } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1290]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1291]! } - public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1292]!, self._r[1292]!, [_0]) } - public var Month_ShortApril: String { return self._s[1293]! } - public var AuthSessions_CurrentSession: String { return self._s[1294]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1297]! } - public var Wallet_Navigation_Cancel: String { return self._s[1299]! } - public var WallpaperPreview_CropTopText: String { return self._s[1300]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1301]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1302]! } - public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1303]!, self._r[1303]!, [_0, _1]) + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1293]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1294]! } + public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1295]!, self._r[1295]!, [_0]) } - public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1304]! } - public var Channel_Setup_TypePrivate: String { return self._s[1306]! } - public var Forward_ChannelReadOnly: String { return self._s[1309]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1310]! } - public var AddContact_SharedContactException: String { return self._s[1311]! } - public var UserInfo_BotPrivacy: String { return self._s[1313]! } - public var Wallet_CreateInvoice_Title: String { return self._s[1314]! } - public var Notification_PassportValueEmail: String { return self._s[1315]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1316]! } - public var GroupPermission_NewTitle: String { return self._s[1317]! } - public var CallFeedback_ReasonDropped: String { return self._s[1318]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1319]! } - public var Channel_SignMessages_Help: String { return self._s[1321]! } - public var Undo_ChatDeleted: String { return self._s[1323]! } - public var Conversation_ChatBackground: String { return self._s[1324]! } + public var Month_ShortApril: String { return self._s[1296]! } + public var AuthSessions_CurrentSession: String { return self._s[1297]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1300]! } + public var Wallet_Navigation_Cancel: String { return self._s[1302]! } + public var WallpaperPreview_CropTopText: String { return self._s[1303]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1304]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1305]! } + public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1306]!, self._r[1306]!, [_0, _1]) + } + public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1307]! } + public var Channel_Setup_TypePrivate: String { return self._s[1309]! } + public var Forward_ChannelReadOnly: String { return self._s[1312]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1313]! } + public var AddContact_SharedContactException: String { return self._s[1314]! } + public var UserInfo_BotPrivacy: String { return self._s[1316]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1317]! } + public var Notification_PassportValueEmail: String { return self._s[1318]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1319]! } + public var GroupPermission_NewTitle: String { return self._s[1320]! } + public var CallFeedback_ReasonDropped: String { return self._s[1321]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1322]! } + public var Channel_SignMessages_Help: String { return self._s[1324]! } + public var Undo_ChatDeleted: String { return self._s[1326]! } + public var Conversation_ChatBackground: String { return self._s[1327]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1325]!, self._r[1325]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1328]!, self._r[1328]!, [_1, _2, _3]) } public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1326]!, self._r[1326]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1329]!, self._r[1329]!, [_1, _2, _3]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1327]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1328]! } - public var Passport_Language_pt: String { return self._s[1329]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1330]! } - public var NotificationsSound_Popcorn: String { return self._s[1333]! } - public var AutoNightTheme_Disabled: String { return self._s[1334]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1335]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1336]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1337]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1338]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1330]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1331]! } + public var Passport_Language_pt: String { return self._s[1332]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1333]! } + public var NotificationsSound_Popcorn: String { return self._s[1336]! } + public var AutoNightTheme_Disabled: String { return self._s[1337]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1338]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1339]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1340]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1341]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1339]!, self._r[1339]!, [_0]) + return formatWithArgumentRanges(self._s[1342]!, self._r[1342]!, [_0]) } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1340]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1341]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1343]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1343]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1344]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1346]! } + public var PeerInfo_PaneGroups: String { return self._s[1347]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1344]!, self._r[1344]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1348]!, self._r[1348]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1347]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1348]! } - public var Compose_NewEncryptedChat: String { return self._s[1349]! } - public var Login_CodeFloodError: String { return self._s[1350]! } - public var Calls_TabTitle: String { return self._s[1351]! } - public var Privacy_ProfilePhoto: String { return self._s[1352]! } - public var Passport_Language_he: String { return self._s[1353]! } + public var SocksProxySetup_Hostname: String { return self._s[1351]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1352]! } + public var Compose_NewEncryptedChat: String { return self._s[1353]! } + public var Login_CodeFloodError: String { return self._s[1354]! } + public var Calls_TabTitle: String { return self._s[1355]! } + public var Privacy_ProfilePhoto: String { return self._s[1356]! } + public var Passport_Language_he: String { return self._s[1357]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1354]!, self._r[1354]!, [_0]) + return formatWithArgumentRanges(self._s[1358]!, self._r[1358]!, [_0]) } - public var GroupPermission_Title: String { return self._s[1355]! } + public var GroupPermission_Title: String { return self._s[1359]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1356]!, self._r[1356]!, [_0]) + return formatWithArgumentRanges(self._s[1360]!, self._r[1360]!, [_0]) } - public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1357]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1358]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1359]! } - public var Tour_Text1: String { return self._s[1360]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1361]! } - public var Month_ShortFebruary: String { return self._s[1362]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1363]! } + public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1361]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1362]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1363]! } + public var Tour_Text1: String { return self._s[1364]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1365]! } + public var Month_ShortFebruary: String { return self._s[1366]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1367]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1364]!, self._r[1364]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1368]!, self._r[1368]!, [_1, _2, _3]) } - public var NotificationsSound_Glass: String { return self._s[1365]! } - public var Appearance_ThemeNightBlue: String { return self._s[1366]! } - public var CheckoutInfo_Pay: String { return self._s[1367]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1369]! } - public var Call_CallAgain: String { return self._s[1371]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1372]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1373]! } - public var Passport_InvalidPasswordError: String { return self._s[1374]! } - public var Watch_Message_Game: String { return self._s[1375]! } - public var Stickers_Install: String { return self._s[1376]! } - public var VoiceOver_Chat_Message: String { return self._s[1377]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1378]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1380]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1381]! } - public var AuthSessions_OtherSessions: String { return self._s[1382]! } - public var Channel_Username_Help: String { return self._s[1383]! } - public var Camera_Title: String { return self._s[1384]! } - public var IntentsSettings_Title: String { return self._s[1385]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1387]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1388]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1389]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1390]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1391]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1392]! } - public var ScheduledMessages_DeleteMany: String { return self._s[1393]! } - public var Conversation_RestrictedStickers: String { return self._s[1394]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1396]! } - public var UserInfo_TelegramCall: String { return self._s[1398]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1399]! } - public var CreatePoll_OptionsHeader: String { return self._s[1400]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1401]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1402]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1403]! } - public var Theme_Colors_Proceed: String { return self._s[1404]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1405]! } + public var NotificationsSound_Glass: String { return self._s[1369]! } + public var Appearance_ThemeNightBlue: String { return self._s[1370]! } + public var CheckoutInfo_Pay: String { return self._s[1371]! } + public var PeerInfo_ButtonLeave: String { return self._s[1373]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1374]! } + public var Call_CallAgain: String { return self._s[1376]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1377]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1378]! } + public var Passport_InvalidPasswordError: String { return self._s[1379]! } + public var Watch_Message_Game: String { return self._s[1380]! } + public var Stickers_Install: String { return self._s[1381]! } + public var VoiceOver_Chat_Message: String { return self._s[1382]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1383]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1385]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1386]! } + public var AuthSessions_OtherSessions: String { return self._s[1387]! } + public var Channel_Username_Help: String { return self._s[1388]! } + public var Camera_Title: String { return self._s[1389]! } + public var IntentsSettings_Title: String { return self._s[1390]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1392]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1393]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1394]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1395]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1396]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1397]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1398]! } + public var Conversation_RestrictedStickers: String { return self._s[1399]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1401]! } + public var UserInfo_TelegramCall: String { return self._s[1403]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1404]! } + public var CreatePoll_OptionsHeader: String { return self._s[1405]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1406]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1407]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1408]! } + public var Theme_Colors_Proceed: String { return self._s[1409]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1410]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1406]!, self._r[1406]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1411]!, self._r[1411]!, [_1, _2, _3]) } - public var Wallet_Month_GenAugust: String { return self._s[1407]! } - public var Settings_SaveEditedPhotos: String { return self._s[1408]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1409]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1410]! } - public var Conversation_MessageDialogRetry: String { return self._s[1411]! } - public var ChatList_Context_MarkAsUnread: String { return self._s[1412]! } - public var MessagePoll_SubmitVote: String { return self._s[1413]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1414]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1415]! } - public var Group_Setup_TypeHeader: String { return self._s[1416]! } - public var Paint_RecentStickers: String { return self._s[1417]! } - public var PhotoEditor_GrainTool: String { return self._s[1418]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1419]! } - public var EmptyGroupInfo_Line4: String { return self._s[1420]! } - public var Watch_AuthRequired: String { return self._s[1422]! } + public var Wallet_Month_GenAugust: String { return self._s[1412]! } + public var Settings_SaveEditedPhotos: String { return self._s[1413]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1414]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1415]! } + public var Conversation_MessageDialogRetry: String { return self._s[1416]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1417]! } + public var MessagePoll_SubmitVote: String { return self._s[1418]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1419]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1420]! } + public var Group_Setup_TypeHeader: String { return self._s[1421]! } + public var Paint_RecentStickers: String { return self._s[1422]! } + public var PhotoEditor_GrainTool: String { return self._s[1423]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1424]! } + public var EmptyGroupInfo_Line4: String { return self._s[1425]! } + public var Watch_AuthRequired: String { return self._s[1427]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1423]!, self._r[1423]!, [_0]) + return formatWithArgumentRanges(self._s[1428]!, self._r[1428]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1424]! } - public var ChannelIntro_Text: String { return self._s[1425]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1426]! } - public var GroupPermission_NoSendMedia: String { return self._s[1427]! } - public var Calls_AddTab: String { return self._s[1428]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1429]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1430]! } - public var Conversation_WalletRequiredSetup: String { return self._s[1431]! } - public var Notification_MessageLifetime1d: String { return self._s[1432]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1433]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1434]! } - public var Passport_Identity_GenderFemale: String { return self._s[1435]! } - public var BlockedUsers_BlockTitle: String { return self._s[1436]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1429]! } + public var ChannelIntro_Text: String { return self._s[1430]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1431]! } + public var GroupPermission_NoSendMedia: String { return self._s[1432]! } + public var Calls_AddTab: String { return self._s[1433]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1434]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1435]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1436]! } + public var Notification_MessageLifetime1d: String { return self._s[1437]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1438]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1439]! } + public var Passport_Identity_GenderFemale: String { return self._s[1440]! } + public var BlockedUsers_BlockTitle: String { return self._s[1441]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1437]!, self._r[1437]!, [_1]) + return formatWithArgumentRanges(self._s[1442]!, self._r[1442]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1438]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1439]! } - public var Settings_Context_Logout: String { return self._s[1440]! } - public var Wallet_Info_UnknownTransaction: String { return self._s[1441]! } - public var ChatList_ArchiveAction: String { return self._s[1442]! } - public var AutoNightTheme_Scheduled: String { return self._s[1443]! } - public var TwoFactorSetup_Email_SkipAction: String { return self._s[1444]! } - public var Settings_Devices: String { return self._s[1445]! } - public var ContactInfo_Note: String { return self._s[1446]! } + public var Weekday_Yesterday: String { return self._s[1443]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1444]! } + public var Settings_Context_Logout: String { return self._s[1445]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1446]! } + public var ChatList_ArchiveAction: String { return self._s[1447]! } + public var AutoNightTheme_Scheduled: String { return self._s[1448]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1449]! } + public var Settings_Devices: String { return self._s[1450]! } + public var ContactInfo_Note: String { return self._s[1451]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1447]!, self._r[1447]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, [_1, _2, _3, _4, _5, _6]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1448]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[1449]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1450]! } - public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1451]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1453]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1454]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1455]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1456]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1452]!, self._r[1452]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1457]!, self._r[1457]!, [_1, _2]) } - public var CreatePoll_Create: String { return self._s[1453]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1454]! } + public var CreatePoll_Create: String { return self._s[1458]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1459]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1455]!, self._r[1455]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1460]!, self._r[1460]!, [_1, _2]) } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1456]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1457]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1459]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1461]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1462]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1464]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1460]!, self._r[1460]!, [_1]) + return formatWithArgumentRanges(self._s[1465]!, self._r[1465]!, [_1]) } - public var Preview_OpenInInstagram: String { return self._s[1461]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1462]! } + public var Preview_OpenInInstagram: String { return self._s[1466]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1467]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1463]!, self._r[1463]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1468]!, self._r[1468]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1464]!, self._r[1464]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1469]!, self._r[1469]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1465]! } - public var ArchivedChats_IntroText3: String { return self._s[1466]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1467]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1468]! } - public var Wallet_Month_GenSeptember: String { return self._s[1469]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1470]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1470]! } + public var ArchivedChats_IntroText3: String { return self._s[1471]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1472]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1473]! } + public var Wallet_Month_GenSeptember: String { return self._s[1474]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1475]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1471]!, self._r[1471]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1476]!, self._r[1476]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1473]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1474]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1475]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1476]! } - public var Gif_NoGifsFound: String { return self._s[1477]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1478]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1479]! } - public var EditTheme_Preview: String { return self._s[1480]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1478]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1479]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1480]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1481]! } + public var Gif_NoGifsFound: String { return self._s[1482]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1483]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1484]! } + public var EditTheme_Preview: String { return self._s[1485]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1481]!, self._r[1481]!, [_0]) + return formatWithArgumentRanges(self._s[1486]!, self._r[1486]!, [_0]) } - public var GroupInfo_ActionPromote: String { return self._s[1482]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1483]! } - public var GroupInfo_Permissions_Title: String { return self._s[1484]! } - public var Permissions_ContactsText_v0: String { return self._s[1485]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1486]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1487]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1490]! } - public var Passport_FieldEmailHelp: String { return self._s[1491]! } + public var GroupInfo_ActionPromote: String { return self._s[1487]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1488]! } + public var GroupInfo_Permissions_Title: String { return self._s[1489]! } + public var Permissions_ContactsText_v0: String { return self._s[1490]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1491]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1492]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1495]! } + public var Passport_FieldEmailHelp: String { return self._s[1496]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1492]!, self._r[1492]!, [_0]) + return formatWithArgumentRanges(self._s[1497]!, self._r[1497]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1493]! } - public var Weekday_ShortSaturday: String { return self._s[1494]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1495]! } - public var Watch_Conversation_UserInfo: String { return self._s[1496]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1497]! } - public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1498]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1499]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1500]! } - public var PhotoEditor_VignetteTool: String { return self._s[1501]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1502]! } - public var Passport_Language_et: String { return self._s[1503]! } - public var AppUpgrade_Running: String { return self._s[1504]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1506]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1507]! } - public var Passport_Language_bg: String { return self._s[1508]! } - public var Stickers_NoStickersFound: String { return self._s[1510]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1498]! } + public var Weekday_ShortSaturday: String { return self._s[1499]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1500]! } + public var Watch_Conversation_UserInfo: String { return self._s[1501]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1502]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1503]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1504]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1505]! } + public var PhotoEditor_VignetteTool: String { return self._s[1506]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1507]! } + public var Passport_Language_et: String { return self._s[1508]! } + public var AppUpgrade_Running: String { return self._s[1509]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1511]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1512]! } + public var Passport_Language_bg: String { return self._s[1513]! } + public var Stickers_NoStickersFound: String { return self._s[1515]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1512]!, self._r[1512]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1517]!, self._r[1517]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1513]!, self._r[1513]!, [_0]) + return formatWithArgumentRanges(self._s[1518]!, self._r[1518]!, [_0]) } - public var Wallet_Month_GenJuly: String { return self._s[1514]! } - public var Wallet_Receive_AddressHeader: String { return self._s[1515]! } - public var Wallet_Send_AmountText: String { return self._s[1516]! } - public var Settings_About: String { return self._s[1517]! } + public var Wallet_Month_GenJuly: String { return self._s[1519]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1520]! } + public var Wallet_Send_AmountText: String { return self._s[1521]! } + public var Settings_About: String { return self._s[1522]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1518]!, self._r[1518]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1523]!, self._r[1523]!, [_0, _1, _2]) } - public var ChatList_Context_MarkAsRead: String { return self._s[1520]! } - public var KeyCommand_NewMessage: String { return self._s[1521]! } - public var Group_ErrorAddBlocked: String { return self._s[1522]! } + public var ChatList_Context_MarkAsRead: String { return self._s[1525]! } + public var KeyCommand_NewMessage: String { return self._s[1526]! } + public var Group_ErrorAddBlocked: String { return self._s[1527]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1523]!, self._r[1523]!, [_0]) - } - public var Map_LocationTitle: String { return self._s[1524]! } - public var ReportGroupLocation_Title: String { return self._s[1525]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1526]! } - public var Cache_ClearProgress: String { return self._s[1527]! } - public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1528]!, self._r[1528]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1529]! } - public var Passport_UpdateRequiredError: String { return self._s[1530]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1531]! } + public var Map_LocationTitle: String { return self._s[1529]! } + public var ReportGroupLocation_Title: String { return self._s[1530]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1531]! } + public var Cache_ClearProgress: String { return self._s[1532]! } + public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1533]!, self._r[1533]!, [_0]) + } + public var GroupRemoved_AddToGroup: String { return self._s[1534]! } + public var Passport_UpdateRequiredError: String { return self._s[1535]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1536]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1532]!, self._r[1532]!, [_1]) + return formatWithArgumentRanges(self._s[1537]!, self._r[1537]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1534]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1535]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1536]! } - public var Passport_Language_ka: String { return self._s[1537]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1539]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1540]! } + public var PeerInfo_ButtonSearch: String { return self._s[1541]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1542]! } + public var Passport_Language_ka: String { return self._s[1543]! } public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1538]!, self._r[1538]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1544]!, self._r[1544]!, [_1, _2, _3]) } - public var Call_Decline: String { return self._s[1539]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1540]! } - public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1543]! } + public var Call_Decline: String { return self._s[1545]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1546]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1549]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1544]!, self._r[1544]!, [_0]) - } - public var CallFeedback_Send: String { return self._s[1545]! } - public var EditTheme_EditTitle: String { return self._s[1546]! } - public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1547]!, self._r[1547]!, [_1, _2]) - } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1548]! } - public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1550]!, self._r[1550]!, [_0]) } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1551]! } - public var Passport_DeletePassport: String { return self._s[1552]! } - public var Appearance_AppIconFilled: String { return self._s[1553]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1554]! } - public var Month_ShortDecember: String { return self._s[1555]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1557]! } + public var CallFeedback_Send: String { return self._s[1551]! } + public var EditTheme_EditTitle: String { return self._s[1552]! } + public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1553]!, self._r[1553]!, [_1, _2]) + } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1554]! } + public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1556]!, self._r[1556]!, [_0]) + } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1557]! } + public var Passport_DeletePassport: String { return self._s[1558]! } + public var Appearance_AppIconFilled: String { return self._s[1559]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1560]! } + public var Month_ShortDecember: String { return self._s[1561]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1563]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1558]!, self._r[1558]!, [_0]) + return formatWithArgumentRanges(self._s[1564]!, self._r[1564]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1559]! } - public var Conversation_EncryptedDescription1: String { return self._s[1560]! } - public var Conversation_EncryptedDescription2: String { return self._s[1561]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1562]! } - public var Conversation_EncryptedDescription3: String { return self._s[1564]! } - public var PhotoEditor_SharpenTool: String { return self._s[1565]! } - public var Wallet_Configuration_Title: String { return self._s[1566]! } + public var Channel_Stickers_Searching: String { return self._s[1565]! } + public var Conversation_EncryptedDescription1: String { return self._s[1566]! } + public var Conversation_EncryptedDescription2: String { return self._s[1567]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1568]! } + public var Conversation_EncryptedDescription3: String { return self._s[1570]! } + public var PhotoEditor_SharpenTool: String { return self._s[1571]! } + public var Wallet_Configuration_Title: String { return self._s[1572]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1567]!, self._r[1567]!, [_0]) + return formatWithArgumentRanges(self._s[1573]!, self._r[1573]!, [_0]) } - public var Conversation_EncryptedDescription4: String { return self._s[1569]! } - public var Channel_Members_AddMembers: String { return self._s[1570]! } - public var Wallpaper_Search: String { return self._s[1571]! } - public var Weekday_Friday: String { return self._s[1573]! } - public var Privacy_ContactsSync: String { return self._s[1574]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1575]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1576]! } + public var Conversation_EncryptedDescription4: String { return self._s[1575]! } + public var Channel_Members_AddMembers: String { return self._s[1576]! } + public var Wallpaper_Search: String { return self._s[1577]! } + public var Weekday_Friday: String { return self._s[1579]! } + public var Privacy_ContactsSync: String { return self._s[1580]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1581]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1582]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1577]!, self._r[1577]!, [_0]) + return formatWithArgumentRanges(self._s[1583]!, self._r[1583]!, [_0]) } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1578]! } - public var GroupInfo_Permissions_Removed: String { return self._s[1579]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[1580]! } - public var Passport_Identity_GenderMale: String { return self._s[1581]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1584]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1585]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1586]! } + public var Passport_Identity_GenderMale: String { return self._s[1587]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1582]!, self._r[1582]!, [_0]) + return formatWithArgumentRanges(self._s[1588]!, self._r[1588]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1583]! } - public var Conversation_JumpToDate: String { return self._s[1584]! } - public var Contacts_GlobalSearch: String { return self._s[1585]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1586]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1587]! } - public var Profile_MessageLifetime1d: String { return self._s[1588]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1589]! } + public var Conversation_JumpToDate: String { return self._s[1590]! } + public var Contacts_GlobalSearch: String { return self._s[1591]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1592]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1593]! } + public var Profile_MessageLifetime1d: String { return self._s[1594]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1589]!, self._r[1589]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1595]!, self._r[1595]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1592]! } + public var StickerPack_BuiltinPackName: String { return self._s[1598]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1593]!, self._r[1593]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1599]!, self._r[1599]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1594]! } - public var Passport_InfoTitle: String { return self._s[1596]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1597]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1600]! } + public var Passport_InfoTitle: String { return self._s[1602]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1603]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1601]!, self._r[1601]!, [_0]) + return formatWithArgumentRanges(self._s[1607]!, self._r[1607]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1602]!, self._r[1602]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1608]!, self._r[1608]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1603]! } - public var Profile_BotInfo: String { return self._s[1604]! } - public var Watch_Compose_CreateMessage: String { return self._s[1605]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1606]! } - public var Month_ShortNovember: String { return self._s[1607]! } - public var Conversation_ScamWarning: String { return self._s[1608]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1609]! } - public var Appearance_TextSize_Title: String { return self._s[1610]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1611]! } - public var NotificationsSound_Chime: String { return self._s[1612]! } - public var Passport_Language_ko: String { return self._s[1614]! } - public var InviteText_URL: String { return self._s[1615]! } - public var TextFormat_Monospace: String { return self._s[1616]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1609]! } + public var Profile_BotInfo: String { return self._s[1610]! } + public var Watch_Compose_CreateMessage: String { return self._s[1611]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1612]! } + public var Month_ShortNovember: String { return self._s[1613]! } + public var Conversation_ScamWarning: String { return self._s[1614]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1615]! } + public var Appearance_TextSize_Title: String { return self._s[1616]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1617]! } + public var NotificationsSound_Chime: String { return self._s[1618]! } + public var Passport_Language_ko: String { return self._s[1620]! } + public var InviteText_URL: String { return self._s[1621]! } + public var TextFormat_Monospace: String { return self._s[1622]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1617]!, self._r[1617]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1623]!, self._r[1623]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1618]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1624]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1619]!, self._r[1619]!, [_0]) + return formatWithArgumentRanges(self._s[1625]!, self._r[1625]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1620]!, self._r[1620]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1626]!, self._r[1626]!, [_1, _2]) } - public var Wallet_Words_Title: String { return self._s[1621]! } - public var Wallet_Month_ShortMay: String { return self._s[1622]! } - public var EditTheme_CreateTitle: String { return self._s[1624]! } - public var Passport_InfoLearnMore: String { return self._s[1625]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1626]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1627]! } - public var Your_card_has_expired: String { return self._s[1628]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1629]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1630]! } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1634]! } - public var Conversation_Report: String { return self._s[1636]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1637]! } - public var Notification_MessageLifetime1m: String { return self._s[1638]! } - public var Privacy_ContactsTitle: String { return self._s[1639]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1640]! } - public var Wallet_WordCheck_Title: String { return self._s[1641]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1642]! } - public var Channel_Members_Title: String { return self._s[1643]! } - public var Map_OpenInWaze: String { return self._s[1644]! } - public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1645]! } - public var Login_PhoneBannedError: String { return self._s[1646]! } + public var Wallet_Words_Title: String { return self._s[1627]! } + public var Wallet_Month_ShortMay: String { return self._s[1628]! } + public var EditTheme_CreateTitle: String { return self._s[1630]! } + public var Passport_InfoLearnMore: String { return self._s[1631]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1632]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1633]! } + public var Your_card_has_expired: String { return self._s[1634]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1635]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1636]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1640]! } + public var Conversation_Report: String { return self._s[1642]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1643]! } + public var Notification_MessageLifetime1m: String { return self._s[1644]! } + public var Privacy_ContactsTitle: String { return self._s[1645]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1646]! } + public var Wallet_WordCheck_Title: String { return self._s[1647]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1648]! } + public var Channel_Members_Title: String { return self._s[1649]! } + public var Map_OpenInWaze: String { return self._s[1650]! } + public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1651]! } + public var Login_PhoneBannedError: String { return self._s[1652]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1647]!, self._r[1647]!, [_0]) + return formatWithArgumentRanges(self._s[1653]!, self._r[1653]!, [_0]) } - public var IntentsSettings_MainAccount: String { return self._s[1648]! } - public var Group_Management_AddModeratorHelp: String { return self._s[1649]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1650]! } - public var Common_OK: String { return self._s[1651]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1652]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[1653]! } - public var Cache_Music: String { return self._s[1654]! } - public var Wallet_Configuration_SourceURL: String { return self._s[1655]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1656]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1659]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1660]! } + public var IntentsSettings_MainAccount: String { return self._s[1654]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1655]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1656]! } + public var Common_OK: String { return self._s[1657]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1658]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1659]! } + public var Cache_Music: String { return self._s[1660]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1661]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1662]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1665]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1666]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1661]!, self._r[1661]!, [_1]) + return formatWithArgumentRanges(self._s[1667]!, self._r[1667]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1662]!, self._r[1662]!, [_0]) + return formatWithArgumentRanges(self._s[1668]!, self._r[1668]!, [_0]) } - public var TwoFactorSetup_Done_Action: String { return self._s[1663]! } + public var TwoFactorSetup_Done_Action: String { return self._s[1669]! } public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1664]!, self._r[1664]!, [_0]) + return formatWithArgumentRanges(self._s[1670]!, self._r[1670]!, [_0]) } - public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1665]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1667]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1668]! } - public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1670]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1671]! } - public var State_ConnectingToProxyInfo: String { return self._s[1672]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[1673]! } - public var Message_VideoMessage: String { return self._s[1675]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1676]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1677]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1678]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1679]! } + public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1671]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1673]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1674]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1676]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1677]! } + public var State_ConnectingToProxyInfo: String { return self._s[1678]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1679]! } + public var Message_VideoMessage: String { return self._s[1681]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1682]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1683]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1684]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1685]! } public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1680]!, self._r[1680]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1686]!, self._r[1686]!, [_1, _2, _3]) } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1681]! } - public var Activity_RecordingAudio: String { return self._s[1682]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1683]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1684]! } - public var Wallet_Info_Address: String { return self._s[1685]! } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1687]! } + public var Activity_RecordingAudio: String { return self._s[1688]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1689]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1690]! } + public var Wallet_Info_Address: String { return self._s[1691]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1687]!, self._r[1687]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1693]!, self._r[1693]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1691]!, self._r[1691]!, [_0]) + return formatWithArgumentRanges(self._s[1697]!, self._r[1697]!, [_0]) } - public var Conversation_ApplyLocalization: String { return self._s[1692]! } - public var TwoFactorSetup_Intro_Action: String { return self._s[1693]! } - public var UserInfo_AddPhone: String { return self._s[1694]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1695]! } + public var Conversation_ApplyLocalization: String { return self._s[1698]! } + public var TwoFactorSetup_Intro_Action: String { return self._s[1699]! } + public var UserInfo_AddPhone: String { return self._s[1700]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1701]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1696]!, self._r[1696]!, [_0]) + return formatWithArgumentRanges(self._s[1702]!, self._r[1702]!, [_0]) } - public var Passport_Scans: String { return self._s[1698]! } - public var BlockedUsers_Unblock: String { return self._s[1699]! } + public var Passport_Scans: String { return self._s[1704]! } + public var BlockedUsers_Unblock: String { return self._s[1705]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1700]!, self._r[1700]!, [_1]) + return formatWithArgumentRanges(self._s[1706]!, self._r[1706]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1701]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1702]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1703]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1704]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1705]! } + public var Channel_Management_LabelCreator: String { return self._s[1707]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1708]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1709]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1710]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1711]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1706]!, self._r[1706]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1712]!, self._r[1712]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1707]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1708]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1709]! } - public var ChannelIntro_CreateChannel: String { return self._s[1710]! } - public var Conversation_UnreadMessages: String { return self._s[1711]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1712]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1713]! } - public var Theme_Context_Apply: String { return self._s[1714]! } - public var Notification_GroupActivated: String { return self._s[1715]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1716]! } - public var Wallet_Intro_CreateWallet: String { return self._s[1717]! } + public var Login_PhoneNumberHelp: String { return self._s[1713]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1714]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1715]! } + public var ChannelIntro_CreateChannel: String { return self._s[1716]! } + public var Conversation_UnreadMessages: String { return self._s[1717]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1718]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1719]! } + public var Theme_Context_Apply: String { return self._s[1720]! } + public var Notification_GroupActivated: String { return self._s[1721]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1722]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1723]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1718]!, self._r[1718]!, [_0]) + return formatWithArgumentRanges(self._s[1724]!, self._r[1724]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1719]!, self._r[1719]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1725]!, self._r[1725]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1721]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1727]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1722]!, self._r[1722]!, [_0]) + return formatWithArgumentRanges(self._s[1728]!, self._r[1728]!, [_0]) } - public var Undo_DeletedChannel: String { return self._s[1723]! } - public var CallFeedback_AddComment: String { return self._s[1724]! } + public var Undo_DeletedChannel: String { return self._s[1729]! } + public var CallFeedback_AddComment: String { return self._s[1730]! } public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1725]!, self._r[1725]!, [_0]) + return formatWithArgumentRanges(self._s[1731]!, self._r[1731]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1726]! } + public var Document_TargetConfirmationFormat: String { return self._s[1732]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1727]!, self._r[1727]!, [_0]) + return formatWithArgumentRanges(self._s[1733]!, self._r[1733]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1728]! } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1734]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1729]!, self._r[1729]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1735]!, self._r[1735]!, [_1, _2, _3, _4]) } - public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1730]! } - public var Theme_ErrorNotFound: String { return self._s[1731]! } - public var Contacts_SortByName: String { return self._s[1732]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1733]! } + public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1736]! } + public var Theme_ErrorNotFound: String { return self._s[1737]! } + public var Contacts_SortByName: String { return self._s[1738]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1739]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1735]!, self._r[1735]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1741]!, self._r[1741]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1736]! } - public var ScheduledMessages_EditTime: String { return self._s[1737]! } - public var Conversation_ClearSelfHistory: String { return self._s[1738]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1739]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1740]! } - public var Stickers_SuggestNone: String { return self._s[1741]! } - public var ChatSettings_Cache: String { return self._s[1742]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1743]! } - public var Media_ShareThisPhoto: String { return self._s[1744]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1745]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1746]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1747]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1748]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1749]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1750]! } - public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1751]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1742]! } + public var ScheduledMessages_EditTime: String { return self._s[1743]! } + public var Conversation_ClearSelfHistory: String { return self._s[1744]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1745]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1746]! } + public var Stickers_SuggestNone: String { return self._s[1747]! } + public var ChatSettings_Cache: String { return self._s[1748]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1749]! } + public var Media_ShareThisPhoto: String { return self._s[1750]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1751]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1752]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1753]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1754]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1755]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1756]! } + public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1757]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1752]!, self._r[1752]!, [_0]) + return formatWithArgumentRanges(self._s[1758]!, self._r[1758]!, [_0]) } - public var Permissions_CellularDataTitle_v0: String { return self._s[1753]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1755]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1756]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1757]! } - public var Map_OpenIn: String { return self._s[1758]! } - public var PeerInfo_ButtonCall: String { return self._s[1759]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1759]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1761]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1762]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1763]! } + public var Map_OpenIn: String { return self._s[1764]! } + public var PeerInfo_ButtonCall: String { return self._s[1765]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1762]!, self._r[1762]!, [_1]) + return formatWithArgumentRanges(self._s[1768]!, self._r[1768]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1763]!, self._r[1763]!, [_0]) + return formatWithArgumentRanges(self._s[1769]!, self._r[1769]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1764]! } - public var MessagePoll_LabelClosed: String { return self._s[1765]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1767]! } - public var Wallet_Send_SendAnyway: String { return self._s[1768]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1769]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1770]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1771]! } - public var Map_SetThisPlace: String { return self._s[1772]! } - public var Login_SelectCountry_Title: String { return self._s[1773]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1774]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1770]! } + public var MessagePoll_LabelClosed: String { return self._s[1771]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1773]! } + public var Wallet_Send_SendAnyway: String { return self._s[1774]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1775]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1776]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1777]! } + public var Map_SetThisPlace: String { return self._s[1778]! } + public var Login_SelectCountry_Title: String { return self._s[1779]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1780]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1775]!, self._r[1775]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1781]!, self._r[1781]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1776]! } - public var Watch_Suggestion_BRB: String { return self._s[1777]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1778]! } - public var Contacts_PermissionsTitle: String { return self._s[1779]! } - public var Conversation_RestrictedInline: String { return self._s[1780]! } - public var Appearance_RemoveThemeColor: String { return self._s[1782]! } - public var StickerPack_ViewPack: String { return self._s[1783]! } - public var Wallet_UnknownError: String { return self._s[1784]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1782]! } + public var Watch_Suggestion_BRB: String { return self._s[1783]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1784]! } + public var Contacts_PermissionsTitle: String { return self._s[1785]! } + public var Conversation_RestrictedInline: String { return self._s[1786]! } + public var Appearance_RemoveThemeColor: String { return self._s[1788]! } + public var StickerPack_ViewPack: String { return self._s[1789]! } + public var Wallet_UnknownError: String { return self._s[1790]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1785]!, self._r[1785]!, [_0]) + return formatWithArgumentRanges(self._s[1791]!, self._r[1791]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1787]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1790]! } - public var MessagePoll_LabelQuiz: String { return self._s[1792]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1793]! } - public var Channel_Info_Stickers: String { return self._s[1794]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1795]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1796]! } - public var Passport_DeletePersonalDetails: String { return self._s[1797]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1798]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1799]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1800]! } - public var Conversation_SearchNoResults: String { return self._s[1803]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1804]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1805]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1806]! } - public var Login_Code: String { return self._s[1807]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1808]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1809]! } - public var Weekday_ShortThursday: String { return self._s[1810]! } - public var Resolve_ErrorNotFound: String { return self._s[1812]! } - public var LastSeen_Offline: String { return self._s[1813]! } - public var PeopleNearby_NoMembers: String { return self._s[1814]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1815]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1816]! } - public var GroupInfo_Title: String { return self._s[1818]! } - public var NotificationsSound_Note: String { return self._s[1819]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1820]! } - public var Watch_Message_Poll: String { return self._s[1821]! } - public var Privacy_Calls: String { return self._s[1822]! } + public var Compose_NewChannel: String { return self._s[1793]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1796]! } + public var MessagePoll_LabelQuiz: String { return self._s[1798]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1799]! } + public var Channel_Info_Stickers: String { return self._s[1800]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1801]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1802]! } + public var Passport_DeletePersonalDetails: String { return self._s[1803]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1804]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1805]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1806]! } + public var Conversation_SearchNoResults: String { return self._s[1809]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1810]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1811]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1812]! } + public var Login_Code: String { return self._s[1813]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1814]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1815]! } + public var Weekday_ShortThursday: String { return self._s[1816]! } + public var Resolve_ErrorNotFound: String { return self._s[1818]! } + public var LastSeen_Offline: String { return self._s[1819]! } + public var PeopleNearby_NoMembers: String { return self._s[1820]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1821]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1822]! } + public var GroupInfo_Title: String { return self._s[1824]! } + public var NotificationsSound_Note: String { return self._s[1825]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1826]! } + public var Watch_Message_Poll: String { return self._s[1827]! } + public var Privacy_Calls: String { return self._s[1828]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1823]!, self._r[1823]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1829]!, self._r[1829]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1824]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1825]! } - public var Notifications_Reset: String { return self._s[1826]! } - public var Conversation_Pin: String { return self._s[1827]! } - public var Passport_Language_lv: String { return self._s[1828]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1829]! } - public var BlockedUsers_Info: String { return self._s[1830]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1832]! } - public var Watch_Conversation_Unblock: String { return self._s[1834]! } + public var Month_ShortAugust: String { return self._s[1830]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1831]! } + public var Notifications_Reset: String { return self._s[1832]! } + public var Conversation_Pin: String { return self._s[1833]! } + public var Passport_Language_lv: String { return self._s[1834]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1835]! } + public var BlockedUsers_Info: String { return self._s[1836]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1838]! } + public var Watch_Conversation_Unblock: String { return self._s[1840]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1835]!, self._r[1835]!, [_0]) + return formatWithArgumentRanges(self._s[1841]!, self._r[1841]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1836]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1837]! } + public var CloudStorage_Title: String { return self._s[1842]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1843]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1838]!, self._r[1838]!, [_0]) + return formatWithArgumentRanges(self._s[1844]!, self._r[1844]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1839]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1840]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1841]! } - public var Passport_Address_EditBankStatement: String { return self._s[1842]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1845]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1846]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1847]! } + public var Passport_Address_EditBankStatement: String { return self._s[1848]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1843]!, self._r[1843]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1849]!, self._r[1849]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1844]! } - public var ShareMenu_Comment: String { return self._s[1845]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1846]! } - public var Notifications_PermissionsTitle: String { return self._s[1847]! } - public var GroupPermission_NoSendLinks: String { return self._s[1848]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1849]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1850]! } - public var Settings_Support: String { return self._s[1851]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1852]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1853]! } - public var Privacy_Forwards_Preview: String { return self._s[1854]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1855]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1856]! } - public var Common_Select: String { return self._s[1858]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1859]! } - public var WallpaperSearch_ColorGray: String { return self._s[1862]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1863]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1864]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1865]! } - public var PollResults_Title: String { return self._s[1866]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1867]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1868]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1869]! } - public var Widget_AuthRequired: String { return self._s[1870]! } - public var Camera_FlashOn: String { return self._s[1871]! } - public var Conversation_ContextMenuLookUp: String { return self._s[1872]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1873]! } - public var Watch_Suggestion_OK: String { return self._s[1874]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1850]! } + public var ShareMenu_Comment: String { return self._s[1851]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1852]! } + public var Notifications_PermissionsTitle: String { return self._s[1853]! } + public var GroupPermission_NoSendLinks: String { return self._s[1854]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1855]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1856]! } + public var PeerInfo_PaneLinks: String { return self._s[1857]! } + public var Settings_Support: String { return self._s[1858]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1859]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1860]! } + public var Privacy_Forwards_Preview: String { return self._s[1861]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1862]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1863]! } + public var Common_Select: String { return self._s[1865]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1866]! } + public var WallpaperSearch_ColorGray: String { return self._s[1869]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1870]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1871]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1872]! } + public var PollResults_Title: String { return self._s[1873]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1874]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1875]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1876]! } + public var Widget_AuthRequired: String { return self._s[1877]! } + public var Camera_FlashOn: String { return self._s[1878]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1879]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1880]! } + public var Watch_Suggestion_OK: String { return self._s[1881]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1876]!, self._r[1876]!, [_0]) + return formatWithArgumentRanges(self._s[1883]!, self._r[1883]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1878]!, self._r[1878]!, [_0]) + return formatWithArgumentRanges(self._s[1885]!, self._r[1885]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1879]! } - public var DialogList_AdLabel: String { return self._s[1880]! } - public var WatchRemote_NotificationText: String { return self._s[1881]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1882]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1883]! } - public var Conversation_ReportSpam: String { return self._s[1884]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1885]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1887]! } - public var PhoneLabel_Title: String { return self._s[1888]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1889]! } - public var Settings_ChangePhoneNumber: String { return self._s[1890]! } - public var Notifications_ExceptionsTitle: String { return self._s[1891]! } - public var Notifications_AlertTones: String { return self._s[1892]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1893]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1894]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1895]! } - public var VoiceOver_Chat_Photo: String { return self._s[1897]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1898]! } - public var ReportPeer_ReasonOther: String { return self._s[1899]! } - public var ChatList_Context_JoinChannel: String { return self._s[1900]! } - public var KeyCommand_ScrollDown: String { return self._s[1902]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[1903]! } + public var TextFormat_Strikethrough: String { return self._s[1886]! } + public var DialogList_AdLabel: String { return self._s[1887]! } + public var WatchRemote_NotificationText: String { return self._s[1888]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1889]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1890]! } + public var Conversation_ReportSpam: String { return self._s[1891]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1892]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1894]! } + public var PhoneLabel_Title: String { return self._s[1895]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1896]! } + public var Settings_ChangePhoneNumber: String { return self._s[1897]! } + public var Notifications_ExceptionsTitle: String { return self._s[1898]! } + public var Notifications_AlertTones: String { return self._s[1899]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1900]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1901]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1902]! } + public var VoiceOver_Chat_Photo: String { return self._s[1904]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1905]! } + public var ReportPeer_ReasonOther: String { return self._s[1906]! } + public var ChatList_Context_JoinChannel: String { return self._s[1907]! } + public var KeyCommand_ScrollDown: String { return self._s[1909]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1910]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1904]!, self._r[1904]!, [_0]) + return formatWithArgumentRanges(self._s[1911]!, self._r[1911]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1905]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1906]! } - public var AuthSessions_LogOut: String { return self._s[1907]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1908]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1909]! } - public var Passport_Phone_Title: String { return self._s[1910]! } - public var ContactList_Context_StartSecretChat: String { return self._s[1911]! } - public var Settings_PhoneNumber: String { return self._s[1912]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1912]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1913]! } + public var AuthSessions_LogOut: String { return self._s[1914]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1915]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1916]! } + public var Passport_Phone_Title: String { return self._s[1917]! } + public var ContactList_Context_StartSecretChat: String { return self._s[1918]! } + public var Settings_PhoneNumber: String { return self._s[1919]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1913]!, self._r[1913]!, [_0]) + return formatWithArgumentRanges(self._s[1920]!, self._r[1920]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[1915]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1916]! } - public var WebSearch_SearchNoResults: String { return self._s[1917]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1919]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[1920]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1921]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[1922]! } - public var PhotoEditor_CurvesTool: String { return self._s[1923]! } - public var Checkout_PaymentMethod: String { return self._s[1925]! } + public var NotificationsSound_Alert: String { return self._s[1922]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1923]! } + public var WebSearch_SearchNoResults: String { return self._s[1924]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1926]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[1927]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1928]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[1929]! } + public var PhotoEditor_CurvesTool: String { return self._s[1930]! } + public var Checkout_PaymentMethod: String { return self._s[1932]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1926]!, self._r[1926]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1933]!, self._r[1933]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[1927]! } - public var Camera_PhotoMode: String { return self._s[1930]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1931]! } - public var Appearance_TextSize_Apply: String { return self._s[1932]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1934]! } - public var CallSettings_OnMobile: String { return self._s[1935]! } - public var Tour_Text2: String { return self._s[1936]! } + public var Contacts_AccessDeniedError: String { return self._s[1934]! } + public var Camera_PhotoMode: String { return self._s[1937]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1938]! } + public var Appearance_TextSize_Apply: String { return self._s[1939]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1941]! } + public var CallSettings_OnMobile: String { return self._s[1942]! } + public var Tour_Text2: String { return self._s[1943]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1937]!, self._r[1937]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1944]!, self._r[1944]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1939]! } - public var Permissions_Skip: String { return self._s[1940]! } - public var Wallet_Words_NotDoneOk: String { return self._s[1941]! } - public var SecretImage_Title: String { return self._s[1942]! } - public var Watch_MessageView_Title: String { return self._s[1943]! } - public var Channel_DiscussionGroupAdd: String { return self._s[1944]! } - public var AttachmentMenu_Poll: String { return self._s[1945]! } + public var DialogList_EncryptionProcessing: String { return self._s[1946]! } + public var Permissions_Skip: String { return self._s[1947]! } + public var Wallet_Words_NotDoneOk: String { return self._s[1948]! } + public var SecretImage_Title: String { return self._s[1949]! } + public var Watch_MessageView_Title: String { return self._s[1950]! } + public var Channel_DiscussionGroupAdd: String { return self._s[1951]! } + public var AttachmentMenu_Poll: String { return self._s[1952]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1946]!, self._r[1946]!, [_0]) + return formatWithArgumentRanges(self._s[1953]!, self._r[1953]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1947]!, self._r[1947]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1954]!, self._r[1954]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[1948]! } - public var WallpaperPreview_Title: String { return self._s[1949]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1950]! } - public var Settings_ProxyConnecting: String { return self._s[1951]! } - public var Settings_CheckPhoneNumberText: String { return self._s[1953]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[1954]! } - public var Wallet_Intro_Title: String { return self._s[1955]! } - public var TwoFactorSetup_Password_Action: String { return self._s[1956]! } - public var Profile_MessageLifetime5s: String { return self._s[1957]! } - public var Username_InvalidCharacters: String { return self._s[1958]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1959]! } - public var ScheduledMessages_ClearAll: String { return self._s[1960]! } - public var WallpaperPreview_CropBottomText: String { return self._s[1961]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1962]! } - public var Settings_AddAccount: String { return self._s[1963]! } - public var Notification_CreatedChannel: String { return self._s[1966]! } + public var Notification_CallCanceled: String { return self._s[1955]! } + public var WallpaperPreview_Title: String { return self._s[1956]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1957]! } + public var Settings_ProxyConnecting: String { return self._s[1958]! } + public var Settings_CheckPhoneNumberText: String { return self._s[1960]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[1961]! } + public var Wallet_Intro_Title: String { return self._s[1962]! } + public var TwoFactorSetup_Password_Action: String { return self._s[1963]! } + public var Profile_MessageLifetime5s: String { return self._s[1964]! } + public var Username_InvalidCharacters: String { return self._s[1965]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1966]! } + public var ScheduledMessages_ClearAll: String { return self._s[1967]! } + public var WallpaperPreview_CropBottomText: String { return self._s[1968]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1969]! } + public var Settings_AddAccount: String { return self._s[1970]! } + public var Notification_CreatedChannel: String { return self._s[1973]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1967]!, self._r[1967]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1974]!, self._r[1974]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[1969]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1970]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[1971]! } - public var Contacts_TopSection: String { return self._s[1972]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1973]! } + public var Passcode_AppLockedAlert: String { return self._s[1976]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1977]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[1978]! } + public var Contacts_TopSection: String { return self._s[1979]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1980]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1974]!, self._r[1974]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1981]!, self._r[1981]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[1975]! } - public var Wallet_Completed_ViewWallet: String { return self._s[1976]! } + public var Wallet_Info_Receive: String { return self._s[1982]! } + public var Wallet_Completed_ViewWallet: String { return self._s[1983]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1977]!, self._r[1977]!, [_0]) + return formatWithArgumentRanges(self._s[1984]!, self._r[1984]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[1978]! } - public var UserInfo_TapToCall: String { return self._s[1979]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1981]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1982]! } - public var Common_Search: String { return self._s[1983]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[1984]! } + public var ReportPeer_ReasonSpam: String { return self._s[1985]! } + public var UserInfo_TapToCall: String { return self._s[1986]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1988]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1989]! } + public var Common_Search: String { return self._s[1990]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[1991]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1985]!, self._r[1985]!, [_0]) - } - public var Wallet_Month_ShortJuly: String { return self._s[1986]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1988]! } - public var Message_InvoiceLabel: String { return self._s[1989]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1990]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1991]! } - public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1992]!, self._r[1992]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[1993]! } - public var Conversation_Info: String { return self._s[1994]! } - public var Login_InfoDeletePhoto: String { return self._s[1995]! } - public var Passport_Language_vi: String { return self._s[1997]! } - public var UserInfo_ScamUserWarning: String { return self._s[1998]! } - public var Conversation_Search: String { return self._s[1999]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2001]! } - public var ReportPeer_ReasonPornography: String { return self._s[2002]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[2003]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2004]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2005]! } - public var Channel_Setup_TypeHeader: String { return self._s[2006]! } - public var AuthSessions_LoggedIn: String { return self._s[2007]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2008]! } - public var Login_SmsRequestState3: String { return self._s[2009]! } - public var Passport_Address_EditUtilityBill: String { return self._s[2010]! } - public var Appearance_ReduceMotionInfo: String { return self._s[2011]! } - public var Join_ChannelsTooMuch: String { return self._s[2012]! } - public var Channel_Edit_LinkItem: String { return self._s[2013]! } - public var Privacy_Calls_P2PNever: String { return self._s[2014]! } - public var Conversation_AddToReadingList: String { return self._s[2016]! } - public var Share_MultipleMessagesDisabled: String { return self._s[2017]! } - public var Message_Animation: String { return self._s[2018]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[2019]! } - public var Map_Unknown: String { return self._s[2020]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[2021]! } + public var Wallet_Month_ShortJuly: String { return self._s[1993]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1995]! } + public var Message_InvoiceLabel: String { return self._s[1996]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1997]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1998]! } + public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1999]!, self._r[1999]!, [_0]) + } + public var IntentsSettings_Reset: String { return self._s[2000]! } + public var Conversation_Info: String { return self._s[2001]! } + public var Login_InfoDeletePhoto: String { return self._s[2002]! } + public var Passport_Language_vi: String { return self._s[2004]! } + public var UserInfo_ScamUserWarning: String { return self._s[2005]! } + public var Conversation_Search: String { return self._s[2006]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2008]! } + public var ReportPeer_ReasonPornography: String { return self._s[2009]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[2010]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2011]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2012]! } + public var Channel_Setup_TypeHeader: String { return self._s[2013]! } + public var AuthSessions_LoggedIn: String { return self._s[2014]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2015]! } + public var Login_SmsRequestState3: String { return self._s[2016]! } + public var Passport_Address_EditUtilityBill: String { return self._s[2017]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2018]! } + public var Join_ChannelsTooMuch: String { return self._s[2019]! } + public var Channel_Edit_LinkItem: String { return self._s[2020]! } + public var Privacy_Calls_P2PNever: String { return self._s[2021]! } + public var Conversation_AddToReadingList: String { return self._s[2023]! } + public var Share_MultipleMessagesDisabled: String { return self._s[2024]! } + public var Message_Animation: String { return self._s[2025]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[2026]! } + public var Map_Unknown: String { return self._s[2027]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[2028]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2022]!, self._r[2022]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2029]!, self._r[2029]!, [_1, _2]) } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2023]!, self._r[2023]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2030]!, self._r[2030]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[2024]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[2025]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2026]! } + public var Call_StatusRequesting: String { return self._s[2031]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[2032]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2033]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2027]!, self._r[2027]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2034]!, self._r[2034]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2028]!, self._r[2028]!, [_0]) + return formatWithArgumentRanges(self._s[2035]!, self._r[2035]!, [_0]) } - public var Update_Skip: String { return self._s[2029]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2030]! } - public var BlockedUsers_Title: String { return self._s[2031]! } - public var Weekday_Monday: String { return self._s[2032]! } + public var Update_Skip: String { return self._s[2036]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2037]! } + public var BlockedUsers_Title: String { return self._s[2038]! } + public var Weekday_Monday: String { return self._s[2039]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2033]!, self._r[2033]!, [_1]) + return formatWithArgumentRanges(self._s[2040]!, self._r[2040]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[2034]! } - public var NotificationsSound_Bell: String { return self._s[2035]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[2036]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2037]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2038]! } - public var ChatSettings_Groups: String { return self._s[2039]! } - public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2040]! } + public var Username_CheckingUsername: String { return self._s[2041]! } + public var NotificationsSound_Bell: String { return self._s[2042]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[2043]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2044]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2045]! } + public var ChatSettings_Groups: String { return self._s[2046]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2047]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2041]!, self._r[2041]!, [_0]) + return formatWithArgumentRanges(self._s[2048]!, self._r[2048]!, [_0]) } - public var Your_card_was_declined: String { return self._s[2042]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2044]! } - public var Wallet_Month_ShortApril: String { return self._s[2045]! } - public var ChatList_Unmute: String { return self._s[2046]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2047]! } - public var PhotoEditor_CurvesAll: String { return self._s[2048]! } - public var Weekday_ShortTuesday: String { return self._s[2049]! } - public var DialogList_Read: String { return self._s[2050]! } - public var Appearance_AppIconClassic: String { return self._s[2051]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2052]! } - public var Passport_Identity_Gender: String { return self._s[2053]! } + public var Your_card_was_declined: String { return self._s[2049]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2051]! } + public var Wallet_Month_ShortApril: String { return self._s[2052]! } + public var ChatList_Unmute: String { return self._s[2053]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2054]! } + public var PhotoEditor_CurvesAll: String { return self._s[2055]! } + public var Weekday_ShortTuesday: String { return self._s[2056]! } + public var DialogList_Read: String { return self._s[2057]! } + public var Appearance_AppIconClassic: String { return self._s[2058]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2059]! } + public var Passport_Identity_Gender: String { return self._s[2060]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2054]!, self._r[2054]!, [_0]) + return formatWithArgumentRanges(self._s[2061]!, self._r[2061]!, [_0]) } - public var Target_SelectGroup: String { return self._s[2055]! } - public var Map_HomeAndWorkInfo: String { return self._s[2057]! } + public var Target_SelectGroup: String { return self._s[2062]! } + public var Map_HomeAndWorkInfo: String { return self._s[2064]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2058]!, self._r[2058]!, [_0]) + return formatWithArgumentRanges(self._s[2065]!, self._r[2065]!, [_0]) } - public var Passport_Language_en: String { return self._s[2059]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2060]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2061]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[2062]! } - public var ScheduledMessages_SendNow: String { return self._s[2063]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[2065]! } - public var Login_InfoHelp: String { return self._s[2066]! } - public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2067]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2068]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2069]! } + public var Passport_Language_en: String { return self._s[2066]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2067]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2068]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2069]! } + public var ScheduledMessages_SendNow: String { return self._s[2070]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2072]! } + public var Login_InfoHelp: String { return self._s[2073]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2074]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2075]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2076]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2070]!, self._r[2070]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2077]!, self._r[2077]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2073]! } - public var CreatePoll_Title: String { return self._s[2074]! } - public var MessagePoll_QuizNoUsers: String { return self._s[2075]! } - public var Conversation_ViewTheme: String { return self._s[2076]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2077]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2078]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2079]! } - public var UserInfo_GroupsInCommon: String { return self._s[2080]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2081]! } - public var Call_AudioRouteHide: String { return self._s[2082]! } + public var SocksProxySetup_AddProxy: String { return self._s[2080]! } + public var CreatePoll_Title: String { return self._s[2081]! } + public var MessagePoll_QuizNoUsers: String { return self._s[2082]! } + public var Conversation_ViewTheme: String { return self._s[2083]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2084]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2085]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2086]! } + public var UserInfo_GroupsInCommon: String { return self._s[2087]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2088]! } + public var Call_AudioRouteHide: String { return self._s[2089]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2084]!, self._r[2084]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2091]!, self._r[2091]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2085]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2086]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[2087]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2092]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2093]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[2094]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2088]!, self._r[2088]!, [_0]) + return formatWithArgumentRanges(self._s[2095]!, self._r[2095]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2089]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2090]! } - public var StickerPackActionInfo_AddedTitle: String { return self._s[2091]! } - public var Notifications_Title: String { return self._s[2092]! } - public var Group_Username_InvalidTooShort: String { return self._s[2093]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2094]! } + public var TextFormat_Bold: String { return self._s[2096]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2097]! } + public var StickerPackActionInfo_AddedTitle: String { return self._s[2098]! } + public var Notifications_Title: String { return self._s[2099]! } + public var Group_Username_InvalidTooShort: String { return self._s[2100]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2101]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2095]!, self._r[2095]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2102]!, self._r[2102]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2097]! } - public var Stickers_SuggestAdded: String { return self._s[2098]! } - public var Login_CountryCode: String { return self._s[2099]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2100]! } - public var Map_GetDirections: String { return self._s[2101]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2102]! } - public var Login_PhoneFloodError: String { return self._s[2103]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2104]! } + public var Stickers_SuggestAdded: String { return self._s[2105]! } + public var Login_CountryCode: String { return self._s[2106]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2107]! } + public var Map_GetDirections: String { return self._s[2108]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2109]! } + public var Login_PhoneFloodError: String { return self._s[2110]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_0]) + return formatWithArgumentRanges(self._s[2111]!, self._r[2111]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2105]!, self._r[2105]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2106]! } - public var Settings_SetUsername: String { return self._s[2108]! } - public var Group_Location_ChangeLocation: String { return self._s[2109]! } - public var Notification_GroupInviterSelf: String { return self._s[2110]! } - public var InstantPage_TapToOpenLink: String { return self._s[2111]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2113]! } + public var Settings_SetUsername: String { return self._s[2115]! } + public var Group_Location_ChangeLocation: String { return self._s[2116]! } + public var Notification_GroupInviterSelf: String { return self._s[2117]! } + public var InstantPage_TapToOpenLink: String { return self._s[2118]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_0]) + return formatWithArgumentRanges(self._s[2119]!, self._r[2119]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2113]! } - public var SecretChat_Title: String { return self._s[2114]! } - public var Group_UpgradeNoticeText1: String { return self._s[2115]! } - public var AuthSessions_Title: String { return self._s[2116]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2120]! } + public var SecretChat_Title: String { return self._s[2121]! } + public var Group_UpgradeNoticeText1: String { return self._s[2122]! } + public var AuthSessions_Title: String { return self._s[2123]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2117]!, self._r[2117]!, [_0]) + return formatWithArgumentRanges(self._s[2124]!, self._r[2124]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2118]! } - public var Channel_About_Title: String { return self._s[2119]! } - public var Theme_ThemeChanged: String { return self._s[2120]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2121]! } + public var PhotoEditor_CropAuto: String { return self._s[2125]! } + public var Channel_About_Title: String { return self._s[2126]! } + public var Theme_ThemeChanged: String { return self._s[2127]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2128]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2123]!, self._r[2123]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2130]!, self._r[2130]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2124]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2126]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2127]! } + public var VoiceOver_MessageContextReport: String { return self._s[2131]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2133]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2134]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2128]!, self._r[2128]!, [_1]) + return formatWithArgumentRanges(self._s[2135]!, self._r[2135]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2130]!, self._r[2130]!, [_0]) + return formatWithArgumentRanges(self._s[2137]!, self._r[2137]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2131]!, self._r[2131]!, [_0]) + return formatWithArgumentRanges(self._s[2138]!, self._r[2138]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2132]! } - public var PeopleNearby_DiscoverDescription: String { return self._s[2134]! } - public var Presence_online: String { return self._s[2136]! } - public var PasscodeSettings_Title: String { return self._s[2137]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2138]! } - public var Web_OpenExternal: String { return self._s[2139]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2141]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2142]! } - public var LocalGroup_Title: String { return self._s[2143]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2139]! } + public var PeopleNearby_DiscoverDescription: String { return self._s[2141]! } + public var Presence_online: String { return self._s[2143]! } + public var PasscodeSettings_Title: String { return self._s[2144]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2145]! } + public var Web_OpenExternal: String { return self._s[2146]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2148]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2149]! } + public var LocalGroup_Title: String { return self._s[2150]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2144]!, self._r[2144]!, [_0]) + return formatWithArgumentRanges(self._s[2151]!, self._r[2151]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2145]! } - public var Conversation_StopQuizConfirmation: String { return self._s[2146]! } - public var Map_YouAreHere: String { return self._s[2147]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2152]! } + public var Conversation_StopQuizConfirmation: String { return self._s[2153]! } + public var Map_YouAreHere: String { return self._s[2154]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2148]!, self._r[2148]!, [_0]) + return formatWithArgumentRanges(self._s[2155]!, self._r[2155]!, [_0]) } public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2149]!, self._r[2149]!, [_0]) + return formatWithArgumentRanges(self._s[2156]!, self._r[2156]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[2150]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2151]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2152]! } + public var Theme_Context_ChangeColors: String { return self._s[2157]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2158]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2159]! } public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2153]!, self._r[2153]!, [_0]) + return formatWithArgumentRanges(self._s[2160]!, self._r[2160]!, [_0]) } public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2154]!, self._r[2154]!, [_0]) + return formatWithArgumentRanges(self._s[2161]!, self._r[2161]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[2155]! } - public var Bot_Start: String { return self._s[2156]! } + public var SocksProxySetup_Username: String { return self._s[2162]! } + public var Bot_Start: String { return self._s[2163]! } public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2157]!, self._r[2157]!, [_0]) - } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2158]!, self._r[2158]!, [_0]) - } - public var Contacts_SortByPresence: String { return self._s[2159]! } - public var AccentColor_Title: String { return self._s[2161]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2162]! } - public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2163]!, self._r[2163]!, [_1, _2]) - } - public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2164]!, self._r[2164]!, [_0]) } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2165]!, self._r[2165]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[2166]! } + public var AccentColor_Title: String { return self._s[2168]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2169]! } + public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2170]!, self._r[2170]!, [_1, _2]) + } + public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2171]!, self._r[2171]!, [_0]) + } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2165]!, self._r[2165]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2172]!, self._r[2172]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[2166]! } - public var Login_InfoAvatarPhoto: String { return self._s[2167]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2168]! } - public var Tour_Title4: String { return self._s[2169]! } - public var Passport_Identity_Translation: String { return self._s[2170]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2171]! } - public var Login_TermsOfServiceLabel: String { return self._s[2173]! } - public var Passport_Language_it: String { return self._s[2174]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2175]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2176]! } - public var Conversation_ClearAll: String { return self._s[2178]! } - public var Wallet_Send_UninitializedText: String { return self._s[2180]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2181]! } - public var TwoStepAuth_FloodError: String { return self._s[2182]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[2173]! } + public var Login_InfoAvatarPhoto: String { return self._s[2174]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2175]! } + public var Tour_Title4: String { return self._s[2176]! } + public var Passport_Identity_Translation: String { return self._s[2177]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2178]! } + public var Login_TermsOfServiceLabel: String { return self._s[2180]! } + public var Passport_Language_it: String { return self._s[2181]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2182]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2183]! } + public var Conversation_ClearAll: String { return self._s[2185]! } + public var Wallet_Send_UninitializedText: String { return self._s[2187]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2188]! } + public var TwoStepAuth_FloodError: String { return self._s[2189]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2183]!, self._r[2183]!, [_1]) + return formatWithArgumentRanges(self._s[2190]!, self._r[2190]!, [_1]) } - public var Paint_Delete: String { return self._s[2184]! } + public var Paint_Delete: String { return self._s[2191]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2185]!, self._r[2185]!, [_0]) + return formatWithArgumentRanges(self._s[2192]!, self._r[2192]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2186]! } + public var Privacy_AddNewPeer: String { return self._s[2193]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2187]!, self._r[2187]!, [_1]) + return formatWithArgumentRanges(self._s[2194]!, self._r[2194]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2188]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2195]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2189]!, self._r[2189]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2196]!, self._r[2196]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2190]! } + public var Message_PinnedAudioMessage: String { return self._s[2197]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2191]!, self._r[2191]!, [_0]) + return formatWithArgumentRanges(self._s[2198]!, self._r[2198]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2192]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2193]! } - public var Wallet_Month_GenNovember: String { return self._s[2194]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2195]! } - public var Conversation_MessageEditedLabel: String { return self._s[2196]! } + public var Notification_Mute1hMin: String { return self._s[2199]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2200]! } + public var Wallet_Month_GenNovember: String { return self._s[2201]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2202]! } + public var Conversation_MessageEditedLabel: String { return self._s[2203]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2197]!, self._r[2197]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2204]!, self._r[2204]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2198]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2199]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2205]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2206]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2200]!, self._r[2200]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2201]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2208]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2202]!, self._r[2202]!, [_1]) + return formatWithArgumentRanges(self._s[2209]!, self._r[2209]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2203]! } - public var Month_GenOctober: String { return self._s[2204]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2205]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2206]! } - public var MediaPicker_TimerTooltip: String { return self._s[2208]! } - public var SharedMedia_TitleAll: String { return self._s[2209]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2212]! } - public var Conversation_RestrictedMedia: String { return self._s[2213]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2214]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2216]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2217]! } + public var AccessDenied_LocationTracking: String { return self._s[2210]! } + public var Month_GenOctober: String { return self._s[2211]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2212]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2213]! } + public var MediaPicker_TimerTooltip: String { return self._s[2215]! } + public var SharedMedia_TitleAll: String { return self._s[2216]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2219]! } + public var Conversation_RestrictedMedia: String { return self._s[2220]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2221]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2223]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2224]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2218]!, self._r[2218]!, [_0]) + return formatWithArgumentRanges(self._s[2225]!, self._r[2225]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2221]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2223]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2224]! } + public var Conversation_SavedMessages: String { return self._s[2228]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2230]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2231]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2226]!, self._r[2226]!, [_0]) + return formatWithArgumentRanges(self._s[2233]!, self._r[2233]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2227]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2234]! } public func VoiceOver_Chat_Title(_ _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 ReportPeer_AlertSuccess: String { return self._s[2229]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2230]! } + public var ReportPeer_AlertSuccess: String { return self._s[2236]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2237]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2231]!, self._r[2231]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2238]!, self._r[2238]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2232]! } - public var PhotoEditor_FadeTool: String { return self._s[2233]! } - public var Privacy_ContactsReset: String { return self._s[2234]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2239]! } + public var PhotoEditor_FadeTool: String { return self._s[2240]! } + public var Privacy_ContactsReset: String { return self._s[2241]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2236]!, self._r[2236]!, [_0]) + return formatWithArgumentRanges(self._s[2243]!, self._r[2243]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2237]! } - public var ChatList_Mute: String { return self._s[2238]! } + public var Message_PinnedVideoMessage: String { return self._s[2244]! } + public var ChatList_Mute: String { return self._s[2245]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2239]!, self._r[2239]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2246]!, self._r[2246]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2240]! } - public var Conversation_PinnedQuiz: String { return self._s[2242]! } - public var ShareMenu_SelectChats: String { return self._s[2244]! } - public var ChatList_Context_Unarchive: String { return self._s[2245]! } - public var MusicPlayer_VoiceNote: String { return self._s[2246]! } - public var Conversation_RestrictedText: String { return self._s[2247]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2248]! } - public var Wallet_Month_GenApril: String { return self._s[2249]! } - public var Wallet_Month_ShortMarch: String { return self._s[2250]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2251]! } - public var Cache_Videos: String { return self._s[2252]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2253]! } - public var Wallet_Month_GenFebruary: String { return self._s[2254]! } - public var FeatureDisabled_Oops: String { return self._s[2256]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2257]! } + public var Permissions_CellularDataText_v0: String { return self._s[2247]! } + public var Conversation_PinnedQuiz: String { return self._s[2249]! } + public var ShareMenu_SelectChats: String { return self._s[2251]! } + public var ChatList_Context_Unarchive: String { return self._s[2252]! } + public var MusicPlayer_VoiceNote: String { return self._s[2253]! } + public var Conversation_RestrictedText: String { return self._s[2254]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2255]! } + public var Wallet_Month_GenApril: String { return self._s[2256]! } + public var Wallet_Month_ShortMarch: String { return self._s[2257]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2258]! } + public var Cache_Videos: String { return self._s[2259]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2260]! } + public var Wallet_Month_GenFebruary: String { return self._s[2261]! } + public var FeatureDisabled_Oops: String { return self._s[2263]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2264]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2258]!, self._r[2258]!, [_0]) + return formatWithArgumentRanges(self._s[2265]!, self._r[2265]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2260]! } - public var GroupPermission_NoSendPolls: String { return self._s[2261]! } - public var Wallet_Qr_ScanCode: String { return self._s[2262]! } - public var Message_VideoExpired: String { return self._s[2264]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2265]! } - public var Notifications_Badge: String { return self._s[2266]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2267]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2268]! } - public var Username_InvalidTooShort: String { return self._s[2269]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2270]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2271]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2272]! } + public var Stickers_GroupStickersHelp: String { return self._s[2267]! } + public var GroupPermission_NoSendPolls: String { return self._s[2268]! } + public var Wallet_Qr_ScanCode: String { return self._s[2269]! } + public var Message_VideoExpired: String { return self._s[2271]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2272]! } + public var Notifications_Badge: String { return self._s[2273]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2274]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2275]! } + public var Username_InvalidTooShort: String { return self._s[2276]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2277]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2278]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2279]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2273]!, self._r[2273]!, [_1]) + return formatWithArgumentRanges(self._s[2280]!, self._r[2280]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2274]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2275]! } - public var SharedMedia_CategoryDocs: String { return self._s[2278]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2281]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2282]! } + public var SharedMedia_CategoryDocs: String { return self._s[2285]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2279]!, self._r[2279]!, [_1]) + return formatWithArgumentRanges(self._s[2286]!, self._r[2286]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2280]! } - public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2281]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2283]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2287]! } + public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2288]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2290]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2284]!, self._r[2284]!, [_1]) + return formatWithArgumentRanges(self._s[2291]!, self._r[2291]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2285]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2292]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2286]!, self._r[2286]!, [_0]) + return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2287]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2288]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2289]! } - public var Channel_UpdatePhotoItem: String { return self._s[2290]! } - public var GroupInfo_LeftStatus: String { return self._s[2291]! } - public var Watch_MessageView_Forward: String { return self._s[2293]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2294]! } - public var Cache_ClearEmpty: String { return self._s[2296]! } - public var Localization_LanguageName: String { return self._s[2297]! } - public var Wallet_AccessDenied_Title: String { return self._s[2298]! } - public var WebSearch_GIFs: String { return self._s[2299]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2300]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2301]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2302]! } - public var Common_Back: String { return self._s[2303]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2304]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2305]! } - public var Wallet_Send_Send: String { return self._s[2306]! } + public var ChatSettings_PrivateChats: String { return self._s[2294]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2295]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2296]! } + public var Channel_UpdatePhotoItem: String { return self._s[2297]! } + public var GroupInfo_LeftStatus: String { return self._s[2298]! } + public var Watch_MessageView_Forward: String { return self._s[2300]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2301]! } + public var Cache_ClearEmpty: String { return self._s[2303]! } + public var Localization_LanguageName: String { return self._s[2304]! } + public var Wallet_AccessDenied_Title: String { return self._s[2305]! } + public var WebSearch_GIFs: String { return self._s[2306]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2307]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2308]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2309]! } + public var Common_Back: String { return self._s[2310]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2311]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2312]! } + public var Wallet_Send_Send: String { return self._s[2313]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2308]!, self._r[2308]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2309]! } - public var Wallet_Month_GenJune: String { return self._s[2310]! } - public var Passport_Email_Help: String { return self._s[2311]! } - public var Watch_Conversation_Reply: String { return self._s[2313]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2316]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2317]! } - public var Channel_BanUser_Unban: String { return self._s[2319]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2320]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2321]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2323]! } - public var Wallet_Send_AddressHeader: String { return self._s[2324]! } - public var Passport_Identity_Name: String { return self._s[2325]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2316]! } + public var Wallet_Month_GenJune: String { return self._s[2317]! } + public var Passport_Email_Help: String { return self._s[2318]! } + public var Watch_Conversation_Reply: String { return self._s[2320]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2323]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2324]! } + public var Channel_BanUser_Unban: String { return self._s[2326]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2327]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2328]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2330]! } + public var Wallet_Send_AddressHeader: String { return self._s[2331]! } + public var Passport_Identity_Name: String { return self._s[2332]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_0]) + return formatWithArgumentRanges(self._s[2333]!, self._r[2333]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2327]! } - public var Conversation_BlockUser: String { return self._s[2328]! } - public var Month_GenJanuary: String { return self._s[2329]! } - public var ChatSettings_TextSize: String { return self._s[2330]! } - public var Notification_PassportValuePhone: String { return self._s[2331]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2332]! } - public var Passport_Language_ne: String { return self._s[2333]! } - public var Notification_CallBack: String { return self._s[2334]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2335]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2336]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2334]! } + public var Conversation_BlockUser: String { return self._s[2335]! } + public var Month_GenJanuary: String { return self._s[2336]! } + public var ChatSettings_TextSize: String { return self._s[2337]! } + public var Notification_PassportValuePhone: String { return self._s[2338]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2339]! } + public var Passport_Language_ne: String { return self._s[2340]! } + public var Notification_CallBack: String { return self._s[2341]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2342]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2343]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2337]!, self._r[2337]!, [_0]) + return formatWithArgumentRanges(self._s[2344]!, self._r[2344]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2338]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2339]! } - public var Stickers_FrequentlyUsed: String { return self._s[2340]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2341]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2343]! } + public var Channel_Info_Management: String { return self._s[2345]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2346]! } + public var Stickers_FrequentlyUsed: String { return self._s[2347]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2348]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2350]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2344]!, self._r[2344]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2351]!, self._r[2351]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2345]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2346]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2347]! } - public var CreatePoll_TextHeader: String { return self._s[2348]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2352]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2353]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2354]! } + public var CreatePoll_TextHeader: String { return self._s[2355]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0]) - } - public var PhotoEditor_QualityMedium: String { return self._s[2350]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2351]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2353]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2354]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2355]! } - public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2356]!, self._r[2356]!, [_0]) } + public var PhotoEditor_QualityMedium: String { return self._s[2357]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2358]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2360]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2361]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2362]! } + public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2363]!, self._r[2363]!, [_0]) + } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2357]!, self._r[2357]!, [_1]) + return formatWithArgumentRanges(self._s[2364]!, self._r[2364]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2358]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2359]! } - public var Conversation_LinkDialogOpen: String { return self._s[2361]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2362]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2363]! } - public var Settings_Username: String { return self._s[2365]! } - public var Conversation_Block: String { return self._s[2367]! } - public var Wallpaper_Wallpaper: String { return self._s[2368]! } - public var SocksProxySetup_UseProxy: String { return self._s[2370]! } - public var Wallet_Send_Confirmation: String { return self._s[2371]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2372]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2373]! } - public var MessageTimer_Forever: String { return self._s[2374]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2375]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2376]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2377]! } - public var Passport_Language_da: String { return self._s[2378]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2379]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2365]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2366]! } + public var Conversation_LinkDialogOpen: String { return self._s[2368]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2369]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2370]! } + public var Settings_Username: String { return self._s[2372]! } + public var Conversation_Block: String { return self._s[2374]! } + public var Wallpaper_Wallpaper: String { return self._s[2375]! } + public var SocksProxySetup_UseProxy: String { return self._s[2377]! } + public var Wallet_Send_Confirmation: String { return self._s[2378]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2379]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2380]! } + public var MessageTimer_Forever: String { return self._s[2381]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2382]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2383]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2384]! } + public var Passport_Language_da: String { return self._s[2385]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2386]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2380]!, self._r[2380]!, [_0]) + return formatWithArgumentRanges(self._s[2387]!, self._r[2387]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2381]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2388]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2383]!, self._r[2383]!, [_0]) + return formatWithArgumentRanges(self._s[2390]!, self._r[2390]!, [_0]) } - public var Settings_AddDevice: String { return self._s[2384]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2386]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2387]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2388]! } - public var Conversation_PinnedPoll: String { return self._s[2389]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2390]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2391]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2392]! } + public var Settings_AddDevice: String { return self._s[2391]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2393]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2394]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2395]! } + public var Conversation_PinnedPoll: String { return self._s[2396]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2397]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2398]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2399]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2393]!, self._r[2393]!, [_1]) + return formatWithArgumentRanges(self._s[2400]!, self._r[2400]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2394]! } - public var Cache_ByPeerHeader: String { return self._s[2395]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2401]! } + public var Cache_ByPeerHeader: String { return self._s[2402]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2396]!, self._r[2396]!, [_0]) + return formatWithArgumentRanges(self._s[2403]!, self._r[2403]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2397]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2400]! } - public var Wallet_Completed_Title: String { return self._s[2401]! } - public var Notification_PinnedMessage: String { return self._s[2402]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2403]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2405]! } - public var Contacts_SortBy: String { return self._s[2406]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2404]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2407]! } + public var Wallet_Completed_Title: String { return self._s[2408]! } + public var Notification_PinnedMessage: String { return self._s[2409]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2410]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2412]! } + public var Contacts_SortBy: String { return self._s[2413]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2407]!, self._r[2407]!, [_1]) + return formatWithArgumentRanges(self._s[2414]!, self._r[2414]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2409]! } + public var Appearance_ColorThemeNight: String { return self._s[2416]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2410]!, self._r[2410]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2417]!, self._r[2417]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2411]! } - public var Watch_UserInfo_Service: String { return self._s[2412]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2414]! } - public var Conversation_Unpin: String { return self._s[2416]! } - public var CancelResetAccount_Title: String { return self._s[2417]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2418]! } + public var Call_EncryptionKey_Title: String { return self._s[2418]! } + public var Watch_UserInfo_Service: String { return self._s[2419]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2421]! } + public var Conversation_Unpin: String { return self._s[2423]! } + public var CancelResetAccount_Title: String { return self._s[2424]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2425]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2420]!, self._r[2420]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2427]!, self._r[2427]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2421]! } - public var Appearance_BubbleCorners_Title: String { return self._s[2422]! } - public var CallSettings_Title: String { return self._s[2423]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2424]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2426]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2427]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2428]! } + public var Appearance_BubbleCorners_Title: String { return self._s[2429]! } + public var CallSettings_Title: String { return self._s[2430]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2431]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2433]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2434]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2428]!, self._r[2428]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2435]!, self._r[2435]!, [_1, _2]) } - public var Passport_Identity_DocumentDetails: String { return self._s[2429]! } - public var LoginPassword_PasswordHelp: String { return self._s[2430]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2431]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2432]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2433]! } - public var Checkout_TotalPaidAmount: String { return self._s[2434]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2436]! } + public var LoginPassword_PasswordHelp: String { return self._s[2437]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2438]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2439]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2440]! } + public var Checkout_TotalPaidAmount: String { return self._s[2441]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2435]!, self._r[2435]!, [_0]) + return formatWithArgumentRanges(self._s[2442]!, self._r[2442]!, [_0]) } - public var ChatState_Updating: String { return self._s[2436]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[2437]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2439]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2440]! } + public var ChatState_Updating: String { return self._s[2443]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2444]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2446]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2447]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2441]!, self._r[2441]!, [_1]) + return formatWithArgumentRanges(self._s[2448]!, self._r[2448]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2442]! } - public var Contacts_InviteFriends: String { return self._s[2444]! } - public var Map_ChooseLocationTitle: String { return self._s[2445]! } - public var Conversation_StopPoll: String { return self._s[2447]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2449]! } + public var Contacts_InviteFriends: String { return self._s[2451]! } + public var Map_ChooseLocationTitle: String { return self._s[2452]! } + public var Conversation_StopPoll: String { return self._s[2454]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2448]!, self._r[2448]!, [_0]) + return formatWithArgumentRanges(self._s[2455]!, self._r[2455]!, [_0]) } - public var Call_Camera: String { return self._s[2449]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2450]! } - public var AppWallet_Intro_Text: String { return self._s[2451]! } - public var Appearance_BubbleCornersSetting: String { return self._s[2452]! } - public var Calls_RatingFeedback: String { return self._s[2453]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2455]! } - public var Wallet_Alert_OK: String { return self._s[2456]! } - public var NotificationsSound_Pulse: String { return self._s[2457]! } - public var Watch_LastSeen_Lately: String { return self._s[2458]! } - public var ReportGroupLocation_Report: String { return self._s[2461]! } - public var Widget_NoUsers: String { return self._s[2462]! } - public var Conversation_UnvotePoll: String { return self._s[2463]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2465]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2466]! } - public var NotificationsSound_Circles: String { return self._s[2467]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2470]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2471]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2472]! } - public var Proxy_TooltipUnavailable: String { return self._s[2473]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2475]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2477]! } - public var Conversation_FileDropbox: String { return self._s[2478]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2479]! } - public var Tour_Text3: String { return self._s[2481]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2483]! } - public var GroupPermission_NoSendMessages: String { return self._s[2484]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2485]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2486]! } + public var Call_Camera: String { return self._s[2456]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2457]! } + public var AppWallet_Intro_Text: String { return self._s[2458]! } + public var Appearance_BubbleCornersSetting: String { return self._s[2459]! } + public var Calls_RatingFeedback: String { return self._s[2460]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2462]! } + public var Wallet_Alert_OK: String { return self._s[2463]! } + public var NotificationsSound_Pulse: String { return self._s[2464]! } + public var Watch_LastSeen_Lately: String { return self._s[2465]! } + public var ReportGroupLocation_Report: String { return self._s[2468]! } + public var Widget_NoUsers: String { return self._s[2469]! } + public var Conversation_UnvotePoll: String { return self._s[2470]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2472]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2473]! } + public var NotificationsSound_Circles: String { return self._s[2474]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2477]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2478]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2479]! } + public var Proxy_TooltipUnavailable: String { return self._s[2480]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2482]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2484]! } + public var Conversation_FileDropbox: String { return self._s[2485]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2486]! } + public var Tour_Text3: String { return self._s[2488]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2490]! } + public var GroupPermission_NoSendMessages: String { return self._s[2491]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2492]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2493]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2488]!, self._r[2488]!, [_0]) + return formatWithArgumentRanges(self._s[2495]!, self._r[2495]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2489]! } - public var Checkout_ShippingOption_Title: String { return self._s[2490]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2491]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2496]! } + public var Checkout_ShippingOption_Title: String { return self._s[2497]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2498]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2492]!, self._r[2492]!, [_0]) + return formatWithArgumentRanges(self._s[2499]!, self._r[2499]!, [_0]) } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2493]!, self._r[2493]!, [_0]) + return formatWithArgumentRanges(self._s[2500]!, self._r[2500]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2494]! } - public var EditTheme_FileReadError: String { return self._s[2495]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2496]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2497]! } - public var AutoDownloadSettings_Photos: String { return self._s[2499]! } - public var Appearance_PreviewIncomingText: String { return self._s[2500]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2501]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2502]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2503]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2504]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2505]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2506]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2507]! } - public var Notification_SecretChatScreenshot: String { return self._s[2508]! } - public var AccessDenied_Wallpapers: String { return self._s[2509]! } - public var ChatList_Context_Mute: String { return self._s[2511]! } - public var Passport_Address_City: String { return self._s[2512]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2513]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2514]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2515]! } - public var AccessDenied_LocationDisabled: String { return self._s[2516]! } - public var Group_Location_Title: String { return self._s[2517]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2519]! } - public var GroupInfo_Sound: String { return self._s[2520]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2521]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2522]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2523]! } - public var Contacts_Title: String { return self._s[2524]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2525]! } - public var Passport_Language_fr: String { return self._s[2526]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2527]! } - public var Notifications_ResetAllNotifications: String { return self._s[2528]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2530]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2532]! } - public var Checkout_NewCard_Title: String { return self._s[2533]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2534]! } - public var Conversation_ForwardChats: String { return self._s[2535]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2537]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2538]! } - public var Settings_FAQ: String { return self._s[2540]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2541]! } - public var Conversation_ContextMenuForward: String { return self._s[2542]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2545]! } - public var PrivacyPolicy_Title: String { return self._s[2548]! } - public var Notifications_TextTone: String { return self._s[2549]! } - public var Profile_CreateNewContact: String { return self._s[2550]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2551]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2553]! } - public var Call_Speaker: String { return self._s[2554]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2555]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2557]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2558]! } + public var Channel_Management_LabelAdministrator: String { return self._s[2501]! } + public var EditTheme_FileReadError: String { return self._s[2502]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2503]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2504]! } + public var AutoDownloadSettings_Photos: String { return self._s[2506]! } + public var Appearance_PreviewIncomingText: String { return self._s[2507]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2508]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2509]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2510]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2511]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2512]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2513]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2514]! } + public var Notification_SecretChatScreenshot: String { return self._s[2515]! } + public var AccessDenied_Wallpapers: String { return self._s[2516]! } + public var ChatList_Context_Mute: String { return self._s[2518]! } + public var Passport_Address_City: String { return self._s[2519]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2520]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2521]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2522]! } + public var AccessDenied_LocationDisabled: String { return self._s[2523]! } + public var Group_Location_Title: String { return self._s[2524]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2526]! } + public var GroupInfo_Sound: String { return self._s[2527]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2528]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2529]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2530]! } + public var Contacts_Title: String { return self._s[2531]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2532]! } + public var Passport_Language_fr: String { return self._s[2533]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2534]! } + public var Notifications_ResetAllNotifications: String { return self._s[2535]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2537]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2539]! } + public var Checkout_NewCard_Title: String { return self._s[2540]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2541]! } + public var Conversation_ForwardChats: String { return self._s[2542]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2544]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2545]! } + public var Settings_FAQ: String { return self._s[2547]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2548]! } + public var Conversation_ContextMenuForward: String { return self._s[2549]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2552]! } + public var PrivacyPolicy_Title: String { return self._s[2555]! } + public var Notifications_TextTone: String { return self._s[2556]! } + public var Profile_CreateNewContact: String { return self._s[2557]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2558]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2560]! } + public var Call_Speaker: String { return self._s[2561]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2562]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2564]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2565]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2559]!, self._r[2559]!, [_0]) + return formatWithArgumentRanges(self._s[2566]!, self._r[2566]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2560]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2561]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2562]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2563]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2564]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2565]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2566]! } - public var Bot_Unblock: String { return self._s[2567]! } - public var TextFormat_Italic: String { return self._s[2568]! } - public var WallpaperSearch_ColorPink: String { return self._s[2569]! } - public var Settings_About_Help: String { return self._s[2571]! } - public var SearchImages_Title: String { return self._s[2572]! } - public var Weekday_Wednesday: String { return self._s[2573]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2574]! } - public var ExplicitContent_AlertTitle: String { return self._s[2575]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2567]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2568]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2569]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2570]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2571]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2572]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2573]! } + public var Bot_Unblock: String { return self._s[2574]! } + public var TextFormat_Italic: String { return self._s[2575]! } + public var WallpaperSearch_ColorPink: String { return self._s[2576]! } + public var Settings_About_Help: String { return self._s[2578]! } + public var SearchImages_Title: String { return self._s[2579]! } + public var Weekday_Wednesday: String { return self._s[2580]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2581]! } + public var ExplicitContent_AlertTitle: String { return self._s[2582]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2576]!, self._r[2576]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2583]!, self._r[2583]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2577]! } - public var Weekday_Thursday: String { return self._s[2578]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2579]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2580]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2584]! } + public var Weekday_Thursday: String { return self._s[2585]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2586]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2587]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2581]!, self._r[2581]!, [_0]) + return formatWithArgumentRanges(self._s[2588]!, self._r[2588]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2582]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2583]! } - public var Passport_RequestedInformation: String { return self._s[2584]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2585]! } - public var Conversation_EncryptionProcessing: String { return self._s[2587]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2588]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2590]! } - public var Channel_Setup_Title: String { return self._s[2591]! } - public var Conversation_SearchPlaceholder: String { return self._s[2592]! } - public var OldChannels_GroupEmptyFormat: String { return self._s[2593]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2594]! } - public var Checkout_ErrorGeneric: String { return self._s[2595]! } - public var Passport_Language_hu: String { return self._s[2596]! } - public var GroupPermission_EditingDisabled: String { return self._s[2597]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2599]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2589]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2590]! } + public var Passport_RequestedInformation: String { return self._s[2591]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2592]! } + public var Conversation_EncryptionProcessing: String { return self._s[2594]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2595]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2597]! } + public var Channel_Setup_Title: String { return self._s[2598]! } + public var Conversation_SearchPlaceholder: String { return self._s[2599]! } + public var OldChannels_GroupEmptyFormat: String { return self._s[2600]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2601]! } + public var Checkout_ErrorGeneric: String { return self._s[2602]! } + public var Passport_Language_hu: String { return self._s[2603]! } + public var GroupPermission_EditingDisabled: String { return self._s[2604]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2606]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2600]!, self._r[2600]!, [_0]) + return formatWithArgumentRanges(self._s[2607]!, self._r[2607]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2603]!, self._r[2603]!, [_1]) + return formatWithArgumentRanges(self._s[2610]!, self._r[2610]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2604]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2611]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2605]!, self._r[2605]!, [_0]) + return formatWithArgumentRanges(self._s[2612]!, self._r[2612]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2606]! } - public var Group_Location_Info: String { return self._s[2607]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2608]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2609]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2613]! } + public var Group_Location_Info: String { return self._s[2614]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2615]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2616]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2610]!, self._r[2610]!, [_0]) + return formatWithArgumentRanges(self._s[2617]!, self._r[2617]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2611]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2612]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2613]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2614]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2618]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2619]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2620]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2621]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2615]!, self._r[2615]!, [_0]) + return formatWithArgumentRanges(self._s[2622]!, self._r[2622]!, [_0]) } public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2616]!, self._r[2616]!, [_0]) + return formatWithArgumentRanges(self._s[2623]!, self._r[2623]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2617]! } - public var Message_PinnedAnimationMessage: String { return self._s[2619]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2621]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2622]! } - public var Wallet_Info_TransactionTo: String { return self._s[2624]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2625]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2626]! } - public var Embed_PlayingInPIP: String { return self._s[2627]! } - public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2628]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2629]! } + public var Passport_Language_cs: String { return self._s[2624]! } + public var Message_PinnedAnimationMessage: String { return self._s[2626]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2628]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2629]! } + public var Wallet_Info_TransactionTo: String { return self._s[2631]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2632]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2633]! } + public var Embed_PlayingInPIP: String { return self._s[2634]! } + public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2635]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2636]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2630]!, self._r[2630]!, [_0]) + return formatWithArgumentRanges(self._s[2637]!, self._r[2637]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2631]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2638]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_1]) + return formatWithArgumentRanges(self._s[2639]!, self._r[2639]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2633]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2634]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2635]! } - public var AutoNightTheme_System: String { return self._s[2636]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2637]! } - public var CreatePoll_QuizTitle: String { return self._s[2638]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2639]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2640]! } + public var Notification_PaymentSent: String { return self._s[2640]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2641]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2642]! } + public var AutoNightTheme_System: String { return self._s[2643]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2644]! } + public var CreatePoll_QuizTitle: String { return self._s[2645]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2646]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2647]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2643]!, self._r[2643]!, [_1]) + return formatWithArgumentRanges(self._s[2650]!, self._r[2650]!, [_1]) } public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2644]!, self._r[2644]!, [_1]) + return formatWithArgumentRanges(self._s[2651]!, self._r[2651]!, [_1]) } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2645]!, self._r[2645]!, [_1]) + return formatWithArgumentRanges(self._s[2652]!, self._r[2652]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2647]! } - public var PasscodeSettings_HelpTop: String { return self._s[2648]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2649]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2650]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2651]! } - public var EditTheme_ShortLink: String { return self._s[2652]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2653]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2654]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2655]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2656]! } - public var Call_Accept: String { return self._s[2658]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2659]! } - public var Month_GenMarch: String { return self._s[2661]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2662]! } - public var LoginPassword_Title: String { return self._s[2663]! } - public var Call_End: String { return self._s[2664]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2665]! } - public var VoiceOver_Chat_Contact: String { return self._s[2666]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2667]! } - public var CallSettings_Always: String { return self._s[2668]! } - public var CallFeedback_Success: String { return self._s[2669]! } - public var TwoStepAuth_SetupHint: String { return self._s[2670]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2654]! } + public var PasscodeSettings_HelpTop: String { return self._s[2655]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2656]! } + public var PeerInfo_AddToContacts: String { return self._s[2657]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2658]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2659]! } + public var EditTheme_ShortLink: String { return self._s[2660]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2661]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2662]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2663]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2664]! } + public var Call_Accept: String { return self._s[2666]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2667]! } + public var Month_GenMarch: String { return self._s[2669]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2670]! } + public var LoginPassword_Title: String { return self._s[2671]! } + public var Call_End: String { return self._s[2672]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2673]! } + public var VoiceOver_Chat_Contact: String { return self._s[2674]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2675]! } + public var CallSettings_Always: String { return self._s[2676]! } + public var CallFeedback_Success: String { return self._s[2677]! } + public var TwoStepAuth_SetupHint: String { return self._s[2678]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2671]!, self._r[2671]!, [_1]) + return formatWithArgumentRanges(self._s[2679]!, self._r[2679]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2672]! } - public var PeerInfo_ButtonAddMember: String { return self._s[2673]! } - public var Login_PhoneTitle: String { return self._s[2674]! } - public var Passport_FieldPhoneHelp: String { return self._s[2675]! } - public var Weekday_ShortSunday: String { return self._s[2676]! } - public var Passport_InfoFAQ_URL: String { return self._s[2677]! } - public var ContactInfo_Job: String { return self._s[2679]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2680]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2681]! } - public var CreatePoll_QuizTip: String { return self._s[2682]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2683]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2684]! } - public var Invite_ChannelsTooMuch: String { return self._s[2685]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2686]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2687]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2688]! } - public var Wallet_Receive_AmountText: String { return self._s[2689]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2690]! } - public var CallFeedback_ReasonNoise: String { return self._s[2691]! } - public var Appearance_AppIconDefault: String { return self._s[2693]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2694]! } - public var MediaPicker_AddCaption: String { return self._s[2695]! } - public var CallSettings_TabIconDescription: String { return self._s[2696]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2680]! } + public var PeerInfo_ButtonAddMember: String { return self._s[2681]! } + public var Login_PhoneTitle: String { return self._s[2682]! } + public var Passport_FieldPhoneHelp: String { return self._s[2683]! } + public var Weekday_ShortSunday: String { return self._s[2684]! } + public var Passport_InfoFAQ_URL: String { return self._s[2685]! } + public var ContactInfo_Job: String { return self._s[2687]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2688]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2689]! } + public var CreatePoll_QuizTip: String { return self._s[2690]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2691]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2692]! } + public var Invite_ChannelsTooMuch: String { return self._s[2693]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2694]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2695]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2696]! } + public var Wallet_Receive_AmountText: String { return self._s[2697]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2698]! } + public var CallFeedback_ReasonNoise: String { return self._s[2699]! } + public var Appearance_AppIconDefault: String { return self._s[2701]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2702]! } + public var MediaPicker_AddCaption: String { return self._s[2703]! } + public var CallSettings_TabIconDescription: String { return self._s[2704]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2697]!, self._r[2697]!, [_0]) + return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2698]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2706]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2699]!, self._r[2699]!, [_0]) + return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_0]) } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2700]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2701]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2702]! } - public var DialogList_SearchSectionRecent: String { return self._s[2703]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2704]! } - public var CreatePoll_Anonymous: String { return self._s[2705]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2708]! } - public var LastSeen_WithinAWeek: String { return self._s[2709]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2710]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2712]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2713]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2708]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2709]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2710]! } + public var DialogList_SearchSectionRecent: String { return self._s[2711]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2712]! } + public var CreatePoll_Anonymous: String { return self._s[2713]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2716]! } + public var LastSeen_WithinAWeek: String { return self._s[2717]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2718]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2720]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2721]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2714]!, self._r[2714]!, [_0]) + return formatWithArgumentRanges(self._s[2722]!, self._r[2722]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2715]! } - public var Conversation_StatusLeftGroup: String { return self._s[2716]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2717]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2719]! } - public var GroupPermission_AddSuccess: String { return self._s[2720]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2722]! } - public var Conversation_ContextMenuCopy: String { return self._s[2723]! } - public var AccessDenied_CallMicrophone: String { return self._s[2724]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2723]! } + public var Conversation_StatusLeftGroup: String { return self._s[2724]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2725]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2727]! } + public var GroupPermission_AddSuccess: String { return self._s[2728]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2730]! } + public var Conversation_ContextMenuCopy: String { return self._s[2731]! } + public var AccessDenied_CallMicrophone: String { return self._s[2732]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2725]!, self._r[2725]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2726]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2727]! } - public var Checkout_PaymentMethod_New: String { return self._s[2728]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2729]! } - public var PhotoEditor_QualityTool: String { return self._s[2730]! } - public var Login_SendCodeViaSms: String { return self._s[2731]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2732]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2733]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2734]! } - public var Login_EmailNotConfiguredError: String { return self._s[2735]! } - public var SocksProxySetup_Status: String { return self._s[2736]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2737]! } - public var PrivacyPolicy_Accept: String { return self._s[2738]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2739]! } - public var Appearance_AppIconClassicX: String { return self._s[2740]! } + public var Login_InvalidFirstNameError: String { return self._s[2734]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2735]! } + public var Checkout_PaymentMethod_New: String { return self._s[2736]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2737]! } + public var PhotoEditor_QualityTool: String { return self._s[2738]! } + public var Login_SendCodeViaSms: String { return self._s[2739]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2740]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2741]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2742]! } + public var Login_EmailNotConfiguredError: String { return self._s[2743]! } + public var SocksProxySetup_Status: String { return self._s[2744]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2745]! } + public var PrivacyPolicy_Accept: String { return self._s[2746]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2747]! } + public var Appearance_AppIconClassicX: String { return self._s[2748]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2741]!, self._r[2741]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2749]!, self._r[2749]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2742]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2744]! } - public var AutoNightTheme_Automatic: String { return self._s[2745]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2746]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2747]! } - public var Cache_Help: String { return self._s[2748]! } - public var Group_ErrorAccessDenied: String { return self._s[2749]! } - public var Passport_Language_fa: String { return self._s[2750]! } - public var Wallet_Intro_Text: String { return self._s[2751]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2752]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2753]! } - public var PrivacySettings_LastSeen: String { return self._s[2754]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2750]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2752]! } + public var AutoNightTheme_Automatic: String { return self._s[2753]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2754]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2755]! } + public var Cache_Help: String { return self._s[2756]! } + public var Group_ErrorAccessDenied: String { return self._s[2757]! } + public var Passport_Language_fa: String { return self._s[2758]! } + public var Wallet_Intro_Text: String { return self._s[2759]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2760]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2761]! } + public var PrivacySettings_LastSeen: String { return self._s[2762]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2755]!, self._r[2755]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2763]!, self._r[2763]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2759]! } - public var Preview_SaveGif: String { return self._s[2760]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2761]! } - public var Profile_About: String { return self._s[2762]! } - public var Channel_About_Placeholder: String { return self._s[2763]! } - public var Login_InfoTitle: String { return self._s[2764]! } + public var Wallet_Configuration_Apply: String { return self._s[2767]! } + public var Preview_SaveGif: String { return self._s[2768]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2769]! } + public var Profile_About: String { return self._s[2770]! } + public var Channel_About_Placeholder: String { return self._s[2771]! } + public var Login_InfoTitle: String { return self._s[2772]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2765]!, self._r[2765]!, [_0]) + return formatWithArgumentRanges(self._s[2773]!, self._r[2773]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2766]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2768]! } - public var ContactInfo_Title: String { return self._s[2769]! } - public var Media_ShareThisVideo: String { return self._s[2770]! } - public var Weekday_ShortFriday: String { return self._s[2771]! } - public var AccessDenied_Contacts: String { return self._s[2773]! } - public var Notification_CallIncomingShort: String { return self._s[2774]! } - public var Group_Setup_TypePublic: String { return self._s[2775]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2776]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2777]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2780]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2781]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2782]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2783]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2784]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2774]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2776]! } + public var ContactInfo_Title: String { return self._s[2777]! } + public var Media_ShareThisVideo: String { return self._s[2778]! } + public var Weekday_ShortFriday: String { return self._s[2779]! } + public var AccessDenied_Contacts: String { return self._s[2781]! } + public var Notification_CallIncomingShort: String { return self._s[2782]! } + public var Group_Setup_TypePublic: String { return self._s[2783]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2784]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2785]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2788]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2789]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2790]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2791]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2792]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2785]!, self._r[2785]!, [_0]) + return formatWithArgumentRanges(self._s[2793]!, self._r[2793]!, [_0]) } - public var DialogList_Typing: String { return self._s[2786]! } - public var CallFeedback_IncludeLogs: String { return self._s[2788]! } - public var Checkout_Phone: String { return self._s[2790]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2793]! } - public var Privacy_Calls_Integration: String { return self._s[2794]! } - public var Notifications_PermissionsAllow: String { return self._s[2795]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2800]! } - public var Settings_ChatSettings: String { return self._s[2801]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2802]! } + public var DialogList_Typing: String { return self._s[2794]! } + public var CallFeedback_IncludeLogs: String { return self._s[2796]! } + public var Checkout_Phone: String { return self._s[2798]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2801]! } + public var Privacy_Calls_Integration: String { return self._s[2802]! } + public var Notifications_PermissionsAllow: String { return self._s[2803]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2808]! } + public var Settings_ChatSettings: String { return self._s[2809]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2810]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2804]!, self._r[2804]!, [_0]) + return formatWithArgumentRanges(self._s[2812]!, self._r[2812]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2813]!, self._r[2813]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2807]! } + public var GroupRemoved_DeleteUser: String { return self._s[2815]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2808]!, self._r[2808]!, [_0]) + return formatWithArgumentRanges(self._s[2816]!, self._r[2816]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2809]!, self._r[2809]!, [_1]) + return formatWithArgumentRanges(self._s[2817]!, self._r[2817]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2810]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2811]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2813]! } - public var Conversation_Unblock: String { return self._s[2814]! } - public var PrivacySettings_DataSettings: String { return self._s[2815]! } - public var WallpaperPreview_PatternPaternApply: String { return self._s[2816]! } - public var Group_PublicLink_Info: String { return self._s[2817]! } + public var Login_ContinueWithLocalization: String { return self._s[2818]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2819]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2821]! } + public var Conversation_Unblock: String { return self._s[2822]! } + public var PrivacySettings_DataSettings: String { return self._s[2823]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[2824]! } + public var Group_PublicLink_Info: String { return self._s[2825]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2818]!, self._r[2818]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2826]!, self._r[2826]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2819]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2827]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2820]!, self._r[2820]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2828]!, self._r[2828]!, [_0, _1]) } - public var OldChannels_ChannelsHeader: String { return self._s[2822]! } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2823]! } - public var PrivacySettings_Passcode: String { return self._s[2825]! } - public var Call_Mute: String { return self._s[2826]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2827]! } - public var Passport_Language_dz: String { return self._s[2828]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2829]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2830]! } - public var Passport_Language_tk: String { return self._s[2831]! } + public var OldChannels_ChannelsHeader: String { return self._s[2830]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2831]! } + public var PrivacySettings_Passcode: String { return self._s[2833]! } + public var Call_Mute: String { return self._s[2834]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2835]! } + public var Passport_Language_dz: String { return self._s[2836]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2837]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2838]! } + public var Passport_Language_tk: String { return self._s[2839]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2832]!, self._r[2832]!, [_0]) + return formatWithArgumentRanges(self._s[2840]!, self._r[2840]!, [_0]) } - public var Settings_Search: String { return self._s[2833]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2834]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2835]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2836]! } - public var Conversation_ContextMenuReply: String { return self._s[2837]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2838]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2839]! } - public var Tour_Title1: String { return self._s[2840]! } - public var Wallet_Alert_Cancel: String { return self._s[2841]! } - public var Conversation_ClearGroupHistory: String { return self._s[2843]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2844]! } - public var WallpaperPreview_Motion: String { return self._s[2845]! } + public var Settings_Search: String { return self._s[2841]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2842]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2843]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2844]! } + public var Conversation_ContextMenuReply: String { return self._s[2845]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2846]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2847]! } + public var Tour_Title1: String { return self._s[2848]! } + public var Wallet_Alert_Cancel: String { return self._s[2849]! } + public var Conversation_ClearGroupHistory: String { return self._s[2851]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2852]! } + public var WallpaperPreview_Motion: String { return self._s[2853]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2846]!, self._r[2846]!, [_0]) + return formatWithArgumentRanges(self._s[2854]!, self._r[2854]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2847]! } - public var Call_RateCall: String { return self._s[2848]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2849]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2850]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2851]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2853]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2855]! } + public var Call_RateCall: String { return self._s[2856]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2857]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2858]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2859]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2861]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2855]!, self._r[2855]!, [_0]) + return formatWithArgumentRanges(self._s[2863]!, self._r[2863]!, [_0]) } - public var Compose_Create: String { return self._s[2856]! } - public var Contacts_InviteToTelegram: String { return self._s[2857]! } - public var GroupInfo_Notifications: String { return self._s[2858]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2860]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2861]! } - public var Month_GenApril: String { return self._s[2862]! } - public var Appearance_AutoNightTheme: String { return self._s[2863]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2865]! } - public var Login_CodeSentSms: String { return self._s[2867]! } + public var Compose_Create: String { return self._s[2864]! } + public var Contacts_InviteToTelegram: String { return self._s[2865]! } + public var GroupInfo_Notifications: String { return self._s[2866]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2868]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2869]! } + public var Month_GenApril: String { return self._s[2870]! } + public var Appearance_AutoNightTheme: String { return self._s[2871]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2873]! } + public var Login_CodeSentSms: String { return self._s[2875]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2868]!, self._r[2868]!, [_0]) + return formatWithArgumentRanges(self._s[2876]!, self._r[2876]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2869]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2870]! } - public var Passport_Language_hr: String { return self._s[2871]! } - public var Common_ActionNotAllowedError: String { return self._s[2872]! } + public var EmptyGroupInfo_Line3: String { return self._s[2877]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2878]! } + public var Passport_Language_hr: String { return self._s[2879]! } + public var Common_ActionNotAllowedError: String { return self._s[2880]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_0]) + return formatWithArgumentRanges(self._s[2881]!, self._r[2881]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2874]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2875]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2876]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2877]! } - public var Privacy_SecretChatsTitle: String { return self._s[2878]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2880]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2881]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2882]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2883]! } - public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2884]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2885]! } - public var Preview_DeleteGif: String { return self._s[2886]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2887]! } - public var Group_ErrorNotMutualContact: String { return self._s[2888]! } - public var Notification_MessageLifetime5s: String { return self._s[2889]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[2890]! } - public var OldChannels_ChannelFormat: String { return self._s[2891]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2882]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2883]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2884]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2885]! } + public var Privacy_SecretChatsTitle: String { return self._s[2886]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2888]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2889]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2890]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2891]! } + public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2892]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2893]! } + public var Preview_DeleteGif: String { return self._s[2894]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2895]! } + public var Group_ErrorNotMutualContact: String { return self._s[2896]! } + public var Notification_MessageLifetime5s: String { return self._s[2897]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[2898]! } + public var OldChannels_ChannelFormat: String { return self._s[2899]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2892]!, self._r[2892]!, [_0]) + return formatWithArgumentRanges(self._s[2900]!, self._r[2900]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2893]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2895]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2896]! } - public var Passport_Address_AddBankStatement: String { return self._s[2897]! } - public var Notification_CallIncoming: String { return self._s[2898]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[2899]! } - public var Compose_NewGroupTitle: String { return self._s[2900]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2902]! } - public var Passport_Address_Postcode: String { return self._s[2904]! } + public var VoiceOver_Chat_Video: String { return self._s[2901]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2903]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2904]! } + public var Passport_Address_AddBankStatement: String { return self._s[2905]! } + public var Notification_CallIncoming: String { return self._s[2906]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[2907]! } + public var Compose_NewGroupTitle: String { return self._s[2908]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2910]! } + public var Passport_Address_Postcode: String { return self._s[2912]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2905]!, self._r[2905]!, [_0]) - } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2906]! } - public var Wallet_Month_ShortOctober: String { return self._s[2907]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2908]! } - public var WallpaperColors_Title: String { return self._s[2909]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2910]! } - public var VoiceOver_MessageContextForward: String { return self._s[2911]! } - public var GroupPermission_Duration: String { return self._s[2912]! } - public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2913]!, self._r[2913]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2914]! } - public var Username_Placeholder: String { return self._s[2915]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2916]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2917]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2918]! } - public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2920]!, self._r[2920]!, [_1, _2]) + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2914]! } + public var Wallet_Month_ShortOctober: String { return self._s[2915]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2916]! } + public var WallpaperColors_Title: String { return self._s[2917]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2918]! } + public var VoiceOver_MessageContextForward: String { return self._s[2919]! } + public var GroupPermission_Duration: String { return self._s[2920]! } + public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2921]!, self._r[2921]!, [_0]) } - public var Passport_PasswordDescription: String { return self._s[2921]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2922]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2923]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2924]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2925]! } - public var Conversation_ContextMenuMore: String { return self._s[2926]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2927]! } - public var CallSettings_TabIcon: String { return self._s[2928]! } - public var KeyCommand_Find: String { return self._s[2929]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[2930]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2931]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2932]! } - public var Message_PinnedGame: String { return self._s[2933]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2934]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2936]! } - public var Login_CallRequestState2: String { return self._s[2938]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2940]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2922]! } + public var Username_Placeholder: String { return self._s[2923]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2924]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2925]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2926]! } + public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2928]!, self._r[2928]!, [_1, _2]) + } + public var Passport_PasswordDescription: String { return self._s[2929]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2930]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2931]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2932]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2933]! } + public var Conversation_ContextMenuMore: String { return self._s[2934]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2935]! } + public var CallSettings_TabIcon: String { return self._s[2936]! } + public var KeyCommand_Find: String { return self._s[2937]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[2938]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2939]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2940]! } + public var Message_PinnedGame: String { return self._s[2941]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2942]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2944]! } + public var Login_CallRequestState2: String { return self._s[2946]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2948]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2941]!, self._r[2941]!, [_0]) + return formatWithArgumentRanges(self._s[2949]!, self._r[2949]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2943]!, self._r[2943]!, [_0]) + return formatWithArgumentRanges(self._s[2951]!, self._r[2951]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[2944]! } - public var WallpaperPreview_Blurred: String { return self._s[2945]! } - public var Conversation_InstantPagePreview: String { return self._s[2946]! } - public var PeerInfo_ButtonUnmute: String { return self._s[2947]! } + public var AuthSessions_AddDevice: String { return self._s[2952]! } + public var WallpaperPreview_Blurred: String { return self._s[2953]! } + public var Conversation_InstantPagePreview: String { return self._s[2954]! } + public var PeerInfo_ButtonUnmute: String { return self._s[2955]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2948]!, self._r[2948]!, [_0]) + return formatWithArgumentRanges(self._s[2956]!, self._r[2956]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2951]! } - public var WallpaperSearch_ColorRed: String { return self._s[2952]! } - public var GroupPermission_NoPinMessages: String { return self._s[2953]! } - public var Passport_Language_es: String { return self._s[2954]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2956]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2957]! } + public var SecretTimer_VideoDescription: String { return self._s[2959]! } + public var WallpaperSearch_ColorRed: String { return self._s[2960]! } + public var GroupPermission_NoPinMessages: String { return self._s[2961]! } + public var Passport_Language_es: String { return self._s[2962]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2964]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2965]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2958]!, self._r[2958]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2966]!, self._r[2966]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2959]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2960]! } - public var Watch_UserInfo_Unmute: String { return self._s[2961]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2962]! } - public var AccessDenied_CameraRestricted: String { return self._s[2964]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2967]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2968]! } + public var Watch_UserInfo_Unmute: String { return self._s[2969]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2970]! } + public var AccessDenied_CameraRestricted: String { return self._s[2972]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2965]!, self._r[2965]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2973]!, self._r[2973]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2967]! } - public var Settings_CopyUsername: String { return self._s[2968]! } - public var Contacts_SearchLabel: String { return self._s[2969]! } - public var Map_OpenInYandexNavigator: String { return self._s[2971]! } - public var PasscodeSettings_EncryptData: String { return self._s[2972]! } - public var Settings_Wallet: String { return self._s[2973]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2974]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2975]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2976]! } - public var DialogList_AdNoticeAlert: String { return self._s[2977]! } - public var Wallet_Month_GenMay: String { return self._s[2979]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2980]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2981]! } - public var Localization_LanguageCustom: String { return self._s[2982]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2983]! } - public var CallFeedback_Title: String { return self._s[2984]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2987]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2988]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[2989]! } - public var Conversation_InfoGroup: String { return self._s[2990]! } - public var Compose_NewMessage: String { return self._s[2991]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2992]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2993]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[2994]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2995]! } + public var ChatList_ReadAll: String { return self._s[2975]! } + public var Settings_CopyUsername: String { return self._s[2976]! } + public var Contacts_SearchLabel: String { return self._s[2977]! } + public var Map_OpenInYandexNavigator: String { return self._s[2979]! } + public var PasscodeSettings_EncryptData: String { return self._s[2980]! } + public var Settings_Wallet: String { return self._s[2981]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2982]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2983]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2984]! } + public var DialogList_AdNoticeAlert: String { return self._s[2985]! } + public var Wallet_Month_GenMay: String { return self._s[2987]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2988]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2989]! } + public var Localization_LanguageCustom: String { return self._s[2990]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2991]! } + public var CallFeedback_Title: String { return self._s[2992]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2995]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2996]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[2997]! } + public var Conversation_InfoGroup: String { return self._s[2998]! } + public var Compose_NewMessage: String { return self._s[2999]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3000]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3001]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3002]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3003]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2996]!, self._r[2996]!, [_0]) + return formatWithArgumentRanges(self._s[3004]!, self._r[3004]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2997]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2998]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2999]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[3000]! } - public var Channel_BlackList_Title: String { return self._s[3001]! } - public var UserInfo_PhoneCall: String { return self._s[3002]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3004]! } - public var Wallet_Month_ShortJanuary: String { return self._s[3005]! } - public var State_connecting: String { return self._s[3006]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3007]! } - public var Wallet_Month_GenMarch: String { return self._s[3008]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[3009]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[3010]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3005]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3006]! } + public var ChangePhoneNumberCode_Help: String { return self._s[3007]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[3008]! } + public var Channel_BlackList_Title: String { return self._s[3009]! } + public var UserInfo_PhoneCall: String { return self._s[3010]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3012]! } + public var Wallet_Month_ShortJanuary: String { return self._s[3013]! } + public var State_connecting: String { return self._s[3014]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3015]! } + public var Wallet_Month_GenMarch: String { return self._s[3016]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[3017]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[3018]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3011]!, self._r[3011]!, [_0]) + return formatWithArgumentRanges(self._s[3019]!, self._r[3019]!, [_0]) } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3012]!, self._r[3012]!, [_0]) + return formatWithArgumentRanges(self._s[3020]!, self._r[3020]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[3013]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3014]! } - public var Passport_Identity_EditPassport: String { return self._s[3015]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[3017]! } - public var Localization_EnglishLanguageName: String { return self._s[3018]! } - public var Share_AuthDescription: String { return self._s[3019]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3020]! } - public var Passport_Identity_Surname: String { return self._s[3021]! } - public var Compose_TokenListPlaceholder: String { return self._s[3022]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3023]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[3024]! } - public var Settings_AboutEmpty: String { return self._s[3025]! } - public var Conversation_Unmute: String { return self._s[3026]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[3028]! } - public var Wallet_Sending_Text: String { return self._s[3029]! } + public var Notifications_GroupNotifications: String { return self._s[3021]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3022]! } + public var Passport_Identity_EditPassport: String { return self._s[3023]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[3025]! } + public var Localization_EnglishLanguageName: String { return self._s[3026]! } + public var Share_AuthDescription: String { return self._s[3027]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3028]! } + public var Passport_Identity_Surname: String { return self._s[3029]! } + public var Compose_TokenListPlaceholder: String { return self._s[3030]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3031]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[3032]! } + public var Settings_AboutEmpty: String { return self._s[3033]! } + public var Conversation_Unmute: String { return self._s[3034]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[3036]! } + public var Wallet_Sending_Text: String { return self._s[3037]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3030]!, self._r[3030]!, [_1]) - } - public var Login_CodeSentCall: String { return self._s[3031]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3033]! } - public var ChatSettings_Appearance: String { return self._s[3034]! } - public var ClearCache_StorageUsage: String { return self._s[3035]! } - public var Appearance_PickAccentColor: String { return self._s[3036]! } - public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3037]!, self._r[3037]!, [_1, _2]) - } - public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3038]!, self._r[3038]!, [_1]) } - public var Notification_CallMissed: String { return self._s[3039]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3040]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3041]! } - public var Wallet_Month_GenOctober: String { return self._s[3043]! } - public var ChatAdmins_AdminLabel: String { return self._s[3044]! } - public var KeyCommand_JumpToNextChat: String { return self._s[3045]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[3047]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3048]! } - public var Month_GenJune: String { return self._s[3049]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[3050]! } - public var Watch_Location_Current: String { return self._s[3051]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3052]! } - public var Conversation_TitleMute: String { return self._s[3053]! } - public var Map_PlacesInThisArea: String { return self._s[3054]! } + public var Login_CodeSentCall: String { return self._s[3039]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3041]! } + public var ChatSettings_Appearance: String { return self._s[3042]! } + public var ClearCache_StorageUsage: String { return self._s[3043]! } + public var Appearance_PickAccentColor: String { return self._s[3044]! } + public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3045]!, self._r[3045]!, [_1, _2]) + } + public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3046]!, self._r[3046]!, [_1]) + } + public var Notification_CallMissed: String { return self._s[3047]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3048]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3049]! } + public var Wallet_Month_GenOctober: String { return self._s[3051]! } + public var ChatAdmins_AdminLabel: String { return self._s[3052]! } + public var KeyCommand_JumpToNextChat: String { return self._s[3053]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[3055]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3056]! } + public var Month_GenJune: String { return self._s[3057]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[3058]! } + public var Watch_Location_Current: String { return self._s[3059]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3060]! } + public var Conversation_TitleMute: String { return self._s[3061]! } + public var Map_PlacesInThisArea: String { return self._s[3062]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3055]!, self._r[3055]!, [_1]) + return formatWithArgumentRanges(self._s[3063]!, self._r[3063]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3056]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3064]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3057]!, self._r[3057]!, [_0]) + return formatWithArgumentRanges(self._s[3065]!, self._r[3065]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[3058]! } - public var Chat_SlowmodeSendError: String { return self._s[3059]! } - public var MaskStickerSettings_Info: String { return self._s[3060]! } - public var EditTheme_Expand_TopInfo: String { return self._s[3061]! } + public var Call_ReportPlaceholder: String { return self._s[3066]! } + public var Chat_SlowmodeSendError: String { return self._s[3067]! } + public var MaskStickerSettings_Info: String { return self._s[3068]! } + public var EditTheme_Expand_TopInfo: String { return self._s[3069]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_0]) + return formatWithArgumentRanges(self._s[3070]!, self._r[3070]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[3063]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3065]! } - public var Contacts_ShareTelegram: String { return self._s[3066]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3067]! } - public var Map_AddressOnMap: String { return self._s[3068]! } - public var Channel_ErrorAccessDenied: String { return self._s[3069]! } - public var UserInfo_ScamBotWarning: String { return self._s[3071]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[3072]! } - public var Call_ConnectionErrorTitle: String { return self._s[3073]! } - public var UserInfo_NotificationsEnable: String { return self._s[3074]! } - public var ArchivedChats_IntroText1: String { return self._s[3075]! } - public var Tour_Text4: String { return self._s[3078]! } - public var WallpaperSearch_Recent: String { return self._s[3079]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3080]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3081]! } - public var Profile_MessageLifetime2s: String { return self._s[3083]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3084]! } - public var Notification_MessageLifetime2s: String { return self._s[3085]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[3071]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3073]! } + public var Contacts_ShareTelegram: String { return self._s[3074]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3075]! } + public var Map_AddressOnMap: String { return self._s[3076]! } + public var Channel_ErrorAccessDenied: String { return self._s[3077]! } + public var UserInfo_ScamBotWarning: String { return self._s[3079]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[3080]! } + public var Call_ConnectionErrorTitle: String { return self._s[3081]! } + public var UserInfo_NotificationsEnable: String { return self._s[3082]! } + public var ArchivedChats_IntroText1: String { return self._s[3083]! } + public var Tour_Text4: String { return self._s[3086]! } + public var WallpaperSearch_Recent: String { return self._s[3087]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3088]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3089]! } + public var Profile_MessageLifetime2s: String { return self._s[3091]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3092]! } + public var Notification_MessageLifetime2s: String { return self._s[3093]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3086]!, self._r[3086]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3094]!, self._r[3094]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[3087]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3088]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3089]! } + public var Cache_ClearCache: String { return self._s[3095]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3096]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3097]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3093]!, self._r[3093]!, [_0]) + return formatWithArgumentRanges(self._s[3101]!, self._r[3101]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3095]!, self._r[3095]!, [_0]) + return formatWithArgumentRanges(self._s[3103]!, self._r[3103]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3096]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3097]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3098]! } - public var ChatList_UnarchiveAction: String { return self._s[3099]! } - public var AutoNightTheme_Title: String { return self._s[3100]! } - public var InstantPage_FeedbackButton: String { return self._s[3101]! } - public var Passport_FieldAddress: String { return self._s[3102]! } + public var LocalGroup_Text: String { return self._s[3104]! } + public var PeerInfo_PaneMembers: String { return self._s[3105]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3106]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3107]! } + public var ChatList_UnarchiveAction: String { return self._s[3108]! } + public var AutoNightTheme_Title: String { return self._s[3109]! } + public var InstantPage_FeedbackButton: String { return self._s[3110]! } + public var Passport_FieldAddress: String { return self._s[3111]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3103]!, self._r[3103]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3112]!, self._r[3112]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3104]! } + public var Month_ShortMarch: String { return self._s[3113]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3105]!, self._r[3105]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3114]!, self._r[3114]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3106]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3107]! } - public var Passport_FloodError: String { return self._s[3108]! } - public var SecretGif_Title: String { return self._s[3109]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3110]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3111]! } - public var Passport_Language_th: String { return self._s[3113]! } - public var Passport_Address_Address: String { return self._s[3114]! } - public var Login_InvalidLastNameError: String { return self._s[3115]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3116]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3117]! } - public var ChatList_Context_Archive: String { return self._s[3118]! } - public var SettingsSearch_FAQ: String { return self._s[3119]! } - public var ShareMenu_Send: String { return self._s[3120]! } - public var ChatState_Connecting: String { return self._s[3121]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3123]! } - public var Month_GenNovember: String { return self._s[3125]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3127]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3115]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3116]! } + public var Passport_FloodError: String { return self._s[3117]! } + public var SecretGif_Title: String { return self._s[3118]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3119]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3120]! } + public var Passport_Language_th: String { return self._s[3122]! } + public var Passport_Address_Address: String { return self._s[3123]! } + public var Login_InvalidLastNameError: String { return self._s[3124]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3125]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3126]! } + public var ChatList_Context_Archive: String { return self._s[3127]! } + public var SettingsSearch_FAQ: String { return self._s[3128]! } + public var ShareMenu_Send: String { return self._s[3129]! } + public var ChatState_Connecting: String { return self._s[3130]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3132]! } + public var Month_GenNovember: String { return self._s[3134]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3136]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3128]!, self._r[3128]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3137]!, self._r[3137]!, [_1, _2]) } - public var Conversation_SwipeToReplyHintText: String { return self._s[3129]! } - public var Checkout_Email: String { return self._s[3130]! } - public var NotificationsSound_Tritone: String { return self._s[3131]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3133]! } - public var Wallet_ContextMenuCopy: String { return self._s[3135]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3138]! } + public var Checkout_Email: String { return self._s[3139]! } + public var NotificationsSound_Tritone: String { return self._s[3140]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3142]! } + public var Wallet_ContextMenuCopy: String { return self._s[3144]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3137]!, self._r[3137]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3146]!, self._r[3146]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3138]! } + public var Appearance_TextSize_Automatic: String { return self._s[3147]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3139]!, self._r[3139]!, [_1]) + return formatWithArgumentRanges(self._s[3148]!, self._r[3148]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3140]!, self._r[3140]!, [_0]) + return formatWithArgumentRanges(self._s[3149]!, self._r[3149]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3141]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3150]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3142]!, self._r[3142]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3151]!, self._r[3151]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3143]! } - public var Notification_Exceptions_Add: String { return self._s[3144]! } - public var DialogList_You: String { return self._s[3145]! } - public var MediaPicker_Send: String { return self._s[3148]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3149]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3150]! } - public var Call_AudioRouteSpeaker: String { return self._s[3151]! } - public var Watch_UserInfo_Title: String { return self._s[3152]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3153]! } - public var Appearance_AccentColor: String { return self._s[3155]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3152]! } + public var Notification_Exceptions_Add: String { return self._s[3153]! } + public var DialogList_You: String { return self._s[3154]! } + public var MediaPicker_Send: String { return self._s[3157]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3158]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3159]! } + public var Call_AudioRouteSpeaker: String { return self._s[3160]! } + public var Watch_UserInfo_Title: String { return self._s[3161]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3162]! } + public var Appearance_AccentColor: String { return self._s[3164]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3156]!, self._r[3156]!, [_0]) + return formatWithArgumentRanges(self._s[3165]!, self._r[3165]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3157]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3166]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3158]!, self._r[3158]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3167]!, self._r[3167]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3159]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3160]! } - public var Notification_CallOutgoing: String { return self._s[3161]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3162]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3163]! } - public var Call_RecordingDisabledMessage: String { return self._s[3164]! } - public var Message_Game: String { return self._s[3165]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3166]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3167]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3168]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3169]! } - public var Date_DialogDateFormat: String { return self._s[3171]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3172]! } - public var Notifications_InAppNotifications: String { return self._s[3173]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3168]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3169]! } + public var Notification_CallOutgoing: String { return self._s[3170]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3171]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3172]! } + public var Call_RecordingDisabledMessage: String { return self._s[3173]! } + public var Message_Game: String { return self._s[3174]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3175]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3176]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3177]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3178]! } + public var Date_DialogDateFormat: String { return self._s[3180]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3181]! } + public var Notifications_InAppNotifications: String { return self._s[3182]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3174]!, self._r[3174]!, [_0]) + return formatWithArgumentRanges(self._s[3183]!, self._r[3183]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3175]!, self._r[3175]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3184]!, self._r[3184]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3176]! } + public var NewContact_Title: String { return self._s[3185]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3177]!, self._r[3177]!, [_0]) + return formatWithArgumentRanges(self._s[3186]!, self._r[3186]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3178]! } + public var Conversation_ViewContactDetails: String { return self._s[3187]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3180]!, self._r[3180]!, [_1]) + return formatWithArgumentRanges(self._s[3189]!, self._r[3189]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3181]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3182]! } - public var PrivacySettings_Title: String { return self._s[3183]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3186]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3187]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3188]! } - public var Contacts_PhoneNumber: String { return self._s[3189]! } - public var PeerInfo_ButtonMute: String { return self._s[3190]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3192]! } - public var Map_ShowPlaces: String { return self._s[3193]! } - public var ChatAdmins_Title: String { return self._s[3194]! } - public var InstantPage_Reference: String { return self._s[3196]! } - public var Wallet_Info_Updating: String { return self._s[3197]! } - public var ReportGroupLocation_Text: String { return self._s[3198]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3190]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3191]! } + public var PrivacySettings_Title: String { return self._s[3192]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3195]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3196]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3197]! } + public var Contacts_PhoneNumber: String { return self._s[3198]! } + public var PeerInfo_ButtonMute: String { return self._s[3199]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3201]! } + public var Map_ShowPlaces: String { return self._s[3202]! } + public var ChatAdmins_Title: String { return self._s[3203]! } + public var InstantPage_Reference: String { return self._s[3205]! } + public var Wallet_Info_Updating: String { return self._s[3206]! } + public var ReportGroupLocation_Text: String { return self._s[3207]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3199]!, self._r[3199]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3208]!, self._r[3208]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3200]! } - public var Watch_UserInfo_Block: String { return self._s[3201]! } - public var ChatSettings_Stickers: String { return self._s[3202]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3203]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3204]! } + public var Camera_FlashOff: String { return self._s[3209]! } + public var Watch_UserInfo_Block: String { return self._s[3210]! } + public var ChatSettings_Stickers: String { return self._s[3211]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3212]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3213]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3205]!, self._r[3205]!, [_0]) + return formatWithArgumentRanges(self._s[3214]!, self._r[3214]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3206]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3207]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3208]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3209]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3210]! } - public var VoiceOver_MessageContextShare: String { return self._s[3211]! } + public var Settings_ViewPhoto: String { return self._s[3215]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3216]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3217]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3218]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3219]! } + public var VoiceOver_MessageContextShare: String { return self._s[3220]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3213]!, self._r[3213]!, [_0]) + return formatWithArgumentRanges(self._s[3222]!, self._r[3222]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3214]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3215]! } + public var Privacy_DeleteDrafts: String { return self._s[3223]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3224]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3216]!, self._r[3216]!, [_0]) - } - public var DialogList_SavedMessagesHelp: String { return self._s[3217]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3218]! } - public var DialogList_SavedMessages: String { return self._s[3219]! } - public var GroupInfo_UpgradeButton: String { return self._s[3220]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3222]! } - public var DialogList_Pin: String { return self._s[3223]! } - public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3224]!, self._r[3224]!, [_0, _1]) - } - public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3225]!, self._r[3225]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3226]! } - public var UserInfo_NotificationsDisable: String { return self._s[3227]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[3228]! } - public var Paint_Outlined: String { return self._s[3229]! } - public var Activity_PlayingGame: String { return self._s[3230]! } - public var SearchImages_NoImagesFound: String { return self._s[3231]! } - public var SocksProxySetup_ProxyType: String { return self._s[3232]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3234]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3235]! } - public var Settings_AppLanguage: String { return self._s[3236]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3237]! } - public var Common_ChoosePhoto: String { return self._s[3238]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3239]! } - public var CallFeedback_ReasonEcho: String { return self._s[3240]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3226]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3227]! } + public var DialogList_SavedMessages: String { return self._s[3228]! } + public var GroupInfo_UpgradeButton: String { return self._s[3229]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3231]! } + public var DialogList_Pin: String { return self._s[3232]! } + public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3233]!, self._r[3233]!, [_0, _1]) + } + public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3234]!, self._r[3234]!, [_0]) + } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3235]! } + public var UserInfo_NotificationsDisable: String { return self._s[3236]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[3237]! } + public var Paint_Outlined: String { return self._s[3238]! } + public var Activity_PlayingGame: String { return self._s[3239]! } + public var SearchImages_NoImagesFound: String { return self._s[3240]! } + public var SocksProxySetup_ProxyType: String { return self._s[3241]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3243]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3244]! } + public var Settings_AppLanguage: String { return self._s[3245]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3246]! } + public var Common_ChoosePhoto: String { return self._s[3247]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3248]! } + public var CallFeedback_ReasonEcho: String { return self._s[3249]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3241]!, self._r[3241]!, [_1]) + return formatWithArgumentRanges(self._s[3250]!, self._r[3250]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3242]! } - public var PollResults_Collapse: String { return self._s[3243]! } - public var Activity_UploadingVideo: String { return self._s[3244]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3245]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3246]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3247]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3248]! } - public var PUSH_SENDER_YOU: String { return self._s[3249]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3250]! } - public var Checkout_PayWithTouchId: String { return self._s[3251]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3252]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3251]! } + public var PollResults_Collapse: String { return self._s[3252]! } + public var Activity_UploadingVideo: String { return self._s[3253]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3254]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3255]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3256]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3257]! } + public var PUSH_SENDER_YOU: String { return self._s[3258]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3259]! } + public var Checkout_PayWithTouchId: String { return self._s[3260]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3261]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3254]!, self._r[3254]!, [_1]) + return formatWithArgumentRanges(self._s[3263]!, self._r[3263]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3255]! } + public var Notifications_ExceptionsNone: String { return self._s[3264]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3256]!, self._r[3256]!, [_0]) + return formatWithArgumentRanges(self._s[3265]!, self._r[3265]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3257]!, self._r[3257]!, [_1]) + return formatWithArgumentRanges(self._s[3266]!, self._r[3266]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3259]! } - public var Passport_Address_Region: String { return self._s[3262]! } - public var ChatList_DeleteChat: String { return self._s[3263]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3264]! } - public var PhotoEditor_TiltShift: String { return self._s[3265]! } - public var Settings_FAQ_URL: String { return self._s[3266]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3267]! } - public var Passport_Language_sl: String { return self._s[3268]! } - public var Settings_PrivacySettings: String { return self._s[3270]! } - public var SharedMedia_TitleLink: String { return self._s[3271]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3272]! } - public var Settings_SetProfilePhoto: String { return self._s[3273]! } - public var Channel_About_Help: String { return self._s[3274]! } - public var Contacts_PermissionsEnable: String { return self._s[3275]! } - public var Wallet_Sending_Title: String { return self._s[3276]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3277]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3278]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3280]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3281]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3282]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3283]! } - public var OldChannels_Title: String { return self._s[3284]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3285]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3287]! } - public var Map_OpenInYandexMaps: String { return self._s[3289]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3290]! } - public var VoiceOver_MessageContextReply: String { return self._s[3291]! } - public var PhotoEditor_SaturationTool: String { return self._s[3293]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3268]! } + public var Passport_Address_Region: String { return self._s[3271]! } + public var ChatList_DeleteChat: String { return self._s[3272]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3273]! } + public var PhotoEditor_TiltShift: String { return self._s[3274]! } + public var Settings_FAQ_URL: String { return self._s[3275]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3276]! } + public var Passport_Language_sl: String { return self._s[3277]! } + public var Settings_PrivacySettings: String { return self._s[3279]! } + public var SharedMedia_TitleLink: String { return self._s[3280]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3281]! } + public var Settings_SetProfilePhoto: String { return self._s[3282]! } + public var Channel_About_Help: String { return self._s[3283]! } + public var Contacts_PermissionsEnable: String { return self._s[3284]! } + public var Wallet_Sending_Title: String { return self._s[3285]! } + public var PeerInfo_PaneMedia: String { return self._s[3286]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3287]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3288]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3290]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3291]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3292]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3293]! } + public var OldChannels_Title: String { return self._s[3294]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3295]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3297]! } + public var Map_OpenInYandexMaps: String { return self._s[3299]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3300]! } + public var VoiceOver_MessageContextReply: String { return self._s[3301]! } + public var PhotoEditor_SaturationTool: String { return self._s[3303]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3294]!, self._r[3294]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3304]!, self._r[3304]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3295]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3296]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3297]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3305]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3306]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3307]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3298]!, self._r[3298]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3308]!, self._r[3308]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3299]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3301]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3302]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3309]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3311]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3312]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3303]!, self._r[3303]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3313]!, self._r[3313]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3304]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3314]! } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3305]!, self._r[3305]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3315]!, self._r[3315]!, [_1, _2, _3]) } - public var WallpaperPreview_PatternTitle: String { return self._s[3306]! } - public var GroupInfo_PublicLinkAdd: String { return self._s[3307]! } - public var Passport_PassportInformation: String { return self._s[3310]! } - public var Theme_Unsupported: String { return self._s[3311]! } - public var WatchRemote_AlertTitle: String { return self._s[3312]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3313]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3315]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3316]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3317]! } + public var Passport_PassportInformation: String { return self._s[3320]! } + public var Theme_Unsupported: String { return self._s[3321]! } + public var WatchRemote_AlertTitle: String { return self._s[3322]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3323]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3325]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3316]!, self._r[3316]!, [_0]) + return formatWithArgumentRanges(self._s[3326]!, self._r[3326]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3317]!, self._r[3317]!, [_1]) + return formatWithArgumentRanges(self._s[3327]!, self._r[3327]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3318]! } - public var Wallet_Navigation_Done: String { return self._s[3320]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3321]! } - public var AccessDenied_CameraDisabled: String { return self._s[3322]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3328]! } + public var Wallet_Navigation_Done: String { return self._s[3330]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3331]! } + public var AccessDenied_CameraDisabled: String { return self._s[3332]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3323]!, self._r[3323]!, [_0]) - } - public var ClearCache_Forever: String { return self._s[3324]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3325]! } - public var CreatePoll_Quiz: String { return self._s[3326]! } - public var PhotoEditor_ContrastTool: String { return self._s[3329]! } - public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3330]!, self._r[3330]!, [_1]) - } - public var DialogList_Draft: String { return self._s[3331]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3332]! } - public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3333]!, self._r[3333]!, [_0]) } - public var Privacy_TopPeersDelete: String { return self._s[3335]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3336]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3337]! } - public var WebSearch_RecentSectionClear: String { return self._s[3338]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3339]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3341]! } - public var PeerInfo_ButtonMore: String { return self._s[3343]! } - public var Common_Done: String { return self._s[3344]! } - public var Shortcut_SwitchAccount: String { return self._s[3345]! } - public var AuthSessions_EmptyText: String { return self._s[3346]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3347]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3348]! } - public var Tour_Title5: String { return self._s[3349]! } - public var Wallet_Settings_Title: String { return self._s[3350]! } + public var ClearCache_Forever: String { return self._s[3334]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3335]! } + public var CreatePoll_Quiz: String { return self._s[3336]! } + public var PhotoEditor_ContrastTool: String { return self._s[3339]! } + public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3340]!, self._r[3340]!, [_1]) + } + public var DialogList_Draft: String { return self._s[3341]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3342]! } + public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) + } + public var Privacy_TopPeersDelete: String { return self._s[3345]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3346]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3347]! } + public var WebSearch_RecentSectionClear: String { return self._s[3348]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3349]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3351]! } + public var PeerInfo_ButtonMore: String { return self._s[3353]! } + public var Common_Done: String { return self._s[3354]! } + public var Shortcut_SwitchAccount: String { return self._s[3355]! } + public var AuthSessions_EmptyText: String { return self._s[3356]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3357]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3358]! } + public var Tour_Title5: String { return self._s[3359]! } + public var Wallet_Settings_Title: String { return self._s[3360]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3351]!, self._r[3351]!, [_0]) + return formatWithArgumentRanges(self._s[3361]!, self._r[3361]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3352]! } - public var Conversation_LinkDialogSave: String { return self._s[3353]! } - public var GroupInfo_ActionRestrict: String { return self._s[3354]! } - public var Checkout_Title: String { return self._s[3355]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3357]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3359]! } - public var Notification_RenamedGroup: String { return self._s[3360]! } - public var PeopleNearby_Groups: String { return self._s[3361]! } - public var Checkout_PayWithFaceId: String { return self._s[3362]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3363]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3365]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3366]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3367]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3362]! } + public var Conversation_LinkDialogSave: String { return self._s[3363]! } + public var GroupInfo_ActionRestrict: String { return self._s[3364]! } + public var Checkout_Title: String { return self._s[3365]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3367]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3369]! } + public var Notification_RenamedGroup: String { return self._s[3370]! } + public var PeopleNearby_Groups: String { return self._s[3371]! } + public var Checkout_PayWithFaceId: String { return self._s[3372]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3373]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3375]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3376]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3377]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3368]!, self._r[3368]!, [_0]) + return formatWithArgumentRanges(self._s[3378]!, self._r[3378]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3370]! } + public var Profile_AddToExisting: String { return self._s[3380]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3371]!, self._r[3371]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3381]!, self._r[3381]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3373]! } - public var Permissions_PrivacyPolicy: String { return self._s[3374]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3375]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3376]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3378]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3380]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3381]! } + public var Cache_Files: String { return self._s[3383]! } + public var Permissions_PrivacyPolicy: String { return self._s[3384]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3385]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3386]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3388]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3390]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3391]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3382]!, self._r[3382]!, [_0]) + return formatWithArgumentRanges(self._s[3392]!, self._r[3392]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3383]! } - public var VoiceOver_AttachMedia: String { return self._s[3386]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3387]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3393]! } + public var VoiceOver_AttachMedia: String { return self._s[3396]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3397]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3388]!, self._r[3388]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3398]!, self._r[3398]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3389]! } - public var Conversation_SetReminder_Title: String { return self._s[3390]! } - public var Passport_FieldAddressHelp: String { return self._s[3391]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3392]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3393]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3399]! } + public var Conversation_SetReminder_Title: String { return self._s[3400]! } + public var Passport_FieldAddressHelp: String { return self._s[3401]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3402]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3403]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3394]!, self._r[3394]!, [_0]) + return formatWithArgumentRanges(self._s[3404]!, self._r[3404]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3395]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3396]! } - public var Login_UnknownError: String { return self._s[3397]! } - public var Group_UpgradeNoticeText2: String { return self._s[3400]! } - public var Watch_Compose_AddContact: String { return self._s[3401]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3402]! } - public var Web_Error: String { return self._s[3403]! } - public var Gif_Search: String { return self._s[3404]! } - public var Profile_MessageLifetime1h: String { return self._s[3405]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3406]! } - public var Channel_Username_CheckingUsername: String { return self._s[3407]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3408]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3409]! } - public var Channel_AboutItem: String { return self._s[3410]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3412]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3413]! } - public var GroupInfo_SharedMedia: String { return self._s[3414]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3405]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3406]! } + public var Login_UnknownError: String { return self._s[3407]! } + public var Group_UpgradeNoticeText2: String { return self._s[3410]! } + public var Watch_Compose_AddContact: String { return self._s[3411]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3412]! } + public var Web_Error: String { return self._s[3413]! } + public var Gif_Search: String { return self._s[3414]! } + public var Profile_MessageLifetime1h: String { return self._s[3415]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3416]! } + public var Channel_Username_CheckingUsername: String { return self._s[3417]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3418]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3419]! } + public var Channel_AboutItem: String { return self._s[3420]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3422]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3423]! } + public var GroupInfo_SharedMedia: String { return self._s[3424]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3415]!, self._r[3415]!, [_1]) + return formatWithArgumentRanges(self._s[3425]!, self._r[3425]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3416]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3426]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3417]!, self._r[3417]!, [_1]) + return formatWithArgumentRanges(self._s[3427]!, self._r[3427]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3418]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3419]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3420]! } - public var CreatePoll_AddOption: String { return self._s[3421]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3422]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3423]! } - public var Channel_Management_AddModerator: String { return self._s[3424]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3425]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3426]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3427]! } - public var Theme_Colors_Background: String { return self._s[3428]! } - public var NotificationsSound_Hello: String { return self._s[3430]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3431]! } - public var Channel_Stickers_Placeholder: String { return self._s[3433]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3428]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3429]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3430]! } + public var CreatePoll_AddOption: String { return self._s[3431]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3432]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3433]! } + public var Channel_Management_AddModerator: String { return self._s[3434]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3435]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3436]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3437]! } + public var Theme_Colors_Background: String { return self._s[3438]! } + public var NotificationsSound_Hello: String { return self._s[3440]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3441]! } + public var Channel_Stickers_Placeholder: String { return self._s[3443]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3434]!, self._r[3434]!, [_0]) + return formatWithArgumentRanges(self._s[3444]!, self._r[3444]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3435]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3436]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3437]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3438]! } - public var AutoDownloadSettings_Channels: String { return self._s[3439]! } - public var Passport_Language_mn: String { return self._s[3440]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3443]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3444]! } - public var Passport_Language_ja: String { return self._s[3446]! } - public var Settings_About_Title: String { return self._s[3447]! } - public var Settings_NotificationsAndSounds: String { return self._s[3448]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3449]! } - public var Settings_BlockedUsers: String { return self._s[3450]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3445]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3446]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3447]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3448]! } + public var AutoDownloadSettings_Channels: String { return self._s[3449]! } + public var Passport_Language_mn: String { return self._s[3450]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3453]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3454]! } + public var Passport_Language_ja: String { return self._s[3456]! } + public var Settings_About_Title: String { return self._s[3457]! } + public var Settings_NotificationsAndSounds: String { return self._s[3458]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3459]! } + public var Settings_BlockedUsers: String { return self._s[3460]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3451]!, self._r[3451]!, [_0]) + return formatWithArgumentRanges(self._s[3461]!, self._r[3461]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3452]! } - public var Wallet_Weekday_Today: String { return self._s[3453]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3454]! } - public var Widget_ApplicationLocked: String { return self._s[3455]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3456]! } - public var Channel_Username_Title: String { return self._s[3457]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3462]! } + public var Wallet_Weekday_Today: String { return self._s[3463]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3464]! } + public var Widget_ApplicationLocked: String { return self._s[3465]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3466]! } + public var Channel_Username_Title: String { return self._s[3467]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3458]!, self._r[3458]!, [_0]) + return formatWithArgumentRanges(self._s[3468]!, self._r[3468]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3460]! } - public var AppleWatch_Title: String { return self._s[3461]! } - public var Activity_RecordingVideoMessage: String { return self._s[3462]! } + public var AttachmentMenu_File: String { return self._s[3470]! } + public var AppleWatch_Title: String { return self._s[3471]! } + public var Activity_RecordingVideoMessage: String { return self._s[3472]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3463]!, self._r[3463]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3473]!, self._r[3473]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3464]! } - public var Weekday_Saturday: String { return self._s[3465]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3466]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3467]! } - public var Common_Next: String { return self._s[3469]! } - public var Channel_Stickers_YourStickers: String { return self._s[3471]! } - public var Message_Theme: String { return self._s[3472]! } - public var Call_AudioRouteHeadphones: String { return self._s[3473]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3475]! } - public var Watch_Contacts_NoResults: String { return self._s[3477]! } - public var PhotoEditor_TintTool: String { return self._s[3480]! } - public var LoginPassword_ResetAccount: String { return self._s[3482]! } - public var Settings_SavedMessages: String { return self._s[3483]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3484]! } - public var Bot_GenericSupportStatus: String { return self._s[3485]! } - public var StickerPack_Add: String { return self._s[3486]! } - public var Checkout_TotalAmount: String { return self._s[3487]! } - public var Your_cards_number_is_invalid: String { return self._s[3488]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3489]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3490]! } + public var Theme_Colors_Messages: String { return self._s[3474]! } + public var Weekday_Saturday: String { return self._s[3475]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3476]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3477]! } + public var Common_Next: String { return self._s[3479]! } + public var Channel_Stickers_YourStickers: String { return self._s[3481]! } + public var Message_Theme: String { return self._s[3482]! } + public var Call_AudioRouteHeadphones: String { return self._s[3483]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3485]! } + public var Watch_Contacts_NoResults: String { return self._s[3487]! } + public var PhotoEditor_TintTool: String { return self._s[3490]! } + public var LoginPassword_ResetAccount: String { return self._s[3492]! } + public var Settings_SavedMessages: String { return self._s[3493]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3494]! } + public var Bot_GenericSupportStatus: String { return self._s[3495]! } + public var StickerPack_Add: String { return self._s[3496]! } + public var Checkout_TotalAmount: String { return self._s[3497]! } + public var Your_cards_number_is_invalid: String { return self._s[3498]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3499]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3500]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3491]!, self._r[3491]!, [_0]) + return formatWithArgumentRanges(self._s[3501]!, self._r[3501]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3492]!, self._r[3492]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3502]!, self._r[3502]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3493]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3503]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3495]!, self._r[3495]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3505]!, self._r[3505]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3496]!, self._r[3496]!, [_0]) + return formatWithArgumentRanges(self._s[3506]!, self._r[3506]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3497]! } - public var StickerPack_Share: String { return self._s[3498]! } - public var Passport_DeleteAddress: String { return self._s[3499]! } - public var Settings_Passport: String { return self._s[3500]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3501]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3502]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3503]! } - public var Contacts_PermissionsText: String { return self._s[3504]! } - public var Group_Setup_HistoryVisible: String { return self._s[3505]! } - public var Wallet_Month_ShortDecember: String { return self._s[3507]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3508]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3509]! } - public var SocksProxySetup_Title: String { return self._s[3510]! } - public var Notification_Mute1h: String { return self._s[3511]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3507]! } + public var StickerPack_Share: String { return self._s[3508]! } + public var Passport_DeleteAddress: String { return self._s[3509]! } + public var Settings_Passport: String { return self._s[3510]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3511]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3512]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3513]! } + public var Contacts_PermissionsText: String { return self._s[3514]! } + public var Group_Setup_HistoryVisible: String { return self._s[3515]! } + public var Wallet_Month_ShortDecember: String { return self._s[3517]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3518]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3519]! } + public var SocksProxySetup_Title: String { return self._s[3520]! } + public var Notification_Mute1h: String { return self._s[3521]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3512]!, self._r[3512]!, [_0]) + return formatWithArgumentRanges(self._s[3522]!, self._r[3522]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3513]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3523]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_1]) + return formatWithArgumentRanges(self._s[3524]!, self._r[3524]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3515]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3518]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3520]! } - public var DialogList_NoMessagesText: String { return self._s[3521]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3522]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3523]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3525]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3526]! } - public var Common_TakePhotoOrVideo: String { return self._s[3527]! } - public var Wallet_Words_Text: String { return self._s[3528]! } - public var Call_StatusBusy: String { return self._s[3529]! } - public var Conversation_PinnedMessage: String { return self._s[3530]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3531]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3532]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3533]! } - public var Undo_ChatCleared: String { return self._s[3534]! } - public var AppleWatch_ReplyPresets: String { return self._s[3535]! } - public var Passport_DiscardMessageDescription: String { return self._s[3537]! } - public var Login_NetworkError: String { return self._s[3538]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3525]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3528]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3530]! } + public var DialogList_NoMessagesText: String { return self._s[3531]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3532]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3533]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3535]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3536]! } + public var Common_TakePhotoOrVideo: String { return self._s[3537]! } + public var Wallet_Words_Text: String { return self._s[3538]! } + public var Call_StatusBusy: String { return self._s[3539]! } + public var Conversation_PinnedMessage: String { return self._s[3540]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3541]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3542]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3543]! } + public var Undo_ChatCleared: String { return self._s[3544]! } + public var AppleWatch_ReplyPresets: String { return self._s[3545]! } + public var Passport_DiscardMessageDescription: String { return self._s[3547]! } + public var Login_NetworkError: String { return self._s[3548]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3539]!, self._r[3539]!, [_0]) + return formatWithArgumentRanges(self._s[3549]!, self._r[3549]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3540]!, self._r[3540]!, [_0]) + return formatWithArgumentRanges(self._s[3550]!, self._r[3550]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3541]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3543]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3544]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3551]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3553]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3554]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3546]!, self._r[3546]!, [_0]) + return formatWithArgumentRanges(self._s[3556]!, self._r[3556]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3547]! } - public var VoiceOver_Chat_Music: String { return self._s[3548]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3549]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3551]! } - public var ConversationMedia_Title: String { return self._s[3552]! } - public var EncryptionKey_Title: String { return self._s[3554]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3555]! } - public var Notification_Exceptions_AddException: String { return self._s[3556]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3557]! } - public var Profile_MessageLifetime1m: String { return self._s[3558]! } + public var Call_ConnectionErrorMessage: String { return self._s[3557]! } + public var VoiceOver_Chat_Music: String { return self._s[3558]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3559]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3561]! } + public var ConversationMedia_Title: String { return self._s[3562]! } + public var EncryptionKey_Title: String { return self._s[3564]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3565]! } + public var Notification_Exceptions_AddException: String { return self._s[3566]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3567]! } + public var Profile_MessageLifetime1m: String { return self._s[3568]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3559]!, self._r[3559]!, [_1]) + return formatWithArgumentRanges(self._s[3569]!, self._r[3569]!, [_1]) } - public var Month_GenMay: String { return self._s[3560]! } + public var Month_GenMay: String { return self._s[3570]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3561]!, self._r[3561]!, [_0]) + return formatWithArgumentRanges(self._s[3571]!, self._r[3571]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3562]! } - public var Wallet_Send_AddressInfo: String { return self._s[3563]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3564]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3565]! } + public var PeopleNearby_Users: String { return self._s[3572]! } + public var Wallet_Send_AddressInfo: String { return self._s[3573]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3574]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3575]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3567]!, self._r[3567]!, [_0]) + return formatWithArgumentRanges(self._s[3577]!, self._r[3577]!, [_0]) } - public var Conversation_EmptyPlaceholder: String { return self._s[3568]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3569]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3570]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3571]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3572]! } - public var Channel_JoinChannel: String { return self._s[3574]! } - public var Appearance_Animations: String { return self._s[3577]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3578]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3579]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3580]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3581]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3582]! } + public var Channel_JoinChannel: String { return self._s[3584]! } + public var Appearance_Animations: String { return self._s[3587]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3578]!, self._r[3578]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3588]!, self._r[3588]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3580]! } - public var Appearance_ShareTheme: String { return self._s[3581]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3582]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3584]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3585]! } - public var Passport_Address_Street: String { return self._s[3586]! } - public var Conversation_AddContact: String { return self._s[3587]! } - public var Login_PhonePlaceholder: String { return self._s[3588]! } - public var Channel_Members_InviteLink: String { return self._s[3590]! } - public var Bot_Stop: String { return self._s[3591]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3593]! } - public var Notification_PassportValueAddress: String { return self._s[3594]! } - public var Month_ShortJuly: String { return self._s[3595]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3596]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3597]! } - public var Passport_Identity_ReverseSide: String { return self._s[3598]! } - public var Watch_Stickers_Recents: String { return self._s[3601]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3603]! } - public var Map_SendThisLocation: String { return self._s[3604]! } + public var Stickers_GroupStickers: String { return self._s[3590]! } + public var Appearance_ShareTheme: String { return self._s[3591]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3592]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3594]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3595]! } + public var Passport_Address_Street: String { return self._s[3596]! } + public var Conversation_AddContact: String { return self._s[3597]! } + public var Login_PhonePlaceholder: String { return self._s[3598]! } + public var Channel_Members_InviteLink: String { return self._s[3600]! } + public var Bot_Stop: String { return self._s[3601]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3603]! } + public var Notification_PassportValueAddress: String { return self._s[3604]! } + public var Month_ShortJuly: String { return self._s[3605]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3606]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3607]! } + public var Passport_Identity_ReverseSide: String { return self._s[3608]! } + public var Watch_Stickers_Recents: String { return self._s[3611]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3613]! } + public var Map_SendThisLocation: String { return self._s[3614]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3605]!, self._r[3605]!, [_0]) + return formatWithArgumentRanges(self._s[3615]!, self._r[3615]!, [_0]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3606]!, self._r[3606]!, [_0]) + return formatWithArgumentRanges(self._s[3616]!, self._r[3616]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3607]! } - public var Wallet_Intro_NotNow: String { return self._s[3608]! } + public var ConvertToSupergroup_Note: String { return self._s[3617]! } + public var Wallet_Intro_NotNow: String { return self._s[3618]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3609]!, self._r[3609]!, [_0]) + return formatWithArgumentRanges(self._s[3619]!, self._r[3619]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3610]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3620]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3611]!, self._r[3611]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3621]!, self._r[3621]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3613]! } - public var Wallpaper_SearchShort: String { return self._s[3614]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3616]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3617]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3618]! } + public var Login_CallRequestState3: String { return self._s[3623]! } + public var Wallpaper_SearchShort: String { return self._s[3624]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3626]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3627]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3628]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3619]!, self._r[3619]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3620]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3622]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3625]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3630]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3632]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3635]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3626]!, self._r[3626]!, [_0]) + return formatWithArgumentRanges(self._s[3636]!, self._r[3636]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3627]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3628]! } + public var Passport_CorrectErrors: String { return self._s[3637]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3638]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_0]) + return formatWithArgumentRanges(self._s[3639]!, self._r[3639]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3630]! } - public var Channel_DiscussionGroup: String { return self._s[3631]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3632]! } + public var Map_SendMyCurrentLocation: String { return self._s[3640]! } + public var Channel_DiscussionGroup: String { return self._s[3641]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3642]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3633]!, self._r[3633]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3643]!, self._r[3643]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3634]! } - public var Permissions_NotificationsText_v0: String { return self._s[3635]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3636]! } - public var Appearance_AppIcon: String { return self._s[3637]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3638]! } - public var LoginPassword_FloodError: String { return self._s[3639]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3641]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3642]! } + public var SharedMedia_SearchNoResults: String { return self._s[3644]! } + public var Permissions_NotificationsText_v0: String { return self._s[3645]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3646]! } + public var Appearance_AppIcon: String { return self._s[3647]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3648]! } + public var LoginPassword_FloodError: String { return self._s[3649]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3651]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3652]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3643]!, self._r[3643]!, [_0]) + return formatWithArgumentRanges(self._s[3653]!, self._r[3653]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3644]! } + public var Passport_Language_bn: String { return self._s[3654]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3645]!, self._r[3645]!, [_0]) + return formatWithArgumentRanges(self._s[3655]!, self._r[3655]!, [_0]) } - public var ChatList_Context_Pin: String { return self._s[3646]! } + public var ChatList_Context_Pin: String { return self._s[3656]! } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3647]!, self._r[3647]!, [_0]) + return formatWithArgumentRanges(self._s[3657]!, self._r[3657]!, [_0]) } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3648]!, self._r[3648]!, [_0]) + return formatWithArgumentRanges(self._s[3658]!, self._r[3658]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3649]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3653]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3655]! } - public var Wallet_Month_GenDecember: String { return self._s[3656]! } - public var Contacts_PermissionsAllow: String { return self._s[3657]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3658]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3659]! } - public var WallpaperPreview_Pattern: String { return self._s[3660]! } - public var Paint_Duplicate: String { return self._s[3661]! } - public var Passport_Address_Country: String { return self._s[3662]! } - public var Notification_RenamedChannel: String { return self._s[3664]! } - public var ChatList_Context_Unmute: String { return self._s[3665]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3666]! } - public var Group_MessagePhotoUpdated: String { return self._s[3667]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3668]! } - public var Conversation_ContextMenuBan: String { return self._s[3669]! } - public var TwoStepAuth_EmailSent: String { return self._s[3670]! } - public var MessagePoll_NoVotes: String { return self._s[3671]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3672]! } - public var Passport_Language_is: String { return self._s[3674]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3676]! } - public var Tour_Text5: String { return self._s[3677]! } + public var Wallet_Navigation_Close: String { return self._s[3659]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3663]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3665]! } + public var Wallet_Month_GenDecember: String { return self._s[3666]! } + public var Contacts_PermissionsAllow: String { return self._s[3667]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3668]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3669]! } + public var WallpaperPreview_Pattern: String { return self._s[3670]! } + public var Paint_Duplicate: String { return self._s[3671]! } + public var Passport_Address_Country: String { return self._s[3672]! } + public var Notification_RenamedChannel: String { return self._s[3674]! } + public var ChatList_Context_Unmute: String { return self._s[3675]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3676]! } + public var Group_MessagePhotoUpdated: String { return self._s[3677]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3678]! } + public var Conversation_ContextMenuBan: String { return self._s[3679]! } + public var TwoStepAuth_EmailSent: String { return self._s[3680]! } + public var MessagePoll_NoVotes: String { return self._s[3681]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3682]! } + public var Passport_Language_is: String { return self._s[3684]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3686]! } + public var Tour_Text5: String { return self._s[3687]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3680]!, self._r[3680]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3690]!, self._r[3690]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3681]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3682]! } + public var Undo_SecretChatDeleted: String { return self._s[3691]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3692]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3683]!, self._r[3683]!, [_0]) + return formatWithArgumentRanges(self._s[3693]!, self._r[3693]!, [_0]) } - public var Forward_ErrorDisabledForChat: String { return self._s[3684]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3685]! } - public var Paint_Edit: String { return self._s[3687]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3689]! } - public var Undo_DeletedGroup: String { return self._s[3691]! } - public var LoginPassword_ForgotPassword: String { return self._s[3692]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3693]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3694]! } + public var Forward_ErrorDisabledForChat: String { return self._s[3694]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3695]! } + public var Paint_Edit: String { return self._s[3697]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3699]! } + public var Undo_DeletedGroup: String { return self._s[3701]! } + public var LoginPassword_ForgotPassword: String { return self._s[3702]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3703]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3704]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3695]!, self._r[3695]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3705]!, self._r[3705]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3696]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3697]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3698]! } - public var Passport_Language_uz: String { return self._s[3699]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3700]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3701]! } - public var Map_StopLiveLocation: String { return self._s[3703]! } - public var VoiceOver_MessageContextSend: String { return self._s[3705]! } - public var PasscodeSettings_Help: String { return self._s[3706]! } - public var NotificationsSound_Input: String { return self._s[3707]! } - public var Share_Title: String { return self._s[3710]! } - public var LogoutOptions_Title: String { return self._s[3711]! } - public var Wallet_Send_AddressText: String { return self._s[3712]! } - public var Login_TermsOfServiceAgree: String { return self._s[3713]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3714]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3715]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3716]! } - public var EnterPasscode_EnterTitle: String { return self._s[3717]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3706]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3707]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3708]! } + public var Passport_Language_uz: String { return self._s[3709]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3710]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3711]! } + public var Map_StopLiveLocation: String { return self._s[3713]! } + public var VoiceOver_MessageContextSend: String { return self._s[3715]! } + public var PasscodeSettings_Help: String { return self._s[3716]! } + public var NotificationsSound_Input: String { return self._s[3717]! } + public var Share_Title: String { return self._s[3720]! } + public var LogoutOptions_Title: String { return self._s[3721]! } + public var Wallet_Send_AddressText: String { return self._s[3722]! } + public var Login_TermsOfServiceAgree: String { return self._s[3723]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3724]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3725]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3726]! } + public var EnterPasscode_EnterTitle: String { return self._s[3727]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3718]!, self._r[3718]!, [_0]) + return formatWithArgumentRanges(self._s[3728]!, self._r[3728]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3719]! } - public var Conversation_AddToContacts: String { return self._s[3720]! } + public var Settings_CopyPhoneNumber: String { return self._s[3729]! } + public var Conversation_AddToContacts: String { return self._s[3730]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3721]!, self._r[3721]!, [_0]) - } - public var NotificationsSound_Keys: String { return self._s[3722]! } - public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3723]!, self._r[3723]!, [_0]) - } - public var Notification_MessageLifetime1w: String { return self._s[3724]! } - public var Message_Video: String { return self._s[3725]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3726]! } - public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3727]!, self._r[3727]!, [_1]) - } - public var Wallet_Receive_AmountInfo: String { return self._s[3730]! } - public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3731]!, self._r[3731]!, [_0]) } + public var NotificationsSound_Keys: String { return self._s[3732]! } + public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3733]!, self._r[3733]!, [_0]) + } + public var Notification_MessageLifetime1w: String { return self._s[3734]! } + public var Message_Video: String { return self._s[3735]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3736]! } + public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3737]!, self._r[3737]!, [_1]) + } + public var Wallet_Receive_AmountInfo: String { return self._s[3740]! } + public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3741]!, self._r[3741]!, [_0]) + } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3732]!, self._r[3732]!, [_0]) + return formatWithArgumentRanges(self._s[3742]!, self._r[3742]!, [_0]) } - public var Passport_Language_mk: String { return self._s[3733]! } + public var Passport_Language_mk: String { return self._s[3743]! } public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3734]!, self._r[3734]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_1, _2, _3]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3735]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3736]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3738]! } - public var PrivacyPolicy_Decline: String { return self._s[3739]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3740]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3741]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3742]! } - public var Permissions_SiriAllow_v0: String { return self._s[3744]! } - public var Wallet_Month_ShortAugust: String { return self._s[3745]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3746]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3745]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3746]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3748]! } + public var PrivacyPolicy_Decline: String { return self._s[3749]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3750]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3751]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3752]! } + public var Permissions_SiriAllow_v0: String { return self._s[3754]! } + public var Wallet_Month_ShortAugust: String { return self._s[3755]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3756]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3747]!, self._r[3747]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3757]!, self._r[3757]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3748]!, self._r[3748]!, [_0]) + return formatWithArgumentRanges(self._s[3758]!, self._r[3758]!, [_0]) } - public var Paint_Regular: String { return self._s[3749]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3750]! } - public var SocksProxySetup_ShareLink: String { return self._s[3751]! } - public var Wallet_Qr_Title: String { return self._s[3752]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3753]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3755]! } - public var Wallet_Settings_Configuration: String { return self._s[3756]! } - public var GroupInfo_InviteByLink: String { return self._s[3757]! } - public var MessageTimer_Custom: String { return self._s[3758]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3759]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[3760]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3762]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3763]! } - public var VoiceOver_Chat_Selected: String { return self._s[3764]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3765]! } - public var Channel_Username_InvalidTaken: String { return self._s[3766]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3767]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3768]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3769]! } - public var Settings_ChatBackground: String { return self._s[3770]! } - public var Channel_Subscribers_Title: String { return self._s[3771]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3772]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3773]! } - public var Watch_ConnectionDescription: String { return self._s[3774]! } - public var OldChannels_NoticeText: String { return self._s[3777]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3778]! } - public var IntentsSettings_SuggestBy: String { return self._s[3780]! } - public var Theme_ThemeChangedText: String { return self._s[3781]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3782]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3783]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3784]! } - public var EditProfile_Title: String { return self._s[3785]! } - public var NotificationsSound_Bamboo: String { return self._s[3787]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3789]! } - public var Login_SmsRequestState2: String { return self._s[3790]! } - public var Passport_Language_ar: String { return self._s[3791]! } + public var Paint_Regular: String { return self._s[3759]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3760]! } + public var SocksProxySetup_ShareLink: String { return self._s[3761]! } + public var Wallet_Qr_Title: String { return self._s[3762]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3763]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3765]! } + public var Wallet_Settings_Configuration: String { return self._s[3766]! } + public var GroupInfo_InviteByLink: String { return self._s[3767]! } + public var MessageTimer_Custom: String { return self._s[3768]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3769]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[3770]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3772]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3773]! } + public var VoiceOver_Chat_Selected: String { return self._s[3774]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3775]! } + public var Channel_Username_InvalidTaken: String { return self._s[3776]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3777]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3778]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3779]! } + public var Settings_ChatBackground: String { return self._s[3780]! } + public var Channel_Subscribers_Title: String { return self._s[3781]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3782]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3783]! } + public var Watch_ConnectionDescription: String { return self._s[3784]! } + public var OldChannels_NoticeText: String { return self._s[3787]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3788]! } + public var IntentsSettings_SuggestBy: String { return self._s[3790]! } + public var Theme_ThemeChangedText: String { return self._s[3791]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3792]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3793]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3794]! } + public var EditProfile_Title: String { return self._s[3795]! } + public var NotificationsSound_Bamboo: String { return self._s[3797]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3799]! } + public var Login_SmsRequestState2: String { return self._s[3800]! } + public var Passport_Language_ar: String { return self._s[3801]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3792]!, self._r[3792]!, [_0]) + return formatWithArgumentRanges(self._s[3802]!, self._r[3802]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3793]! } - public var Wallet_Created_Text: String { return self._s[3794]! } - public var Conversation_MessageDialogEdit: String { return self._s[3796]! } - public var Wallet_Created_Proceed: String { return self._s[3797]! } - public var Wallet_Words_Done: String { return self._s[3798]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3799]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3803]! } + public var Wallet_Created_Text: String { return self._s[3804]! } + public var Conversation_MessageDialogEdit: String { return self._s[3806]! } + public var Wallet_Created_Proceed: String { return self._s[3807]! } + public var Wallet_Words_Done: String { return self._s[3808]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3809]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3800]!, self._r[3800]!, [_1]) + return formatWithArgumentRanges(self._s[3810]!, self._r[3810]!, [_1]) } - public var Common_Close: String { return self._s[3801]! } - public var GroupInfo_PublicLink: String { return self._s[3802]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3803]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3804]! } + public var Common_Close: String { return self._s[3811]! } + public var GroupInfo_PublicLink: String { return self._s[3812]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3813]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3814]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3808]!, self._r[3808]!, [_0]) + return formatWithArgumentRanges(self._s[3818]!, self._r[3818]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3809]! } + public var UserInfo_About_Placeholder: String { return self._s[3819]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3810]!, self._r[3810]!, [_0]) + return formatWithArgumentRanges(self._s[3820]!, self._r[3820]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3811]! } - public var Channel_Info_Banned: String { return self._s[3813]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3821]! } + public var Channel_Info_Banned: String { return self._s[3823]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3814]!, self._r[3814]!, [_0]) + return formatWithArgumentRanges(self._s[3824]!, self._r[3824]!, [_0]) } - public var Appearance_Other: String { return self._s[3815]! } - public var Passport_Language_my: String { return self._s[3816]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3817]! } + public var Appearance_Other: String { return self._s[3825]! } + public var Passport_Language_my: String { return self._s[3826]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3827]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3818]!, self._r[3818]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3828]!, self._r[3828]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3819]! } - public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3820]! } - public var Preview_CopyAddress: String { return self._s[3821]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3829]! } + public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3830]! } + public var Preview_CopyAddress: String { return self._s[3831]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3822]!, self._r[3822]!, [_0]) + return formatWithArgumentRanges(self._s[3832]!, self._r[3832]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3823]! } - public var UserInfo_BotSettings: String { return self._s[3824]! } - public var LiveLocation_MenuStopAll: String { return self._s[3826]! } - public var Passport_PasswordCreate: String { return self._s[3827]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3828]! } - public var Message_PinnedLocationMessage: String { return self._s[3829]! } - public var Map_Satellite: String { return self._s[3830]! } - public var Watch_Message_Unsupported: String { return self._s[3831]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3832]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3833]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3833]! } + public var UserInfo_BotSettings: String { return self._s[3834]! } + public var LiveLocation_MenuStopAll: String { return self._s[3836]! } + public var Passport_PasswordCreate: String { return self._s[3837]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3838]! } + public var Message_PinnedLocationMessage: String { return self._s[3839]! } + public var Map_Satellite: String { return self._s[3840]! } + public var Watch_Message_Unsupported: String { return self._s[3841]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3842]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3843]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3844]!, self._r[3844]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3835]!, self._r[3835]!, [_0]) + return formatWithArgumentRanges(self._s[3845]!, self._r[3845]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3836]! } + public var Wallet_WordImport_Continue: String { return self._s[3846]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3837]!, self._r[3837]!, [_0]) + return formatWithArgumentRanges(self._s[3847]!, self._r[3847]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3838]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3839]! } - public var NotificationsSound_None: String { return self._s[3840]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3841]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3843]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3844]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3848]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3849]! } + public var NotificationsSound_None: String { return self._s[3850]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3851]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3853]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3854]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3845]!, self._r[3845]!, [_1]) + return formatWithArgumentRanges(self._s[3855]!, self._r[3855]!, [_1]) } - public var Cache_Indexing: String { return self._s[3846]! } - public var DialogList_RecentTitlePeople: String { return self._s[3848]! } - public var DialogList_EncryptionRejected: String { return self._s[3849]! } - public var GroupInfo_Administrators: String { return self._s[3850]! } - public var Passport_ScanPassportHelp: String { return self._s[3851]! } - public var Application_Name: String { return self._s[3852]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3853]! } - public var PeopleNearby_MakeVisible: String { return self._s[3855]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3856]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3857]! } + public var Cache_Indexing: String { return self._s[3856]! } + public var DialogList_RecentTitlePeople: String { return self._s[3858]! } + public var DialogList_EncryptionRejected: String { return self._s[3859]! } + public var GroupInfo_Administrators: String { return self._s[3860]! } + public var Passport_ScanPassportHelp: String { return self._s[3861]! } + public var Application_Name: String { return self._s[3862]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3863]! } + public var PeopleNearby_MakeVisible: String { return self._s[3865]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3866]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3867]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3858]!, self._r[3858]!, [_0]) + return formatWithArgumentRanges(self._s[3868]!, self._r[3868]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3859]!, self._r[3859]!, [_0]) + return formatWithArgumentRanges(self._s[3869]!, self._r[3869]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3860]!, self._r[3860]!, [_0]) + return formatWithArgumentRanges(self._s[3870]!, self._r[3870]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3861]! } - public var Privacy_ChatsTitle: String { return self._s[3862]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3863]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3864]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3865]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3866]! } - public var WebBrowser_Title: String { return self._s[3867]! } - public var Group_LinkedChannel: String { return self._s[3868]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3869]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3870]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3871]! } - public var Appearance_TextSize_UseSystem: String { return self._s[3872]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3873]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[3875]! } - public var Channel_Setup_TypePublic: String { return self._s[3877]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3871]! } + public var Privacy_ChatsTitle: String { return self._s[3872]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3873]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3874]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3875]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3876]! } + public var WebBrowser_Title: String { return self._s[3877]! } + public var Group_LinkedChannel: String { return self._s[3878]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3879]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3880]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3881]! } + public var Appearance_TextSize_UseSystem: String { return self._s[3882]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3883]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3885]! } + public var Channel_Setup_TypePublic: String { return self._s[3887]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3878]!, self._r[3878]!, [_0]) + return formatWithArgumentRanges(self._s[3888]!, self._r[3888]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3880]! } - public var MessagePoll_ViewResults: String { return self._s[3881]! } - public var Map_OpenInMaps: String { return self._s[3883]! } + public var Channel_TypeSetup_Title: String { return self._s[3890]! } + public var MessagePoll_ViewResults: String { return self._s[3891]! } + public var Map_OpenInMaps: String { return self._s[3893]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3884]!, self._r[3884]!, [_1]) + return formatWithArgumentRanges(self._s[3894]!, self._r[3894]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3886]! } + public var NotificationsSound_Tremolo: String { return self._s[3896]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3887]!, self._r[3887]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3897]!, self._r[3897]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3888]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3889]! } - public var Passport_PasswordHelp: String { return self._s[3890]! } - public var Login_CodeExpiredError: String { return self._s[3891]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3892]! } - public var Conversation_TitleUnmute: String { return self._s[3893]! } - public var Passport_Identity_ScansHelp: String { return self._s[3894]! } - public var Passport_Language_lo: String { return self._s[3895]! } - public var Camera_FlashAuto: String { return self._s[3896]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3897]! } - public var Common_Cancel: String { return self._s[3898]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3899]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3900]! } - public var Appearance_TintAllColors: String { return self._s[3901]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3898]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3899]! } + public var Passport_PasswordHelp: String { return self._s[3900]! } + public var Login_CodeExpiredError: String { return self._s[3901]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3902]! } + public var Conversation_TitleUnmute: String { return self._s[3903]! } + public var Passport_Identity_ScansHelp: String { return self._s[3904]! } + public var Passport_Language_lo: String { return self._s[3905]! } + public var Camera_FlashAuto: String { return self._s[3906]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3907]! } + public var Common_Cancel: String { return self._s[3908]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3909]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3910]! } + public var Appearance_TintAllColors: String { return self._s[3911]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3902]!, self._r[3902]!, [_1]) + return formatWithArgumentRanges(self._s[3912]!, self._r[3912]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3903]! } - public var ChatSettings_Title: String { return self._s[3905]! } - public var Passport_PasswordReset: String { return self._s[3906]! } - public var SocksProxySetup_TypeNone: String { return self._s[3907]! } - public var EditTheme_Title: String { return self._s[3910]! } - public var PhoneNumberHelp_Help: String { return self._s[3911]! } - public var Checkout_EnterPassword: String { return self._s[3912]! } - public var Activity_UploadingDocument: String { return self._s[3914]! } - public var Share_AuthTitle: String { return self._s[3915]! } - public var State_Connecting: String { return self._s[3916]! } - public var Profile_MessageLifetime1w: String { return self._s[3917]! } - public var Conversation_ContextMenuReport: String { return self._s[3918]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3919]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3920]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3913]! } + public var ChatSettings_Title: String { return self._s[3915]! } + public var Passport_PasswordReset: String { return self._s[3916]! } + public var SocksProxySetup_TypeNone: String { return self._s[3917]! } + public var EditTheme_Title: String { return self._s[3920]! } + public var PhoneNumberHelp_Help: String { return self._s[3921]! } + public var Checkout_EnterPassword: String { return self._s[3922]! } + public var Activity_UploadingDocument: String { return self._s[3924]! } + public var Share_AuthTitle: String { return self._s[3925]! } + public var State_Connecting: String { return self._s[3926]! } + public var Profile_MessageLifetime1w: String { return self._s[3927]! } + public var Conversation_ContextMenuReport: String { return self._s[3928]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3929]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3930]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3921]!, self._r[3921]!, [_0]) + return formatWithArgumentRanges(self._s[3931]!, self._r[3931]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3922]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[3923]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3925]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3926]! } - public var PhotoEditor_Set: String { return self._s[3927]! } - public var EmptyGroupInfo_Title: String { return self._s[3928]! } - public var Login_PadPhoneHelp: String { return self._s[3929]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3931]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3933]! } - public var NotificationsSound_Complete: String { return self._s[3934]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3935]! } - public var Group_Info_AdminLog: String { return self._s[3936]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3937]! } + public var AuthSessions_Terminate: String { return self._s[3932]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[3933]! } + public var PeerInfo_PaneAudio: String { return self._s[3934]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3936]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3937]! } + public var PhotoEditor_Set: String { return self._s[3938]! } + public var EmptyGroupInfo_Title: String { return self._s[3939]! } + public var Login_PadPhoneHelp: String { return self._s[3940]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3942]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3944]! } + public var NotificationsSound_Complete: String { return self._s[3945]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3946]! } + public var Group_Info_AdminLog: String { return self._s[3947]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3948]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3938]!, self._r[3938]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3949]!, self._r[3949]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3939]! } - public var Group_Location_CreateInThisPlace: String { return self._s[3941]! } - public var Conversation_Admin: String { return self._s[3942]! } - public var Conversation_GifTooltip: String { return self._s[3943]! } - public var Passport_NotLoggedInMessage: String { return self._s[3944]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3950]! } + public var Group_Location_CreateInThisPlace: String { return self._s[3952]! } + public var Conversation_Admin: String { return self._s[3953]! } + public var Conversation_GifTooltip: String { return self._s[3954]! } + public var Passport_NotLoggedInMessage: String { return self._s[3955]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3946]!, self._r[3946]!, [_0]) + return formatWithArgumentRanges(self._s[3957]!, self._r[3957]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3947]! } - public var SharedMedia_EmptyTitle: String { return self._s[3949]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3951]! } - public var Username_Help: String { return self._s[3952]! } - public var DialogList_LanguageTooltip: String { return self._s[3954]! } - public var Map_LoadError: String { return self._s[3955]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3956]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3957]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3958]! } - public var Notification_Exceptions_NewException: String { return self._s[3959]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3960]! } - public var WatchRemote_AlertText: String { return self._s[3961]! } + public var Profile_MessageLifetimeForever: String { return self._s[3958]! } + public var SharedMedia_EmptyTitle: String { return self._s[3960]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3962]! } + public var Username_Help: String { return self._s[3963]! } + public var DialogList_LanguageTooltip: String { return self._s[3965]! } + public var Map_LoadError: String { return self._s[3966]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3967]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3968]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3969]! } + public var Notification_Exceptions_NewException: String { return self._s[3970]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3971]! } + public var WatchRemote_AlertText: String { return self._s[3972]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3962]!, self._r[3962]!, [_1, _2, _3]) - } - public var ChatSettings_ConnectionType_Title: String { return self._s[3966]! } - public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3967]!, self._r[3967]!, [_1, _2]) - } - public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3968]!, self._r[3968]!, [_0]) - } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3969]! } - public var WebBrowser_DefaultBrowser: String { return self._s[3970]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3971]! } - public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3972]!, self._r[3972]!, [_0]) - } - public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3973]!, self._r[3973]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3974]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3975]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[3977]! } - public var Wallet_Created_ExportErrorText: String { return self._s[3978]! } - public var ChatList_UndoArchiveText1: String { return self._s[3979]! } - public var AccessDenied_VideoMicrophone: String { return self._s[3980]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3981]! } - public var Cache_ClearNone: String { return self._s[3982]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[3983]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[3984]! } - public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3985]!, self._r[3985]!, [_0]) + public var ChatSettings_ConnectionType_Title: String { return self._s[3977]! } + public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3978]!, self._r[3978]!, [_1, _2]) } - public var Passport_Identity_Country: String { return self._s[3986]! } + public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3979]!, self._r[3979]!, [_0]) + } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3980]! } + public var WebBrowser_DefaultBrowser: String { return self._s[3981]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3982]! } + public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3983]!, self._r[3983]!, [_0]) + } + public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3984]!, self._r[3984]!, [_1, _2, _3]) + } + public var Group_AdminLog_EmptyText: String { return self._s[3985]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3986]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[3988]! } + public var Wallet_Created_ExportErrorText: String { return self._s[3989]! } + public var ChatList_UndoArchiveText1: String { return self._s[3990]! } + public var AccessDenied_VideoMicrophone: String { return self._s[3991]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3992]! } + public var Cache_ClearNone: String { return self._s[3993]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[3994]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[3995]! } + public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3996]!, self._r[3996]!, [_0]) + } + public var Passport_Identity_Country: String { return self._s[3997]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3987]!, self._r[3987]!, [_0]) + return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_0]) } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3988]!, self._r[3988]!, [_0]) + return formatWithArgumentRanges(self._s[3999]!, self._r[3999]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[3989]! } - public var AccessDenied_Settings: String { return self._s[3990]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3991]! } - public var Month_ShortMay: String { return self._s[3992]! } - public var Compose_NewGroup: String { return self._s[3994]! } - public var Group_Setup_TypePrivate: String { return self._s[3996]! } - public var Login_PadPhoneHelpTitle: String { return self._s[3998]! } - public var Appearance_ThemeDayClassic: String { return self._s[3999]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4000]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[4001]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4002]! } - public var Conversation_typing: String { return self._s[4004]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[4005]! } - public var Paint_Masks: String { return self._s[4006]! } - public var Contacts_DeselectAll: String { return self._s[4007]! } + public var Exceptions_AddToExceptions: String { return self._s[4000]! } + public var AccessDenied_Settings: String { return self._s[4001]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4002]! } + public var Month_ShortMay: String { return self._s[4003]! } + public var Compose_NewGroup: String { return self._s[4005]! } + public var Group_Setup_TypePrivate: String { return self._s[4007]! } + public var Login_PadPhoneHelpTitle: String { return self._s[4009]! } + public var Appearance_ThemeDayClassic: String { return self._s[4010]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4011]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[4012]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4013]! } + public var Conversation_typing: String { return self._s[4015]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[4016]! } + public var Paint_Masks: String { return self._s[4017]! } + public var Contacts_DeselectAll: String { return self._s[4018]! } public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4008]!, self._r[4008]!, [_0]) + return formatWithArgumentRanges(self._s[4019]!, self._r[4019]!, [_0]) } - public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4009]! } - public var Username_InvalidTaken: String { return self._s[4010]! } - public var Call_StatusNoAnswer: String { return self._s[4011]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[4012]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4013]! } - public var Passport_Identity_Selfie: String { return self._s[4014]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4015]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4016]! } - public var Conversation_ClearSecretHistory: String { return self._s[4017]! } - public var PeopleNearby_Description: String { return self._s[4019]! } - public var NetworkUsageSettings_Title: String { return self._s[4020]! } - public var Your_cards_security_code_is_invalid: String { return self._s[4022]! } + public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4020]! } + public var Username_InvalidTaken: String { return self._s[4021]! } + public var Call_StatusNoAnswer: String { return self._s[4022]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[4023]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4024]! } + public var Passport_Identity_Selfie: String { return self._s[4025]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4026]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4027]! } + public var Conversation_ClearSecretHistory: String { return self._s[4028]! } + public var PeopleNearby_Description: String { return self._s[4030]! } + public var NetworkUsageSettings_Title: String { return self._s[4031]! } + public var Your_cards_security_code_is_invalid: String { return self._s[4033]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4024]!, self._r[4024]!, [_0]) + return formatWithArgumentRanges(self._s[4035]!, self._r[4035]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4025]!, self._r[4025]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4036]!, self._r[4036]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[4027]! } - public var VoiceOver_Navigation_Search: String { return self._s[4028]! } - public var Map_LiveLocationTitle: String { return self._s[4029]! } - public var Login_InfoAvatarAdd: String { return self._s[4030]! } - public var Passport_Identity_FilesView: String { return self._s[4031]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[4032]! } - public var Privacy_Calls_NeverAllow: String { return self._s[4033]! } - public var VoiceOver_Chat_File: String { return self._s[4034]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4035]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[4038]! } + public var VoiceOver_Navigation_Search: String { return self._s[4039]! } + public var Map_LiveLocationTitle: String { return self._s[4040]! } + public var Login_InfoAvatarAdd: String { return self._s[4041]! } + public var Passport_Identity_FilesView: String { return self._s[4042]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[4043]! } + public var Privacy_Calls_NeverAllow: String { return self._s[4044]! } + public var VoiceOver_Chat_File: String { return self._s[4045]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4046]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4036]!, self._r[4036]!, [_0]) + return formatWithArgumentRanges(self._s[4047]!, self._r[4047]!, [_0]) } - public var ContactInfo_PhoneNumberHidden: String { return self._s[4037]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[4038]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4039]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[4048]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[4049]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4050]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4040]!, self._r[4040]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4041]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[4042]! } - public var Tour_Title2: String { return self._s[4043]! } - public var Wallet_Sent_ViewWallet: String { return self._s[4044]! } - public var Conversation_FileOpenIn: String { return self._s[4045]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4046]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4047]! } - public var Wallpaper_Set: String { return self._s[4048]! } - public var Passport_Identity_Translations: String { return self._s[4050]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4052]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[4053]! } + public var Tour_Title2: String { return self._s[4054]! } + public var Wallet_Sent_ViewWallet: String { return self._s[4055]! } + public var Conversation_FileOpenIn: String { return self._s[4056]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4057]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4058]! } + public var Wallpaper_Set: String { return self._s[4059]! } + public var Passport_Identity_Translations: String { return self._s[4061]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_0]) + return formatWithArgumentRanges(self._s[4062]!, self._r[4062]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4052]! } + public var Channel_LeaveChannel: String { return self._s[4063]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4053]!, self._r[4053]!, [_1]) + return formatWithArgumentRanges(self._s[4064]!, self._r[4064]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4055]! } - public var PhotoEditor_HighlightsTint: String { return self._s[4056]! } - public var MessagePoll_LabelPoll: String { return self._s[4057]! } - public var Passport_Email_Delete: String { return self._s[4058]! } - public var Conversation_Mute: String { return self._s[4060]! } - public var Channel_AddBotAsAdmin: String { return self._s[4061]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[4063]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4064]! } - public var ChatSettings_IntentsSettings: String { return self._s[4066]! } - public var Channel_Management_LabelOwner: String { return self._s[4067]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4066]! } + public var PhotoEditor_HighlightsTint: String { return self._s[4067]! } + public var MessagePoll_LabelPoll: String { return self._s[4068]! } + public var Passport_Email_Delete: String { return self._s[4069]! } + public var Conversation_Mute: String { return self._s[4071]! } + public var Channel_AddBotAsAdmin: String { return self._s[4072]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[4074]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4075]! } + public var ChatSettings_IntentsSettings: String { return self._s[4077]! } + public var Channel_Management_LabelOwner: String { return self._s[4078]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4068]!, self._r[4068]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[4069]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[4070]! } - public var Common_No: String { return self._s[4071]! } - public var Weekday_Sunday: String { return self._s[4072]! } - public var Notification_Reply: String { return self._s[4073]! } - public var Conversation_ViewMessage: String { return self._s[4074]! } + public var Calls_CallTabDescription: String { return self._s[4080]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[4081]! } + public var Common_No: String { return self._s[4082]! } + public var Weekday_Sunday: String { return self._s[4083]! } + public var Notification_Reply: String { return self._s[4084]! } + public var Conversation_ViewMessage: String { return self._s[4085]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4075]!, self._r[4075]!, [_0]) + return formatWithArgumentRanges(self._s[4086]!, self._r[4086]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4076]!, self._r[4076]!, [_0]) + return formatWithArgumentRanges(self._s[4087]!, self._r[4087]!, [_0]) } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4077]!, self._r[4077]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4088]!, self._r[4088]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4078]! } - public var Wallet_Send_Title: String { return self._s[4079]! } - public var Message_PinnedDocumentMessage: String { return self._s[4080]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[4081]! } - public var DialogList_TabTitle: String { return self._s[4083]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4084]! } - public var Passport_FieldEmail: String { return self._s[4085]! } - public var Conversation_UnpinMessageAlert: String { return self._s[4086]! } - public var Passport_Address_TypeBankStatement: String { return self._s[4087]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[4088]! } - public var Passport_Identity_ExpiryDate: String { return self._s[4089]! } - public var Privacy_Calls_P2P: String { return self._s[4090]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4089]! } + public var Wallet_Send_Title: String { return self._s[4090]! } + public var Message_PinnedDocumentMessage: String { return self._s[4091]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[4092]! } + public var DialogList_TabTitle: String { return self._s[4094]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4095]! } + public var Passport_FieldEmail: String { return self._s[4096]! } + public var Conversation_UnpinMessageAlert: String { return self._s[4097]! } + public var Passport_Address_TypeBankStatement: String { return self._s[4098]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[4099]! } + public var Passport_Identity_ExpiryDate: String { return self._s[4100]! } + public var Privacy_Calls_P2P: String { return self._s[4101]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4092]!, self._r[4092]!, [_0]) + return formatWithArgumentRanges(self._s[4103]!, self._r[4103]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4093]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[4104]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4094]!, self._r[4094]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4105]!, self._r[4105]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[4095]! } - public var EnterPasscode_ChangeTitle: String { return self._s[4096]! } - public var TwoFactorSetup_Email_Title: String { return self._s[4097]! } - public var Passport_InfoText: String { return self._s[4098]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4099]! } + public var Stickers_ClearRecent: String { return self._s[4106]! } + public var EnterPasscode_ChangeTitle: String { return self._s[4107]! } + public var TwoFactorSetup_Email_Title: String { return self._s[4108]! } + public var Passport_InfoText: String { return self._s[4109]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4110]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4100]!, self._r[4100]!, [_0]) + return formatWithArgumentRanges(self._s[4111]!, self._r[4111]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4101]!, self._r[4101]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4112]!, self._r[4112]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4102]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[4103]! } - public var VoiceOver_Navigation_Compose: String { return self._s[4104]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[4105]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4107]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4108]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4113]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4114]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4115]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4116]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4118]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4119]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4109]!, self._r[4109]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4120]!, self._r[4120]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4112]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4113]! } - public var Map_HomeAndWorkTitle: String { return self._s[4114]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4123]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4124]! } + public var Map_HomeAndWorkTitle: String { return self._s[4125]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4116]!, self._r[4116]!, [_0]) + return formatWithArgumentRanges(self._s[4127]!, self._r[4127]!, [_0]) } - public var DialogList_Unread: String { return self._s[4117]! } + public var DialogList_Unread: String { return self._s[4128]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4118]!, self._r[4118]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4129]!, self._r[4129]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4119]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4120]! } + public var User_DeletedAccount: String { return self._s[4130]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4131]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4121]!, self._r[4121]!, [_0]) + return formatWithArgumentRanges(self._s[4132]!, self._r[4132]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4122]! } - public var SharedMedia_CategoryMedia: String { return self._s[4123]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4124]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4125]! } - public var Watch_ChatList_Compose: String { return self._s[4126]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4127]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4128]! } - public var Watch_Microphone_Access: String { return self._s[4129]! } - public var Group_Setup_HistoryHeader: String { return self._s[4130]! } - public var Map_SetThisLocation: String { return self._s[4131]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4132]! } - public var Activity_UploadingPhoto: String { return self._s[4133]! } - public var Conversation_Edit: String { return self._s[4135]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4136]! } - public var Login_TermsOfServiceDecline: String { return self._s[4137]! } - public var Message_PinnedContactMessage: String { return self._s[4138]! } + public var UserInfo_NotificationsDefault: String { return self._s[4133]! } + public var SharedMedia_CategoryMedia: String { return self._s[4134]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4135]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4136]! } + public var Watch_ChatList_Compose: String { return self._s[4137]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4138]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4139]! } + public var Watch_Microphone_Access: String { return self._s[4140]! } + public var Group_Setup_HistoryHeader: String { return self._s[4141]! } + public var Map_SetThisLocation: String { return self._s[4142]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4143]! } + public var Activity_UploadingPhoto: String { return self._s[4144]! } + public var Conversation_Edit: String { return self._s[4146]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4147]! } + public var Login_TermsOfServiceDecline: String { return self._s[4148]! } + public var Message_PinnedContactMessage: String { return self._s[4149]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4139]!, self._r[4139]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4150]!, self._r[4150]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4140]!, self._r[4140]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4151]!, self._r[4151]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4141]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4143]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4144]! } + public var Appearance_LargeEmoji: String { return self._s[4152]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4154]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4155]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4145]!, self._r[4145]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4156]!, self._r[4156]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4146]! } - public var Message_PinnedPhotoMessage: String { return self._s[4147]! } - public var Passport_FieldPhone: String { return self._s[4148]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4149]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4150]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4152]! } - public var Conversation_Call: String { return self._s[4153]! } - public var Common_TakePhoto: String { return self._s[4155]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4156]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4157]! } - public var Channel_NotificationLoading: String { return self._s[4158]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4157]! } + public var Message_PinnedPhotoMessage: String { return self._s[4158]! } + public var Passport_FieldPhone: String { return self._s[4159]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4160]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4161]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4163]! } + public var Conversation_Call: String { return self._s[4164]! } + public var Common_TakePhoto: String { return self._s[4166]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4167]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4168]! } + public var Channel_NotificationLoading: String { return self._s[4169]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4159]!, self._r[4159]!, [_0]) + return formatWithArgumentRanges(self._s[4170]!, self._r[4170]!, [_0]) } public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4160]!, self._r[4160]!, [_0]) + return formatWithArgumentRanges(self._s[4171]!, self._r[4171]!, [_0]) } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4161]!, self._r[4161]!, [_1]) + return formatWithArgumentRanges(self._s[4172]!, self._r[4172]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[4162]! } + public var Permissions_SiriTitle_v0: String { return self._s[4173]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4163]!, self._r[4163]!, [_0]) + return formatWithArgumentRanges(self._s[4174]!, self._r[4174]!, [_0]) } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4164]!, self._r[4164]!, [_0]) + return formatWithArgumentRanges(self._s[4175]!, self._r[4175]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4165]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4166]! } - public var ClearCache_FreeSpace: String { return self._s[4167]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[4168]! } - public var Common_edit: String { return self._s[4169]! } - public var PrivacySettings_AuthSessions: String { return self._s[4170]! } - public var Month_ShortJune: String { return self._s[4171]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4172]! } - public var Call_ReportSend: String { return self._s[4173]! } - public var Watch_LastSeen_JustNow: String { return self._s[4174]! } - public var Notifications_MessageNotifications: String { return self._s[4175]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4176]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4178]! } - public var Group_Status: String { return self._s[4179]! } + public var Channel_MessagePhotoRemoved: String { return self._s[4176]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4177]! } + public var ClearCache_FreeSpace: String { return self._s[4178]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[4179]! } + public var Common_edit: String { return self._s[4180]! } + public var PrivacySettings_AuthSessions: String { return self._s[4181]! } + public var Month_ShortJune: String { return self._s[4182]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4183]! } + public var Call_ReportSend: String { return self._s[4184]! } + public var Watch_LastSeen_JustNow: String { return self._s[4185]! } + public var Notifications_MessageNotifications: String { return self._s[4186]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4187]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4189]! } + public var Group_Status: String { return self._s[4190]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4180]!, self._r[4180]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4191]!, self._r[4191]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4181]! } - public var ShareMenu_ShareTo: String { return self._s[4182]! } - public var Conversation_Moderate_Ban: String { return self._s[4183]! } + public var TextFormat_AddLinkTitle: String { return self._s[4192]! } + public var ShareMenu_ShareTo: String { return self._s[4193]! } + public var Conversation_Moderate_Ban: String { return self._s[4194]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4184]!, self._r[4184]!, [_0]) + return formatWithArgumentRanges(self._s[4195]!, self._r[4195]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4185]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4186]! } + public var SharedMedia_ViewInChat: String { return self._s[4196]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4197]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4187]!, self._r[4187]!, [_1]) + return formatWithArgumentRanges(self._s[4198]!, self._r[4198]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4188]!, self._r[4188]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4199]!, self._r[4199]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4190]!, self._r[4190]!, [_0]) + return formatWithArgumentRanges(self._s[4201]!, self._r[4201]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4191]! } - public var Appearance_ReduceMotion: String { return self._s[4192]! } + public var Map_OpenInHereMaps: String { return self._s[4202]! } + public var Appearance_ReduceMotion: String { return self._s[4203]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4193]!, self._r[4193]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4204]!, self._r[4204]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4194]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4195]! } - public var PhotoEditor_Skip: String { return self._s[4196]! } - public func MessageTimer_Days(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4205]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4206]! } + public var PhotoEditor_Skip: String { return self._s[4207]! } + public func OldChannels_GroupFormat(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func MessagePoll_VotedCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func Map_ETAMinutes(_ value: Int32) -> String { + public func QuickSend_Photos(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) @@ -4749,7 +4760,7 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[3 * 6 + Int(form.rawValue)]!, stringValue) } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + public func Call_ShortSeconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) @@ -4759,283 +4770,284 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Months(_ value: Int32) -> String { + public func MuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, _1, _2) } - public func SharedMedia_Video(_ value: Int32) -> String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedContacts(_ value: Int32) -> String { + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Map_ETAHours(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveYear(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) - } - public func QuickSend_Photos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) - } - public func UserCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessagePoll_VotedCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_StickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Weeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusOnline(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_Exceptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessagePoll_QuizCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessageTimer_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func GroupInfo_ParticipantCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Invitation_Members(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) - } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) - } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) - } - public func InviteText_ContactsCountText(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } public func MessageTimer_ShortHours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_File(_ value: Int32) -> String { + public func MuteExpires_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusMembers(_ value: Int32) -> String { + public func StickerPack_AddStickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_InviteContacts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeletedChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_Leave(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, _1, _2) } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public func MessageTimer_Weeks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { + public func ForwardedVideos(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) + } + public func InviteText_ContactsCountText(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func OldChannels_InactiveMonth(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } public func ForwardedPolls(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + public func StickerPack_StickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[27 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedGifs(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_ShortMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_InactiveWeek(_ value: Int32) -> String { + public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[33 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Contacts_InviteContacts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[34 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Generic(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_Exceptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_File(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Passport_Scans(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Invitation_Members(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Map_ETAMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusSubscribers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Theme_UsersCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func UserCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) @@ -5045,305 +5057,304 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { + public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocation_MenuChatsCount(_ value: Int32) -> String { + public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, _1, _2) + public func Media_SharePhoto(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[68 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Link(_ value: Int32) -> String { + public func Contacts_ImportersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, _1, _2) + public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + public func MessageTimer_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, _1, _2) + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, stringValue) } - public func PollResults_ShowMore(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Years(_ value: Int32) -> String { + public func MuteFor_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { + public func MuteExpires_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreExtended(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[77 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func ForwardedStickers(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusSubscribers(_ value: Int32) -> String { + public func OldChannels_Leave(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public func ForwardedPhotos(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + public func ForwardedVideoMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedAudios(_ value: Int32) -> String { + public func StickerPack_AddMaskCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) } - public func Passport_Scans(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Days(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareVideo(_ value: Int32) -> String { + public func ChatList_DeletedChats(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_SharePhoto(_ value: Int32) -> String { + public func PollResults_ShowMore(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_SelectedChats(_ value: Int32) -> String { + public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteFor_Hours(_ value: Int32) -> String { + public func ForwardedLocations(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, _1, _2) } - public func ForwardedPhotos(_ value: Int32) -> String { + public func ForwardedFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[95 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func OldChannels_InactiveYear(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_InactiveMonth(_ value: Int32) -> String { + public func MessageTimer_ShortDays(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, _1, _2) } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + public func OldChannels_InactiveWeek(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedMessages(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedGifs(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_GroupFormat(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, _1, _2) } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + public func SharedMedia_Photo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedLocations(_ value: Int32) -> String { + public func SharedMedia_Link(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Minutes(_ value: Int32) -> String { + public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { + public func Media_ShareItem(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, _1, _2) } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[110 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessagePoll_QuizCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideos(_ value: Int32) -> String { + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[114 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, _1, _2) } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, _1, _2) } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { + public func ForwardedAudios(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[120 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareItem(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func ChatList_SelectedChats(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Hours(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[123 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortMinutes(_ value: Int32) -> String { + public func ForwardedStickers(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[124 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func Notification_GameScoreSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[125 * 6 + Int(form.rawValue)]!, stringValue) } - public func Theme_UsersCount(_ value: Int32) -> String { + public func Media_ShareVideo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonLeave.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonLeave.imageset/Contents.json new file mode 100644 index 0000000000..46ec950a2e --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonLeave.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "ic_pf_leave.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonLeave.imageset/ic_pf_leave.pdf b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonLeave.imageset/ic_pf_leave.pdf new file mode 100644 index 0000000000..aa85ce0619 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonLeave.imageset/ic_pf_leave.pdf differ diff --git a/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonSearch.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonSearch.imageset/Contents.json new file mode 100644 index 0000000000..9b09c7c13b --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonSearch.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "ic_search.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonSearch.imageset/ic_search.pdf b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonSearch.imageset/ic_search.pdf new file mode 100644 index 0000000000..ece31c0048 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Peer Info/ButtonSearch.imageset/ic_search.pdf differ diff --git a/submodules/TelegramUI/TelegramUI/ChatController.swift b/submodules/TelegramUI/TelegramUI/ChatController.swift index 5b48c84791..b9cb8fcc48 100644 --- a/submodules/TelegramUI/TelegramUI/ChatController.swift +++ b/submodules/TelegramUI/TelegramUI/ChatController.swift @@ -1911,7 +1911,9 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self.chatTitleView?.pressed = { [weak self] in if let strongSelf = self { if strongSelf.chatLocation == .peer(strongSelf.context.account.peerId) { - strongSelf.effectiveNavigationController?.pushViewController(PeerMediaCollectionController(context: strongSelf.context, peerId: strongSelf.context.account.peerId)) + if let peer = strongSelf.presentationInterfaceState.renderedPeer?.chatMainPeer, let infoController = strongSelf.context.sharedContext.makePeerInfoController(context: strongSelf.context, peer: peer, mode: .generic, avatarInitiallyExpanded: false, fromChat: true) { + strongSelf.effectiveNavigationController?.pushViewController(infoController) + } } else { strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { return $0.updatedTitlePanelContext { @@ -1936,6 +1938,9 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G } } } + self.chatTitleView?.longPressed = { [weak self] in + self?.interfaceInteraction?.beginMessageSearch(.everything, "") + } let chatInfoButtonItem: UIBarButtonItem switch chatLocation { @@ -1954,6 +1959,10 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G .action(ContextMenuActionItem(text: strongSelf.presentationData.strings.Conversation_LinkDialogOpen, icon: { _ in nil }, action: { _, f in f(.dismissWithoutContent) self?.navigationButtonAction(.openChatInfo(expandAvatar: true)) + })), + .action(ContextMenuActionItem(text: strongSelf.presentationData.strings.Conversation_Search, icon: { _ in nil }, action: { _, f in + f(.dismissWithoutContent) + self?.interfaceInteraction?.beginMessageSearch(.everything, "") })) ] let contextController = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .controller(ContextControllerContentSourceImpl(controller: galleryController, sourceNode: node)), items: .single(items), reactionItems: [], gesture: gesture) @@ -5391,7 +5400,10 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G |> deliverOnMainQueue).start(next: { [weak self] peerView in if let strongSelf = self, let peer = peerView.peers[peerView.peerId], peer.restrictionText(platform: "ios", contentSettings: strongSelf.context.currentContentSettings.with { $0 }) == nil && !strongSelf.presentationInterfaceState.isNotAccessible { if peer.id == strongSelf.context.account.peerId { - strongSelf.effectiveNavigationController?.pushViewController(PeerMediaCollectionController(context: strongSelf.context, peerId: strongSelf.context.account.peerId)) + if let peer = strongSelf.presentationInterfaceState.renderedPeer?.chatMainPeer, let infoController = strongSelf.context.sharedContext.makePeerInfoController(context: strongSelf.context, peer: peer, mode: .generic, avatarInitiallyExpanded: false, fromChat: true) { + strongSelf.effectiveNavigationController?.pushViewController(infoController) + } + //strongSelf.effectiveNavigationController?.pushViewController(PeerMediaCollectionController(context: strongSelf.context, peerId: strongSelf.context.account.peerId)) } else { var expandAvatar = expandAvatar if peer.smallProfileImage == nil { @@ -7154,7 +7166,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G } self.navigationActionDisposable.set((peerSignal |> take(1) |> deliverOnMainQueue).start(next: { [weak self] peer in if let strongSelf = self, let peer = peer { - if let infoController = strongSelf.context.sharedContext.makePeerInfoController(context: strongSelf.context, peer: peer, mode: .generic, avatarInitiallyExpanded: expandAvatar, fromChat: true) { + if let infoController = strongSelf.context.sharedContext.makePeerInfoController(context: strongSelf.context, peer: peer, mode: .generic, avatarInitiallyExpanded: expandAvatar, fromChat: false) { strongSelf.effectiveNavigationController?.pushViewController(infoController) } } diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift index 34f88f5cd1..f66ed95d0d 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistoryGridNode.swift @@ -305,7 +305,7 @@ public final class ChatHistoryGridNode: GridNode, ChatHistoryNode { } let associatedData = ChatMessageItemAssociatedData(automaticDownloadPeerType: .channel, automaticDownloadNetworkType: .cellular, isRecentActions: false) - let processedView = ChatHistoryView(originalView: view, filteredEntries: chatHistoryEntriesForView(location: .peer(peerId), view: view, includeUnreadEntry: false, includeEmptyEntry: false, includeChatInfoEntry: false, includeSearchEntry: false, reverse: false, groupMessages: false, selectedMessages: nil, presentationData: chatPresentationData, historyAppearsCleared: false, associatedData: associatedData, updatingMedia: [:]), associatedData: associatedData, id: id) + let processedView = ChatHistoryView(originalView: view, filteredEntries: chatHistoryEntriesForView(location: .peer(peerId), view: view, includeUnreadEntry: false, includeEmptyEntry: false, includeChatInfoEntry: false, includeSearchEntry: false, reverse: false, groupMessages: false, selectedMessages: nil, presentationData: chatPresentationData, historyAppearsCleared: false, associatedData: associatedData, updatingMedia: [:]), associatedData: associatedData, lastHeaderId: 0, id: id) let previous = previousView.swap(processedView) let rawTransition = preparedChatHistoryViewTransition(from: previous, to: processedView, reason: reason, reverse: false, chatLocation: .peer(peerId), controllerInteraction: controllerInteraction, scrollPosition: scrollPosition, initialData: nil, keyboardButtonsMessage: nil, cachedData: nil, cachedDataMessages: nil, readStateData: nil, flashIndicators: flashIndicators, updatedMessageSelection: false) diff --git a/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift b/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift index f8fd60a4f5..0742b7d9c5 100644 --- a/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatHistoryListNode.swift @@ -66,26 +66,15 @@ private class ChatHistoryListSelectionRecognizer: UIPanGestureRecognizer { private let historyMessageCount: Int = 90 +public enum ChatHistoryListDisplayHeaders { + case none + case all + case allButLast +} + public enum ChatHistoryListMode: Equatable { case bubbles - case list(search: Bool, reversed: Bool) - - public static func ==(lhs: ChatHistoryListMode, rhs: ChatHistoryListMode) -> Bool { - switch lhs { - case .bubbles: - if case .bubbles = rhs { - return true - } else { - return false - } - case let .list(search, reversed): - if case .list(search, reversed) = rhs { - return true - } else { - return false - } - } - } + case list(search: Bool, reversed: Bool, displayHeaders: ChatHistoryListDisplayHeaders) } enum ChatHistoryViewScrollPosition { @@ -122,6 +111,7 @@ struct ChatHistoryView { let originalView: MessageHistoryView let filteredEntries: [ChatHistoryEntry] let associatedData: ChatMessageItemAssociatedData + let lastHeaderId: Int64 let id: Int32 } @@ -229,7 +219,7 @@ private func maxMessageIndexForEntries(_ view: ChatHistoryView, indexRange: (Int return (incoming, overall) } -private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, entries: [ChatHistoryViewTransitionInsertEntry]) -> [ListViewInsertItem] { +private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, lastHeaderId: Int64, entries: [ChatHistoryViewTransitionInsertEntry]) -> [ListViewInsertItem] { return entries.map { entry -> ListViewInsertItem in switch entry.entry { case let .MessageEntry(message, presentationData, read, _, selection, attributes): @@ -237,8 +227,18 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) - case let .list(search, _): - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: search) + case let .list(_, _, displayHeaders): + let displayHeader: Bool + switch displayHeaders { + case .none: + displayHeader = false + case .all: + displayHeader = true + case .allButLast: + displayHeader = listMessageDateHeaderId(timestamp: message.timestamp) != lastHeaderId + } + + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: displayHeader) } return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .MessageGroupEntry(_, messages, presentationData): @@ -246,9 +246,9 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .group(messages: messages)) - case let .list(search, _): + case let .list(_, _, _): assertionFailure() - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: search) + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: false) } return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .UnreadEntry(_, presentationData): @@ -263,7 +263,7 @@ private func mappedInsertEntries(context: AccountContext, chatLocation: ChatLoca } } -private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, entries: [ChatHistoryViewTransitionUpdateEntry]) -> [ListViewUpdateItem] { +private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, lastHeaderId: Int64, entries: [ChatHistoryViewTransitionUpdateEntry]) -> [ListViewUpdateItem] { return entries.map { entry -> ListViewUpdateItem in switch entry.entry { case let .MessageEntry(message, presentationData, read, _, selection, attributes): @@ -271,8 +271,17 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) - case let .list(search, _): - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: search) + case let .list(_, _, displayHeaders): + let displayHeader: Bool + switch displayHeaders { + case .none: + displayHeader = false + case .all: + displayHeader = true + case .allButLast: + displayHeader = listMessageDateHeaderId(timestamp: message.timestamp) != lastHeaderId + } + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: message, selection: selection, displayHeader: displayHeader) } return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .MessageGroupEntry(_, messages, presentationData): @@ -280,9 +289,9 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca switch mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, content: .group(messages: messages)) - case let .list(search, _): + case let .list(_, _, _): assertionFailure() - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: search) + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: context, chatLocation: chatLocation, controllerInteraction: controllerInteraction, message: messages[0].0, selection: .none, displayHeader: false) } return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: item, directionHint: entry.directionHint) case let .UnreadEntry(_, presentationData): @@ -297,8 +306,8 @@ private func mappedUpdateEntries(context: AccountContext, chatLocation: ChatLoca } } -private func mappedChatHistoryViewListTransition(context: AccountContext, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, transition: ChatHistoryViewTransition) -> ChatHistoryListViewTransition { - return ChatHistoryListViewTransition(historyView: transition.historyView, deleteItems: transition.deleteItems, insertItems: mappedInsertEntries(context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, mode: mode, entries: transition.insertEntries), updateItems: mappedUpdateEntries(context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, mode: mode, entries: transition.updateEntries), options: transition.options, scrollToItem: transition.scrollToItem, stationaryItemRange: transition.stationaryItemRange, initialData: transition.initialData, keyboardButtonsMessage: transition.keyboardButtonsMessage, cachedData: transition.cachedData, cachedDataMessages: transition.cachedDataMessages, readStateData: transition.readStateData, scrolledToIndex: transition.scrolledToIndex, peerType: associatedData.automaticDownloadPeerType, networkType: associatedData.automaticDownloadNetworkType, animateIn: transition.animateIn, reason: transition.reason, flashIndicators: transition.flashIndicators) +private func mappedChatHistoryViewListTransition(context: AccountContext, chatLocation: ChatLocation, associatedData: ChatMessageItemAssociatedData, controllerInteraction: ChatControllerInteraction, mode: ChatHistoryListMode, lastHeaderId: Int64, transition: ChatHistoryViewTransition) -> ChatHistoryListViewTransition { + return ChatHistoryListViewTransition(historyView: transition.historyView, deleteItems: transition.deleteItems, insertItems: mappedInsertEntries(context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, mode: mode, lastHeaderId: lastHeaderId, entries: transition.insertEntries), updateItems: mappedUpdateEntries(context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, mode: mode, lastHeaderId: lastHeaderId, entries: transition.updateEntries), options: transition.options, scrollToItem: transition.scrollToItem, stationaryItemRange: transition.stationaryItemRange, initialData: transition.initialData, keyboardButtonsMessage: transition.keyboardButtonsMessage, cachedData: transition.cachedData, cachedDataMessages: transition.cachedDataMessages, readStateData: transition.readStateData, scrolledToIndex: transition.scrolledToIndex, peerType: associatedData.automaticDownloadPeerType, networkType: associatedData.automaticDownloadNetworkType, animateIn: transition.animateIn, reason: transition.reason, flashIndicators: transition.flashIndicators) } private final class ChatHistoryTransactionOpaqueState { @@ -731,7 +740,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { var reverse = false var includeSearchEntry = false - if case let .list(search, reverseValue) = mode { + if case let .list(search, reverseValue, _) = mode { includeSearchEntry = search reverse = reverseValue } @@ -743,7 +752,9 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { 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, updatingMedia: updatingMedia), associatedData: associatedData, id: id) + let 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, updatingMedia: updatingMedia) + let lastHeaderId = filteredEntries.last.flatMap { listMessageDateHeaderId(timestamp: $0.index.timestamp) } ?? 0 + let processedView = ChatHistoryView(originalView: view, filteredEntries: filteredEntries, associatedData: associatedData, lastHeaderId: lastHeaderId, id: id) let previousValueAndVersion = previousView.swap((processedView, update.1, selectedMessages)) let previous = previousValueAndVersion?.0 let previousSelectedMessages = previousValueAndVersion?.2 @@ -794,7 +805,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { } } 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, updatedMessageSelection: previousSelectedMessages != selectedMessages) - let mappedTransition = mappedChatHistoryViewListTransition(context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, mode: mode, transition: rawTransition) + let mappedTransition = mappedChatHistoryViewListTransition(context: context, chatLocation: chatLocation, associatedData: associatedData, controllerInteraction: controllerInteraction, mode: mode, lastHeaderId: lastHeaderId, transition: rawTransition) Queue.mainQueue().async { guard let strongSelf = self else { return @@ -1670,8 +1681,17 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { switch self.mode { case .bubbles: item = ChatMessageItem(presentationData: presentationData, context: self.context, chatLocation: self.chatLocation, associatedData: associatedData, controllerInteraction: self.controllerInteraction, content: .message(message: message, read: read, selection: selection, attributes: attributes)) - case let .list(search, _): - item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: self.context, chatLocation: self.chatLocation, controllerInteraction: self.controllerInteraction, message: message, selection: selection, displayHeader: search) + case let .list(_, _, displayHeaders): + let displayHeader: Bool + switch displayHeaders { + case .none: + displayHeader = false + case .all: + displayHeader = true + case .allButLast: + displayHeader = listMessageDateHeaderId(timestamp: message.timestamp) != historyView.lastHeaderId + } + item = ListMessageItem(theme: presentationData.theme.theme, strings: presentationData.strings, fontSize: presentationData.fontSize, dateTimeFormat: presentationData.dateTimeFormat, context: self.context, chatLocation: self.chatLocation, controllerInteraction: self.controllerInteraction, message: message, selection: selection, displayHeader: displayHeader) } let updateItem = ListViewUpdateItem(index: index, previousIndex: index, item: item, directionHint: nil) self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [updateItem], options: [.AnimateInsertion], scrollToItem: nil, additionalScrollDistance: 0.0, updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) diff --git a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift index 12964d2a8b..597862487c 100644 --- a/submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift +++ b/submodules/TelegramUI/TelegramUI/ChatInterfaceStateNavigationButtons.swift @@ -73,15 +73,15 @@ func rightNavigationButtonForChatInterfaceState(_ presentationInterfaceState: Ch } if presentationInterfaceState.isScheduledMessages { - return nil + return chatInfoNavigationButton } if case .standard(true) = presentationInterfaceState.mode { - return nil + return chatInfoNavigationButton } else if let peer = presentationInterfaceState.renderedPeer?.peer { if presentationInterfaceState.accountPeerId == peer.id { if presentationInterfaceState.isScheduledMessages { - return nil + return chatInfoNavigationButton } else { let buttonItem = UIBarButtonItem(image: PresentationResourcesRootController.navigationCompactSearchIcon(presentationInterfaceState.theme), style: .plain, target: target, action: selector) buttonItem.accessibilityLabel = strings.Conversation_Search diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift index d9b6abe090..7ff5e59baa 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageBubbleItemNode.swift @@ -2311,7 +2311,8 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode item.controllerInteraction.displayMessageTooltip(item.content.firstMessage.id, item.presentationData.strings.Conversation_ForwardAuthorHiddenTooltip, self, avatarNode.frame) } else { if item.message.id.peerId == item.context.account.peerId, let channel = item.content.firstMessage.forwardInfo?.author as? TelegramChannel, channel.username == nil { - if case .member = channel.participationStatus { + if case let .broadcast(info) = channel.info, info.flags.contains(.hasDiscussionGroup) { + } else if case .member = channel.participationStatus { } else { item.controllerInteraction.displayMessageTooltip(item.message.id, item.presentationData.strings.Conversation_PrivateChannelTooltip, self, avatarNode.frame) return true @@ -2360,7 +2361,8 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode if let item = self.item, let forwardInfo = item.message.forwardInfo { if let sourceMessageId = forwardInfo.sourceMessageId { if let channel = forwardInfo.author as? TelegramChannel, channel.username == nil { - if case .member = channel.participationStatus { + if case let .broadcast(info) = channel.info, info.flags.contains(.hasDiscussionGroup) { + } else if case .member = channel.participationStatus { } else { item.controllerInteraction.displayMessageTooltip(item.message.id, item.presentationData.strings.Conversation_PrivateChannelTooltip, forwardInfoNode, nil) return true diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift index 0239c5e24c..852f4ddb66 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageForwardInfoNode.swift @@ -59,7 +59,8 @@ class ChatMessageForwardInfoNode: ASDisplayNode { var highlight = true if let peer = peer { if let channel = peer as? TelegramChannel, channel.username == nil { - if case .member = channel.participationStatus { + if case let .broadcast(info) = channel.info, info.flags.contains(.hasDiscussionGroup) { + } else if case .member = channel.participationStatus { } else { highlight = false } diff --git a/submodules/TelegramUI/TelegramUI/ChatTitleView.swift b/submodules/TelegramUI/TelegramUI/ChatTitleView.swift index e429d1315e..2202a0e001 100644 --- a/submodules/TelegramUI/TelegramUI/ChatTitleView.swift +++ b/submodules/TelegramUI/TelegramUI/ChatTitleView.swift @@ -176,6 +176,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } var pressed: (() -> Void)? + var longPressed: (() -> Void)? var titleContent: ChatTitleContent? { didSet { @@ -533,6 +534,7 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } } } + self.button.view.addGestureRecognizer(UILongPressGestureRecognizer(target: self, action: #selector(self.longPressGesture(_:)))) } required init?(coder aDecoder: NSCoder) { @@ -664,10 +666,19 @@ final class ChatTitleView: UIView, NavigationBarTitleView { } } - @objc func buttonPressed() { + @objc private func buttonPressed() { self.pressed?() } + @objc private func longPressGesture(_ gesture: UILongPressGestureRecognizer) { + switch gesture.state { + case .began: + self.longPressed?() + default: + break + } + } + func animateLayoutTransition() { UIView.transition(with: self, duration: 0.25, options: [.transitionCrossDissolve], animations: { }, completion: nil) diff --git a/submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift b/submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift index 0e6f49d611..44f4e1aa1b 100644 --- a/submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift +++ b/submodules/TelegramUI/TelegramUI/ListMessageDateHeader.swift @@ -14,6 +14,24 @@ private let timezoneOffset: Int32 = { return Int32(timeinfoNow.tm_gmtoff) }() +func listMessageDateHeaderId(timestamp: Int32) -> Int64 { + var time: time_t = time_t(timestamp + timezoneOffset) + var timeinfo: tm = tm() + localtime_r(&time, &timeinfo) + + let roundedTimestamp = timeinfo.tm_year * 100 + timeinfo.tm_mon + + return Int64(roundedTimestamp) +} + +func listMessageDateHeaderInfo(timestamp: Int32) -> (year: Int32, month: Int32) { + var time: time_t = time_t(timestamp + timezoneOffset) + var timeinfo: tm = tm() + localtime_r(&time, &timeinfo) + + return (timeinfo.tm_year, timeinfo.tm_mon) +} + final class ListMessageDateHeader: ListViewItemHeader { private let timestamp: Int32 private let roundedTimestamp: Int32 diff --git a/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift b/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift index 6ff8ed7f57..268183aae1 100644 --- a/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift +++ b/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift @@ -46,7 +46,7 @@ private func chatMessageGalleryControllerData(context: AccountContext, message: switch action.action { case let .photoUpdated(image): if let peer = messageMainPeer(message), let image = image { - let promise: Promise<[AvatarGalleryEntry]> = Promise([AvatarGalleryEntry.image(image.reference, image.representations.map({ ImageRepresentationWithReference(representation: $0, reference: .media(media: .message(message: MessageReference(message), media: media), resource: $0.resource)) }), peer, message.timestamp, nil, message.id)]) + let promise: Promise<[AvatarGalleryEntry]> = Promise([AvatarGalleryEntry.image(image.imageId, image.reference, image.representations.map({ ImageRepresentationWithReference(representation: $0, reference: .media(media: .message(message: MessageReference(message), media: media), resource: $0.resource)) }), peer, message.timestamp, nil, message.id)]) let galleryController = AvatarGalleryController(context: context, peer: peer, remoteEntries: promise, replaceRootController: { controller, ready in }) diff --git a/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift b/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift index b7645e5646..330f8213b5 100644 --- a/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/OverlayPlayerControllerNode.swift @@ -150,7 +150,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu tagMask = .voiceOrInstantVideo } - 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)) + 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, displayHeaders: .none)) super.init() @@ -480,7 +480,7 @@ final class OverlayAudioPlayerControllerNode: ViewControllerTracingNode, UIGestu tagMask = .voiceOrInstantVideo } - 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)) + 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, displayHeaders: .none)) historyNode.preloadPages = true historyNode.stackFromBottom = true historyNode.updateFloatingHeaderOffset = { [weak self] offset, _ in diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift new file mode 100644 index 0000000000..25b847138a --- /dev/null +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenCallListItem.swift @@ -0,0 +1,111 @@ +import Foundation +import UIKit +import AsyncDisplayKit +import Display +import TelegramPresentationData +import ItemListAddressItem +import SwiftSignalKit +import AccountContext +import Postbox +import PeerInfoUI +import ItemListUI + +final class PeerInfoScreenCallListItem: PeerInfoScreenItem { + let id: AnyHashable + let messages: [Message] + + init( + id: AnyHashable, + messages: [Message] + ) { + self.id = id + self.messages = messages + } + + func node() -> PeerInfoScreenItemNode { + return PeerInfoScreenCallListItemNode() + } +} + +private final class PeerInfoScreenCallListItemNode: PeerInfoScreenItemNode { + private let selectionNode: PeerInfoScreenSelectableBackgroundNode + private let bottomSeparatorNode: ASDisplayNode + + private var item: PeerInfoScreenCallListItem? + private var itemNode: ItemListCallListItemNode? + + override init() { + var bringToFrontForHighlightImpl: (() -> Void)? + self.selectionNode = PeerInfoScreenSelectableBackgroundNode(bringToFrontForHighlight: { bringToFrontForHighlightImpl?() }) + self.selectionNode.isUserInteractionEnabled = false + + self.bottomSeparatorNode = ASDisplayNode() + self.bottomSeparatorNode.isLayerBacked = true + + super.init() + + bringToFrontForHighlightImpl = { [weak self] in + self?.bringToFrontForHighlight?() + } + + self.addSubnode(self.bottomSeparatorNode) + self.addSubnode(self.selectionNode) + } + + override func update(width: CGFloat, presentationData: PresentationData, item: PeerInfoScreenItem, topItem: PeerInfoScreenItem?, bottomItem: PeerInfoScreenItem?, transition: ContainedViewLayoutTransition) -> CGFloat { + guard let item = item as? PeerInfoScreenCallListItem else { + return 10.0 + } + + self.item = item + + self.selectionNode.pressed = nil + + let sideInset: CGFloat = 16.0 + + self.bottomSeparatorNode.backgroundColor = presentationData.theme.list.itemBlocksSeparatorColor + + let addressItem = ItemListCallListItem(presentationData: ItemListPresentationData(presentationData), dateTimeFormat: presentationData.dateTimeFormat, messages: item.messages, sectionId: 0, style: .blocks, displayDecorations: false) + + let params = ListViewItemLayoutParams(width: width, leftInset: 0.0, rightInset: 0.0, availableHeight: 1000.0) + + let itemNode: ItemListCallListItemNode + if let current = self.itemNode { + itemNode = current + addressItem.updateNode(async: { $0() }, node: { + return itemNode + }, params: params, previousItem: nil, nextItem: nil, animation: .None, completion: { (layout, apply) in + let nodeFrame = CGRect(origin: CGPoint(), size: CGSize(width: width, height: layout.size.height)) + + itemNode.contentSize = layout.contentSize + itemNode.insets = layout.insets + itemNode.frame = nodeFrame + + apply(ListViewItemApply(isOnScreen: true)) + }) + } else { + var itemNodeValue: ListViewItemNode? + addressItem.nodeConfiguredForParams(async: { $0() }, params: params, synchronousLoads: false, previousItem: nil, nextItem: nil, completion: { node, apply in + itemNodeValue = node + apply().1(ListViewItemApply(isOnScreen: true)) + }) + itemNode = itemNodeValue as! ItemListCallListItemNode + itemNode.isUserInteractionEnabled = false + self.itemNode = itemNode + self.addSubnode(itemNode) + } + + let height = itemNode.contentSize.height + + transition.updateFrame(node: itemNode, frame: CGRect(origin: CGPoint(), size: itemNode.bounds.size)) + + let highlightNodeOffset: CGFloat = topItem == nil ? 0.0 : UIScreenPixel + self.selectionNode.update(size: CGSize(width: width, height: height + highlightNodeOffset), theme: presentationData.theme, transition: transition) + transition.updateFrame(node: self.selectionNode, frame: CGRect(origin: CGPoint(x: 0.0, y: -highlightNodeOffset), size: CGSize(width: width, height: height + highlightNodeOffset))) + + transition.updateFrame(node: self.bottomSeparatorNode, frame: CGRect(origin: CGPoint(x: sideInset, y: height - UIScreenPixel), size: CGSize(width: width - sideInset, height: UIScreenPixel))) + transition.updateAlpha(node: self.bottomSeparatorNode, alpha: bottomItem == nil ? 0.0 : 1.0) + + return height + } +} diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift new file mode 100644 index 0000000000..69c2fd2669 --- /dev/null +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenDisclosureEncryptionKeyItem.swift @@ -0,0 +1,118 @@ +import AsyncDisplayKit +import Display +import TelegramPresentationData +import SyncCore +import EncryptionKeyVisualization + +final class PeerInfoScreenDisclosureEncryptionKeyItem: PeerInfoScreenItem { + let id: AnyHashable + let text: String + let fingerprint: SecretChatKeyFingerprint + let action: (() -> Void)? + + init(id: AnyHashable, text: String, fingerprint: SecretChatKeyFingerprint, action: (() -> Void)?) { + self.id = id + self.text = text + self.fingerprint = fingerprint + self.action = action + } + + func node() -> PeerInfoScreenItemNode { + return PeerInfoScreenDisclosureEncryptionKeyItemNode() + } +} + +private final class PeerInfoScreenDisclosureEncryptionKeyItemNode: PeerInfoScreenItemNode { + private let selectionNode: PeerInfoScreenSelectableBackgroundNode + private let textNode: ImmediateTextNode + private let keyNode: ASImageNode + private let arrowNode: ASImageNode + private let bottomSeparatorNode: ASDisplayNode + + private var item: PeerInfoScreenDisclosureEncryptionKeyItem? + + override init() { + var bringToFrontForHighlightImpl: (() -> Void)? + self.selectionNode = PeerInfoScreenSelectableBackgroundNode(bringToFrontForHighlight: { bringToFrontForHighlightImpl?() }) + + self.textNode = ImmediateTextNode() + self.textNode.displaysAsynchronously = false + self.textNode.isUserInteractionEnabled = false + + self.keyNode = ASImageNode() + self.keyNode.displaysAsynchronously = false + self.keyNode.displayWithoutProcessing = true + self.keyNode.isUserInteractionEnabled = false + + self.arrowNode = ASImageNode() + self.arrowNode.isLayerBacked = true + self.arrowNode.displaysAsynchronously = false + self.arrowNode.displayWithoutProcessing = true + self.arrowNode.isUserInteractionEnabled = false + + self.bottomSeparatorNode = ASDisplayNode() + self.bottomSeparatorNode.isLayerBacked = true + + super.init() + + bringToFrontForHighlightImpl = { [weak self] in + self?.bringToFrontForHighlight?() + } + + self.addSubnode(self.bottomSeparatorNode) + self.addSubnode(self.selectionNode) + self.addSubnode(self.textNode) + self.addSubnode(self.keyNode) + self.addSubnode(self.arrowNode) + } + + override func update(width: CGFloat, presentationData: PresentationData, item: PeerInfoScreenItem, topItem: PeerInfoScreenItem?, bottomItem: PeerInfoScreenItem?, transition: ContainedViewLayoutTransition) -> CGFloat { + guard let item = item as? PeerInfoScreenDisclosureEncryptionKeyItem else { + return 10.0 + } + + if self.item?.fingerprint != item.fingerprint { + self.keyNode.image = secretChatKeyImage(item.fingerprint, size: CGSize(width: 24.0, height: 24.0)) + } + + self.item = item + + self.selectionNode.pressed = item.action + + let sideInset: CGFloat = 16.0 + + self.bottomSeparatorNode.backgroundColor = presentationData.theme.list.itemBlocksSeparatorColor + + self.textNode.maximumNumberOfLines = 1 + self.textNode.attributedText = NSAttributedString(string: item.text, font: Font.regular(17.0), textColor: presentationData.theme.list.itemPrimaryTextColor) + + let textSize = self.textNode.updateLayout(CGSize(width: width - sideInset * 2.0 - 44.0, height: .greatestFiniteMagnitude)) + + let arrowInset: CGFloat = 18.0 + + let textFrame = CGRect(origin: CGPoint(x: sideInset, y: 11.0), size: textSize) + + let height = textSize.height + 22.0 + + if let arrowImage = PresentationResourcesItemList.disclosureArrowImage(presentationData.theme) { + self.arrowNode.image = arrowImage + let arrowFrame = CGRect(origin: CGPoint(x: width - 7.0 - arrowImage.size.width, y: floorToScreenPixels((height - arrowImage.size.height) / 2.0)), size: arrowImage.size) + transition.updateFrame(node: self.arrowNode, frame: arrowFrame) + } + + if let image = self.keyNode.image { + self.keyNode.frame = CGRect(origin: CGPoint(x: width - sideInset - arrowInset - image.size.width, y: floor((height - image.size.height) / 2.0)), size: image.size) + } + + transition.updateFrame(node: self.textNode, frame: textFrame) + + let highlightNodeOffset: CGFloat = topItem == nil ? 0.0 : UIScreenPixel + self.selectionNode.update(size: CGSize(width: width, height: height + highlightNodeOffset), theme: presentationData.theme, transition: transition) + transition.updateFrame(node: self.selectionNode, frame: CGRect(origin: CGPoint(x: 0.0, y: -highlightNodeOffset), size: CGSize(width: width, height: height + highlightNodeOffset))) + + transition.updateFrame(node: self.bottomSeparatorNode, frame: CGRect(origin: CGPoint(x: sideInset, y: height - UIScreenPixel), size: CGSize(width: width - sideInset, height: UIScreenPixel))) + transition.updateAlpha(node: self.bottomSeparatorNode, alpha: bottomItem == nil ? 0.0 : 1.0) + + return height + } +} diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift index 33a0ebfdac..6455c35496 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/ListItems/PeerInfoScreenLabeledValueItem.swift @@ -23,6 +23,7 @@ final class PeerInfoScreenLabeledValueItem: PeerInfoScreenItem { let action: (() -> Void)? let longTapAction: ((ASDisplayNode) -> Void)? let linkItemAction: ((TextLinkItemActionType, TextLinkItem) -> Void)? + let requestLayout: () -> Void init( id: AnyHashable, @@ -32,7 +33,8 @@ final class PeerInfoScreenLabeledValueItem: PeerInfoScreenItem { textBehavior: PeerInfoScreenLabeledValueTextBehavior = .singleLine, action: (() -> Void)?, longTapAction: ((ASDisplayNode) -> Void)? = nil, - linkItemAction: ((TextLinkItemActionType, TextLinkItem) -> Void)? = nil + linkItemAction: ((TextLinkItemActionType, TextLinkItem) -> Void)? = nil, + requestLayout: @escaping () -> Void ) { self.id = id self.label = label @@ -42,6 +44,7 @@ final class PeerInfoScreenLabeledValueItem: PeerInfoScreenItem { self.action = action self.longTapAction = longTapAction self.linkItemAction = linkItemAction + self.requestLayout = requestLayout } func node() -> PeerInfoScreenItemNode { @@ -55,11 +58,16 @@ private final class PeerInfoScreenLabeledValueItemNode: PeerInfoScreenItemNode { private let textNode: ImmediateTextNode private let bottomSeparatorNode: ASDisplayNode + private let expandNode: ImmediateTextNode + private let expandButonNode: HighlightTrackingButtonNode + private var linkHighlightingNode: LinkHighlightingNode? private var item: PeerInfoScreenLabeledValueItem? private var theme: PresentationTheme? + private var isExpanded: Bool = false + override init() { var bringToFrontForHighlightImpl: (() -> Void)? self.selectionNode = PeerInfoScreenSelectableBackgroundNode(bringToFrontForHighlight: { bringToFrontForHighlightImpl?() }) @@ -76,6 +84,12 @@ private final class PeerInfoScreenLabeledValueItemNode: PeerInfoScreenItemNode { self.bottomSeparatorNode = ASDisplayNode() self.bottomSeparatorNode.isLayerBacked = true + self.expandNode = ImmediateTextNode() + self.expandNode.displaysAsynchronously = false + self.expandNode.isUserInteractionEnabled = false + + self.expandButonNode = HighlightTrackingButtonNode() + super.init() bringToFrontForHighlightImpl = { [weak self] in @@ -86,6 +100,27 @@ private final class PeerInfoScreenLabeledValueItemNode: PeerInfoScreenItemNode { self.addSubnode(self.selectionNode) self.addSubnode(self.labelNode) self.addSubnode(self.textNode) + + self.addSubnode(self.expandNode) + self.addSubnode(self.expandButonNode) + + self.expandButonNode.addTarget(self, action: #selector(self.expandPressed), forControlEvents: .touchUpInside) + self.expandButonNode.highligthedChanged = { [weak self] highlighted in + if let strongSelf = self { + if highlighted { + strongSelf.expandNode.layer.removeAnimation(forKey: "opacity") + strongSelf.expandNode.alpha = 0.4 + } else { + strongSelf.expandNode.alpha = 1.0 + strongSelf.expandNode.layer.animateAlpha(from: 0.4, to: 1.0, duration: 0.2) + } + } + } + } + + @objc private func expandPressed() { + self.isExpanded = true + self.item?.requestLayout() } override func didLoad() { @@ -96,6 +131,9 @@ private final class PeerInfoScreenLabeledValueItemNode: PeerInfoScreenItemNode { guard let strongSelf = self, let item = strongSelf.item else { return .keepWithSingleTap } + if !strongSelf.expandButonNode.isHidden, strongSelf.expandButonNode.view.hitTest(strongSelf.view.convert(point, to: strongSelf.expandButonNode.view), with: nil) != nil { + return .fail + } if let _ = strongSelf.linkItemAtPoint(point) { return .waitForSingleTap } @@ -162,14 +200,19 @@ private final class PeerInfoScreenLabeledValueItemNode: PeerInfoScreenItemNode { textColorValue = presentationData.theme.list.itemAccentColor } + self.expandNode.attributedText = NSAttributedString(string: presentationData.strings.PeerInfo_BioExpand, font: Font.regular(17.0), textColor: presentationData.theme.list.itemAccentColor) + let expandSize = self.expandNode.updateLayout(CGSize(width: width, height: 100.0)) + self.labelNode.attributedText = NSAttributedString(string: item.label, font: Font.regular(14.0), textColor: presentationData.theme.list.itemPrimaryTextColor) switch item.textBehavior { case .singleLine: + self.textNode.cutout = nil self.textNode.maximumNumberOfLines = 1 self.textNode.attributedText = NSAttributedString(string: item.text, font: Font.regular(17.0), textColor: textColorValue) case let .multiLine(maxLines, enabledEntities): - self.textNode.maximumNumberOfLines = maxLines + self.textNode.maximumNumberOfLines = self.isExpanded ? maxLines : 3 + self.textNode.cutout = self.isExpanded ? nil : TextNodeCutout(bottomRight: CGSize(width: expandSize.width + 4.0, height: expandSize.height)) if enabledEntities.isEmpty { self.textNode.attributedText = NSAttributedString(string: item.text, font: Font.regular(17.0), textColor: textColorValue) } else { @@ -188,11 +231,24 @@ private final class PeerInfoScreenLabeledValueItemNode: PeerInfoScreenItemNode { } let labelSize = self.labelNode.updateLayout(CGSize(width: width - sideInset * 2.0, height: .greatestFiniteMagnitude)) - let textSize = self.textNode.updateLayout(CGSize(width: width - sideInset * 2.0, height: .greatestFiniteMagnitude)) + let textLayout = self.textNode.updateLayoutInfo(CGSize(width: width - sideInset * 2.0, height: .greatestFiniteMagnitude)) + let textSize = textLayout.size + + if case .multiLine = item.textBehavior, textLayout.truncated, !self.isExpanded { + self.expandNode.isHidden = false + self.expandButonNode.isHidden = false + } else { + self.expandNode.isHidden = true + self.expandButonNode.isHidden = true + } let labelFrame = CGRect(origin: CGPoint(x: sideInset, y: 11.0), size: labelSize) let textFrame = CGRect(origin: CGPoint(x: sideInset, y: labelFrame.maxY + 3.0), size: textSize) + let expandFrame = CGRect(origin: CGPoint(x: textFrame.minX + max(self.textNode.trailingLineWidth ?? 0.0, textFrame.width) - expandSize.width, y: textFrame.maxY - expandSize.height), size: expandSize) + self.expandNode.frame = expandFrame + self.expandButonNode.frame = expandFrame.insetBy(dx: -8.0, dy: -8.0) + transition.updateFrame(node: self.labelNode, frame: labelFrame) transition.updateFrame(node: self.textNode, frame: textFrame) diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift index e655f28ab3..c0408f0821 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoGroupsInCommonPaneNode.swift @@ -133,8 +133,18 @@ final class PeerInfoGroupsInCommonPaneNode: ASDisplayNode, PeerInfoPaneNode { transition.updateFrame(node: self.listNode, frame: CGRect(origin: CGPoint(), size: size)) let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) + + var scrollToItem: ListViewScrollToItem? + if isScrollingLockedAtTop { + switch self.listNode.visibleContentOffset() { + case .known(0.0): + break + default: + scrollToItem = ListViewScrollToItem(index: 0, position: .top(0.0), animated: true, curve: .Spring(duration: duration), directionHint: .Up) + } + } - self.listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous, .LowLatency], scrollToItem: nil, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: size, insets: UIEdgeInsets(top: 0.0, left: sideInset, bottom: bottomInset, right: sideInset), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + self.listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous, .LowLatency], scrollToItem: scrollToItem, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: size, insets: UIEdgeInsets(top: 0.0, left: sideInset, bottom: bottomInset, right: sideInset), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) self.listNode.scrollEnabled = !isScrollingLockedAtTop @@ -194,6 +204,9 @@ final class PeerInfoGroupsInCommonPaneNode: ASDisplayNode, PeerInfoPaneNode { } } + func cancelPreviewGestures() { + } + func transitionNodeForGallery(messageId: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { return nil } diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift index b021f9542c..2a2e4d2a76 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoListPaneNode.swift @@ -44,7 +44,7 @@ final class PeerInfoListPaneNode: ASDisplayNode, PeerInfoPaneNode { self.selectedMessages = chatControllerInteraction.selectionState.flatMap { $0.selectedIds } self.selectedMessagesPromise.set(.single(self.selectedMessages)) - self.listNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: tagMask, subject: nil, controllerInteraction: chatControllerInteraction, selectedMessages: self.selectedMessagesPromise.get(), mode: .list(search: false, reversed: false)) + self.listNode = ChatHistoryListNode(context: context, chatLocation: .peer(peerId), tagMask: tagMask, subject: nil, controllerInteraction: chatControllerInteraction, selectedMessages: self.selectedMessagesPromise.get(), mode: .list(search: false, reversed: false, displayHeaders: .allButLast)) super.init() @@ -77,6 +77,14 @@ final class PeerInfoListPaneNode: ASDisplayNode, PeerInfoPaneNode { transition.updateFrame(node: self.listNode, frame: CGRect(origin: CGPoint(), size: size)) let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) self.listNode.updateLayout(transition: transition, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: size, insets: UIEdgeInsets(top: 0.0, left: sideInset, bottom: bottomInset, right: sideInset), duration: duration, curve: curve)) + if isScrollingLockedAtTop { + switch self.listNode.visibleContentOffset() { + case .known(0.0), .none: + break + default: + self.listNode.scrollToEndOfHistory() + } + } self.listNode.scrollEnabled = !isScrollingLockedAtTop } @@ -98,6 +106,9 @@ final class PeerInfoListPaneNode: ASDisplayNode, PeerInfoPaneNode { } } + func cancelPreviewGestures() { + } + func transitionNodeForGallery(messageId: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { var transitionNode: (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? self.listNode.forEachItemNode { itemNode in diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift index f22ca30ca6..5bc764ed19 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoMembersPane.swift @@ -177,7 +177,16 @@ final class PeerInfoMembersPaneNode: ASDisplayNode, PeerInfoPaneNode { transition.updateFrame(node: self.listNode, frame: CGRect(origin: CGPoint(), size: size)) let (duration, curve) = listViewAnimationDurationAndCurve(transition: transition) - self.listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous, .LowLatency], scrollToItem: nil, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: size, insets: UIEdgeInsets(top: 0.0, left: sideInset, bottom: bottomInset, right: sideInset), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + var scrollToItem: ListViewScrollToItem? + if isScrollingLockedAtTop { + switch self.listNode.visibleContentOffset() { + case .known(0.0): + break + default: + scrollToItem = ListViewScrollToItem(index: 0, position: .top(0.0), animated: true, curve: .Spring(duration: duration), directionHint: .Up) + } + } + self.listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous, .LowLatency], scrollToItem: scrollToItem, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: size, insets: UIEdgeInsets(top: 0.0, left: sideInset, bottom: bottomInset, right: sideInset), duration: duration, curve: curve), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) self.listNode.scrollEnabled = !isScrollingLockedAtTop @@ -238,6 +247,9 @@ final class PeerInfoMembersPaneNode: ASDisplayNode, PeerInfoPaneNode { } } + func cancelPreviewGestures() { + } + func transitionNodeForGallery(messageId: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { return nil } diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift index 8f901e2cd8..cc2ff6f4ab 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift @@ -92,6 +92,10 @@ private final class VisualMediaItemNode: ASDisplayNode { return .waitForSingleTap } self.imageNode.view.addGestureRecognizer(recognizer) + + self.mediaBadgeNode.pressed = { [weak self] in + self?.progressPressed() + } } @objc func tapGesture(_ recognizer: TapLongTapOrDoubleTapGestureRecognizer) { @@ -99,13 +103,66 @@ private final class VisualMediaItemNode: ASDisplayNode { if let (gesture, _) = recognizer.lastRecognizedGestureAndLocation { if case .tap = gesture { if let (item, _, _, _) = self.item { - self.interaction.openMessage(item.message) + var media: Media? + for value in item.message.media { + if let image = value as? TelegramMediaImage { + media = image + break + } else if let file = value as? TelegramMediaFile { + media = file + break + } + } + + if let media = media { + if let file = media as? TelegramMediaFile { + if isMediaStreamable(message: item.message, media: file) { + self.interaction.openMessage(item.message) + } else { + self.progressPressed() + } + } else { + self.interaction.openMessage(item.message) + } + } } } } } } + private func progressPressed() { + guard let message = self.item?.0.message else { + return + } + + var media: Media? + for value in message.media { + if let image = value as? TelegramMediaImage { + media = image + break + } else if let file = value as? TelegramMediaFile { + media = file + break + } + } + + if let resourceStatus = self.resourceStatus, let file = media as? TelegramMediaFile { + switch resourceStatus { + case .Fetching: + messageMediaFileCancelInteractiveFetch(context: self.context, messageId: message.id, file: file) + case .Local: + self.interaction.openMessage(message) + case .Remote: + self.fetchDisposable.set(messageMediaFileInteractiveFetched(context: self.context, message: message, file: file, userInitiated: true).start()) + } + } + } + + func cancelPreviewGesture() { + self.containerNode.cancelGesture() + } + func update(size: CGSize, item: VisualMediaItem, theme: PresentationTheme, synchronousLoad: Bool) { if item === self.item?.0 && size == self.item?.2 { return @@ -142,32 +199,36 @@ private final class VisualMediaItemNode: ASDisplayNode { self.mediaBadgeNode.isHidden = false self.resourceStatus = nil - self.fetchStatusDisposable.set((messageMediaFileStatus(context: context, messageId: item.message.id, file: file) |> deliverOnMainQueue).start(next: { [weak self] status in + + self.item = (item, media, size, mediaDimensions) + + self.fetchStatusDisposable.set((messageMediaFileStatus(context: context, messageId: item.message.id, file: file) + |> deliverOnMainQueue).start(next: { [weak self] status in if let strongSelf = self, let (item, _, _, _) = strongSelf.item { strongSelf.resourceStatus = status let isStreamable = isMediaStreamable(message: item.message, media: file) - let statusState: RadialStatusNodeState = .none - /*if isStreamable { + var statusState: RadialStatusNodeState = .none + if isStreamable { statusState = .none } else { switch status { - case let .Fetching(_, progress): - let adjustedProgress = max(progress, 0.027) - statusState = .progress(color: .white, lineWidth: nil, value: CGFloat(adjustedProgress), cancelEnabled: true) - case .Local: - statusState = .none - case .Remote: - statusState = .download(.white) + case let .Fetching(_, progress): + let adjustedProgress = max(progress, 0.027) + statusState = .progress(color: .white, lineWidth: nil, value: CGFloat(adjustedProgress), cancelEnabled: true) + case .Local: + statusState = .none + case .Remote: + statusState = .download(.white) } - }*/ + } switch statusState { - case .none: - break - default: - strongSelf.statusNode.isHidden = false + case .none: + break + default: + strongSelf.statusNode.isHidden = false } strongSelf.statusNode.transitionToState(statusState, animated: true, completion: { @@ -324,12 +385,64 @@ private final class VisualMediaItem { } } +private final class FloatingHeaderNode: ASDisplayNode { + private let backgroundNode: ASImageNode + private let labelNode: ImmediateTextNode + + private var currentParams: (constrainedWidth: CGFloat, year: Int32, month: Int32, theme: PresentationTheme)? + private var currentSize: CGSize? + + override init() { + self.backgroundNode = ASImageNode() + self.backgroundNode.displaysAsynchronously = false + self.backgroundNode.displayWithoutProcessing = true + + self.labelNode = ImmediateTextNode() + self.labelNode.displaysAsynchronously = false + + super.init() + + self.addSubnode(self.backgroundNode) + self.addSubnode(self.labelNode) + } + + func update(constrainedWidth: CGFloat, year: Int32, month: Int32, theme: PresentationTheme, strings: PresentationStrings) -> CGSize { + if let currentParams = self.currentParams, let currentSize = self.currentSize { + if currentParams.constrainedWidth == constrainedWidth && + currentParams.year == year && + currentParams.month == month && + currentParams.theme === theme { + return currentSize + } + } + + if self.currentParams?.theme !== theme { + self.backgroundNode.image = generateStretchableFilledCircleImage(diameter: 27.0, color: mediaBadgeBackgroundColor) + } + + self.currentParams = (constrainedWidth, year, month, theme) + + self.labelNode.attributedText = NSAttributedString(string: stringForMonth(strings: strings, month: month, ofYear: year), font: Font.regular(14.0), textColor: .white) + let labelSize = self.labelNode.updateLayout(CGSize(width: constrainedWidth, height: .greatestFiniteMagnitude)) + + let sideInset: CGFloat = 10.0 + self.labelNode.frame = CGRect(origin: CGPoint(x: sideInset, y: floor((27.0 - labelSize.height) / 2.0)), size: labelSize) + self.backgroundNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: labelSize.width + sideInset * 2.0, height: 27.0)) + + let size = CGSize(width: labelSize.width + sideInset * 2.0, height: 27.0) + return size + } +} + final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScrollViewDelegate { private let context: AccountContext private let peerId: PeerId private let chatControllerInteraction: ChatControllerInteraction private let scrollNode: ASScrollNode + private let floatingHeaderNode: FloatingHeaderNode + private var flashHeaderDelayTimer: Foundation.Timer? + private var isDeceleratingAfterTracking = false private var _itemInteraction: VisualMediaItemInteraction? private var itemInteraction: VisualMediaItemInteraction { @@ -362,6 +475,8 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro self.chatControllerInteraction = chatControllerInteraction self.scrollNode = ASScrollNode() + self.floatingHeaderNode = FloatingHeaderNode() + self.floatingHeaderNode.alpha = 0.0 super.init() @@ -388,6 +503,7 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro self.scrollNode.view.delegate = self self.addSubnode(self.scrollNode) + self.addSubnode(self.floatingHeaderNode) self.requestHistoryAroundVisiblePosition() @@ -431,11 +547,11 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro private func updateHistory(view: MessageHistoryView, updateType: ViewUpdateType) { self.currentView = view - self.mediaItems.removeAll() switch updateType { case .FillHole: self.requestHistoryAroundVisiblePosition() default: + self.mediaItems.removeAll() for entry in view.entries.reversed() { self.mediaItems.append(VisualMediaItem(message: entry.message)) } @@ -484,6 +600,7 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro let startTime = CACurrentMediaTime() var currentOffset = self.scrollNode.view.contentOffset let decelerationRate: CGFloat = 0.998 + self.scrollViewDidEndDragging(self.scrollNode.view, willDecelerate: true) self.decelerationAnimator = ConstantDisplayLinkAnimator(update: { [weak self] in guard let strongSelf = self else { return @@ -502,18 +619,30 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro currentVelocity = 0.0 } + var didEnd = false if abs(currentVelocity) < 0.1 { strongSelf.decelerationAnimator?.isPaused = true strongSelf.decelerationAnimator = nil + didEnd = true } var contentOffset = strongSelf.scrollNode.view.contentOffset contentOffset.y = floorToScreenPixels(currentOffset.y) strongSelf.scrollNode.view.setContentOffset(contentOffset, animated: false) + strongSelf.scrollViewDidScroll(strongSelf.scrollNode.view) + if didEnd { + strongSelf.scrollViewDidEndDecelerating(strongSelf.scrollNode.view) + } }) self.decelerationAnimator?.isPaused = false } } + func cancelPreviewGestures() { + for (_, itemNode) in self.visibleMediaItems { + itemNode.cancelPreviewGesture() + } + } + func transitionNodeForGallery(messageId: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { for item in self.mediaItems { if item.message.id == messageId { @@ -542,18 +671,23 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro transition.updateFrame(node: self.scrollNode, frame: CGRect(origin: CGPoint(), size: size)) + let availableWidth = size.width - sideInset * 2.0 + let itemSpacing: CGFloat = 1.0 - let itemsInRow: Int = max(3, min(6, Int(size.width / 100.0))) - let itemSize: CGFloat = floor(size.width / CGFloat(itemsInRow)) + let itemsInRow: Int = max(3, min(6, Int(availableWidth / 140.0))) + let itemSize: CGFloat = floor(availableWidth / CGFloat(itemsInRow)) let rowCount: Int = self.mediaItems.count / itemsInRow + (self.mediaItems.count % itemsInRow == 0 ? 0 : 1) + let contentHeight = CGFloat(rowCount + 1) * itemSpacing + CGFloat(rowCount) * itemSize + bottomInset self.scrollNode.view.contentSize = CGSize(width: size.width, height: contentHeight) - self.updateVisibleItems(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, theme: presentationData.theme, synchronousLoad: synchronous) + self.updateVisibleItems(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, theme: presentationData.theme, strings: presentationData.strings, synchronousLoad: synchronous) if isScrollingLockedAtTop { - transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(), size: self.scrollNode.bounds.size)) + if self.scrollNode.view.contentOffset.y > .ulpOfOne { + transition.updateBounds(node: self.scrollNode, bounds: CGRect(origin: CGPoint(), size: self.scrollNode.bounds.size)) + } } self.scrollNode.view.isScrollEnabled = !isScrollingLockedAtTop } @@ -561,11 +695,17 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro func scrollViewWillBeginDragging(_ scrollView: UIScrollView) { self.decelerationAnimator?.isPaused = true self.decelerationAnimator = nil + + for (_, itemNode) in self.visibleMediaItems { + itemNode.cancelPreviewGesture() + } + + self.updateHeaderFlashing(animated: true) } func scrollViewDidScroll(_ scrollView: UIScrollView) { if let (size, sideInset, bottomInset, visibleHeight, _, presentationData) = self.currentParams { - self.updateVisibleItems(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, theme: presentationData.theme, synchronousLoad: false) + self.updateVisibleItems(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, theme: presentationData.theme, strings: presentationData.strings, synchronousLoad: false) if scrollView.contentOffset.y >= scrollView.contentSize.height - scrollView.bounds.height * 2.0, let currentView = self.currentView, currentView.earlierId != nil { if !self.isRequestingView { @@ -576,7 +716,24 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro } } - private func updateVisibleItems(size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, theme: PresentationTheme, synchronousLoad: Bool) { + func scrollViewDidEndDragging(_ scrollView: UIScrollView, willDecelerate decelerate: Bool) { + if decelerate { + self.isDeceleratingAfterTracking = true + self.updateHeaderFlashing(animated: true) + } else { + self.isDeceleratingAfterTracking = false + self.resetHeaderFlashTimer(start: true) + self.updateHeaderFlashing(animated: true) + } + } + + func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) { + self.isDeceleratingAfterTracking = false + self.resetHeaderFlashTimer(start: true) + self.updateHeaderFlashing(animated: true) + } + + private func updateVisibleItems(size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, theme: PresentationTheme, strings: PresentationStrings, synchronousLoad: Bool) { let availableWidth = size.width - sideInset * 2.0 let itemSpacing: CGFloat = 1.0 @@ -585,7 +742,8 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro let rowCount: Int = self.mediaItems.count / itemsInRow + (self.mediaItems.count % itemsInRow == 0 ? 0 : 1) - let visibleRect = self.scrollNode.view.bounds + let headerItemMinY = self.scrollNode.view.bounds.minY + 20.0 + let visibleRect = self.scrollNode.view.bounds.insetBy(dx: 0.0, dy: -400.0) var minVisibleRow = Int(floor((visibleRect.minY - itemSpacing) / (itemSize + itemSpacing))) minVisibleRow = max(0, minVisibleRow) var maxVisibleRow = Int(ceil((visibleRect.maxY - itemSpacing) / (itemSize + itemSpacing))) @@ -594,6 +752,8 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro let minVisibleIndex = minVisibleRow * itemsInRow let maxVisibleIndex = min(self.mediaItems.count - 1, (maxVisibleRow + 1) * itemsInRow - 1) + var headerItem: Message? + var validIds = Set() if minVisibleIndex <= maxVisibleIndex { for i in minVisibleIndex ... maxVisibleIndex { @@ -612,6 +772,9 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro self.scrollNode.addSubnode(itemNode) } itemNode.frame = itemFrame + if headerItem == nil && itemFrame.maxY > headerItemMinY { + headerItem = self.mediaItems[i].message + } var itemSynchronousLoad = false if itemFrame.maxY <= visibleHeight { itemSynchronousLoad = synchronousLoad @@ -630,6 +793,68 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro itemNode.removeFromSupernode() } } + + if let headerItem = headerItem { + let (year, month) = listMessageDateHeaderInfo(timestamp: headerItem.timestamp) + let headerSize = self.floatingHeaderNode.update(constrainedWidth: size.width, year: year, month: month, theme: theme, strings: strings) + self.floatingHeaderNode.frame = CGRect(origin: CGPoint(x: floor((size.width - headerSize.width) / 2.0), y: 7.0), size: headerSize) + self.floatingHeaderNode.isHidden = false + } else { + self.floatingHeaderNode.isHidden = true + } + } + + private func resetHeaderFlashTimer(start: Bool, duration: Double = 0.3) { + if let flashHeaderDelayTimer = self.flashHeaderDelayTimer { + flashHeaderDelayTimer.invalidate() + self.flashHeaderDelayTimer = nil + } + + if start { + final class TimerProxy: NSObject { + private let action: () -> () + + init(_ action: @escaping () -> ()) { + self.action = action + super.init() + } + + @objc func timerEvent() { + self.action() + } + } + + let timer = Timer(timeInterval: duration, target: TimerProxy { [weak self] in + if let strongSelf = self { + if let flashHeaderDelayTimer = strongSelf.flashHeaderDelayTimer { + flashHeaderDelayTimer.invalidate() + strongSelf.flashHeaderDelayTimer = nil + strongSelf.updateHeaderFlashing(animated: true) + } + } + }, selector: #selector(TimerProxy.timerEvent), userInfo: nil, repeats: false) + self.flashHeaderDelayTimer = timer + RunLoop.main.add(timer, forMode: RunLoop.Mode.common) + self.updateHeaderFlashing(animated: true) + } + } + + private func headerIsFlashing() -> Bool { + return self.scrollNode.view.isDragging || self.isDeceleratingAfterTracking || self.flashHeaderDelayTimer != nil + } + + private func updateHeaderFlashing(animated: Bool) { + let flashing = self.headerIsFlashing() + let alpha: CGFloat = flashing ? 1.0 : 0.0 + let previousAlpha = self.floatingHeaderNode.alpha + + if !previousAlpha.isEqual(to: alpha) { + self.floatingHeaderNode.alpha = alpha + if animated { + let duration: Double = flashing ? 0.3 : 0.4 + self.floatingHeaderNode.layer.animateAlpha(from: previousAlpha, to: alpha, duration: duration) + } + } } override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift index 04bb02018e..88d2d9c5a7 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoData.swift @@ -66,6 +66,7 @@ final class PeerInfoScreenData { let groupsInCommon: GroupsInCommonContext? let linkedDiscussionPeer: Peer? let members: PeerInfoMembersData? + let encryptionKeyFingerprint: SecretChatKeyFingerprint? init( peer: Peer?, @@ -77,7 +78,8 @@ final class PeerInfoScreenData { availablePanes: [PeerInfoPaneKey], groupsInCommon: GroupsInCommonContext?, linkedDiscussionPeer: Peer?, - members: PeerInfoMembersData? + members: PeerInfoMembersData?, + encryptionKeyFingerprint: SecretChatKeyFingerprint? ) { self.peer = peer self.cachedData = cachedData @@ -89,6 +91,7 @@ final class PeerInfoScreenData { self.groupsInCommon = groupsInCommon self.linkedDiscussionPeer = linkedDiscussionPeer self.members = members + self.encryptionKeyFingerprint = encryptionKeyFingerprint } } @@ -203,6 +206,8 @@ private func peerInfoScreenInputData(context: AccountContext, peerId: PeerId) -> } } else if let group = peer as? TelegramGroup { return .group(groupId: group.id) + } else if let secretChat = peer as? TelegramSecretChat { + return .user(userId: secretChat.regularPeerId, secretChatId: peer.id, kind: .user) } else { return .none } @@ -272,12 +277,13 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen availablePanes: [], groupsInCommon: nil, linkedDiscussionPeer: nil, - members: nil + members: nil, + encryptionKeyFingerprint: nil )) - case let .user(peerId, secretChatId, kind): + case let .user(userPeerId, secretChatId, kind): let groupsInCommon: GroupsInCommonContext? if case .user = kind { - groupsInCommon = GroupsInCommonContext(account: context.account, peerId: peerId) + groupsInCommon = GroupsInCommonContext(account: context.account, peerId: userPeerId) } else { groupsInCommon = nil } @@ -306,9 +312,12 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen } subscriber.putNext(data) } - let disposable = (context.account.viewTracker.peerView(peerId, updateData: false) + let disposable = (context.account.viewTracker.peerView(userPeerId, updateData: false) |> map { view -> StatusInputData in - guard let user = view.peers[peerId] as? TelegramUser else { + guard let user = view.peers[userPeerId] as? TelegramUser else { + return .none + } + if user.id == context.account.peerId { return .none } if user.isDeleted { @@ -320,7 +329,7 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen if user.botInfo != nil { return .bot } - guard let presence = view.peerPresences[peerId] as? TelegramUserPresence else { + guard let presence = view.peerPresences[userPeerId] as? TelegramUserPresence else { return .none } return .presence(presence) @@ -366,10 +375,10 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen var combinedKeys: [PostboxViewKey] = [] combinedKeys.append(globalNotificationsKey) if let secretChatId = secretChatId { - combinedKeys.append(.peerChatState(peerId: peerId)) + combinedKeys.append(.peerChatState(peerId: secretChatId)) } return combineLatest( - context.account.viewTracker.peerView(peerId, updateData: true), + context.account.viewTracker.peerView(userPeerId, updateData: true), peerInfoAvailableMediaPanes(context: context, peerId: peerId), context.account.postbox.combinedView(keys: combinedKeys), status @@ -382,6 +391,13 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen } } + var encryptionKeyFingerprint: SecretChatKeyFingerprint? + if let secretChatId = secretChatId, let peerChatStateView = combinedView.views[.peerChatState(peerId: secretChatId)] as? PeerChatStateView { + if let peerChatState = peerChatStateView.chatState as? SecretChatKeyState { + encryptionKeyFingerprint = peerChatState.keyFingerprint + } + } + var availablePanes = availablePanes if availablePanes != nil, groupsInCommon != nil, let cachedData = peerView.cachedData as? CachedUserData { if cachedData.commonGroupCount != 0 { @@ -390,7 +406,7 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen } return PeerInfoScreenData( - peer: peerView.peers[peerId], + peer: peerView.peers[userPeerId], cachedData: peerView.cachedData, status: status, notificationSettings: peerView.notificationSettings as? TelegramPeerNotificationSettings, @@ -399,7 +415,8 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen availablePanes: availablePanes ?? [], groupsInCommon: groupsInCommon, linkedDiscussionPeer: nil, - members: nil + members: nil, + encryptionKeyFingerprint: encryptionKeyFingerprint ) } case .channel: @@ -448,21 +465,87 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen availablePanes: availablePanes ?? [], groupsInCommon: nil, linkedDiscussionPeer: discussionPeer, - members: nil + members: nil, + encryptionKeyFingerprint: nil ) } case let .group(groupId): - let status = context.account.viewTracker.peerView(groupId, updateData: false) - |> map { peerView -> PeerInfoStatusData? in - guard let channel = peerView.peers[groupId] as? TelegramChannel else { - return PeerInfoStatusData(text: strings.Group_Status, isActivity: false) + var onlineMemberCount: Signal = .single(nil) + if peerId.namespace == Namespaces.Peer.CloudChannel { + onlineMemberCount = context.account.viewTracker.peerView(groupId, updateData: false) + |> map { view -> Bool? in + if let cachedData = view.cachedData as? CachedChannelData, let peer = peerViewMainPeer(view) as? TelegramChannel { + if case .broadcast = peer.info { + return nil + } else if let memberCount = cachedData.participantsSummary.memberCount, memberCount > 50 { + return true + } else { + return false + } + } else { + return false + } } - if let cachedChannelData = peerView.cachedData as? CachedChannelData, let memberCount = cachedChannelData.participantsSummary.memberCount, memberCount != 0 { - return PeerInfoStatusData(text: strings.Conversation_StatusMembers(memberCount), isActivity: false) - } else { - return PeerInfoStatusData(text: strings.Group_Status, isActivity: false) + |> distinctUntilChanged + |> mapToSignal { isLarge -> Signal in + if let isLarge = isLarge { + if isLarge { + return context.peerChannelMemberCategoriesContextsManager.recentOnline(postbox: context.account.postbox, network: context.account.network, accountPeerId: context.account.peerId, peerId: peerId) + |> map(Optional.init) + } else { + return context.peerChannelMemberCategoriesContextsManager.recentOnlineSmall(postbox: context.account.postbox, network: context.account.network, accountPeerId: context.account.peerId, peerId: peerId) + |> map(Optional.init) + } + } else { + return .single(nil) + } } } + + let status = combineLatest(queue: .mainQueue(), + context.account.viewTracker.peerView(groupId, updateData: false), + onlineMemberCount + ) + |> map { peerView, onlineMemberCount -> PeerInfoStatusData? in + if let cachedChannelData = peerView.cachedData as? CachedChannelData, let memberCount = cachedChannelData.participantsSummary.memberCount { + if let onlineMemberCount = onlineMemberCount, onlineMemberCount > 1 { + var string = "" + + string.append("\(strings.Conversation_StatusMembers(Int32(memberCount))), ") + string.append(strings.Conversation_StatusOnline(Int32(onlineMemberCount))) + return PeerInfoStatusData(text: string, isActivity: false) + } else if memberCount > 0 { + return PeerInfoStatusData(text: strings.Conversation_StatusMembers(Int32(memberCount)), isActivity: false) + } + } else if let group = peerView.peers[groupId] as? TelegramGroup, let cachedGroupData = peerView.cachedData as? CachedGroupData { + var onlineCount = 0 + if let participants = cachedGroupData.participants { + let timestamp = CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 + for participant in participants.participants { + if let presence = peerView.peerPresences[participant.peerId] as? TelegramUserPresence { + let relativeStatus = relativeUserPresenceStatus(presence, relativeTo: Int32(timestamp)) + switch relativeStatus { + case .online: + onlineCount += 1 + default: + break + } + } + } + } + if onlineCount > 1 { + var string = "" + + string.append("\(strings.Conversation_StatusMembers(Int32(group.participantCount))), ") + string.append(strings.Conversation_StatusOnline(Int32(onlineCount))) + return PeerInfoStatusData(text: string, isActivity: false) + } else { + return PeerInfoStatusData(text: strings.Conversation_StatusMembers(Int32(group.participantCount)), isActivity: false) + } + } + + return PeerInfoStatusData(text: strings.Group_Status, isActivity: false) + } |> distinctUntilChanged let membersContext = PeerInfoMembersContext(context: context, peerId: groupId) @@ -519,7 +602,8 @@ func peerInfoScreenData(context: AccountContext, peerId: PeerId, strings: Presen availablePanes: availablePanes ?? [], groupsInCommon: nil, linkedDiscussionPeer: discussionPeer, - members: membersData + members: membersData, + encryptionKeyFingerprint: nil ) } } @@ -619,10 +703,12 @@ func availableActionsForMemberOfPeer(accountPeerId: PeerId, peer: Peer, member: return result } -func peerInfoHeaderButtons(peer: Peer?, cachedData: CachedPeerData?) -> [PeerInfoHeaderButtonKey] { +func peerInfoHeaderButtons(peer: Peer?, cachedData: CachedPeerData?, isOpenedFromChat: Bool) -> [PeerInfoHeaderButtonKey] { var result: [PeerInfoHeaderButtonKey] = [] if let user = peer as? TelegramUser { - result.append(.message) + if !isOpenedFromChat { + result.append(.message) + } var callsAvailable = false if !user.isDeleted, user.botInfo == nil, !user.flags.contains(.isSupport) { if let cachedUserData = cachedData as? CachedUserData { @@ -634,22 +720,27 @@ func peerInfoHeaderButtons(peer: Peer?, cachedData: CachedPeerData?) -> [PeerInf result.append(.call) } result.append(.mute) + if isOpenedFromChat { + result.append(.search) + } result.append(.more) } else if let channel = peer as? TelegramChannel { + var displayLeave = !channel.flags.contains(.isCreator) switch channel.info { case .broadcast: - if let cachedData = cachedData as? CachedChannelData { - if cachedData.linkedDiscussionPeerId != nil { - result.append(.discussion) - } - } + displayLeave = true case .group: + displayLeave = false if channel.flags.contains(.isCreator) || channel.hasPermission(.inviteMembers) { result.append(.addMember) } } result.append(.mute) + result.append(.search) + if displayLeave { + result.append(.leave) + } result.append(.more) } else if let group = peer as? TelegramGroup { var canEditGroupInfo = false @@ -681,6 +772,7 @@ func peerInfoHeaderButtons(peer: Peer?, cachedData: CachedPeerData?) -> [PeerInf } result.append(.mute) + result.append(.search) result.append(.more) } return result diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift index e5c1f21c19..6b5995e738 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoHeaderNode.swift @@ -21,6 +21,8 @@ enum PeerInfoHeaderButtonKey: Hashable { case mute case more case addMember + case search + case leave } enum PeerInfoHeaderButtonIcon { @@ -30,6 +32,8 @@ enum PeerInfoHeaderButtonIcon { case unmute case more case addMember + case search + case leave } final class PeerInfoHeaderButtonNode: HighlightableButtonNode { @@ -104,6 +108,10 @@ final class PeerInfoHeaderButtonNode: HighlightableButtonNode { imageName = "Peer Info/ButtonMore" case .addMember: imageName = "Peer Info/ButtonAddMember" + case .search: + imageName = "Peer Info/ButtonSearch" + case .leave: + imageName = "Peer Info/ButtonLeave" } if let image = UIImage(bundleImageName: imageName) { let imageRect = CGRect(origin: CGPoint(x: floor((size.width - image.size.width) / 2.0), y: floor((size.height - image.size.height) / 2.0)), size: image.size) @@ -168,7 +176,7 @@ final class PeerInfoAvatarListItemNode: ASDisplayNode { super.init() - self.imageNode.contentAnimations = .subsequentUpdates + self.imageNode.contentAnimations = [.firstUpdate, .subsequentUpdates] self.addSubnode(self.imageNode) self.imageNode.imageUpdated = { [weak self] _ in @@ -220,7 +228,6 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { private var items: [PeerInfoAvatarListItem] = [] private var itemNodes: [WrappedMediaResourceId: PeerInfoAvatarListItemNode] = [:] private var stripNodes: [ASImageNode] = [] - private let inactiveStripImage: UIImage private let activeStripImage: UIImage private var appliedStripNodeCurrentIndex: Int? private var currentIndex: Int = 0 @@ -242,6 +249,14 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { } } + var currentEntry: AvatarGalleryEntry? { + if self.currentIndex >= 0 && self.currentIndex < self.galleryEntries.count { + return self.galleryEntries[self.currentIndex] + } else { + return nil + } + } + init(context: AccountContext) { self.context = context @@ -265,7 +280,7 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { context.drawLinearGradient(gradient, start: CGPoint(x: 0.0, y: 0.0), end: CGPoint(x: size.width, y: 0.0), options: [.drawsBeforeStartLocation, .drawsAfterEndLocation]) }) - self.leftHighlightNode.isHidden = true + self.leftHighlightNode.alpha = 0.0 self.rightHighlightNode = ASImageNode() self.rightHighlightNode.displaysAsynchronously = false @@ -285,11 +300,10 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { context.drawLinearGradient(gradient, start: CGPoint(x: size.width, y: 0.0), end: CGPoint(x: 0.0, y: 0.0), options: [.drawsBeforeStartLocation, .drawsAfterEndLocation]) }) - self.rightHighlightNode.isHidden = true + self.rightHighlightNode.alpha = 0.0 self.stripContainerNode = ASDisplayNode() self.contentNode.addSubnode(self.stripContainerNode) - self.inactiveStripImage = generateSmallHorizontalStretchableFilledCircleImage(diameter: 2.0, color: UIColor(white: 1.0, alpha: 0.2))! self.activeStripImage = generateSmallHorizontalStretchableFilledCircleImage(diameter: 2.0, color: .white)! self.highlightContainerNode = ASDisplayNode() @@ -383,12 +397,30 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { } if strongSelf.highlightedSide != highlightedSide { strongSelf.highlightedSide = highlightedSide + let leftAlpha: CGFloat + let rightAlpha: CGFloat if let highlightedSide = highlightedSide { - strongSelf.leftHighlightNode.isHidden = highlightedSide - strongSelf.rightHighlightNode.isHidden = !highlightedSide + leftAlpha = highlightedSide ? 0.0 : 1.0 + rightAlpha = highlightedSide ? 1.0 : 0.0 } else { - strongSelf.leftHighlightNode.isHidden = true - strongSelf.rightHighlightNode.isHidden = true + leftAlpha = 0.0 + rightAlpha = 0.0 + } + if strongSelf.leftHighlightNode.alpha != leftAlpha { + strongSelf.leftHighlightNode.alpha = leftAlpha + if leftAlpha.isZero { + strongSelf.leftHighlightNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.16, timingFunction: kCAMediaTimingFunctionSpring) + } else { + strongSelf.leftHighlightNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.08) + } + } + if strongSelf.rightHighlightNode.alpha != rightAlpha { + strongSelf.rightHighlightNode.alpha = rightAlpha + if rightAlpha.isZero { + strongSelf.rightHighlightNode.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.16, timingFunction: kCAMediaTimingFunctionSpring) + } else { + strongSelf.rightHighlightNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.08) + } } } } @@ -406,7 +438,15 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { func selectFirstItem() { self.currentIndex = 0 if let size = self.validLayout { - self.updateItems(size: size, transition: .immediate) + self.updateItems(size: size, transition: .immediate, stripTransition: .immediate) + } + } + + func updateEntryIsHidden(entry: AvatarGalleryEntry?) { + if let entry = entry, let index = self.galleryEntries.index(of: entry) { + self.currentItemNode?.isHidden = index == self.currentIndex + } else { + self.currentItemNode?.isHidden = false } } @@ -418,18 +458,18 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { if location.x < size.width * 1.0 / 5.0 { if self.currentIndex != 0 { self.currentIndex -= 1 - self.updateItems(size: size, transition: .immediate) + self.updateItems(size: size, transition: .immediate, stripTransition: .animated(duration: 0.3, curve: .spring)) } else if self.items.count > 1 { self.currentIndex = self.items.count - 1 - self.updateItems(size: size, transition: .immediate, synchronous: true) + self.updateItems(size: size, transition: .immediate, stripTransition: .animated(duration: 0.3, curve: .spring), synchronous: true) } } else { if self.currentIndex < self.items.count - 1 { self.currentIndex += 1 - self.updateItems(size: size, transition: .immediate) + self.updateItems(size: size, transition: .immediate, stripTransition: .animated(duration: 0.3, curve: .spring)) } else if self.items.count > 1 { self.currentIndex = 0 - self.updateItems(size: size, transition: .immediate, synchronous: true) + self.updateItems(size: size, transition: .immediate, stripTransition: .animated(duration: 0.3, curve: .spring), synchronous: true) } } } @@ -452,7 +492,7 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { } self.transitionFraction = transitionFraction if let size = self.validLayout { - self.updateItems(size: size, transition: .animated(duration: 0.3, curve: .spring)) + self.updateItems(size: size, transition: .animated(duration: 0.3, curve: .spring), stripTransition: .animated(duration: 0.3, curve: .spring)) } case .cancelled, .ended: let translation = recognizer.translation(in: self.view) @@ -472,7 +512,7 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { self.currentIndex = updatedIndex self.transitionFraction = 0.0 if let size = self.validLayout { - self.updateItems(size: size, transition: .animated(duration: 0.3, curve: .spring)) + self.updateItems(size: size, transition: .animated(duration: 0.3, curve: .spring), stripTransition: .animated(duration: 0.3, curve: .spring)) } default: break @@ -497,14 +537,14 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { switch entry { case let .topImage(representations, _): items.append(.topImage(representations)) - case let .image(reference, representations, _, _, _, _): + case let .image(_, reference, representations, _, _, _, _): items.append(.image(reference, representations)) } } strongSelf.galleryEntries = entries strongSelf.items = items if let size = strongSelf.validLayout { - strongSelf.updateItems(size: size, transition: .immediate) + strongSelf.updateItems(size: size, transition: .immediate, stripTransition: .immediate) } if items.isEmpty { if !strongSelf.didSetReady { @@ -514,10 +554,10 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { } })) } - self.updateItems(size: size, transition: transition) + self.updateItems(size: size, transition: transition, stripTransition: transition) } - private func updateItems(size: CGSize, transition: ContainedViewLayoutTransition, synchronous: Bool = false) { + private func updateItems(size: CGSize, transition: ContainedViewLayoutTransition, stripTransition: ContainedViewLayoutTransition, synchronous: Bool = false) { var validIds: [WrappedMediaResourceId] = [] var addedItemNodesForAdditiveTransition: [PeerInfoAvatarListItemNode] = [] var additiveTransitionOffset: CGFloat = 0.0 @@ -571,10 +611,9 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { let stripNode = ASImageNode() stripNode.displaysAsynchronously = false stripNode.displayWithoutProcessing = true - if stripNodes.count == self.currentIndex { - stripNode.image = self.activeStripImage - } else { - stripNode.image = self.inactiveStripImage + stripNode.image = self.activeStripImage + if stripNodes.count != self.currentIndex { + stripNode.alpha = 0.2 } self.stripNodes.append(stripNode) self.stripContainerNode.addSubnode(stripNode) @@ -589,12 +628,16 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { if self.appliedStripNodeCurrentIndex != self.currentIndex { if let appliedStripNodeCurrentIndex = self.appliedStripNodeCurrentIndex { if appliedStripNodeCurrentIndex >= 0 && appliedStripNodeCurrentIndex < self.stripNodes.count { - self.stripNodes[appliedStripNodeCurrentIndex].image = self.inactiveStripImage + let previousAlpha = self.stripNodes[appliedStripNodeCurrentIndex].alpha + self.stripNodes[appliedStripNodeCurrentIndex].alpha = 0.2 + if previousAlpha == 1.0 { + self.stripNodes[appliedStripNodeCurrentIndex].layer.animateAlpha(from: 1.0, to: 0.2, duration: 0.5, timingFunction: kCAMediaTimingFunctionSpring) + } } } self.appliedStripNodeCurrentIndex = self.currentIndex if self.currentIndex >= 0 && self.currentIndex < self.stripNodes.count { - self.stripNodes[self.currentIndex].image = self.activeStripImage + self.stripNodes[self.currentIndex].alpha = 1.0 } } if hadOneStripNode && self.stripNodes.count > 1 { @@ -603,15 +646,20 @@ final class PeerInfoAvatarListContainerNode: ASDisplayNode { let stripInset: CGFloat = 8.0 let stripSpacing: CGFloat = 4.0 let stripWidth: CGFloat = max(5.0, floor((size.width - stripInset * 2.0 - stripSpacing * CGFloat(self.stripNodes.count - 1)) / CGFloat(self.stripNodes.count))) - var stripX: CGFloat = stripInset + let currentStripMinX = stripInset + CGFloat(self.currentIndex) * (stripWidth + stripSpacing) + let currentStripMidX = floor(currentStripMinX + stripWidth / 2.0) + let lastStripMaxX = stripInset + CGFloat(self.stripNodes.count - 1) * (stripWidth + stripSpacing) + stripWidth + let maxStripOffset: CGFloat = 0.0 + let stripOffset: CGFloat = min(0.0, max(size.width - stripInset - lastStripMaxX, size.width / 2.0 - currentStripMidX)) for i in 0 ..< self.stripNodes.count { + let stripX: CGFloat = stripInset + CGFloat(i) * (stripWidth + stripSpacing) if i == 0 && self.stripNodes.count == 1 { self.stripNodes[i].isHidden = true } else { self.stripNodes[i].isHidden = false } - self.stripNodes[i].frame = CGRect(origin: CGPoint(x: stripX, y: 0.0), size: CGSize(width: stripWidth + 1.0, height: 2.0)) - stripX += stripWidth + stripSpacing + let stripFrame = CGRect(origin: CGPoint(x: stripOffset + stripX, y: 0.0), size: CGSize(width: stripWidth + 1.0, height: 2.0)) + stripTransition.updateFrame(node: self.stripNodes[i], frame: stripFrame) } if let item = self.items.first, let itemNode = self.itemNodes[item.id] { @@ -1047,8 +1095,10 @@ protocol PeerInfoHeaderTextFieldNode: ASDisplayNode { func update(width: CGFloat, safeInset: CGFloat, hasPrevious: Bool, placeholder: String, isEnabled: Bool, presentationData: PresentationData, updateText: String?) -> CGFloat } -final class PeerInfoHeaderSingleLineTextFieldNode: ASDisplayNode, PeerInfoHeaderTextFieldNode { +final class PeerInfoHeaderSingleLineTextFieldNode: ASDisplayNode, PeerInfoHeaderTextFieldNode, UITextFieldDelegate { private let textNode: TextFieldNode + private let clearIconNode: ASImageNode + private let clearButtonNode: HighlightableButtonNode private let topSeparator: ASDisplayNode private var theme: PresentationTheme? @@ -1059,20 +1109,69 @@ final class PeerInfoHeaderSingleLineTextFieldNode: ASDisplayNode, PeerInfoHeader override init() { self.textNode = TextFieldNode() + + self.clearIconNode = ASImageNode() + self.clearIconNode.isLayerBacked = true + self.clearIconNode.displayWithoutProcessing = true + self.clearIconNode.displaysAsynchronously = false + self.clearIconNode.isHidden = true + + self.clearButtonNode = HighlightableButtonNode() + self.clearButtonNode.isHidden = true + self.topSeparator = ASDisplayNode() super.init() self.addSubnode(self.textNode) + self.addSubnode(self.clearIconNode) + self.addSubnode(self.clearButtonNode) self.addSubnode(self.topSeparator) + + self.textNode.textField.delegate = self + + self.clearButtonNode.addTarget(self, action: #selector(self.clearButtonPressed), forControlEvents: .touchUpInside) + self.clearButtonNode.highligthedChanged = { [weak self] highlighted in + if let strongSelf = self { + if highlighted { + strongSelf.clearIconNode.layer.removeAnimation(forKey: "opacity") + strongSelf.clearIconNode.alpha = 0.4 + } else { + strongSelf.clearIconNode.alpha = 1.0 + strongSelf.clearIconNode.layer.animateAlpha(from: 0.4, to: 1.0, duration: 0.2) + } + } + } + } + + @objc private func clearButtonPressed() { + self.textNode.textField.text = "" + self.updateClearButtonVisibility() + } + + @objc func textFieldDidBeginEditing(_ textField: UITextField) { + self.updateClearButtonVisibility() + } + + @objc func textFieldDidEndEditing(_ textField: UITextField) { + self.updateClearButtonVisibility() + } + + private func updateClearButtonVisibility() { + let isHidden = !self.textNode.textField.isFirstResponder || self.text.isEmpty + self.clearIconNode.isHidden = isHidden + self.clearButtonNode.isHidden = isHidden + self.clearButtonNode.isAccessibilityElement = isHidden } func update(width: CGFloat, safeInset: CGFloat, hasPrevious: Bool, placeholder: String, isEnabled: Bool, presentationData: PresentationData, updateText: String?) -> CGFloat { if self.theme !== presentationData.theme { self.theme = presentationData.theme self.textNode.textField.textColor = presentationData.theme.list.itemPrimaryTextColor - //self.textNode.textField.keyboardAppearance = presentationData.theme.keyboardAppearance + self.textNode.textField.keyboardAppearance = presentationData.theme.rootController.keyboardColor.keyboardAppearance self.textNode.textField.tintColor = presentationData.theme.list.itemAccentColor + + self.clearIconNode.image = PresentationResourcesItemList.itemListClearInputIcon(presentationData.theme) } let attributedPlaceholderText = NSAttributedString(string: placeholder, font: Font.regular(17.0), textColor: presentationData.theme.list.itemPlaceholderTextColor) @@ -1090,7 +1189,13 @@ final class PeerInfoHeaderSingleLineTextFieldNode: ASDisplayNode, PeerInfoHeader let height: CGFloat = 44.0 - self.textNode.frame = CGRect(origin: CGPoint(x: safeInset + 16.0, y: floor((height - 40.0) / 2.0)), size: CGSize(width: max(1.0, width - 16.0 * 2.0), height: 40.0)) + let buttonSize = CGSize(width: 38.0, height: height) + self.clearButtonNode.frame = CGRect(origin: CGPoint(x: width - safeInset - buttonSize.width, y: 0.0), size: buttonSize) + if let image = self.clearIconNode.image { + self.clearIconNode.frame = CGRect(origin: CGPoint(x: width - safeInset - buttonSize.width + floor((buttonSize.width - image.size.width) / 2.0), y: floor((height - image.size.height) / 2.0)), size: image.size) + } + + self.textNode.frame = CGRect(origin: CGPoint(x: safeInset + 16.0, y: floor((height - 40.0) / 2.0)), size: CGSize(width: max(1.0, width - 16.0 * 2.0 - 32.0), height: 40.0)) self.textNode.isUserInteractionEnabled = isEnabled self.textNode.alpha = isEnabled ? 1.0 : 0.6 @@ -1103,6 +1208,8 @@ final class PeerInfoHeaderMultiLineTextFieldNode: ASDisplayNode, PeerInfoHeaderT private let textNode: EditableTextNode private let textNodeContainer: ASDisplayNode private let measureTextNode: ImmediateTextNode + private let clearIconNode: ASImageNode + private let clearButtonNode: HighlightableButtonNode private let topSeparator: ASDisplayNode private let requestUpdateHeight: () -> Void @@ -1119,16 +1226,54 @@ final class PeerInfoHeaderMultiLineTextFieldNode: ASDisplayNode, PeerInfoHeaderT self.requestUpdateHeight = requestUpdateHeight self.textNode = EditableTextNode() + self.textNode.clipsToBounds = false + self.textNode.textView.clipsToBounds = false + self.textNode.textContainerInset = UIEdgeInsets() + self.textNodeContainer = ASDisplayNode() self.measureTextNode = ImmediateTextNode() self.measureTextNode.maximumNumberOfLines = 0 self.topSeparator = ASDisplayNode() + self.clearIconNode = ASImageNode() + self.clearIconNode.isLayerBacked = true + self.clearIconNode.displayWithoutProcessing = true + self.clearIconNode.displaysAsynchronously = false + self.clearIconNode.isHidden = true + + self.clearButtonNode = HighlightableButtonNode() + self.clearButtonNode.isHidden = true + super.init() self.textNodeContainer.addSubnode(self.textNode) self.addSubnode(self.textNodeContainer) + self.addSubnode(self.clearIconNode) + self.addSubnode(self.clearButtonNode) self.addSubnode(self.topSeparator) + + self.clearButtonNode.addTarget(self, action: #selector(self.clearButtonPressed), forControlEvents: .touchUpInside) + self.clearButtonNode.highligthedChanged = { [weak self] highlighted in + if let strongSelf = self { + if highlighted { + strongSelf.clearIconNode.layer.removeAnimation(forKey: "opacity") + strongSelf.clearIconNode.alpha = 0.4 + } else { + strongSelf.clearIconNode.alpha = 1.0 + strongSelf.clearIconNode.layer.animateAlpha(from: 0.4, to: 1.0, duration: 0.2) + } + } + } + } + + @objc private func clearButtonPressed() { + guard let theme = self.theme else { + return + } + let attributedText = NSAttributedString(string: "", font: Font.regular(17.0), textColor: theme.list.itemPrimaryTextColor) + self.textNode.attributedText = attributedText + self.requestUpdateHeight() + self.updateClearButtonVisibility() } func update(width: CGFloat, safeInset: CGFloat, hasPrevious: Bool, placeholder: String, isEnabled: Bool, presentationData: PresentationData, updateText: String?) -> CGFloat { @@ -1137,11 +1282,14 @@ final class PeerInfoHeaderMultiLineTextFieldNode: ASDisplayNode, PeerInfoHeaderT if self.theme !== presentationData.theme { self.theme = presentationData.theme let textColor = presentationData.theme.list.itemPrimaryTextColor + self.textNode.typingAttributes = [NSAttributedString.Key.font.rawValue: Font.regular(17.0), NSAttributedString.Key.foregroundColor.rawValue: textColor] self.textNode.clipsToBounds = true self.textNode.delegate = self self.textNode.hitTestSlop = UIEdgeInsets(top: -5.0, left: -5.0, bottom: -5.0, right: -5.0) + + self.clearIconNode.image = PresentationResourcesItemList.itemListClearInputIcon(presentationData.theme) } self.topSeparator.backgroundColor = presentationData.theme.list.itemBlocksSeparatorColor @@ -1163,18 +1311,39 @@ final class PeerInfoHeaderMultiLineTextFieldNode: ASDisplayNode, PeerInfoHeaderT } let attributedMeasureText = NSAttributedString(string: measureText, font: Font.regular(17.0), textColor: .black) self.measureTextNode.attributedText = attributedMeasureText - let measureTextSize = self.measureTextNode.updateLayout(CGSize(width: width - safeInset * 2.0 - 16 * 2.0, height: .greatestFiniteMagnitude)) + let measureTextSize = self.measureTextNode.updateLayout(CGSize(width: width - safeInset * 2.0 - 16.0 * 2.0 - 38.0, height: .greatestFiniteMagnitude)) self.currentMeasuredHeight = measureTextSize.height let height = measureTextSize.height + 22.0 - let textNodeFrame = CGRect(origin: CGPoint(x: safeInset + 16.0, y: 10.0), size: CGSize(width: width - safeInset * 2.0 - 16.0 * 2.0, height: max(height, 1000.0))) + let buttonSize = CGSize(width: 38.0, height: height) + self.clearButtonNode.frame = CGRect(origin: CGPoint(x: width - safeInset - buttonSize.width, y: 0.0), size: buttonSize) + if let image = self.clearIconNode.image { + self.clearIconNode.frame = CGRect(origin: CGPoint(x: width - safeInset - buttonSize.width + floor((buttonSize.width - image.size.width) / 2.0), y: floor((height - image.size.height) / 2.0)), size: image.size) + } + + let textNodeFrame = CGRect(origin: CGPoint(x: safeInset + 16.0, y: 10.0), size: CGSize(width: width - safeInset * 2.0 - 16.0 * 2.0 - 38.0, height: max(height, 1000.0))) self.textNodeContainer.frame = textNodeFrame self.textNode.frame = CGRect(origin: CGPoint(), size: textNodeFrame.size) return height } + func editableTextNodeDidBeginEditing(_ editableTextNode: ASEditableTextNode) { + self.updateClearButtonVisibility() + } + + func editableTextNodeDidFinishEditing(_ editableTextNode: ASEditableTextNode) { + self.updateClearButtonVisibility() + } + + private func updateClearButtonVisibility() { + let isHidden = !self.textNode.isFirstResponder() || self.text.isEmpty + self.clearIconNode.isHidden = isHidden + self.clearButtonNode.isHidden = isHidden + self.clearButtonNode.isAccessibilityElement = isHidden + } + func editableTextNode(_ editableTextNode: ASEditableTextNode, shouldChangeTextIn range: NSRange, replacementText text: String) -> Bool { guard let theme = self.theme else { return true @@ -1199,7 +1368,7 @@ final class PeerInfoHeaderMultiLineTextFieldNode: ASDisplayNode, PeerInfoHeaderT } let attributedMeasureText = NSAttributedString(string: measureText, font: Font.regular(17.0), textColor: .black) self.measureTextNode.attributedText = attributedMeasureText - let measureTextSize = self.measureTextNode.updateLayout(CGSize(width: width - safeInset * 2.0 - 16 * 2.0, height: .greatestFiniteMagnitude)) + let measureTextSize = self.measureTextNode.updateLayout(CGSize(width: width - safeInset * 2.0 - 16.0 * 2.0 - 38.0, height: .greatestFiniteMagnitude)) if let currentMeasuredHeight = self.currentMeasuredHeight, abs(measureTextSize.height - currentMeasuredHeight) > 0.1 { self.requestUpdateHeight() } @@ -1239,6 +1408,10 @@ final class PeerInfoHeaderEditingContentNode: ASDisplayNode { return self.itemNodes[key]?.text } + func shakeTextForKey(_ key: PeerInfoHeaderTextFieldNodeKey) { + self.itemNodes[key]?.layer.addShakeAnimation() + } + func update(width: CGFloat, safeInset: CGFloat, statusBarHeight: CGFloat, navigationHeight: CGFloat, peer: Peer?, cachedData: CachedPeerData?, isContact: Bool, presentationData: PresentationData, transition: ContainedViewLayoutTransition) -> CGFloat { let avatarSize: CGFloat = 100.0 let avatarFrame = CGRect(origin: CGPoint(x: floor((width - avatarSize) / 2.0), y: statusBarHeight + 10.0), size: CGSize(width: avatarSize, height: avatarSize)) @@ -1348,7 +1521,7 @@ final class PeerInfoHeaderNode: ASDisplayNode { private var context: AccountContext private var presentationData: PresentationData? - private let keepExpandedButtons: PeerInfoScreenKeepExpandedButtons + private let isOpenedFromChat: Bool private(set) var isAvatarExpanded: Bool @@ -1371,16 +1544,16 @@ final class PeerInfoHeaderNode: ASDisplayNode { let navigationButtonContainer: PeerInfoHeaderNavigationButtonContainerNode var performButtonAction: ((PeerInfoHeaderButtonKey) -> Void)? - var requestAvatarExpansion: (([AvatarGalleryEntry], (ASDisplayNode, CGRect, () -> (UIView?, UIView?))) -> Void)? + var requestAvatarExpansion: (([AvatarGalleryEntry], AvatarGalleryEntry?, (ASDisplayNode, CGRect, () -> (UIView?, UIView?))?) -> Void)? var requestOpenAvatarForEditing: (() -> Void)? var requestUpdateLayout: (() -> Void)? var navigationTransition: PeerInfoHeaderNavigationTransition? - init(context: AccountContext, avatarInitiallyExpanded: Bool, keepExpandedButtons: PeerInfoScreenKeepExpandedButtons) { + init(context: AccountContext, avatarInitiallyExpanded: Bool, isOpenedFromChat: Bool) { self.context = context self.isAvatarExpanded = avatarInitiallyExpanded - self.keepExpandedButtons = keepExpandedButtons + self.isOpenedFromChat = isOpenedFromChat self.avatarListNode = PeerInfoAvatarListNode(context: context, readyWhenGalleryLoads: avatarInitiallyExpanded) @@ -1441,13 +1614,7 @@ final class PeerInfoHeaderNode: ASDisplayNode { self.addSubnode(self.navigationButtonContainer) self.avatarListNode.avatarContainerNode.tapped = { [weak self] in - guard let strongSelf = self else { - return - } - let avatarNode = strongSelf.avatarListNode.avatarContainerNode.avatarNode - strongSelf.requestAvatarExpansion?(strongSelf.avatarListNode.listContainerNode.galleryEntries, (avatarNode, avatarNode.bounds, { [weak avatarNode] in - return (avatarNode?.view.snapshotContentTree(unhide: true), nil) - })) + self?.initiateAvatarExpansion() } self.editingContentNode.avatarNode.tapped = { [weak self] in guard let strongSelf = self else { @@ -1457,8 +1624,51 @@ final class PeerInfoHeaderNode: ASDisplayNode { } } - func updateAvatarIsHidden(_ isHidden: Bool) { - self.avatarListNode.avatarContainerNode.avatarNode.isHidden = isHidden + func initiateAvatarExpansion() { + if self.isAvatarExpanded { + if let currentEntry = self.avatarListNode.listContainerNode.currentEntry { + self.requestAvatarExpansion?(self.avatarListNode.listContainerNode.galleryEntries, self.avatarListNode.listContainerNode.currentEntry, self.avatarTransitionArguments(entry: currentEntry)) + } + } else if let entry = self.avatarListNode.listContainerNode.galleryEntries.first{ + let avatarNode = self.avatarListNode.avatarContainerNode.avatarNode + self.requestAvatarExpansion?(self.avatarListNode.listContainerNode.galleryEntries, nil, self.avatarTransitionArguments(entry: entry)) + } + } + + func avatarTransitionArguments(entry: AvatarGalleryEntry) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? { + if self.isAvatarExpanded { + if let avatarNode = self.avatarListNode.listContainerNode.currentItemNode?.imageNode { + return (avatarNode, avatarNode.bounds, { [weak avatarNode] in + return (avatarNode?.view.snapshotContentTree(unhide: true), nil) + }) + } else { + return nil + } + } else if entry == self.avatarListNode.listContainerNode.galleryEntries.first { + let avatarNode = self.avatarListNode.avatarContainerNode.avatarNode + return (avatarNode, avatarNode.bounds, { [weak avatarNode] in + return (avatarNode?.view.snapshotContentTree(unhide: true), nil) + }) + } else { + return nil + } + } + + func addToAvatarTransitionSurface(view: UIView) { + if self.isAvatarExpanded { + self.avatarListNode.listContainerNode.view.addSubview(view) + } else { + self.view.addSubview(view) + } + } + + func updateAvatarIsHidden(entry: AvatarGalleryEntry?) { + if let entry = entry { + self.avatarListNode.avatarContainerNode.avatarNode.isHidden = entry == self.avatarListNode.listContainerNode.galleryEntries.first + } else { + self.avatarListNode.avatarContainerNode.avatarNode.isHidden = false + } + self.avatarListNode.listContainerNode.updateEntryIsHidden(entry: entry) } func update(width: CGFloat, containerHeight: CGFloat, containerInset: CGFloat, statusBarHeight: CGFloat, navigationHeight: CGFloat, contentOffset: CGFloat, presentationData: PresentationData, peer: Peer?, cachedData: CachedPeerData?, notificationSettings: TelegramPeerNotificationSettings?, statusData: PeerInfoStatusData?, isContact: Bool, state: PeerInfoState, transition: ContainedViewLayoutTransition, additive: Bool) -> CGFloat { @@ -1520,7 +1730,7 @@ final class PeerInfoHeaderNode: ASDisplayNode { let expandedAvatarListHeight = min(width, containerHeight - expandedAvatarControlsHeight) let expandedAvatarListSize = CGSize(width: width, height: expandedAvatarListHeight) - let buttonKeys: [PeerInfoHeaderButtonKey] = peerInfoHeaderButtons(peer: peer, cachedData: cachedData) + let buttonKeys: [PeerInfoHeaderButtonKey] = peerInfoHeaderButtons(peer: peer, cachedData: cachedData, isOpenedFromChat: self.isOpenedFromChat) var isVerified = false let titleString: NSAttributedString @@ -1530,7 +1740,11 @@ final class PeerInfoHeaderNode: ASDisplayNode { } if let peer = peer { - titleString = NSAttributedString(string: peer.displayTitle(strings: presentationData.strings, displayOrder: presentationData.nameDisplayOrder), font: Font.medium(24.0), textColor: presentationData.theme.list.itemPrimaryTextColor) + if peer.id == self.context.account.peerId { + titleString = NSAttributedString(string: presentationData.strings.Conversation_SavedMessages, font: Font.medium(24.0), textColor: presentationData.theme.list.itemPrimaryTextColor) + } else { + titleString = NSAttributedString(string: peer.displayTitle(strings: presentationData.strings, displayOrder: presentationData.nameDisplayOrder), font: Font.medium(24.0), textColor: presentationData.theme.list.itemPrimaryTextColor) + } if let statusData = statusData { let subtitleColor: UIColor @@ -1601,7 +1815,9 @@ final class PeerInfoHeaderNode: ASDisplayNode { subtitleFrame = CGRect(origin: CGPoint(x: floor((width - subtitleSize.width) / 2.0), y: titleFrame.maxY + 1.0), size: subtitleSize) } - let titleLockOffset: CGFloat = 7.0 + (subtitleSize.height.isZero ? 8.0 : 0.0) + let singleTitleLockOffset: CGFloat = (peer?.id == self.context.account.peerId || subtitleSize.height.isZero) ? 8.0 : 0.0 + + let titleLockOffset: CGFloat = 7.0 + singleTitleLockOffset let titleMaxLockOffset: CGFloat = 7.0 let titleCollapseOffset = titleFrame.midY - statusBarHeight - titleLockOffset let titleOffset = -min(titleCollapseOffset, contentOffset) @@ -1899,6 +2115,12 @@ final class PeerInfoHeaderNode: ASDisplayNode { case .addMember: buttonText = presentationData.strings.PeerInfo_ButtonAddMember buttonIcon = .addMember + case .search: + buttonText = presentationData.strings.PeerInfo_ButtonSearch + buttonIcon = .search + case .leave: + buttonText = presentationData.strings.PeerInfo_ButtonLeave + buttonIcon = .leave } buttonNode.update(size: buttonFrame.size, text: buttonText, icon: buttonIcon, isExpanded: self.isAvatarExpanded, presentationData: presentationData, transition: buttonTransition) transition.updateSublayerTransformScaleAdditive(node: buttonNode, scale: buttonsScale) @@ -1909,21 +2131,24 @@ final class PeerInfoHeaderNode: ASDisplayNode { buttonsAlphaTransition.updateAlpha(node: buttonNode, alpha: buttonsAlpha) let hiddenWhileExpanded: Bool - switch self.keepExpandedButtons { - case .message: - switch buttonKey { - case .mute: - hiddenWhileExpanded = true - default: - hiddenWhileExpanded = false - } - case .mute: - switch buttonKey { - case .message: - hiddenWhileExpanded = true - default: - hiddenWhileExpanded = false + if buttonKeys.count > 3 { + if self.isOpenedFromChat { + switch buttonKey { + case .message, .search: + hiddenWhileExpanded = true + default: + hiddenWhileExpanded = false + } + } else { + switch buttonKey { + case .mute, .search: + hiddenWhileExpanded = true + default: + hiddenWhileExpanded = false + } } + } else { + hiddenWhileExpanded = false } if self.isAvatarExpanded, hiddenWhileExpanded { diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift index c13323bca0..070320143f 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoPaneContainerNode.swift @@ -16,6 +16,7 @@ protocol PeerInfoPaneNode: ASDisplayNode { func update(size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, isScrollingLockedAtTop: Bool, presentationData: PresentationData, synchronous: Bool, transition: ContainedViewLayoutTransition) func scrollToTop() -> Bool func transferVelocity(_ velocity: CGFloat) + func cancelPreviewGestures() func findLoadedMessage(id: MessageId) -> Message? func transitionNodeForGallery(messageId: MessageId, media: Media) -> (ASDisplayNode, CGRect, () -> (UIView?, UIView?))? func addToTransitionSurface(view: UIView) @@ -26,6 +27,7 @@ protocol PeerInfoPaneNode: ASDisplayNode { final class PeerInfoPaneWrapper { let key: PeerInfoPaneKey let node: PeerInfoPaneNode + var isAnimatingOut: Bool = false private var appliedParams: (CGSize, CGFloat, CGFloat, CGFloat, Bool, PresentationData)? init(key: PeerInfoPaneKey, node: PeerInfoPaneNode) { @@ -114,6 +116,10 @@ struct PeerInfoPaneSpecifier: Equatable { var title: String } +private func interpolateFrame(from fromValue: CGRect, to toValue: CGRect, t: CGFloat) -> CGRect { + return CGRect(x: floorToScreenPixels(toValue.origin.x * t + fromValue.origin.x * (1.0 - t)), y: floorToScreenPixels(toValue.origin.y * t + fromValue.origin.y * (1.0 - t)), width: floorToScreenPixels(toValue.size.width * t + fromValue.size.width * (1.0 - t)), height: floorToScreenPixels(toValue.size.height * t + fromValue.size.height * (1.0 - t))) +} + final class PeerInfoPaneTabsContainerNode: ASDisplayNode { private let scrollNode: ASScrollNode private var paneNodes: [PeerInfoPaneKey: PeerInfoPaneTabsContainerPaneNode] = [:] @@ -148,7 +154,7 @@ final class PeerInfoPaneTabsContainerNode: ASDisplayNode { self.scrollNode.addSubnode(self.selectedLineNode) } - func update(size: CGSize, presentationData: PresentationData, paneList: [PeerInfoPaneSpecifier], selectedPane: PeerInfoPaneKey?, transition: ContainedViewLayoutTransition) { + func update(size: CGSize, presentationData: PresentationData, paneList: [PeerInfoPaneSpecifier], selectedPane: PeerInfoPaneKey?, transitionFraction: CGFloat, transition: ContainedViewLayoutTransition) { transition.updateFrame(node: self.scrollNode, frame: CGRect(origin: CGPoint(), size: size)) let focusOnSelectedPane = self.currentParams?.1 != selectedPane @@ -192,8 +198,8 @@ final class PeerInfoPaneTabsContainerNode: ASDisplayNode { var tabSizes: [(CGSize, PeerInfoPaneTabsContainerPaneNode, Bool)] = [] var totalRawTabSize: CGFloat = 0.0 + var selectionFrames: [CGRect] = [] - var selectedFrame: CGRect? for specifier in paneList { guard let paneNode = self.paneNodes[specifier.key] else { continue @@ -208,8 +214,8 @@ final class PeerInfoPaneTabsContainerNode: ASDisplayNode { totalRawTabSize += paneNodeSize.width } - let spacing: CGFloat = 32.0 - if tabSizes.count == 1 { + let minSpacing: CGFloat = 10.0 + if tabSizes.count <= 1 { for i in 0 ..< tabSizes.count { let (paneNodeSize, paneNode, wasAdded) = tabSizes[i] let leftOffset: CGFloat = 16.0 @@ -226,36 +232,63 @@ final class PeerInfoPaneTabsContainerNode: ASDisplayNode { paneNode.updateArea(size: paneFrame.size, sideInset: areaSideInset) paneNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -areaSideInset, bottom: 0.0, right: -areaSideInset) - if paneList[i].key == selectedPane { - selectedFrame = paneFrame - } + selectionFrames.append(paneFrame) } self.scrollNode.view.contentSize = CGSize(width: size.width, height: size.height) - } else if totalRawTabSize + CGFloat(tabSizes.count + 1) * spacing <= size.width { + } else if totalRawTabSize + CGFloat(tabSizes.count + 1) * minSpacing <= size.width { let availableSpace = size.width let availableSpacing = availableSpace - totalRawTabSize let perTabSpacing = floor(availableSpacing / CGFloat(tabSizes.count + 1)) - var leftOffset = perTabSpacing - for i in 0 ..< tabSizes.count { - let (paneNodeSize, paneNode, wasAdded) = tabSizes[i] - - let paneFrame = CGRect(origin: CGPoint(x: leftOffset, y: floor((size.height - paneNodeSize.height) / 2.0)), size: paneNodeSize) - if wasAdded { - paneNode.frame = paneFrame - paneNode.alpha = 0.0 - transition.updateAlpha(node: paneNode, alpha: 1.0) - } else { - transition.updateFrameAdditiveToCenter(node: paneNode, frame: paneFrame) + let normalizedPerTabWidth = floor(availableSpace / CGFloat(tabSizes.count)) + var maxSpacing: CGFloat = 0.0 + var minSpacing: CGFloat = .greatestFiniteMagnitude + for i in 0 ..< tabSizes.count - 1 { + let distanceToNextBoundary = (normalizedPerTabWidth - tabSizes[i].0.width) / 2.0 + let nextDistanceToBoundary = (normalizedPerTabWidth - tabSizes[i + 1].0.width) / 2.0 + let distance = nextDistanceToBoundary + distanceToNextBoundary + maxSpacing = max(distance, maxSpacing) + minSpacing = min(distance, minSpacing) + } + + if minSpacing >= 100.0 || (maxSpacing / minSpacing) < 0.2 { + for i in 0 ..< tabSizes.count { + let (paneNodeSize, paneNode, wasAdded) = tabSizes[i] + + let paneFrame = CGRect(origin: CGPoint(x: CGFloat(i) * normalizedPerTabWidth + floor((normalizedPerTabWidth - paneNodeSize.width) / 2.0), y: floor((size.height - paneNodeSize.height) / 2.0)), size: paneNodeSize) + if wasAdded { + paneNode.frame = paneFrame + paneNode.alpha = 0.0 + transition.updateAlpha(node: paneNode, alpha: 1.0) + } else { + transition.updateFrameAdditiveToCenter(node: paneNode, frame: paneFrame) + } + let areaSideInset = floor((normalizedPerTabWidth - paneNodeSize.width) / 2.0) + paneNode.updateArea(size: paneFrame.size, sideInset: areaSideInset) + paneNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -areaSideInset, bottom: 0.0, right: -areaSideInset) + + selectionFrames.append(paneFrame) } - let areaSideInset = floor(perTabSpacing / 2.0) - paneNode.updateArea(size: paneFrame.size, sideInset: areaSideInset) - paneNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -areaSideInset, bottom: 0.0, right: -areaSideInset) - - leftOffset += paneNodeSize.width + perTabSpacing - - if paneList[i].key == selectedPane { - selectedFrame = paneFrame + } else { + var leftOffset = perTabSpacing + for i in 0 ..< tabSizes.count { + let (paneNodeSize, paneNode, wasAdded) = tabSizes[i] + + let paneFrame = CGRect(origin: CGPoint(x: leftOffset, y: floor((size.height - paneNodeSize.height) / 2.0)), size: paneNodeSize) + if wasAdded { + paneNode.frame = paneFrame + paneNode.alpha = 0.0 + transition.updateAlpha(node: paneNode, alpha: 1.0) + } else { + transition.updateFrameAdditiveToCenter(node: paneNode, frame: paneFrame) + } + let areaSideInset = floor(perTabSpacing / 2.0) + paneNode.updateArea(size: paneFrame.size, sideInset: areaSideInset) + paneNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -areaSideInset, bottom: 0.0, right: -areaSideInset) + + leftOffset += paneNodeSize.width + perTabSpacing + + selectionFrames.append(paneFrame) } } self.scrollNode.view.contentSize = CGSize(width: size.width, height: size.height) @@ -272,14 +305,29 @@ final class PeerInfoPaneTabsContainerNode: ASDisplayNode { } else { transition.updateFrameAdditiveToCenter(node: paneNode, frame: paneFrame) } - paneNode.updateArea(size: paneFrame.size, sideInset: spacing) - paneNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -spacing, bottom: 0.0, right: -spacing) - if paneList[i].key == selectedPane { - selectedFrame = paneFrame - } - leftOffset += paneNodeSize.width + spacing + paneNode.updateArea(size: paneFrame.size, sideInset: minSpacing) + paneNode.hitTestSlop = UIEdgeInsets(top: 0.0, left: -minSpacing, bottom: 0.0, right: -minSpacing) + + selectionFrames.append(paneFrame) + + leftOffset += paneNodeSize.width + minSpacing + } + self.scrollNode.view.contentSize = CGSize(width: leftOffset - minSpacing + sideInset, height: size.height) + } + + var selectedFrame: CGRect? + if let selectedPane = selectedPane, let currentIndex = paneList.index(where: { $0.key == selectedPane }) { + if currentIndex != 0 && transitionFraction > 0.0 { + let currentFrame = selectionFrames[currentIndex] + let previousFrame = selectionFrames[currentIndex - 1] + selectedFrame = interpolateFrame(from: currentFrame, to: previousFrame, t: abs(transitionFraction)) + } else if currentIndex != paneList.count - 1 && transitionFraction < 0.0 { + let currentFrame = selectionFrames[currentIndex] + let previousFrame = selectionFrames[currentIndex + 1] + selectedFrame = interpolateFrame(from: currentFrame, to: previousFrame, t: abs(transitionFraction)) + } else { + selectedFrame = selectionFrames[currentIndex] } - self.scrollNode.view.contentSize = CGSize(width: leftOffset - spacing + sideInset, height: size.height) } if let selectedFrame = selectedFrame { @@ -313,7 +361,60 @@ final class PeerInfoPaneTabsContainerNode: ASDisplayNode { } } -final class PeerInfoPaneContainerNode: ASDisplayNode { +private final class PeerInfoPendingPane { + let pane: PeerInfoPaneWrapper + private var disposable: Disposable? + var isReady: Bool = false + + init( + context: AccountContext, + chatControllerInteraction: ChatControllerInteraction, + data: PeerInfoScreenData, + openPeerContextAction: @escaping (Peer, ASDisplayNode, ContextGesture?) -> Void, + requestPerformPeerMemberAction: @escaping (PeerInfoMember, PeerMembersListAction) -> Void, + peerId: PeerId, + key: PeerInfoPaneKey, + hasBecomeReady: @escaping (PeerInfoPaneKey) -> Void + ) { + let paneNode: PeerInfoPaneNode + switch key { + case .media: + paneNode = PeerInfoVisualMediaPaneNode(context: context, chatControllerInteraction: chatControllerInteraction, peerId: peerId) + case .files: + paneNode = PeerInfoListPaneNode(context: context, chatControllerInteraction: chatControllerInteraction, peerId: peerId, tagMask: .file) + case .links: + paneNode = PeerInfoListPaneNode(context: context, chatControllerInteraction: chatControllerInteraction, peerId: peerId, tagMask: .webPage) + case .voice: + paneNode = PeerInfoListPaneNode(context: context, chatControllerInteraction: chatControllerInteraction, peerId: peerId, tagMask: .voiceOrInstantVideo) + case .music: + paneNode = PeerInfoListPaneNode(context: context, chatControllerInteraction: chatControllerInteraction, peerId: peerId, tagMask: .music) + case .groupsInCommon: + paneNode = PeerInfoGroupsInCommonPaneNode(context: context, peerId: peerId, chatControllerInteraction: chatControllerInteraction, openPeerContextAction: openPeerContextAction, groupsInCommonContext: data.groupsInCommon!) + case .members: + if case let .longList(membersContext) = data.members { + paneNode = PeerInfoMembersPaneNode(context: context, peerId: peerId, membersContext: membersContext, action: { member, action in + requestPerformPeerMemberAction(member, action) + }) + } else { + preconditionFailure() + } + } + + self.pane = PeerInfoPaneWrapper(key: key, node: paneNode) + self.disposable = (paneNode.isReady + |> take(1) + |> deliverOnMainQueue).start(next: { [weak self] _ in + self?.isReady = true + hasBecomeReady(key) + }) + } + + deinit { + self.disposable?.dispose() + } +} + +final class PeerInfoPaneContainerNode: ASDisplayNode, UIGestureRecognizerDelegate { private let context: AccountContext private let peerId: PeerId @@ -326,11 +427,22 @@ final class PeerInfoPaneContainerNode: ASDisplayNode { var didSetIsReady = false private var currentParams: (size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, expansionFraction: CGFloat, presentationData: PresentationData, data: PeerInfoScreenData?)? - private(set) var currentPaneKey: PeerInfoPaneKey? - private(set) var currentPane: PeerInfoPaneWrapper? - private var currentCandidatePaneKey: PeerInfoPaneKey? - private var candidatePane: (PeerInfoPaneWrapper, Disposable, Bool)? + private(set) var currentPaneKey: PeerInfoPaneKey? + var pendingSwitchToPaneKey: PeerInfoPaneKey? + + var currentPane: PeerInfoPaneWrapper? { + if let currentPaneKey = self.currentPaneKey { + return self.currentPanes[currentPaneKey] + } else { + return nil + } + } + + private var currentPanes: [PeerInfoPaneKey: PeerInfoPaneWrapper] = [:] + private var pendingPanes: [PeerInfoPaneKey: PeerInfoPendingPane] = [:] + + private var transitionFraction: CGFloat = 0.0 var selectionPanelNode: PeerInfoSelectionPanelNode? @@ -338,7 +450,7 @@ final class PeerInfoPaneContainerNode: ASDisplayNode { var openPeerContextAction: ((Peer, ASDisplayNode, ContextGesture?) -> Void)? var requestPerformPeerMemberAction: ((PeerInfoMember, PeerMembersListAction) -> Void)? - var currentPaneUpdated: (() -> Void)? + var currentPaneUpdated: ((Bool) -> Void)? var requestExpandTabs: (() -> Bool)? private var currentAvailablePanes: [PeerInfoPaneKey]? @@ -376,14 +488,103 @@ final class PeerInfoPaneContainerNode: ASDisplayNode { } return } - if strongSelf.currentCandidatePaneKey == key { - return + if strongSelf.currentPanes[key] != nil { + strongSelf.currentPaneKey = key + + if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = strongSelf.currentParams { + strongSelf.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, expansionFraction: expansionFraction, presentationData: presentationData, data: data, transition: .animated(duration: 0.4, curve: .spring)) + + strongSelf.currentPaneUpdated?(true) + } + } else if strongSelf.pendingSwitchToPaneKey != key { + strongSelf.pendingSwitchToPaneKey = key + + if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = strongSelf.currentParams { + strongSelf.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, expansionFraction: expansionFraction, presentationData: presentationData, data: data, transition: .animated(duration: 0.4, curve: .spring)) + } } - strongSelf.currentCandidatePaneKey = key - - if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = strongSelf.currentParams { - strongSelf.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, expansionFraction: expansionFraction, presentationData: presentationData, data: data, transition: .immediate) + } + } + + override func didLoad() { + super.didLoad() + + let panRecognizer = InteractiveTransitionGestureRecognizer(target: self, action: #selector(self.panGesture(_:)), allowedDirections: { [weak self] in + guard let strongSelf = self, let currentPaneKey = strongSelf.currentPaneKey, let availablePanes = strongSelf.currentParams?.data?.availablePanes, let index = availablePanes.index(of: currentPaneKey) else { + return [] } + if index == 0 { + return .left + } + return [.left, .right] + }) + panRecognizer.delegate = self + panRecognizer.delaysTouchesBegan = false + panRecognizer.cancelsTouchesInView = true + self.view.addGestureRecognizer(panRecognizer) + } + + func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldRecognizeSimultaneouslyWith otherGestureRecognizer: UIGestureRecognizer) -> Bool { + return false + } + + func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldBeRequiredToFailBy otherGestureRecognizer: UIGestureRecognizer) -> Bool { + if let _ = otherGestureRecognizer as? InteractiveTransitionGestureRecognizer { + return false + } + if let _ = otherGestureRecognizer as? UIPanGestureRecognizer { + return true + } + return false + } + + @objc private func panGesture(_ recognizer: UIPanGestureRecognizer) { + switch recognizer.state { + case .changed: + if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = self.currentParams, let availablePanes = data?.availablePanes, availablePanes.count > 1, let currentPaneKey = self.currentPaneKey, let currentIndex = availablePanes.index(of: currentPaneKey) { + let translation = recognizer.translation(in: self.view) + var transitionFraction = translation.x / size.width + if currentIndex <= 0 { + transitionFraction = min(0.0, transitionFraction) + } + if currentIndex >= availablePanes.count - 1 { + transitionFraction = max(0.0, transitionFraction) + } + self.transitionFraction = transitionFraction + self.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, expansionFraction: expansionFraction, presentationData: presentationData, data: data, transition: .immediate) + } + case .cancelled, .ended: + if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = self.currentParams, let availablePanes = data?.availablePanes, availablePanes.count > 1, let currentPaneKey = self.currentPaneKey, let currentIndex = availablePanes.index(of: currentPaneKey) { + let translation = recognizer.translation(in: self.view) + let velocity = recognizer.velocity(in: self.view) + var directionIsToRight: Bool? + if abs(velocity.x) > 10.0 { + directionIsToRight = velocity.x < 0.0 + } else { + if abs(translation.x) > size.width / 2.0 { + directionIsToRight = translation.x > size.width / 2.0 + } + } + var updated = false + if let directionIsToRight = directionIsToRight { + var updatedIndex = currentIndex + if directionIsToRight { + updatedIndex = min(updatedIndex + 1, availablePanes.count - 1) + } else { + updatedIndex = max(updatedIndex - 1, 0) + } + let switchToKey = availablePanes[updatedIndex] + if switchToKey != self.currentPaneKey && self.currentPanes[switchToKey] != nil{ + self.currentPaneKey = switchToKey + updated = true + } + } + self.transitionFraction = 0.0 + self.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, expansionFraction: expansionFraction, presentationData: presentationData, data: data, transition: .animated(duration: 0.35, curve: .spring)) + self.currentPaneUpdated?(false) + } + default: + break } } @@ -408,8 +609,12 @@ final class PeerInfoPaneContainerNode: ASDisplayNode { } func updateSelectedMessageIds(_ selectedMessageIds: Set?, animated: Bool) { - self.currentPane?.node.updateSelectedMessages(animated: animated) - self.candidatePane?.0.node.updateSelectedMessages(animated: animated) + for (_, pane) in self.currentPanes { + pane.node.updateSelectedMessages(animated: animated) + } + for (_, pane) in self.pendingPanes { + pane.pane.node.updateSelectedMessages(animated: animated) + } } func update(size: CGSize, sideInset: CGFloat, bottomInset: CGFloat, visibleHeight: CGFloat, expansionFraction: CGFloat, presentationData: PresentationData, data: PeerInfoScreenData?, transition: ContainedViewLayoutTransition) { @@ -417,6 +622,8 @@ final class PeerInfoPaneContainerNode: ASDisplayNode { let availablePanes = data?.availablePanes ?? [] self.currentAvailablePanes = availablePanes + let previousCurrentPaneKey = self.currentPaneKey + if let currentPaneKey = self.currentPaneKey, !availablePanes.contains(currentPaneKey) { var nextCandidatePaneKey: PeerInfoPaneKey? if let index = previousAvailablePanes.index(of: currentPaneKey), index != 0 { @@ -431,25 +638,21 @@ final class PeerInfoPaneContainerNode: ASDisplayNode { } if let nextCandidatePaneKey = nextCandidatePaneKey { - if self.currentCandidatePaneKey != nextCandidatePaneKey { - self.currentCandidatePaneKey = nextCandidatePaneKey - } + self.pendingSwitchToPaneKey = nextCandidatePaneKey } else { - self.currentCandidatePaneKey = nil - if let (_, disposable, _) = self.candidatePane { - disposable.dispose() - self.candidatePane = nil - } - if let currentPane = self.currentPane { - self.currentPane = nil - currentPane.node.removeFromSupernode() - } + self.currentPaneKey = nil + self.pendingSwitchToPaneKey = nil } } else if self.currentPaneKey == nil { - self.currentCandidatePaneKey = availablePanes.first + self.pendingSwitchToPaneKey = availablePanes.first } - let previousCurrentPaneKey = self.currentPaneKey + let currentIndex: Int? + if let currentPaneKey = self.currentPaneKey { + currentIndex = availablePanes.index(of: currentPaneKey) + } else { + currentIndex = nil + } self.currentParams = (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) @@ -469,138 +672,197 @@ final class PeerInfoPaneContainerNode: ASDisplayNode { let paneFrame = CGRect(origin: CGPoint(x: 0.0, y: tabsHeight), size: CGSize(width: size.width, height: size.height - tabsHeight)) - if let currentCandidatePaneKey = self.currentCandidatePaneKey { - if self.candidatePane?.0.key != currentCandidatePaneKey { - self.candidatePane?.1.dispose() - - let paneNode: PeerInfoPaneNode - switch currentCandidatePaneKey { - case .media: - paneNode = PeerInfoVisualMediaPaneNode(context: self.context, chatControllerInteraction: self.chatControllerInteraction!, peerId: self.peerId) - case .files: - paneNode = PeerInfoListPaneNode(context: self.context, chatControllerInteraction: self.chatControllerInteraction!, peerId: self.peerId, tagMask: .file) - case .links: - paneNode = PeerInfoListPaneNode(context: self.context, chatControllerInteraction: self.chatControllerInteraction!, peerId: self.peerId, tagMask: .webPage) - case .voice: - paneNode = PeerInfoListPaneNode(context: self.context, chatControllerInteraction: self.chatControllerInteraction!, peerId: self.peerId, tagMask: .voiceOrInstantVideo) - case .music: - paneNode = PeerInfoListPaneNode(context: self.context, chatControllerInteraction: self.chatControllerInteraction!, peerId: self.peerId, tagMask: .music) - case .groupsInCommon: - paneNode = PeerInfoGroupsInCommonPaneNode(context: self.context, peerId: self.peerId, chatControllerInteraction: self.chatControllerInteraction!, openPeerContextAction: self.openPeerContextAction!, groupsInCommonContext: data!.groupsInCommon!) - case .members: - if case let .longList(membersContext) = data?.members { - paneNode = PeerInfoMembersPaneNode(context: self.context, peerId: self.peerId, membersContext: membersContext, action: { [weak self] member, action in - self?.requestPerformPeerMemberAction?(member, action) - }) - } else { - preconditionFailure() - } + var visiblePaneIndices: [Int] = [] + var requiredPendingKeys: [PeerInfoPaneKey] = [] + if let currentIndex = currentIndex { + if currentIndex != 0 { + visiblePaneIndices.append(currentIndex - 1) + } + visiblePaneIndices.append(currentIndex) + if currentIndex != availablePanes.count - 1 { + visiblePaneIndices.append(currentIndex + 1) + } + + for index in visiblePaneIndices { + let indexOffset = CGFloat(index - currentIndex) + let key = availablePanes[index] + if self.currentPanes[key] == nil && self.pendingPanes[key] == nil { + requiredPendingKeys.append(key) + } + } + } + if let pendingSwitchToPaneKey = self.pendingSwitchToPaneKey { + if self.currentPanes[pendingSwitchToPaneKey] == nil && self.pendingPanes[pendingSwitchToPaneKey] == nil { + if !requiredPendingKeys.contains(pendingSwitchToPaneKey) { + requiredPendingKeys.append(pendingSwitchToPaneKey) } - - let disposable = MetaDisposable() - self.candidatePane = (PeerInfoPaneWrapper(key: currentCandidatePaneKey, node: paneNode), disposable, false) - - var shouldReLayout = false - disposable.set((paneNode.isReady - |> take(1) - |> deliverOnMainQueue).start(next: { [weak self] _ in - guard let strongSelf = self else { - return - } - if let (candidatePane, disposable, _) = strongSelf.candidatePane { - strongSelf.candidatePane = (candidatePane, disposable, true) - - if shouldReLayout { - if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = strongSelf.currentParams { - strongSelf.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, expansionFraction: expansionFraction, presentationData: presentationData, data: data, transition: strongSelf.currentPane != nil ? .animated(duration: 0.35, curve: .spring) : .immediate) - } - } - } - })) - shouldReLayout = true } } - if let (candidatePane, _, isReady) = self.candidatePane, isReady { - let previousPane = self.currentPane - self.candidatePane = nil - self.currentPaneKey = candidatePane.key - self.currentCandidatePaneKey = nil - self.currentPane = candidatePane - - if let selectionPanelNode = self.selectionPanelNode { - self.insertSubnode(candidatePane.node, belowSubnode: selectionPanelNode) - } else { - self.addSubnode(candidatePane.node) + for key in requiredPendingKeys { + if self.pendingPanes[key] == nil { + var leftScope = false + let pane = PeerInfoPendingPane( + context: self.context, + chatControllerInteraction: self.chatControllerInteraction!, + data: data!, + openPeerContextAction: { [weak self] peer, node, gesture in + self?.openPeerContextAction?(peer, node, gesture) + }, + requestPerformPeerMemberAction: { [weak self] member, action in + self?.requestPerformPeerMemberAction?(member, action) + }, + peerId: self.peerId, + key: key, + hasBecomeReady: { [weak self] key in + let apply: () -> Void = { + guard let strongSelf = self else { + return + } + if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = strongSelf.currentParams { + var transition: ContainedViewLayoutTransition = .immediate + if strongSelf.pendingSwitchToPaneKey == key && strongSelf.currentPaneKey != nil { + transition = .animated(duration: 0.4, curve: .spring) + } + strongSelf.update(size: size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, expansionFraction: expansionFraction, presentationData: presentationData, data: data, transition: transition) + } + } + if leftScope { + apply() + } + } + ) + self.pendingPanes[key] = pane + pane.pane.node.frame = paneFrame + pane.pane.update(size: paneFrame.size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, isScrollingLockedAtTop: expansionFraction < 1.0 - CGFloat.ulpOfOne, presentationData: presentationData, synchronous: true, transition: .immediate) + leftScope = true } - candidatePane.node.frame = paneFrame - candidatePane.update(size: paneFrame.size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: max(0.0, visibleHeight - paneFrame.minY), isScrollingLockedAtTop: expansionFraction < 1.0 - CGFloat.ulpOfOne, presentationData: presentationData, synchronous: true, transition: .immediate) - - if let previousPane = previousPane { - let directionToRight: Bool - if let previousIndex = availablePanes.index(of: previousPane.key), let updatedIndex = availablePanes.index(of: candidatePane.key) { - directionToRight = previousIndex < updatedIndex - } else { - directionToRight = false - } - - let offset: CGFloat = directionToRight ? previousPane.node.bounds.width : -previousPane.node.bounds.width - - transition.animatePositionAdditive(node: candidatePane.node, offset: CGPoint(x: offset, y: 0.0)) - let previousNode = previousPane.node - transition.updateFrame(node: previousNode, frame: paneFrame.offsetBy(dx: -offset, dy: 0.0), completion: { [weak previousNode] _ in - previousNode?.removeFromSupernode() - }) - } - } else if let currentPane = self.currentPane { - let paneWasAdded = currentPane.node.supernode == nil - if paneWasAdded { - self.addSubnode(currentPane.node) - } - - let paneTransition: ContainedViewLayoutTransition = paneWasAdded ? .immediate : transition - paneTransition.updateFrame(node: currentPane.node, frame: paneFrame) - currentPane.update(size: paneFrame.size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, isScrollingLockedAtTop: expansionFraction < 1.0 - CGFloat.ulpOfOne, presentationData: presentationData, synchronous: paneWasAdded, transition: paneTransition) } + for (key, pane) in self.pendingPanes { + pane.pane.node.frame = paneFrame + pane.pane.update(size: paneFrame.size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, isScrollingLockedAtTop: expansionFraction < 1.0 - CGFloat.ulpOfOne, presentationData: presentationData, synchronous: self.currentPaneKey == nil, transition: .immediate) + + if pane.isReady { + self.pendingPanes.removeValue(forKey: key) + self.currentPanes[key] = pane.pane + } + } + + var paneDefaultTransition = transition + var previousPaneKey: PeerInfoPaneKey? + var paneSwitchAnimationOffset: CGFloat = 0.0 + + var updatedCurrentIndex = currentIndex + var animatePaneTransitionOffset: CGFloat? + if let pendingSwitchToPaneKey = self.pendingSwitchToPaneKey, let pane = self.currentPanes[pendingSwitchToPaneKey] { + self.pendingSwitchToPaneKey = nil + previousPaneKey = self.currentPaneKey + self.currentPaneKey = pendingSwitchToPaneKey + updatedCurrentIndex = availablePanes.index(of: pendingSwitchToPaneKey) + if let previousPaneKey = previousPaneKey, let previousIndex = availablePanes.index(of: previousPaneKey), let updatedCurrentIndex = updatedCurrentIndex { + if updatedCurrentIndex < previousIndex { + paneSwitchAnimationOffset = -size.width + } else { + paneSwitchAnimationOffset = size.width + } + } + + paneDefaultTransition = .immediate + } + + for (key, pane) in self.currentPanes { + if let index = availablePanes.index(of: key), let updatedCurrentIndex = updatedCurrentIndex { + var paneWasAdded = false + if pane.node.supernode == nil { + self.addSubnode(pane.node) + paneWasAdded = true + } + let indexOffset = CGFloat(index - updatedCurrentIndex) + + let paneTransition: ContainedViewLayoutTransition = paneWasAdded ? .immediate : paneDefaultTransition + let adjustedFrame = paneFrame.offsetBy(dx: size.width * self.transitionFraction + indexOffset * size.width, dy: 0.0) + + let paneCompletion: () -> Void = { [weak self, weak pane] in + guard let strongSelf = self, let pane = pane else { + return + } + pane.isAnimatingOut = false + if let (size, sideInset, bottomInset, visibleHeight, expansionFraction, presentationData, data) = strongSelf.currentParams { + if let availablePanes = data?.availablePanes, let currentPaneKey = strongSelf.currentPaneKey, let currentIndex = availablePanes.index(of: currentPaneKey), let paneIndex = availablePanes.index(of: key), abs(paneIndex - currentIndex) <= 1 { + } else { + if let pane = strongSelf.currentPanes.removeValue(forKey: key) { + //print("remove \(key)") + pane.node.removeFromSupernode() + } + } + } + } + if let previousPaneKey = previousPaneKey, key == previousPaneKey { + pane.node.frame = adjustedFrame + let isAnimatingOut = pane.isAnimatingOut + pane.isAnimatingOut = true + transition.animateFrame(node: pane.node, from: paneFrame, to: paneFrame.offsetBy(dx: -paneSwitchAnimationOffset, dy: 0.0), completion: isAnimatingOut ? nil : { _ in + paneCompletion() + }) + } else if let previousPaneKey = previousPaneKey, key == self.currentPaneKey { + pane.node.frame = adjustedFrame + let isAnimatingOut = pane.isAnimatingOut + pane.isAnimatingOut = true + transition.animatePositionAdditive(node: pane.node, offset: CGPoint(x: paneSwitchAnimationOffset, y: 0.0), completion: isAnimatingOut ? nil : { + paneCompletion() + }) + } else { + let isAnimatingOut = pane.isAnimatingOut + pane.isAnimatingOut = true + paneTransition.updateFrame(node: pane.node, frame: adjustedFrame, completion: isAnimatingOut ? nil : { _ in + paneCompletion() + }) + } + pane.update(size: paneFrame.size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, isScrollingLockedAtTop: expansionFraction < 1.0 - CGFloat.ulpOfOne, presentationData: presentationData, synchronous: paneWasAdded, transition: paneTransition) + } + } + + //print("currentPanes: \(self.currentPanes.map { $0.0 })") + transition.updateFrame(node: self.tabsContainerNode, frame: CGRect(origin: CGPoint(x: 0.0, y: 0.0), size: CGSize(width: size.width, height: tabsHeight))) self.tabsContainerNode.update(size: CGSize(width: size.width, height: tabsHeight), presentationData: presentationData, paneList: availablePanes.map { key in let title: String switch key { case .media: - title = "Media" + title = presentationData.strings.PeerInfo_PaneMedia case .files: - title = "Files" + title = presentationData.strings.PeerInfo_PaneFiles case .links: - title = "Links" + title = presentationData.strings.PeerInfo_PaneLinks case .voice: - title = "Voice Messages" + title = presentationData.strings.PeerInfo_PaneVoice case .music: - title = "Audio" + title = presentationData.strings.PeerInfo_PaneAudio case .groupsInCommon: - title = "Groups" + title = presentationData.strings.PeerInfo_PaneGroups case .members: - title = "Members" + title = presentationData.strings.PeerInfo_PaneMembers } return PeerInfoPaneSpecifier(key: key, title: title) - }, selectedPane: self.currentPaneKey, transition: transition) + }, selectedPane: self.currentPaneKey, transitionFraction: self.transitionFraction, transition: transition) - if let (candidatePane, _, _) = self.candidatePane { + for (_, pane) in self.pendingPanes { let paneTransition: ContainedViewLayoutTransition = .immediate - paneTransition.updateFrame(node: candidatePane.node, frame: paneFrame) - candidatePane.update(size: paneFrame.size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, isScrollingLockedAtTop: expansionFraction < 1.0 - CGFloat.ulpOfOne, presentationData: presentationData, synchronous: true, transition: paneTransition) + paneTransition.updateFrame(node: pane.pane.node, frame: paneFrame) + pane.pane.update(size: paneFrame.size, sideInset: sideInset, bottomInset: bottomInset, visibleHeight: visibleHeight, isScrollingLockedAtTop: expansionFraction < 1.0 - CGFloat.ulpOfOne, presentationData: presentationData, synchronous: true, transition: paneTransition) } if !self.didSetIsReady && data != nil { - if let currentPane = self.currentPane { + if let currentPaneKey = self.currentPaneKey, let currentPane = self.currentPanes[currentPaneKey] { self.didSetIsReady = true self.isReady.set(currentPane.node.isReady) - } else if self.candidatePane == nil { + } else if self.pendingSwitchToPaneKey == nil { self.didSetIsReady = true self.isReady.set(.single(true)) } } if let previousCurrentPaneKey = previousCurrentPaneKey, self.currentPaneKey != previousCurrentPaneKey { - self.currentPaneUpdated?() + self.currentPaneUpdated?(true) } } } diff --git a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift index f781707a0e..fc1cd2f59d 100644 --- a/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift +++ b/submodules/TelegramUI/TelegramUI/PeerInfo/PeerInfoScreen.swift @@ -492,6 +492,8 @@ private final class PeerInfoInteraction { let performMemberAction: (PeerInfoMember, PeerInfoMemberAction) -> Void let openPeerInfoContextMenu: (PeerInfoContextSubject, ASDisplayNode) -> Void let performBioLinkAction: (TextLinkItemActionType, TextLinkItem) -> Void + let requestLayout: () -> Void + let openEncryptionKey: () -> Void init( openUsername: @escaping (String) -> Void, @@ -519,7 +521,9 @@ private final class PeerInfoInteraction { openPeerInfo: @escaping (Peer) -> Void, performMemberAction: @escaping (PeerInfoMember, PeerInfoMemberAction) -> Void, openPeerInfoContextMenu: @escaping (PeerInfoContextSubject, ASDisplayNode) -> Void, - performBioLinkAction: @escaping (TextLinkItemActionType, TextLinkItem) -> Void + performBioLinkAction: @escaping (TextLinkItemActionType, TextLinkItem) -> Void, + requestLayout: @escaping () -> Void, + openEncryptionKey: @escaping () -> Void ) { self.openUsername = openUsername self.openPhone = openPhone @@ -547,18 +551,21 @@ private final class PeerInfoInteraction { self.performMemberAction = performMemberAction self.openPeerInfoContextMenu = openPeerInfoContextMenu self.performBioLinkAction = performBioLinkAction + self.requestLayout = requestLayout + self.openEncryptionKey = openEncryptionKey } } private let enabledBioEntities: EnabledEntityTypes = [.url, .mention, .hashtag] -private func infoItems(data: PeerInfoScreenData?, context: AccountContext, presentationData: PresentationData, interaction: PeerInfoInteraction, nearbyPeer: Bool) -> [(AnyHashable, [PeerInfoScreenItem])] { +private func infoItems(data: PeerInfoScreenData?, context: AccountContext, presentationData: PresentationData, interaction: PeerInfoInteraction, nearbyPeer: Bool, callMessages: [Message]) -> [(AnyHashable, [PeerInfoScreenItem])] { guard let data = data else { return [] } enum Section: Int, CaseIterable { case groupLocation + case calls case peerInfo case peerMembers } @@ -576,12 +583,18 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese } if let user = data.peer as? TelegramUser { + if !callMessages.isEmpty { + items[.calls]!.append(PeerInfoScreenCallListItem(id: 20, messages: callMessages)) + } + if let phone = user.phone { let formattedPhone = formatPhoneNumber(phone) items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 2, label: presentationData.strings.ContactInfo_PhoneLabelMobile, text: formattedPhone, textColor: .accent, action: { interaction.openPhone(phone) }, longTapAction: { sourceNode in interaction.openPeerInfoContextMenu(.phone(formattedPhone), sourceNode) + }, requestLayout: { + interaction.requestLayout() })) } if let username = user.username { @@ -589,13 +602,19 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese interaction.openUsername(username) }, longTapAction: { sourceNode in interaction.openPeerInfoContextMenu(.link, sourceNode) + }, requestLayout: { + interaction.requestLayout() })) } if let cachedData = data.cachedData as? CachedUserData { if user.isScam { - items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: user.botInfo == nil ? presentationData.strings.Profile_About : presentationData.strings.Channel_AboutItem, text: user.botInfo != nil ? presentationData.strings.UserInfo_ScamBotWarning : presentationData.strings.UserInfo_ScamUserWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: user.botInfo != nil ? enabledBioEntities : []), action: nil)) + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: user.botInfo == nil ? presentationData.strings.Profile_About : presentationData.strings.Channel_AboutItem, text: user.botInfo != nil ? presentationData.strings.UserInfo_ScamBotWarning : presentationData.strings.UserInfo_ScamUserWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: user.botInfo != nil ? enabledBioEntities : []), action: nil, requestLayout: { + interaction.requestLayout() + })) } else if let about = cachedData.about, !about.isEmpty { - items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: user.botInfo == nil ? presentationData.strings.Profile_About : presentationData.strings.Channel_AboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction)) + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: user.botInfo == nil ? presentationData.strings.Profile_About : presentationData.strings.Channel_AboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: []), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { + interaction.requestLayout() + })) } } if nearbyPeer { @@ -609,7 +628,7 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese } else { if !data.isContact { if user.botInfo == nil { - items[.peerInfo]!.append(PeerInfoScreenActionItem(id: 3, text: presentationData.strings.UserInfo_AddContact, action: { + items[.peerInfo]!.append(PeerInfoScreenActionItem(id: 3, text: presentationData.strings.PeerInfo_AddToContacts, action: { interaction.openAddContact() })) } @@ -631,6 +650,12 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese } } + if let encryptionKeyFingerprint = data.encryptionKeyFingerprint { + items[.peerInfo]!.append(PeerInfoScreenDisclosureEncryptionKeyItem(id: 6, text: presentationData.strings.Profile_EncryptionKey, fingerprint: encryptionKeyFingerprint, action: { + interaction.openEncryptionKey() + })) + } + if user.botInfo != nil, !user.isVerified { items[.peerInfo]!.append(PeerInfoScreenActionItem(id: 5, text: presentationData.strings.ReportPeer_Report, action: { interaction.openReport(false) @@ -666,13 +691,19 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese interaction.openUsername(username) }, longTapAction: { sourceNode in interaction.openPeerInfoContextMenu(.link, sourceNode) + }, requestLayout: { + interaction.requestLayout() })) } if let cachedData = data.cachedData as? CachedChannelData { if channel.isScam { - items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: ItemAbout, label: presentationData.strings.Channel_AboutItem, text: presentationData.strings.GroupInfo_ScamGroupWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil)) + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: ItemAbout, label: presentationData.strings.Channel_AboutItem, text: presentationData.strings.GroupInfo_ScamGroupWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, requestLayout: { + interaction.requestLayout() + })) } else if let about = cachedData.about, !about.isEmpty { - items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: ItemAbout, label: presentationData.strings.Channel_AboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction)) + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: ItemAbout, label: presentationData.strings.Channel_AboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { + interaction.requestLayout() + })) } if case .broadcast = channel.info { @@ -702,9 +733,13 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese } else if let group = data.peer as? TelegramGroup { if let cachedData = data.cachedData as? CachedGroupData { if group.isScam { - items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: presentationData.strings.Channel_AboutItem, text: presentationData.strings.GroupInfo_ScamGroupWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil)) + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: presentationData.strings.Channel_AboutItem, text: presentationData.strings.GroupInfo_ScamGroupWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, requestLayout: { + interaction.requestLayout() + })) } else if let about = cachedData.about, !about.isEmpty { - items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: presentationData.strings.Channel_AboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction)) + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: presentationData.strings.Channel_AboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { + interaction.requestLayout() + })) } } } @@ -807,7 +842,9 @@ private func editingItems(data: PeerInfoScreenData?, context: AccountContext, pr items[.peerSettings]!.append(PeerInfoScreenDisclosureItem(id: ItemUsername, label: linkText, text: presentationData.strings.Channel_TypeSetup_Title, action: { interaction.editingOpenPublicLinkSetup() })) - + } + + if channel.flags.contains(.isCreator) || (channel.adminRights != nil && channel.hasPermission(.pinMessages)) { let discussionGroupTitle: String if let cachedData = data.cachedData as? CachedChannelData { if let peer = data.linkedDiscussionPeer { @@ -1001,6 +1038,10 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD private let context: AccountContext private let peerId: PeerId + private let isOpenedFromChat: Bool + private let callMessages: [Message] + + private let isMediaOnly: Bool private var presentationData: PresentationData @@ -1046,23 +1087,28 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD private let updateAvatarDisposable = MetaDisposable() private let currentAvatarMixin = Atomic(value: nil) + private var groupMembersSearchContext: GroupMembersSearchContext? + private let _ready = Promise() var ready: Promise { return self._ready } private var didSetReady = false - init(controller: PeerInfoScreen, context: AccountContext, peerId: PeerId, avatarInitiallyExpanded: Bool, keepExpandedButtons: PeerInfoScreenKeepExpandedButtons, nearbyPeer: Bool) { + init(controller: PeerInfoScreen, context: AccountContext, peerId: PeerId, avatarInitiallyExpanded: Bool, isOpenedFromChat: Bool, nearbyPeer: Bool, callMessages: [Message]) { self.controller = controller self.context = context self.peerId = peerId + self.isOpenedFromChat = isOpenedFromChat self.presentationData = context.sharedContext.currentPresentationData.with { $0 } self.nearbyPeer = nearbyPeer + self.callMessages = callMessages + self.isMediaOnly = context.account.peerId == peerId self.scrollNode = ASScrollNode() self.scrollNode.view.delaysContentTouches = false - self.headerNode = PeerInfoHeaderNode(context: context, avatarInitiallyExpanded: avatarInitiallyExpanded, keepExpandedButtons: keepExpandedButtons) + self.headerNode = PeerInfoHeaderNode(context: context, avatarInitiallyExpanded: avatarInitiallyExpanded, isOpenedFromChat: isOpenedFromChat) self.paneContainerNode = PeerInfoPaneContainerNode(context: context, peerId: peerId) super.init() @@ -1145,6 +1191,12 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD }, performBioLinkAction: { [weak self] action, item in self?.performBioLinkAction(action: action, item: item) + }, + requestLayout: { [weak self] in + self?.requestLayout() + }, + openEncryptionKey: { [weak self] in + self?.openEncryptionKey() } ) @@ -1509,6 +1561,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self.addSubnode(self.scrollNode) self.scrollNode.addSubnode(self.paneContainerNode) self.addSubnode(self.headerNode) + self.scrollNode.view.isScrollEnabled = !self.isMediaOnly self.paneContainerNode.chatControllerInteraction = self.chatInterfaceInteraction self.paneContainerNode.openPeerContextAction = { [weak self] peer, node, gesture in @@ -1528,13 +1581,26 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD controller.presentInGlobalOverlay(contextController) } - self.paneContainerNode.currentPaneUpdated = { [weak self] in + self.paneContainerNode.currentPaneUpdated = { [weak self] expand in guard let strongSelf = self else { return } if let (layout, navigationHeight) = strongSelf.validLayout { + if strongSelf.headerNode.isAvatarExpanded { + let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) + + strongSelf.headerNode.updateIsAvatarExpanded(false, transition: transition) + strongSelf.updateNavigationExpansionPresentation(isExpanded: false, animated: true) + + if let (layout, navigationHeight) = strongSelf.validLayout { + strongSelf.containerLayoutUpdated(layout: layout, navigationHeight: navigationHeight, transition: transition, additive: true) + } + } + strongSelf.containerLayoutUpdated(layout: layout, navigationHeight: navigationHeight, transition: .immediate, additive: false) - strongSelf.scrollNode.view.setContentOffset(CGPoint(x: 0.0, y: strongSelf.paneContainerNode.frame.minY - navigationHeight), animated: true) + if expand { + strongSelf.scrollNode.view.setContentOffset(CGPoint(x: 0.0, y: strongSelf.paneContainerNode.frame.minY - navigationHeight), animated: true) + } } } @@ -1542,6 +1608,18 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD guard let strongSelf = self, let (_, navigationHeight) = strongSelf.validLayout else { return false } + + if strongSelf.headerNode.isAvatarExpanded { + let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) + + strongSelf.headerNode.updateIsAvatarExpanded(false, transition: transition) + strongSelf.updateNavigationExpansionPresentation(isExpanded: false, animated: true) + + if let (layout, navigationHeight) = strongSelf.validLayout { + strongSelf.containerLayoutUpdated(layout: layout, navigationHeight: navigationHeight, transition: transition, additive: true) + } + } + let contentOffset = strongSelf.scrollNode.view.contentOffset let paneAreaExpansionFinalPoint: CGFloat = strongSelf.paneContainerNode.frame.minY - navigationHeight if contentOffset.y < paneAreaExpansionFinalPoint - CGFloat.ulpOfOne { @@ -1572,25 +1650,30 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self?.performButtonAction(key: key) } - self.headerNode.requestAvatarExpansion = { [weak self] entries, transitionNode in + self.headerNode.requestAvatarExpansion = { [weak self] entries, centralEntry, _ in guard let strongSelf = self, let peer = strongSelf.data?.peer, peer.smallProfileImage != nil else { return } + if strongSelf.hapticFeedback == nil { + strongSelf.hapticFeedback = HapticFeedback() + } + strongSelf.hapticFeedback?.tap() let entriesPromise = Promise<[AvatarGalleryEntry]>(entries) - let galleryController = AvatarGalleryController(context: strongSelf.context, peer: peer, remoteEntries: entriesPromise, replaceRootController: { controller, ready in + let galleryController = AvatarGalleryController(context: strongSelf.context, peer: peer, sourceHasRoundCorners: !strongSelf.headerNode.isAvatarExpanded, remoteEntries: entriesPromise, centralEntryIndex: centralEntry.flatMap { entries.index(of: $0) }, replaceRootController: { controller, ready in }) strongSelf.hiddenAvatarRepresentationDisposable.set((galleryController.hiddenMedia |> deliverOnMainQueue).start(next: { entry in - if entry == entries.first { - self?.headerNode.updateAvatarIsHidden(true) - } else { - self?.headerNode.updateAvatarIsHidden(false) - } + self?.headerNode.updateAvatarIsHidden(entry: entry) })) strongSelf.view.endEditing(true) - strongSelf.controller?.present(galleryController, in: .window(.root), with: AvatarGalleryControllerPresentationArguments(transitionArguments: { _ in - return GalleryTransitionArguments(transitionNode: transitionNode, addToTransitionSurface: { _ in - }) + strongSelf.controller?.present(galleryController, in: .window(.root), with: AvatarGalleryControllerPresentationArguments(transitionArguments: { entry in + if let transitionNode = self?.headerNode.avatarTransitionArguments(entry: entry) { + return GalleryTransitionArguments(transitionNode: transitionNode, addToTransitionSurface: { view in + self?.headerNode.addToAvatarTransitionSurface(view: view) + }) + } else { + return nil + } })) } @@ -1637,39 +1720,60 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD let lastName = strongSelf.headerNode.editingContentNode.editingTextForKey(.lastName) ?? "" if peer.firstName != firstName || peer.lastName != lastName { - strongSelf.activeActionDisposable.set((updateContactName(account: context.account, peerId: peer.id, firstName: firstName, lastName: lastName) - |> deliverOnMainQueue).start(error: { _ in - guard let strongSelf = self else { - return + if firstName.isEmpty && lastName.isEmpty { + if strongSelf.hapticFeedback == nil { + strongSelf.hapticFeedback = HapticFeedback() } - strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) - }, completed: { - guard let strongSelf = self else { - return + strongSelf.hapticFeedback?.error() + strongSelf.headerNode.editingContentNode.shakeTextForKey(.firstName) + } else { + var dismissStatus: (() -> Void)? + let statusController = OverlayStatusController(theme: strongSelf.presentationData.theme, type: .loading(cancelled: { + dismissStatus?() + })) + dismissStatus = { [weak statusController] in + self?.activeActionDisposable.set(nil) + statusController?.dismiss() } - let context = strongSelf.context - let _ = (getUserPeer(postbox: strongSelf.context.account.postbox, peerId: peer.id) - |> mapToSignal { peer, _ -> Signal in - guard let peer = peer as? TelegramUser, let phone = peer.phone, !phone.isEmpty else { - return .complete() + strongSelf.controller?.present(statusController, in: .window(.root)) + strongSelf.activeActionDisposable.set((updateContactName(account: context.account, peerId: peer.id, firstName: firstName, lastName: lastName) + |> deliverOnMainQueue).start(error: { _ in + dismissStatus?() + + guard let strongSelf = self else { + return } - return (context.sharedContext.contactDataManager?.basicDataForNormalizedPhoneNumber(DeviceContactNormalizedPhoneNumber(rawValue: formatPhoneNumber(phone))) ?? .single([])) - |> take(1) - |> mapToSignal { records -> Signal in - var signals: [Signal] = [] - if let contactDataManager = context.sharedContext.contactDataManager { - for (id, basicData) in records { - signals.append(contactDataManager.appendContactData(DeviceContactExtendedData(basicData: DeviceContactBasicData(firstName: firstName, lastName: lastName, phoneNumbers: basicData.phoneNumbers), middleName: "", prefix: "", suffix: "", organization: "", jobTitle: "", department: "", emailAddresses: [], urls: [], addresses: [], birthdayDate: nil, socialProfiles: [], instantMessagingProfiles: [], note: ""), to: id)) - } - } - return combineLatest(signals) - |> mapToSignal { _ -> Signal in + strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) + }, completed: { + dismissStatus?() + + guard let strongSelf = self else { + return + } + let context = strongSelf.context + let _ = (getUserPeer(postbox: strongSelf.context.account.postbox, peerId: peer.id) + |> mapToSignal { peer, _ -> Signal in + guard let peer = peer as? TelegramUser, let phone = peer.phone, !phone.isEmpty else { return .complete() } - } - }).start() - strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) - })) + return (context.sharedContext.contactDataManager?.basicDataForNormalizedPhoneNumber(DeviceContactNormalizedPhoneNumber(rawValue: formatPhoneNumber(phone))) ?? .single([])) + |> take(1) + |> mapToSignal { records -> Signal in + var signals: [Signal] = [] + if let contactDataManager = context.sharedContext.contactDataManager { + for (id, basicData) in records { + signals.append(contactDataManager.appendContactData(DeviceContactExtendedData(basicData: DeviceContactBasicData(firstName: firstName, lastName: lastName, phoneNumbers: basicData.phoneNumbers), middleName: "", prefix: "", suffix: "", organization: "", jobTitle: "", department: "", emailAddresses: [], urls: [], addresses: [], birthdayDate: nil, socialProfiles: [], instantMessagingProfiles: [], note: ""), to: id)) + } + } + return combineLatest(signals) + |> mapToSignal { _ -> Signal in + return .complete() + } + } + }).start() + strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) + })) + } } else { strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) } @@ -1680,66 +1784,108 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD let title = strongSelf.headerNode.editingContentNode.editingTextForKey(.title) ?? "" let description = strongSelf.headerNode.editingContentNode.editingTextForKey(.description) ?? "" - var updateDataSignals: [Signal] = [] - - if title != group.title { - updateDataSignals.append( - updatePeerTitle(account: strongSelf.context.account, peerId: group.id, title: title) - |> ignoreValues - |> mapError { _ in return Void() } - ) - } - if description != (data.cachedData as? CachedGroupData)?.about { - updateDataSignals.append( - updatePeerDescription(account: strongSelf.context.account, peerId: group.id, description: description.isEmpty ? nil : description) - |> ignoreValues - |> mapError { _ in return Void() } - ) - } - strongSelf.activeActionDisposable.set((combineLatest(updateDataSignals) - |> deliverOnMainQueue).start(error: { _ in - guard let strongSelf = self else { - return + if title.isEmpty { + if strongSelf.hapticFeedback == nil { + strongSelf.hapticFeedback = HapticFeedback() } - strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) - }, completed: { - guard let strongSelf = self else { - return + strongSelf.hapticFeedback?.error() + + strongSelf.headerNode.editingContentNode.shakeTextForKey(.title) + } else { + var updateDataSignals: [Signal] = [] + + if title != group.title { + updateDataSignals.append( + updatePeerTitle(account: strongSelf.context.account, peerId: group.id, title: title) + |> ignoreValues + |> mapError { _ in return Void() } + ) } - strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) - })) + if description != (data.cachedData as? CachedGroupData)?.about { + updateDataSignals.append( + updatePeerDescription(account: strongSelf.context.account, peerId: group.id, description: description.isEmpty ? nil : description) + |> ignoreValues + |> mapError { _ in return Void() } + ) + } + var dismissStatus: (() -> Void)? + let statusController = OverlayStatusController(theme: strongSelf.presentationData.theme, type: .loading(cancelled: { + dismissStatus?() + })) + dismissStatus = { [weak statusController] in + self?.activeActionDisposable.set(nil) + statusController?.dismiss() + } + strongSelf.controller?.present(statusController, in: .window(.root)) + + strongSelf.activeActionDisposable.set((combineLatest(updateDataSignals) + |> deliverOnMainQueue).start(error: { _ in + dismissStatus?() + + guard let strongSelf = self else { + return + } + strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) + }, completed: { + dismissStatus?() + + guard let strongSelf = self else { + return + } + strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) + })) + } } else if let channel = data.peer as? TelegramChannel, canEditPeerInfo(peer: channel) { let title = strongSelf.headerNode.editingContentNode.editingTextForKey(.title) ?? "" let description = strongSelf.headerNode.editingContentNode.editingTextForKey(.description) ?? "" - var updateDataSignals: [Signal] = [] - - if title != channel.title { - updateDataSignals.append( - updatePeerTitle(account: strongSelf.context.account, peerId: channel.id, title: title) - |> ignoreValues - |> mapError { _ in return Void() } - ) - } - if description != (data.cachedData as? CachedChannelData)?.about { - updateDataSignals.append( - updatePeerDescription(account: strongSelf.context.account, peerId: channel.id, description: description.isEmpty ? nil : description) - |> ignoreValues - |> mapError { _ in return Void() } - ) - } - strongSelf.activeActionDisposable.set((combineLatest(updateDataSignals) - |> deliverOnMainQueue).start(error: { _ in - guard let strongSelf = self else { - return + if title.isEmpty { + strongSelf.headerNode.editingContentNode.shakeTextForKey(.title) + } else { + var updateDataSignals: [Signal] = [] + + if title != channel.title { + updateDataSignals.append( + updatePeerTitle(account: strongSelf.context.account, peerId: channel.id, title: title) + |> ignoreValues + |> mapError { _ in return Void() } + ) } - strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) - }, completed: { - guard let strongSelf = self else { - return + if description != (data.cachedData as? CachedChannelData)?.about { + updateDataSignals.append( + updatePeerDescription(account: strongSelf.context.account, peerId: channel.id, description: description.isEmpty ? nil : description) + |> ignoreValues + |> mapError { _ in return Void() } + ) } - strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) - })) + + var dismissStatus: (() -> Void)? + let statusController = OverlayStatusController(theme: strongSelf.presentationData.theme, type: .loading(cancelled: { + dismissStatus?() + })) + dismissStatus = { [weak statusController] in + self?.activeActionDisposable.set(nil) + statusController?.dismiss() + } + strongSelf.controller?.present(statusController, in: .window(.root)) + + strongSelf.activeActionDisposable.set((combineLatest(updateDataSignals) + |> deliverOnMainQueue).start(error: { _ in + dismissStatus?() + + guard let strongSelf = self else { + return + } + strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) + }, completed: { + dismissStatus?() + + guard let strongSelf = self else { + return + } + strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) + })) + } } else { strongSelf.headerNode.navigationButtonContainer.performAction?(.cancel) } @@ -1798,6 +1944,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } private func updateData(_ data: PeerInfoScreenData) { + let previousData = self.data var previousMemberCount: Int? if let data = self.data { if let members = data.members, case let .shortList(_, memberList) = members { @@ -1805,6 +1952,13 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } } self.data = data + if previousData?.members?.membersContext !== data.members?.membersContext { + if let peer = data.peer, let _ = data.members { + self.groupMembersSearchContext = GroupMembersSearchContext(context: self.context, peerId: peer.id) + } else { + self.groupMembersSearchContext = nil + } + } if let (layout, navigationHeight) = self.validLayout { var updatedMemberCount: Int? if let data = self.data { @@ -1829,6 +1983,17 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } private func expandTabs() { + if self.headerNode.isAvatarExpanded { + let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) + + self.headerNode.updateIsAvatarExpanded(false, transition: transition) + self.updateNavigationExpansionPresentation(isExpanded: false, animated: true) + + if let (layout, navigationHeight) = self.validLayout { + self.containerLayoutUpdated(layout: layout, navigationHeight: navigationHeight, transition: transition, additive: true) + } + } + if let (layout, navigationHeight) = self.validLayout { let contentOffset = self.scrollNode.view.contentOffset let paneAreaExpansionFinalPoint: CGFloat = self.paneContainerNode.frame.minY - navigationHeight @@ -1980,10 +2145,12 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD actionSheet?.dismissAnimated() } var items: [ActionSheetItem] = [] - items.append(ActionSheetButtonItem(title: presentationData.strings.ChatSearch_SearchPlaceholder, color: .accent, action: { [weak self] in - dismissAction() - self?.openChatWithMessageSearch() - })) + if !peerInfoHeaderButtons(peer: peer, cachedData: data.cachedData, isOpenedFromChat: self.isOpenedFromChat).contains(.search) || self.headerNode.isAvatarExpanded { + items.append(ActionSheetButtonItem(title: presentationData.strings.ChatSearch_SearchPlaceholder, color: .accent, action: { [weak self] in + dismissAction() + self?.openChatWithMessageSearch() + })) + } if let user = peer as? TelegramUser { if let botInfo = user.botInfo { if botInfo.flags.contains(.worksWithGroups) { @@ -2021,11 +2188,31 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } } - if user.botInfo == nil && !user.flags.contains(.isSupport) { + if user.botInfo == nil && data.isContact { + items.append(ActionSheetButtonItem(title: presentationData.strings.Profile_ShareContactButton, color: .accent, action: { [weak self] in + dismissAction() + guard let strongSelf = self else { + return + } + if let peer = strongSelf.data?.peer as? TelegramUser, let phone = peer.phone { + let contact = TelegramMediaContact(firstName: peer.firstName ?? "", lastName: peer.lastName ?? "", phoneNumber: phone, peerId: peer.id, vCardData: nil) + let shareController = ShareController(context: strongSelf.context, subject: .media(.standalone(media: contact))) + strongSelf.controller?.present(shareController, in: .window(.root)) + } + })) + } + + if self.peerId.namespace == Namespaces.Peer.CloudUser && user.botInfo == nil && !user.flags.contains(.isSupport) { items.append(ActionSheetButtonItem(title: presentationData.strings.UserInfo_StartSecretChat, color: .accent, action: { [weak self] in dismissAction() self?.openStartSecretChat() })) + if data.isContact { + items.append(ActionSheetButtonItem(title: presentationData.strings.Conversation_BlockUser, color: .destructive, action: { [weak self] in + dismissAction() + self?.updateBlocked(block: true) + })) + } } } else if let channel = peer as? TelegramChannel { var canReport = true @@ -2053,11 +2240,13 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self?.openDeletePeer() })) } else { - if case .member = channel.participationStatus { - items.append(ActionSheetButtonItem(title: presentationData.strings.Channel_LeaveChannel, color: .destructive, action: { [weak self] in - dismissAction() - self?.openLeavePeer() - })) + if !peerInfoHeaderButtons(peer: peer, cachedData: data.cachedData, isOpenedFromChat: self.isOpenedFromChat).contains(.leave) { + if case .member = channel.participationStatus { + items.append(ActionSheetButtonItem(title: presentationData.strings.Channel_LeaveChannel, color: .destructive, action: { [weak self] in + dismissAction() + self?.openLeavePeer() + })) + } } } case .group: @@ -2091,6 +2280,10 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD controller.present(actionSheet, in: .window(.root)) case .addMember: self.openAddMember() + case .search: + self.openChatWithMessageSearch() + case .leave: + self.openLeavePeer() } } @@ -2517,6 +2710,13 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD }, completion: { _ in }), in: .window(.root)) } + private func openEncryptionKey() { + guard let data = self.data, let peer = data.peer, let encryptionKeyFingerprint = data.encryptionKeyFingerprint else { + return + } + self.controller?.push(SecretChatKeyController(context: self.context, fingerprint: encryptionKeyFingerprint, peer: peer)) + } + private func openShareBot() { let _ = (getUserPeer(postbox: self.context.account.postbox, peerId: self.peerId) |> deliverOnMainQueue).start(next: { [weak self] peer, _ in @@ -2739,8 +2939,14 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD })) case .link: if let addressName = peer.addressName { + let text: String + if peer is TelegramChannel { + text = "https://t.me/\(addressName)" + } else { + text = "@" + addressName + } let contextMenuController = ContextMenuController(actions: [ContextMenuAction(content: .text(title: self.presentationData.strings.Conversation_ContextMenuCopy, accessibilityLabel: self.presentationData.strings.Conversation_ContextMenuCopy), action: { - UIPasteboard.general.string = "@" + addressName + UIPasteboard.general.string = text })]) controller.present(contextMenuController, in: .window(.root), with: ContextMenuControllerPresentationArguments(sourceNodeAndRect: { [weak self, weak sourceNode] in if let controller = self?.controller, let sourceNode = sourceNode { @@ -2760,6 +2966,10 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self.context.sharedContext.handleTextLinkAction(context: self.context, peerId: peer.id, navigateDisposable: self.resolveUrlDisposable, controller: controller, action: action, itemLink: item) } + private func requestLayout() { + self.headerNode.requestUpdateLayout?() + } + private func openDeletePeer() { let peerId = self.peerId let _ = (self.context.account.postbox.transaction { transaction -> Peer? in @@ -3389,7 +3599,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } if let currentPaneKey = self.paneContainerNode.currentPaneKey, case .members = currentPaneKey { - self.searchDisplayController = SearchDisplayController(presentationData: self.presentationData, mode: .list, placeholder: self.presentationData.strings.Common_Search, contentNode: ChannelMembersSearchContainerNode(context: self.context, peerId: self.peerId, mode: .searchMembers, filters: [], searchContext: nil, openPeer: { [weak self] peer, participant in + self.searchDisplayController = SearchDisplayController(presentationData: self.presentationData, mode: .list, placeholder: self.presentationData.strings.Common_Search, contentNode: ChannelMembersSearchContainerNode(context: self.context, peerId: self.peerId, mode: .searchMembers, filters: [], searchContext: self.groupMembersSearchContext, openPeer: { [weak self] peer, participant in self?.openPeer(peerId: peer.id, navigation: .info) }, updateActivity: { _ in }, pushController: { [weak self] c in @@ -3475,98 +3685,104 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD var contentHeight: CGFloat = 0.0 - let headerHeight = self.headerNode.update(width: layout.size.width, containerHeight: layout.size.height, containerInset: layout.safeInsets.left, statusBarHeight: layout.statusBarHeight ?? 0.0, navigationHeight: navigationHeight, contentOffset: self.scrollNode.view.contentOffset.y, presentationData: self.presentationData, peer: self.data?.peer, cachedData: self.data?.cachedData, notificationSettings: self.data?.notificationSettings, statusData: self.data?.status, isContact: self.data?.isContact ?? false, state: self.state, transition: transition, additive: additive) + let headerHeight = self.headerNode.update(width: layout.size.width, containerHeight: layout.size.height, containerInset: layout.safeInsets.left, statusBarHeight: layout.statusBarHeight ?? 0.0, navigationHeight: navigationHeight, contentOffset: self.isMediaOnly ? 212.0 : self.scrollNode.view.contentOffset.y, presentationData: self.presentationData, peer: self.data?.peer, cachedData: self.data?.cachedData, notificationSettings: self.data?.notificationSettings, statusData: self.data?.status, isContact: self.data?.isContact ?? false, state: self.state, transition: transition, additive: additive) let headerFrame = CGRect(origin: CGPoint(x: 0.0, y: contentHeight), size: CGSize(width: layout.size.width, height: headerHeight)) if additive { transition.updateFrameAdditive(node: self.headerNode, frame: headerFrame) } else { transition.updateFrame(node: self.headerNode, frame: headerFrame) } - contentHeight += headerHeight - contentHeight += sectionSpacing + if !self.isMediaOnly { + contentHeight += headerHeight + contentHeight += sectionSpacing + } else { + contentHeight += navigationHeight + } var validRegularSections: [AnyHashable] = [] - for (sectionId, sectionItems) in infoItems(data: self.data, context: self.context, presentationData: self.presentationData, interaction: self.interaction, nearbyPeer: self.nearbyPeer) { - validRegularSections.append(sectionId) - - let sectionNode: PeerInfoScreenItemSectionContainerNode - if let current = self.regularSections[sectionId] { - sectionNode = current - } else { - sectionNode = PeerInfoScreenItemSectionContainerNode() - self.regularSections[sectionId] = sectionNode - self.scrollNode.addSubnode(sectionNode) - } - - let sectionHeight = sectionNode.update(width: layout.size.width, presentationData: self.presentationData, items: sectionItems, transition: transition) - let sectionFrame = CGRect(origin: CGPoint(x: 0.0, y: contentHeight), size: CGSize(width: layout.size.width, height: sectionHeight)) - if additive { - transition.updateFrameAdditive(node: sectionNode, frame: sectionFrame) - } else { - transition.updateFrame(node: sectionNode, frame: sectionFrame) - } - - transition.updateAlpha(node: sectionNode, alpha: self.state.isEditing ? 0.0 : 1.0) - if !sectionHeight.isZero && !self.state.isEditing { - contentHeight += sectionHeight - contentHeight += sectionSpacing - } - } - var removeRegularSections: [AnyHashable] = [] - for (sectionId, sectionNode) in self.regularSections { - if !validRegularSections.contains(sectionId) { - removeRegularSections.append(sectionId) - } - } - for sectionId in removeRegularSections { - if let sectionNode = self.regularSections.removeValue(forKey: sectionId) { - sectionNode.removeFromSupernode() - } - } - - var validEditingSections: [AnyHashable] = [] - for (sectionId, sectionItems) in editingItems(data: self.data, context: self.context, presentationData: self.presentationData, interaction: self.interaction) { - validEditingSections.append(sectionId) - - var wasAdded = false - let sectionNode: PeerInfoScreenItemSectionContainerNode - if let current = self.editingSections[sectionId] { - sectionNode = current - } else { - wasAdded = true - sectionNode = PeerInfoScreenItemSectionContainerNode() - self.editingSections[sectionId] = sectionNode - self.scrollNode.addSubnode(sectionNode) - } - - let sectionHeight = sectionNode.update(width: layout.size.width, presentationData: self.presentationData, items: sectionItems, transition: transition) - let sectionFrame = CGRect(origin: CGPoint(x: 0.0, y: contentHeight), size: CGSize(width: layout.size.width, height: sectionHeight)) - - if wasAdded { - sectionNode.frame = sectionFrame - sectionNode.alpha = self.state.isEditing ? 1.0 : 0.0 - } else { + if !self.isMediaOnly { + for (sectionId, sectionItems) in infoItems(data: self.data, context: self.context, presentationData: self.presentationData, interaction: self.interaction, nearbyPeer: self.nearbyPeer, callMessages: self.callMessages) { + validRegularSections.append(sectionId) + + let sectionNode: PeerInfoScreenItemSectionContainerNode + if let current = self.regularSections[sectionId] { + sectionNode = current + } else { + sectionNode = PeerInfoScreenItemSectionContainerNode() + self.regularSections[sectionId] = sectionNode + self.scrollNode.addSubnode(sectionNode) + } + + let sectionHeight = sectionNode.update(width: layout.size.width, presentationData: self.presentationData, items: sectionItems, transition: transition) + let sectionFrame = CGRect(origin: CGPoint(x: 0.0, y: contentHeight), size: CGSize(width: layout.size.width, height: sectionHeight)) if additive { transition.updateFrameAdditive(node: sectionNode, frame: sectionFrame) } else { transition.updateFrame(node: sectionNode, frame: sectionFrame) } - transition.updateAlpha(node: sectionNode, alpha: self.state.isEditing ? 1.0 : 0.0) + + transition.updateAlpha(node: sectionNode, alpha: self.state.isEditing ? 0.0 : 1.0) + if !sectionHeight.isZero && !self.state.isEditing { + contentHeight += sectionHeight + contentHeight += sectionSpacing + } } - if !sectionHeight.isZero && self.state.isEditing { - contentHeight += sectionHeight - contentHeight += sectionSpacing + var removeRegularSections: [AnyHashable] = [] + for (sectionId, sectionNode) in self.regularSections { + if !validRegularSections.contains(sectionId) { + removeRegularSections.append(sectionId) + } } - } - var removeEditingSections: [AnyHashable] = [] - for (sectionId, sectionNode) in self.editingSections { - if !validEditingSections.contains(sectionId) { - removeEditingSections.append(sectionId) + for sectionId in removeRegularSections { + if let sectionNode = self.regularSections.removeValue(forKey: sectionId) { + sectionNode.removeFromSupernode() + } } - } - for sectionId in removeEditingSections { - if let sectionNode = self.editingSections.removeValue(forKey: sectionId) { - sectionNode.removeFromSupernode() + + var validEditingSections: [AnyHashable] = [] + for (sectionId, sectionItems) in editingItems(data: self.data, context: self.context, presentationData: self.presentationData, interaction: self.interaction) { + validEditingSections.append(sectionId) + + var wasAdded = false + let sectionNode: PeerInfoScreenItemSectionContainerNode + if let current = self.editingSections[sectionId] { + sectionNode = current + } else { + wasAdded = true + sectionNode = PeerInfoScreenItemSectionContainerNode() + self.editingSections[sectionId] = sectionNode + self.scrollNode.addSubnode(sectionNode) + } + + let sectionHeight = sectionNode.update(width: layout.size.width, presentationData: self.presentationData, items: sectionItems, transition: transition) + let sectionFrame = CGRect(origin: CGPoint(x: 0.0, y: contentHeight), size: CGSize(width: layout.size.width, height: sectionHeight)) + + if wasAdded { + sectionNode.frame = sectionFrame + sectionNode.alpha = self.state.isEditing ? 1.0 : 0.0 + } else { + if additive { + transition.updateFrameAdditive(node: sectionNode, frame: sectionFrame) + } else { + transition.updateFrame(node: sectionNode, frame: sectionFrame) + } + transition.updateAlpha(node: sectionNode, alpha: self.state.isEditing ? 1.0 : 0.0) + } + if !sectionHeight.isZero && self.state.isEditing { + contentHeight += sectionHeight + contentHeight += sectionSpacing + } + } + var removeEditingSections: [AnyHashable] = [] + for (sectionId, sectionNode) in self.editingSections { + if !validEditingSections.contains(sectionId) { + removeEditingSections.append(sectionId) + } + } + for sectionId in removeEditingSections { + if let sectionNode = self.editingSections.removeValue(forKey: sectionId) { + sectionNode.removeFromSupernode() + } } } @@ -3702,7 +3918,7 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD if let (layout, navigationHeight) = self.validLayout { if !additive { - self.headerNode.update(width: layout.size.width, containerHeight: layout.size.height, containerInset: layout.safeInsets.left, statusBarHeight: layout.statusBarHeight ?? 0.0, navigationHeight: navigationHeight, contentOffset: offsetY, presentationData: self.presentationData, peer: self.data?.peer, cachedData: self.data?.cachedData, notificationSettings: self.data?.notificationSettings, statusData: self.data?.status, isContact: self.data?.isContact ?? false, state: self.state, transition: transition, additive: additive) + self.headerNode.update(width: layout.size.width, containerHeight: layout.size.height, containerInset: layout.safeInsets.left, statusBarHeight: layout.statusBarHeight ?? 0.0, navigationHeight: navigationHeight, contentOffset: self.isMediaOnly ? 212.0 : offsetY, presentationData: self.presentationData, peer: self.data?.peer, cachedData: self.data?.cachedData, notificationSettings: self.data?.notificationSettings, statusData: self.data?.status, isContact: self.data?.isContact ?? false, state: self.state, transition: transition, additive: additive) } let paneAreaExpansionDistance: CGFloat = 32.0 @@ -3762,14 +3978,17 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } } - private var canUpdateAvatarExpansion = false - func scrollViewWillBeginDragging(_ scrollView: UIScrollView) { - self.canUpdateAvatarExpansion = true + self.canAddVelocity = true + self.canOpenAvatarByDragging = self.headerNode.isAvatarExpanded + self.paneContainerNode.currentPane?.node.cancelPreviewGestures() } private var previousVelocityM1: CGFloat = 0.0 private var previousVelocity: CGFloat = 0.0 + private var canAddVelocity: Bool = false + + private var canOpenAvatarByDragging = false private let velocityKey: String = encodeText("`wfsujdbmWfmpdjuz", -1) @@ -3780,10 +3999,11 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD self.updateNavigation(transition: .immediate, additive: false) if !self.state.isEditing { - self.previousVelocityM1 = self.previousVelocity - if let value = (scrollView.value(forKey: self.velocityKey) as? NSNumber)?.doubleValue { - //print("previousVelocity \(CGFloat(value))") - self.previousVelocity = CGFloat(value) + if self.canAddVelocity { + self.previousVelocityM1 = self.previousVelocity + if let value = (scrollView.value(forKey: self.velocityKey) as? NSNumber)?.doubleValue { + self.previousVelocity = CGFloat(value) + } } let offsetY = self.scrollNode.view.contentOffset.y @@ -3791,9 +4011,15 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD if offsetY <= -32.0 && scrollView.isDragging && scrollView.isTracking { if let peer = self.data?.peer, peer.smallProfileImage != nil { shouldBeExpanded = true + + if self.canOpenAvatarByDragging && self.headerNode.isAvatarExpanded && offsetY <= -32.0 { + self.canOpenAvatarByDragging = false + self.headerNode.initiateAvatarExpansion() + } } } else if offsetY >= 1.0 { shouldBeExpanded = false + self.canOpenAvatarByDragging = false } if let shouldBeExpanded = shouldBeExpanded, shouldBeExpanded != self.headerNode.isAvatarExpanded { let transition: ContainedViewLayoutTransition = .animated(duration: 0.35, curve: .spring) @@ -3868,14 +4094,23 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD if targetContentOffset.pointee.y < 212.0 { if targetContentOffset.pointee.y < 212.0 / 2.0 { targetContentOffset.pointee.y = 0.0 + self.canAddVelocity = false + self.previousVelocity = 0.0 + self.previousVelocityM1 = 0.0 } else { targetContentOffset.pointee.y = 212.0 + self.canAddVelocity = false + self.previousVelocity = 0.0 + self.previousVelocityM1 = 0.0 } } let paneAreaExpansionDistance: CGFloat = 32.0 let paneAreaExpansionFinalPoint: CGFloat = self.paneContainerNode.frame.minY - navigationHeight if targetContentOffset.pointee.y > paneAreaExpansionFinalPoint - paneAreaExpansionDistance && targetContentOffset.pointee.y < paneAreaExpansionFinalPoint { targetContentOffset.pointee.y = paneAreaExpansionFinalPoint + self.canAddVelocity = false + self.previousVelocity = 0.0 + self.previousVelocityM1 = 0.0 } } } @@ -3908,17 +4143,13 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD } } -public enum PeerInfoScreenKeepExpandedButtons { - case message - case mute -} - public final class PeerInfoScreen: ViewController { private let context: AccountContext private let peerId: PeerId private let avatarInitiallyExpanded: Bool - private let keepExpandedButtons: PeerInfoScreenKeepExpandedButtons + private let isOpenedFromChat: Bool private let nearbyPeer: Bool + private let callMessages: [Message] private var presentationData: PresentationData private var presentationDataDisposable: Disposable? @@ -3934,12 +4165,13 @@ public final class PeerInfoScreen: ViewController { private var validLayout: (layout: ContainerViewLayout, navigationHeight: CGFloat)? - public init(context: AccountContext, peerId: PeerId, avatarInitiallyExpanded: Bool = false, keepExpandedButtons: PeerInfoScreenKeepExpandedButtons = .message, nearbyPeer: Bool = false) { + public init(context: AccountContext, peerId: PeerId, avatarInitiallyExpanded: Bool, isOpenedFromChat: Bool, nearbyPeer: Bool, callMessages: [Message]) { self.context = context self.peerId = peerId self.avatarInitiallyExpanded = avatarInitiallyExpanded - self.keepExpandedButtons = keepExpandedButtons + self.isOpenedFromChat = isOpenedFromChat self.nearbyPeer = nearbyPeer + self.callMessages = callMessages self.presentationData = context.sharedContext.currentPresentationData.with { $0 } @@ -3962,6 +4194,9 @@ public final class PeerInfoScreen: ViewController { if strongSelf.navigationItem.leftBarButtonItem != nil { return nil } + if other.item?.leftBarButtonItem != nil { + return nil + } if strongSelf.controllerNode.scrollNode.view.contentOffset.y > .ulpOfOne { return nil } @@ -4007,7 +4242,7 @@ public final class PeerInfoScreen: ViewController { } override public func loadDisplayNode() { - self.displayNode = PeerInfoScreenNode(controller: self, context: self.context, peerId: self.peerId, avatarInitiallyExpanded: self.avatarInitiallyExpanded, keepExpandedButtons: self.keepExpandedButtons, nearbyPeer: self.nearbyPeer) + self.displayNode = PeerInfoScreenNode(controller: self, context: self.context, peerId: self.peerId, avatarInitiallyExpanded: self.avatarInitiallyExpanded, isOpenedFromChat: self.isOpenedFromChat, nearbyPeer: self.nearbyPeer, callMessages: self.callMessages) self._ready.set(self.controllerNode.ready.get()) diff --git a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift index cae95a602a..a500d42003 100644 --- a/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift +++ b/submodules/TelegramUI/TelegramUI/PeerMediaCollectionControllerNode.swift @@ -29,7 +29,7 @@ private func historyNodeImplForMode(_ mode: PeerMediaCollectionMode, context: Ac } return node case .file: - 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)) + 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, displayHeaders: .all)) node.verticalScrollIndicatorColor = theme.list.scrollIndicatorColor node.didEndScrolling = { [weak node] in guard let node = node else { @@ -40,7 +40,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, subject: messageId.flatMap { .message($0) }, 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, displayHeaders: .all)) node.verticalScrollIndicatorColor = theme.list.scrollIndicatorColor node.didEndScrolling = { [weak node] in guard let node = node else { @@ -51,7 +51,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, subject: messageId.flatMap { .message($0) }, 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, displayHeaders: .all)) node.verticalScrollIndicatorColor = theme.list.scrollIndicatorColor node.didEndScrolling = { [weak node] in guard let node = node else { diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping index 16074d02e9..2f6ecd7fdb 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/SharedAccountContext.swift b/submodules/TelegramUI/TelegramUI/SharedAccountContext.swift index 5a05111f1f..57e6012d9f 100644 --- a/submodules/TelegramUI/TelegramUI/SharedAccountContext.swift +++ b/submodules/TelegramUI/TelegramUI/SharedAccountContext.swift @@ -1007,7 +1007,7 @@ public final class SharedAccountContextImpl: SharedAccountContext { } public func makePeerInfoController(context: AccountContext, peer: Peer, mode: PeerInfoControllerMode, avatarInitiallyExpanded: Bool, fromChat: Bool) -> ViewController? { - let controller = peerInfoControllerImpl(context: context, peer: peer, mode: mode, avatarInitiallyExpanded: avatarInitiallyExpanded, keepExpandedButtons: fromChat ? .mute : .message) + let controller = peerInfoControllerImpl(context: context, peer: peer, mode: mode, avatarInitiallyExpanded: avatarInitiallyExpanded, isOpenedFromChat: fromChat) controller?.navigationPresentation = .modalInLargeLayout return controller } @@ -1249,19 +1249,25 @@ public final class SharedAccountContextImpl: SharedAccountContext { private let defaultChatControllerInteraction = ChatControllerInteraction.default -private func peerInfoControllerImpl(context: AccountContext, peer: Peer, mode: PeerInfoControllerMode, avatarInitiallyExpanded: Bool, keepExpandedButtons: PeerInfoScreenKeepExpandedButtons) -> ViewController? { +private func peerInfoControllerImpl(context: AccountContext, peer: Peer, mode: PeerInfoControllerMode, avatarInitiallyExpanded: Bool, isOpenedFromChat: Bool) -> ViewController? { if let _ = peer as? TelegramGroup { - return PeerInfoScreen(context: context, peerId: peer.id, avatarInitiallyExpanded: avatarInitiallyExpanded, keepExpandedButtons: keepExpandedButtons) + return PeerInfoScreen(context: context, peerId: peer.id, avatarInitiallyExpanded: avatarInitiallyExpanded, isOpenedFromChat: isOpenedFromChat, nearbyPeer: false, callMessages: []) } else if let channel = peer as? TelegramChannel { - return PeerInfoScreen(context: context, peerId: peer.id, avatarInitiallyExpanded: avatarInitiallyExpanded, keepExpandedButtons: keepExpandedButtons) + return PeerInfoScreen(context: context, peerId: peer.id, avatarInitiallyExpanded: avatarInitiallyExpanded, isOpenedFromChat: isOpenedFromChat, nearbyPeer: false, callMessages: []) } else if peer is TelegramUser { var nearbyPeer = false - if case .nearbyPeer = mode { + var callMessages: [Message] = [] + switch mode { + case .nearbyPeer: nearbyPeer = true + case let .calls(messages): + callMessages = messages + case .generic: + break } - return PeerInfoScreen(context: context, peerId: peer.id, avatarInitiallyExpanded: avatarInitiallyExpanded, keepExpandedButtons: keepExpandedButtons, nearbyPeer: nearbyPeer) + return PeerInfoScreen(context: context, peerId: peer.id, avatarInitiallyExpanded: avatarInitiallyExpanded, isOpenedFromChat: isOpenedFromChat, nearbyPeer: nearbyPeer, callMessages: callMessages) } else if peer is TelegramSecretChat { - return userInfoController(context: context, peerId: peer.id, mode: mode) + return PeerInfoScreen(context: context, peerId: peer.id, avatarInitiallyExpanded: avatarInitiallyExpanded, isOpenedFromChat: isOpenedFromChat, nearbyPeer: false, callMessages: []) } return nil } diff --git a/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift b/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift index c180b8a1ef..2865a2719a 100644 --- a/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift +++ b/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift @@ -684,7 +684,7 @@ class WebSearchControllerNode: ASDisplayNode { var entries: [WebSearchGalleryEntry] = [] var centralIndex: Int = 0 for i in 0 ..< results.count { - entries.append(WebSearchGalleryEntry(result: results[i])) + entries.append(WebSearchGalleryEntry(index: entries.count, result: results[i])) if results[i] == currentResult { centralIndex = i } diff --git a/submodules/WebSearchUI/Sources/WebSearchGalleryController.swift b/submodules/WebSearchUI/Sources/WebSearchGalleryController.swift index 38022196fa..44d6053249 100644 --- a/submodules/WebSearchUI/Sources/WebSearchGalleryController.swift +++ b/submodules/WebSearchUI/Sources/WebSearchGalleryController.swift @@ -28,6 +28,7 @@ final class WebSearchGalleryControllerInteraction { } struct WebSearchGalleryEntry: Equatable { + let index: Int let result: ChatContextResult static func ==(lhs: WebSearchGalleryEntry, rhs: WebSearchGalleryEntry) -> Bool { @@ -39,11 +40,11 @@ struct WebSearchGalleryEntry: Equatable { case let .externalReference(_, _, type, _, _, _, content, thumbnail, _): if let content = content, type == "gif", let thumbnailResource = thumbnail?.resource, let dimensions = content.dimensions { let fileReference = FileMediaReference.standalone(media: TelegramMediaFile(fileId: MediaId(namespace: Namespaces.Media.LocalFile, id: 0), partialReference: nil, resource: content.resource, previewRepresentations: [TelegramMediaImageRepresentation(dimensions: dimensions, resource: thumbnailResource)], immediateThumbnailData: nil, mimeType: "video/mp4", size: nil, attributes: [.Animated, .Video(duration: 0, size: dimensions, flags: [])])) - return WebSearchVideoGalleryItem(context: context, presentationData: presentationData, result: self.result, content: NativeVideoContent(id: .contextResult(self.result.queryId, self.result.id), fileReference: fileReference, loopVideo: true, enableSound: false, fetchAutomatically: true), controllerInteraction: controllerInteraction) + return WebSearchVideoGalleryItem(context: context, presentationData: presentationData, index: self.index, result: self.result, content: NativeVideoContent(id: .contextResult(self.result.queryId, self.result.id), fileReference: fileReference, loopVideo: true, enableSound: false, fetchAutomatically: true), controllerInteraction: controllerInteraction) } case let .internalReference(_, _, _, _, _, _, file, _): if let file = file { - return WebSearchVideoGalleryItem(context: context, presentationData: presentationData, result: self.result, content: NativeVideoContent(id: .contextResult(self.result.queryId, self.result.id), fileReference: .standalone(media: file), loopVideo: true, enableSound: false, fetchAutomatically: true), controllerInteraction: controllerInteraction) + return WebSearchVideoGalleryItem(context: context, presentationData: presentationData, index: self.index, result: self.result, content: NativeVideoContent(id: .contextResult(self.result.queryId, self.result.id), fileReference: .standalone(media: file), loopVideo: true, enableSound: false, fetchAutomatically: true), controllerInteraction: controllerInteraction) } } preconditionFailure() diff --git a/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift b/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift index 1f69d4ec7a..788478b84f 100644 --- a/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift +++ b/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift @@ -14,15 +14,22 @@ import TelegramUniversalVideoContent import GalleryUI class WebSearchVideoGalleryItem: GalleryItem { + var id: AnyHashable { + return self.index + } + + let index: Int + let context: AccountContext let presentationData: PresentationData let result: ChatContextResult let content: UniversalVideoContent let controllerInteraction: WebSearchGalleryControllerInteraction? - init(context: AccountContext, presentationData: PresentationData, result: ChatContextResult, content: UniversalVideoContent, controllerInteraction: WebSearchGalleryControllerInteraction?) { + init(context: AccountContext, presentationData: PresentationData, index: Int, result: ChatContextResult, content: UniversalVideoContent, controllerInteraction: WebSearchGalleryControllerInteraction?) { self.context = context self.presentationData = presentationData + self.index = index self.result = result self.content = content self.controllerInteraction = controllerInteraction