diff --git a/Telegram/Telegram-iOS/en.lproj/Localizable.strings b/Telegram/Telegram-iOS/en.lproj/Localizable.strings index a1693e3c72..baa64c2ce9 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -5841,11 +5841,13 @@ Any member of this group will be able to see messages in the channel."; "Notification.ProximityReached" = "%1$@ is now within %2$@ from %3$@"; "Notification.ProximityReachedYou" = "%1$@ is now within %2$@ from you"; -"Location.ProximityNotification.Title" = "Notification"; +"Location.ProximityNotification.Title" = "Proximity Alert"; "Location.ProximityNotification.Notify" = "Notify me within %@"; +"Location.ProximityNotification.NotifyLong" = "Notify when %1$@ is within %2$@"; "Location.ProximityNotification.AlreadyClose" = "You are already closer than %@"; -"Location.ProximityNotification.DistanceKM" = "KM"; -"Location.ProximityNotification.DistanceMI" = "MI"; +"Location.ProximityNotification.DistanceKM" = "km"; +"Location.ProximityNotification.DistanceM" = "m"; +"Location.ProximityNotification.DistanceMI" = "mi"; "Location.ProximityTip" = "Alert when %@ is close"; "Location.ProximityGroupTip" = "Alert when any group member is close"; diff --git a/submodules/AccountContext/Sources/UniversalVideoNode.swift b/submodules/AccountContext/Sources/UniversalVideoNode.swift index 77e7fa0d0a..336c8f6db8 100644 --- a/submodules/AccountContext/Sources/UniversalVideoNode.swift +++ b/submodules/AccountContext/Sources/UniversalVideoNode.swift @@ -29,6 +29,7 @@ public protocol UniversalVideoContentNode: class { func addPlaybackCompleted(_ f: @escaping () -> Void) -> Int func removePlaybackCompleted(_ index: Int) func fetchControl(_ control: UniversalVideoNodeFetchControl) + func notifyPlaybackControlsHidden(_ hidden: Bool) } public protocol UniversalVideoContent { @@ -319,6 +320,14 @@ public final class UniversalVideoNode: ASDisplayNode { }) } + public func notifyPlaybackControlsHidden(_ hidden: Bool) { + self.manager.withUniversalVideoContent(id: self.content.id, { contentNode in + if let contentNode = contentNode { + contentNode.notifyPlaybackControlsHidden(hidden) + } + }) + } + @objc private func tapGesture(_ recognizer: UITapGestureRecognizer) { if case .ended = recognizer.state { self.decoration.tap() diff --git a/submodules/AnimatedStickerNode/Sources/AnimatedStickerNode.swift b/submodules/AnimatedStickerNode/Sources/AnimatedStickerNode.swift index 76d7f5a7cb..b9782133d2 100644 --- a/submodules/AnimatedStickerNode/Sources/AnimatedStickerNode.swift +++ b/submodules/AnimatedStickerNode/Sources/AnimatedStickerNode.swift @@ -762,13 +762,7 @@ public final class AnimatedStickerNode: ASDisplayNode { return self.playbackStatus.get() } - public var autoplay = true { - didSet { - if self.autoplay != oldValue { - self.updateIsPlaying() - } - } - } + public var autoplay = false public var visibility = false { didSet { @@ -835,9 +829,12 @@ public final class AnimatedStickerNode: ASDisplayNode { strongSelf.directData = (directData, path, width, height, cachePathPrefix, source.fitzModifier) } if case let .still(position) = playbackMode { - strongSelf.play(firstFrame: true) strongSelf.seekTo(position) - } else if strongSelf.isPlaying { + } else if strongSelf.isPlaying || strongSelf.autoplay { + if strongSelf.autoplay { + strongSelf.isSetUpForPlayback = false + strongSelf.isPlaying = true + } strongSelf.play() } else if strongSelf.canDisplayFirstFrame { strongSelf.play(firstFrame: true) @@ -884,11 +881,14 @@ public final class AnimatedStickerNode: ASDisplayNode { } private func updateIsPlaying() { + guard !self.autoplay else { + return + } let isPlaying = self.visibility && self.isDisplaying if self.isPlaying != isPlaying { self.isPlaying = isPlaying if isPlaying { - self.play(firstFrame: !self.autoplay) + self.play() } else{ self.pause() } @@ -905,6 +905,9 @@ public final class AnimatedStickerNode: ASDisplayNode { private var isSetUpForPlayback = false public func play(firstFrame: Bool = false) { + if case .once = self.playbackMode { + self.isPlaying = true + } if self.isSetUpForPlayback { let directData = self.directData let cachedData = self.cachedData @@ -1088,7 +1091,6 @@ public final class AnimatedStickerNode: ASDisplayNode { var maybeFrameSource: AnimatedStickerFrameSource? = frameSourceHolder.with { $0 }?.syncWith { $0 }?.value if case .timestamp = position { } else { - var maybeFrameSource: AnimatedStickerFrameSource? if let directData = directData { maybeFrameSource = AnimatedStickerDirectFrameSource(queue: queue, data: directData.0, width: directData.2, height: directData.3, cachePathPrefix: directData.4, fitzModifier: directData.5) if case .end = position { diff --git a/submodules/ComposePollUI/Sources/CreatePollController.swift b/submodules/ComposePollUI/Sources/CreatePollController.swift index 8771c27e46..befd7498d2 100644 --- a/submodules/ComposePollUI/Sources/CreatePollController.swift +++ b/submodules/ComposePollUI/Sources/CreatePollController.swift @@ -811,7 +811,7 @@ public func createPollController(context: AccountContext, peer: Peer, isQuiz: Bo if state.isQuiz { kind = .quiz if !state.solutionText.value.string.isEmpty { - let entities = generateTextEntities(state.solutionText.value.string, enabledTypes: .url, currentEntities: generateChatInputTextEntities(state.solutionText.value)) + let entities = generateTextEntities(state.solutionText.value.string, enabledTypes: .allUrl, currentEntities: generateChatInputTextEntities(state.solutionText.value)) resolvedSolution = TelegramMediaPollResults.Solution(text: state.solutionText.value.string, entities: entities) } } else { diff --git a/submodules/DeviceLocationManager/Sources/DeviceLocationManager.swift b/submodules/DeviceLocationManager/Sources/DeviceLocationManager.swift index 1a20f4e2c1..839f28e184 100644 --- a/submodules/DeviceLocationManager/Sources/DeviceLocationManager.swift +++ b/submodules/DeviceLocationManager/Sources/DeviceLocationManager.swift @@ -59,6 +59,7 @@ public final class DeviceLocationManager: NSObject { self.manager.distanceFilter = 5.0 self.manager.activityType = .other self.manager.pausesLocationUpdatesAutomatically = false + self.manager.headingFilter = 2.0 } public func push(mode: DeviceLocationMode, updated: @escaping (CLLocation, Double?) -> Void) -> Disposable { diff --git a/submodules/FileMediaResourceStatus/Sources/FileMediaResourceStatus.swift b/submodules/FileMediaResourceStatus/Sources/FileMediaResourceStatus.swift index 30b7e823eb..209bae920e 100644 --- a/submodules/FileMediaResourceStatus/Sources/FileMediaResourceStatus.swift +++ b/submodules/FileMediaResourceStatus/Sources/FileMediaResourceStatus.swift @@ -60,7 +60,7 @@ public func messageFileMediaResourceStatus(context: AccountContext, file: Telegr mediaStatus = .playbackStatus(.playing) case .paused: mediaStatus = .playbackStatus(.paused) - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, _): if whilePlaying { mediaStatus = .playbackStatus(.playing) } else { @@ -84,7 +84,7 @@ public func messageFileMediaResourceStatus(context: AccountContext, file: Telegr mediaStatus = .playbackStatus(.playing) case .paused: mediaStatus = .playbackStatus(.paused) - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, _): if whilePlaying { mediaStatus = .playbackStatus(.playing) } else { diff --git a/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift b/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift index 36f09bb9c2..8591cd76b1 100644 --- a/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift +++ b/submodules/GalleryUI/Sources/Items/UniversalVideoGalleryItem.swift @@ -265,6 +265,7 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { private let overlayContentNode: UniversalVideoGalleryItemOverlayNode private var videoNode: UniversalVideoNode? + private var videoNodeUserInteractionEnabled: Bool = false private var videoFramePreview: FramePreview? private var pictureInPictureNode: UniversalVideoGalleryItemPictureInPictureNode? private let statusButtonNode: HighlightableButtonNode @@ -555,6 +556,7 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { } } self.videoNode = videoNode + self.videoNodeUserInteractionEnabled = disablePlayerControls || forceEnableUserInteraction videoNode.isUserInteractionEnabled = disablePlayerControls || forceEnableUserInteraction videoNode.backgroundColor = videoNode.ownsContentNode ? UIColor.black : UIColor(rgb: 0x333335) if item.fromPlayingVideo { @@ -634,6 +636,7 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { var isPaused = true var seekable = false var hasStarted = false + var displayProgress = true if let value = value { hasStarted = value.timestamp > 0 @@ -648,7 +651,8 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { case .playing: isPaused = false playing = true - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, display): + displayProgress = display initialBuffering = true isPaused = !whilePlaying var isStreaming = false @@ -678,6 +682,10 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { if !content.enableSound { isPaused = false } + } else { + strongSelf.updateControlsVisibility(true) + strongSelf.controlsTimer?.invalidate() + strongSelf.controlsTimer = nil } } seekable = value.duration >= 30.0 @@ -700,7 +708,11 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { var fetching = false if initialBuffering { - strongSelf.statusNode.transitionToState(.progress(color: .white, lineWidth: nil, value: nil, cancelEnabled: false), animated: false, completion: {}) + if displayProgress { + strongSelf.statusNode.transitionToState(.progress(color: .white, lineWidth: nil, value: nil, cancelEnabled: false), animated: false, completion: {}) + } else { + strongSelf.statusNode.transitionToState(.none, animated: false, completion: {}) + } } else { var state: RadialStatusNodeState = .play(.white) @@ -789,6 +801,9 @@ final class UniversalVideoGalleryItemNode: ZoomableContentGalleryItemNode { override func controlsVisibilityUpdated(isVisible: Bool) { self.controlsTimer?.invalidate() self.controlsTimer = nil + + self.videoNode?.isUserInteractionEnabled = isVisible ? self.videoNodeUserInteractionEnabled : false + self.videoNode?.notifyPlaybackControlsHidden(!isVisible) } private func updateDisplayPlaceholder(_ displayPlaceholder: Bool) { diff --git a/submodules/InstantPageUI/Sources/InstantPageArticleNode.swift b/submodules/InstantPageUI/Sources/InstantPageArticleNode.swift index 11c3f08153..3173b5f033 100644 --- a/submodules/InstantPageUI/Sources/InstantPageArticleNode.swift +++ b/submodules/InstantPageUI/Sources/InstantPageArticleNode.swift @@ -57,7 +57,7 @@ final class InstantPageArticleNode: ASDisplayNode, InstantPageNode { let imageReference = ImageMediaReference.webPage(webPage: WebpageReference(webPage), media: image) imageNode.setSignal(chatMessagePhoto(postbox: context.account.postbox, photoReference: imageReference)) - self.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, storeToDownloadsPeerType: nil).start()) + self.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, displayAtSize: nil, storeToDownloadsPeerType: nil).start()) self.imageNode = imageNode self.addSubnode(imageNode) diff --git a/submodules/InstantPageUI/Sources/InstantPageImageNode.swift b/submodules/InstantPageUI/Sources/InstantPageImageNode.swift index 0060020d55..9e73a273e2 100644 --- a/submodules/InstantPageUI/Sources/InstantPageImageNode.swift +++ b/submodules/InstantPageUI/Sources/InstantPageImageNode.swift @@ -74,12 +74,12 @@ final class InstantPageImageNode: ASDisplayNode, InstantPageNode { self.imageNode.setSignal(chatMessagePhoto(postbox: context.account.postbox, photoReference: imageReference)) if !interactive || shouldDownloadMediaAutomatically(settings: context.sharedContext.currentAutomaticMediaDownloadSettings.with { $0 }, peerType: sourcePeerType, networkType: MediaAutoDownloadNetworkType(context.account.immediateNetworkType), authorPeerId: nil, contactsPeerIds: Set(), media: image) { - self.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, storeToDownloadsPeerType: nil).start()) + self.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, displayAtSize: nil, storeToDownloadsPeerType: nil).start()) } self.fetchControls = FetchControls(fetch: { [weak self] manual in if let strongSelf = self { - strongSelf.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, storeToDownloadsPeerType: nil).start()) + strongSelf.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, displayAtSize: nil, storeToDownloadsPeerType: nil).start()) } }, cancel: { chatMessagePhotoCancelInteractiveFetch(account: context.account, photoReference: imageReference) @@ -133,7 +133,7 @@ final class InstantPageImageNode: ASDisplayNode, InstantPageNode { } else if let webPage = media.media as? TelegramMediaWebpage, case let .Loaded(content) = webPage.content, let image = content.image { let imageReference = ImageMediaReference.webPage(webPage: WebpageReference(webPage), media: image) self.imageNode.setSignal(chatMessagePhoto(postbox: context.account.postbox, photoReference: imageReference)) - self.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, storeToDownloadsPeerType: nil).start()) + self.fetchedDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: imageReference, displayAtSize: nil, storeToDownloadsPeerType: nil).start()) self.statusNode.transitionToState(.play(.white), animated: false, completion: {}) self.addSubnode(self.statusNode) } diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m index 022b8cc8e0..2a52ae7986 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m @@ -1290,6 +1290,9 @@ - (void)_seekToPosition:(NSTimeInterval)position manual:(bool)__unused manual { + if (self.player == nil) { + return; + } CMTime targetTime = CMTimeMakeWithSeconds(position, NSEC_PER_SEC); if (CMTIME_COMPARE_INLINE(targetTime, !=, _chaseTime)) diff --git a/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift b/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift index 2d6429d89e..4c671c379f 100644 --- a/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift +++ b/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift @@ -147,12 +147,17 @@ public final class ChatMessageLiveLocationPositionNode: ASDisplayNode { var hasPulse = false var heading: Double? var coordinate: (Double, Double)? + + func degToRad(_ degrees: Double) -> Double { + return degrees * Double.pi / 180.0 + } + switch mode { case let .liveLocation(_, active, latitude, longitude, headingValue): backgroundImage = avatarBackgroundImage hasPulse = active coordinate = (latitude, longitude) - heading = headingValue.flatMap { Double($0) } + heading = headingValue.flatMap { degToRad(Double($0)) } case let .location(location): let venueType = location?.venue?.type ?? "" let color = venueType.isEmpty ? theme.list.itemAccentColor : venueIconColor(type: venueType) @@ -162,10 +167,6 @@ public final class ChatMessageLiveLocationPositionNode: ASDisplayNode { } } - func degToRad(_ degrees: Double) -> Double { - return degrees * Double.pi / 180.0 - } - if heading == nil, let currentCoordinate = currentCoordinate, let coordinate = coordinate { let lat1 = degToRad(currentCoordinate.0) let lon1 = degToRad(currentCoordinate.1) @@ -248,7 +249,7 @@ public final class ChatMessageLiveLocationPositionNode: ASDisplayNode { strongSelf.arrowNode.isHidden = heading == nil || !hasPulse strongSelf.arrowNode.position = CGPoint(x: 31.0, y: 64.0) - strongSelf.arrowNode.transform = CATransform3DMakeRotation(CGFloat(heading ?? 0.0 / 180.0 * Double.pi), 0.0, 0.0, 1.0) + strongSelf.arrowNode.transform = CATransform3DMakeRotation(CGFloat(heading ?? 0), 0.0, 0.0, 1.0) } }) } diff --git a/submodules/LocationUI/Sources/LocationActionListItem.swift b/submodules/LocationUI/Sources/LocationActionListItem.swift index 2f7f37a838..9e43984c4b 100644 --- a/submodules/LocationUI/Sources/LocationActionListItem.swift +++ b/submodules/LocationUI/Sources/LocationActionListItem.swift @@ -74,7 +74,7 @@ private func generateLiveLocationIcon(theme: PresentationTheme, stop: Bool) -> U context.scaleBy(x: 1.0, y: -1.0) context.translateBy(x: -size.width / 2.0, y: -size.height / 2.0) - if let image = generateTintedImage(image: UIImage(bundleImageName: "Location/SendLocationIcon"), color: theme.chat.inputPanel.actionControlForegroundColor) { + if let image = generateTintedImage(image: UIImage(bundleImageName: stop ? "Location/SendLocationIcon" : "Location/SendLiveLocationIcon"), color: theme.chat.inputPanel.actionControlForegroundColor) { context.draw(image.cgImage!, in: CGRect(origin: CGPoint(x: floor((size.width - image.size.width) / 2.0), y: floor((size.height - image.size.height) / 2.0)), size: image.size)) } })! diff --git a/submodules/LocationUI/Sources/LocationAnnotation.swift b/submodules/LocationUI/Sources/LocationAnnotation.swift index 0a66824904..5a7cffa715 100644 --- a/submodules/LocationUI/Sources/LocationAnnotation.swift +++ b/submodules/LocationUI/Sources/LocationAnnotation.swift @@ -43,7 +43,7 @@ class LocationPinAnnotation: NSObject, MKAnnotation { let peer: Peer? let message: Message? let forcedSelection: Bool - var heading: Int32? { + @objc dynamic var heading: NSNumber? { willSet { self.willChangeValue(forKey: "heading") } @@ -91,7 +91,7 @@ class LocationPinAnnotation: NSObject, MKAnnotation { } self.selfPeer = selfPeer self.forcedSelection = false - self.heading = heading + self.heading = heading.flatMap { NSNumber(value: $0) } super.init() } @@ -167,6 +167,8 @@ class LocationPinAnnotationView: MKAnnotationView { var hasPulse = false + var headingKvoToken: NSKeyValueObservation? + override class var layerClass: AnyClass { return LocationPinAnnotationLayer.self } @@ -233,6 +235,14 @@ class LocationPinAnnotationView: MKAnnotationView { self.annotation = annotation } + required init?(coder aDecoder: NSCoder) { + fatalError("init(coder:) has not been implemented") + } + + deinit { + self.headingKvoToken?.invalidate() + } + var defaultZPosition: CGFloat { if let annotation = self.annotation as? LocationPinAnnotation { if annotation.forcedSelection { @@ -247,10 +257,6 @@ class LocationPinAnnotationView: MKAnnotationView { } } - required init?(coder aDecoder: NSCoder) { - fatalError("init(coder:) has not been implemented") - } - override var annotation: MKAnnotation? { didSet { if let annotation = self.annotation as? LocationPinAnnotation { @@ -270,6 +276,18 @@ class LocationPinAnnotationView: MKAnnotationView { self.shadowNode.isHidden = true self.smallNode.isHidden = false } + + if let headingKvoToken = self.headingKvoToken { + self.headingKvoToken = nil + headingKvoToken.invalidate() + } + + self.headingKvoToken = annotation.observe(\.heading, options: .new) { [weak self] (_, change) in + guard let heading = change.newValue else { + return + } + self?.updateHeading(heading) + } } else if let peer = annotation.peer { self.iconNode.isHidden = true @@ -278,6 +296,12 @@ class LocationPinAnnotationView: MKAnnotationView { self.setPeer(context: annotation.context, theme: annotation.theme, peer: peer) self.setSelected(true, animated: false) + + if let headingKvoToken = self.headingKvoToken { + self.headingKvoToken = nil + headingKvoToken.invalidate() + } + self.updateHeading(nil) } else if let location = annotation.location { let venueType = location.venue?.type ?? "" let color = venueType.isEmpty ? annotation.theme.list.itemAccentColor : venueIconColor(type: venueType) @@ -299,15 +323,36 @@ class LocationPinAnnotationView: MKAnnotationView { self.setSelected(true, animated: false) } + if let avatarNode = self.avatarNode { + self.avatarNode = nil + avatarNode.removeFromSupernode() + } + if self.initialized && !self.appeared { self.appeared = true self.animateAppearance() } + + if let headingKvoToken = self.headingKvoToken { + self.headingKvoToken = nil + headingKvoToken.invalidate() + } + self.updateHeading(nil) } } } } + private func updateHeading(_ heading: NSNumber?) { + if let heading = heading?.int32Value { + self.arrowNode.isHidden = false + self.arrowNode.transform = CATransform3DMakeRotation(CGFloat(heading) / 180.0 * CGFloat.pi, 0.0, 0.0, 1.0) + } else { + self.arrowNode.isHidden = true + self.arrowNode.transform = CATransform3DIdentity + } + } + override func prepareForReuse() { self.smallNode.isHidden = true self.backgroundNode.isHidden = false diff --git a/submodules/LocationUI/Sources/LocationDistancePickerScreen.swift b/submodules/LocationUI/Sources/LocationDistancePickerScreen.swift index f95b8e9ead..4d15e09503 100644 --- a/submodules/LocationUI/Sources/LocationDistancePickerScreen.swift +++ b/submodules/LocationUI/Sources/LocationDistancePickerScreen.swift @@ -161,8 +161,10 @@ private var unitValues: [Int32] = { private var smallUnitValues: [Int32] = { var values: [Int32] = [] - for i in 0 ..< 100 { - values.append(Int32(i)) + values.append(0) + values.append(5) + for i in 1 ..< 10 { + values.append(Int32(i * 10)) } return values }() @@ -185,6 +187,8 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD private let doneButton: SolidRoundedButtonNode private var pickerView: TimerPickerView? + private let unitLabelNode: ImmediateTextNode + private let smallUnitLabelNode: ImmediateTextNode private var containerLayout: (ContainerViewLayout, CGFloat)? @@ -251,11 +255,18 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD self.doneButton = SolidRoundedButtonNode(theme: SolidRoundedButtonTheme(theme: self.presentationData.theme), height: 52.0, cornerRadius: 11.0, gloss: false) self.doneButton.title = self.presentationData.strings.Conversation_Timer_Send + self.unitLabelNode = ImmediateTextNode() + + self.smallUnitLabelNode = ImmediateTextNode() + super.init() self.backgroundColor = nil self.isOpaque = false + self.unitLabelNode.attributedText = NSAttributedString(string: self.usesMetricSystem ? self.presentationData.strings.Location_ProximityNotification_DistanceKM : self.presentationData.strings.Location_ProximityNotification_DistanceMI, font: Font.regular(15.0), textColor: textColor) + self.smallUnitLabelNode.attributedText = NSAttributedString(string: self.usesMetricSystem ? self.presentationData.strings.Location_ProximityNotification_DistanceM : "", font: Font.regular(15.0), textColor: textColor) + self.dimNode.view.addGestureRecognizer(UITapGestureRecognizer(target: self, action: #selector(self.dimTapGesture(_:)))) self.addSubnode(self.dimNode) @@ -272,6 +283,9 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD self.contentContainerNode.addSubnode(self.cancelButton) self.contentContainerNode.addSubnode(self.doneButton) + self.contentContainerNode.addSubnode(self.unitLabelNode) + self.contentContainerNode.addSubnode(self.smallUnitLabelNode) + self.cancelButton.addTarget(self, action: #selector(self.cancelButtonPressed), forControlEvents: .touchUpInside) self.doneButton.pressed = { [weak self] in if let strongSelf = self, let pickerView = strongSelf.pickerView { @@ -280,7 +294,7 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD let largeValue = unitValues[pickerView.selectedRow(inComponent: 0)] let smallValue = smallUnitValues[pickerView.selectedRow(inComponent: 1)] var value = largeValue * 1000 + smallValue * 10 - if !strongSelf.usesMetricSystem() { + if !strongSelf.usesMetricSystem { value = Int32(Double(value) * 1.60934) } strongSelf.completion?(value) @@ -313,18 +327,21 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD pickerView.delegate = self pickerView.selectRow(0, inComponent: 0, animated: false) - if self.usesMetricSystem() { - pickerView.selectRow(50, inComponent: 1, animated: false) + if self.usesMetricSystem { + pickerView.selectRow(6, inComponent: 1, animated: false) } else { - pickerView.selectRow(30, inComponent: 1, animated: false) + pickerView.selectRow(4, inComponent: 1, animated: false) } self.contentContainerNode.view.addSubview(pickerView) self.pickerView = pickerView + self.contentContainerNode.addSubnode(self.unitLabelNode) + self.contentContainerNode.addSubnode(self.smallUnitLabelNode) + self.updateDoneButtonTitle() } - private func usesMetricSystem() -> Bool { + private var usesMetricSystem: Bool { let locale = localeWithStrings(self.presentationData.strings) if locale.identifier.hasSuffix("GB") { return false @@ -333,7 +350,7 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD } func numberOfComponents(in pickerView: UIPickerView) -> Int { - return 3 + return 2 } private func updateDoneButtonTitle() { @@ -348,7 +365,7 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD let smallValue = smallUnitValues[selectedSmallRow] var value = largeValue * 1000 + smallValue * 10 - if !self.usesMetricSystem() { + if !self.usesMetricSystem { value = Int32(Double(value) * 1.60934) } let distance = stringForDistance(strings: self.presentationData.strings, distance: CLLocationDistance(value)) @@ -377,7 +394,7 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD let smallValue = smallUnitValues[pickerView.selectedRow(inComponent: 1)] var value = largeValue * 1000 + smallValue * 10 - if !self.usesMetricSystem() { + if !self.usesMetricSystem { value = Int32(Double(value) * 1.60934) } self.updated?(value) @@ -409,11 +426,20 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD if component == 0 { let value = unitValues[row] string = "\(value)" - } else if component == 1 { - let value = String(format: "%.2d", smallUnitValues[row]) - string = ".\(value)" } else { - string = self.usesMetricSystem() ? self.presentationData.strings.Location_ProximityNotification_DistanceKM : self.presentationData.strings.Location_ProximityNotification_DistanceMI + if self.usesMetricSystem { + let value = String(format: "%d", smallUnitValues[row] * 10) + string = "\(value)" + } else { + let value = smallUnitValues[row] + if value == 0 { + string = ".0" + } else if value == 5 { + string = ".05" + } else { + string = ".\(value / 10)" + } + } } return NSAttributedString(string: string, font: font, textColor: self.presentationData.theme.actionSheet.primaryTextColor) } @@ -442,6 +468,9 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD self.doneButton.updateTheme(SolidRoundedButtonTheme(theme: self.presentationData.theme)) self.updateDoneButtonTitle() + + self.unitLabelNode.attributedText = NSAttributedString(string: self.usesMetricSystem ? self.presentationData.strings.Location_ProximityNotification_DistanceKM : self.presentationData.strings.Location_ProximityNotification_DistanceMI, font: Font.regular(15.0), textColor: self.presentationData.theme.actionSheet.primaryTextColor) + self.smallUnitLabelNode.attributedText = NSAttributedString(string: self.usesMetricSystem ? self.presentationData.strings.Location_ProximityNotification_DistanceM : "", font: Font.regular(15.0), textColor: self.presentationData.theme.actionSheet.primaryTextColor) } override func didLoad() { @@ -465,8 +494,8 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD func animateIn() { self.dimNode.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.3) - let offset = self.bounds.size.height - self.contentBackgroundNode.frame.minY - self.wrappingScrollNode.layer.animateBoundsOriginYAdditive(from: -offset, to: 0.0, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring) + let offset = self.contentContainerNode.frame.height + self.wrappingScrollNode.layer.animatePosition(from: CGPoint(x: 0.0, y: offset), to: CGPoint(), duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring, additive: true) } func animateOut(completion: (() -> Void)? = nil) { @@ -485,8 +514,8 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD internalCompletion() }) - let offset = self.bounds.size.height - self.contentBackgroundNode.frame.minY - self.wrappingScrollNode.layer.animateBoundsOriginYAdditive(from: 0.0, to: -offset, duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false, completion: { _ in + let offset = self.contentContainerNode.frame.height + self.wrappingScrollNode.layer.animatePosition(from: CGPoint(), to: CGPoint(x: 0.0, y: offset), duration: 0.3, timingFunction: kCAMediaTimingFunctionSpring, removeOnCompletion: false, additive: true, completion: { _ in offsetCompleted = true internalCompletion() }) @@ -555,8 +584,15 @@ class LocationDistancePickerScreenNode: ViewControllerTracingNode, UIScrollViewD let textSize = self.textNode.updateLayout(CGSize(width: width, height: titleHeight)) transition.updateFrame(node: self.textNode, frame: CGRect(origin: CGPoint(x: floor((width - textSize.width) / 2.0), y: floor(doneButtonFrame.center.y - textSize.height / 2.0)), size: textSize)) + + let pickerFrame = CGRect(origin: CGPoint(x: 0.0, y: 54.0), size: CGSize(width: contentFrame.width, height: pickerHeight)) + self.pickerView?.frame = pickerFrame - self.pickerView?.frame = CGRect(origin: CGPoint(x: 0.0, y: 54.0), size: CGSize(width: contentFrame.width, height: pickerHeight)) + let unitLabelSize = self.unitLabelNode.updateLayout(CGSize(width: width, height: titleHeight)) + transition.updateFrame(node: self.unitLabelNode, frame: CGRect(origin: CGPoint(x: floor(pickerFrame.width / 4.0) + 50.0, y: floor(pickerFrame.center.y - unitLabelSize.height / 2.0)), size: unitLabelSize)) + + let smallUnitLabelSize = self.smallUnitLabelNode.updateLayout(CGSize(width: width, height: titleHeight)) + transition.updateFrame(node: self.smallUnitLabelNode, frame: CGRect(origin: CGPoint(x: floor(pickerFrame.width / 4.0 * 3.0) + 50.0, y: floor(pickerFrame.center.y - smallUnitLabelSize.height / 2.0)), size: smallUnitLabelSize)) transition.updateFrame(node: self.contentContainerNode, frame: contentContainerFrame) } diff --git a/submodules/LocationUI/Sources/LocationMapNode.swift b/submodules/LocationUI/Sources/LocationMapNode.swift index 7ec44d33e8..ffaca3d40a 100644 --- a/submodules/LocationUI/Sources/LocationMapNode.swift +++ b/submodules/LocationUI/Sources/LocationMapNode.swift @@ -83,6 +83,11 @@ private class LocationMapView: MKMapView, UIGestureRecognizerDelegate { return pointInside } + + public override func layoutSubviews() { + super.layoutSubviews() + + } } private let arrowImageSize = CGSize(width: 90.0, height: 90.0) @@ -110,14 +115,16 @@ func generateHeadingArrowImage() -> UIImage? { }) } -private func generateProximityDim(size: CGSize, rect: CGRect) -> UIImage { +private func generateProximityDim(size: CGSize) -> UIImage { return generateImage(size, rotatedContext: { size, context in context.clear(CGRect(origin: CGPoint(), size: size)) context.setFillColor(UIColor(rgb: 0x000000, alpha: 0.4).cgColor) context.fill(CGRect(origin: CGPoint(), size: size)) context.setBlendMode(.clear) - context.fillEllipse(in: rect) + + let ellipseSize = CGSize(width: 260.0, height: 260.0) + context.fillEllipse(in: CGRect(origin: CGPoint(x: (size.width - ellipseSize.width) / 2.0, y: (size.height - ellipseSize.height) / 2.0), size: ellipseSize)) })! } @@ -144,64 +151,7 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { context.restoreGState() } } - - class InvertedProximityCircle: NSObject, MKOverlay { - var coordinate: CLLocationCoordinate2D - var radius: Double - var alpha: CGFloat { - didSet { - self.alphaTransition = (oldValue, CACurrentMediaTime(), 0.3) - } - } - var alphaTransition: (from: CGFloat, startTimestamp: Double, duration: Double)? - var boundingMapRect: MKMapRect { - return MKMapRect.world - } - - init(center coord: CLLocationCoordinate2D, radius: Double, alpha: CGFloat = 0.0) { - self.coordinate = coord - self.radius = radius - self.alpha = alpha - } - } - - class InvertedProximityCircleRenderer: MKOverlayRenderer { - var radius: Double = 0.0 - var fillColor: UIColor = UIColor(rgb: 0x000000, alpha: 0.5) - - override func draw(_ mapRect: MKMapRect, zoomScale: MKZoomScale, in context: CGContext) { - guard let overlay = self.overlay as? InvertedProximityCircle else { - return - } - - var alpha: CGFloat = overlay.alpha - if let transition = overlay.alphaTransition { - var t = (CACurrentMediaTime() - transition.startTimestamp) / transition.duration - t = min(1.0, max(0.0, t)) - alpha = transition.from + (alpha - transition.from) * CGFloat(t) - } - - context.setAlpha(alpha) - - let path = UIBezierPath(rect: CGRect(x: mapRect.origin.x, y: mapRect.origin.y, width: mapRect.size.width, height: mapRect.size.height)) - let radiusInMap = overlay.radius * MKMapPointsPerMeterAtLatitude(overlay.coordinate.latitude) * 2.0 - let mapSize: MKMapSize = MKMapSize(width: radiusInMap, height: radiusInMap) - let regionOrigin = MKMapPoint(overlay.coordinate) - var regionRect: MKMapRect = MKMapRect(origin: regionOrigin, size: mapSize) - regionRect = regionRect.offsetBy(dx: -radiusInMap / 2.0, dy: -radiusInMap / 2.0); - regionRect = regionRect.intersection(MKMapRect.world); - - let excludePath: UIBezierPath = UIBezierPath(roundedRect: CGRect(x: regionRect.origin.x, y: regionRect.origin.y, width: regionRect.size.width, height: regionRect.size.height), cornerRadius: CGFloat(regionRect.size.width) / 2.0) - path.append(excludePath) - - context.setFillColor(fillColor.cgColor); - context.addPath(path.cgPath); - context.fillPath(using: .evenOdd) - } - } - private weak var currentInvertedCircleRenderer: InvertedProximityCircleRenderer? - private let locationPromise = Promise(nil) private let pickerAnnotationContainerView: PickerAnnotationContainerView @@ -222,74 +172,34 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { var annotationSelected: ((LocationPinAnnotation?) -> Void)? var userLocationAnnotationSelected: (() -> Void)? - - var indicatorOverlay: InvertedProximityCircle? + + var proximityDimView = UIImageView() var proximityIndicatorRadius: Double? { didSet { - if let activeProximityRadius = self.proximityIndicatorRadius { - if let location = self.currentUserLocation, activeProximityRadius != oldValue { - let indicatorOverlay: InvertedProximityCircle - if let current = self.indicatorOverlay { - indicatorOverlay = current - indicatorOverlay.radius = activeProximityRadius - self.mapView?.removeOverlay(indicatorOverlay) - self.mapView?.addOverlay(indicatorOverlay) - } else { - indicatorOverlay = InvertedProximityCircle(center: location.coordinate, radius: activeProximityRadius) - self.mapView?.addOverlay(indicatorOverlay) - self.indicatorOverlay = indicatorOverlay - indicatorOverlay.alpha = 1.0 - self.updateAnimations() + if let radius = self.proximityIndicatorRadius, let mapView = self.mapView { + if self.proximityDimView.image == nil { + proximityDimView.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) + } + + if oldValue == 0 { + UIView.transition(with: proximityDimView, duration: 0.3, options: .transitionCrossDissolve) { + self.proximityDimView.image = generateProximityDim(size: mapView.bounds.size) + } completion: { _ in + } } } else { - if let indicatorOverlay = self.indicatorOverlay { - indicatorOverlay.alpha = 0.0 - self.updateAnimations() + if self.proximityDimView.image != nil { + UIView.transition(with: proximityDimView, duration: 0.3, options: .transitionCrossDissolve) { + self.proximityDimView.image = nil + } completion: { _ in + + } } } } } - - private var animator: ConstantDisplayLinkAnimator? - private func updateAnimations() { - guard let mapView = self.mapView else { - return - } - var animate = false - let timestamp = CACurrentMediaTime() - - if let indicatorOverlay = self.indicatorOverlay, let transition = indicatorOverlay.alphaTransition { - if transition.startTimestamp + transition.duration < timestamp { - indicatorOverlay.alphaTransition = nil - if indicatorOverlay.alpha.isZero { - self.indicatorOverlay = nil - mapView.removeOverlay(indicatorOverlay) - } - } else { - animate = true - } - } - - if animate { - let animator: ConstantDisplayLinkAnimator - if let current = self.animator { - animator = current - } else { - animator = ConstantDisplayLinkAnimator(update: { [weak self] in - self?.updateAnimations() - }) - self.animator = animator - } - animator.isPaused = false - } else { - self.animator?.isPaused = true - } - - self.currentInvertedCircleRenderer?.setNeedsDisplay(MKMapRect.world) - } - private var circleOverlay: MKCircle? var activeProximityRadius: Double? { didSet { @@ -372,9 +282,26 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { var trackingMode: LocationTrackingMode = .none { didSet { self.mapView?.userTrackingMode = self.trackingMode.userTrackingMode + if self.trackingMode == .followWithHeading && self.headingArrowView?.image != nil { + self.headingArrowView?.image = nil + } else if self.trackingMode != .followWithHeading && self.headingArrowView?.image == nil { + self.headingArrowView?.image = generateHeadingArrowImage() + } } } + var mapOffset: CGFloat = 0.0 + func setMapCenter(coordinate: CLLocationCoordinate2D, radius: Double, insets: UIEdgeInsets, offset: CGFloat, animated: Bool = false) { + self.mapOffset = offset + self.ignoreRegionChanges = true + + let mapRect = MKMapRect(region: MKCoordinateRegion(center: coordinate, latitudinalMeters: radius * 2.0, longitudinalMeters: radius * 2.0)) + self.mapView?.setVisibleMapRect(mapRect, edgePadding: insets, animated: animated) + self.ignoreRegionChanges = false + + self.proximityDimView.center = CGPoint(x: self.bounds.midX, y: self.bounds.midY + offset) + } + func setMapCenter(coordinate: CLLocationCoordinate2D, span: MKCoordinateSpan = defaultMapSpan, offset: CGPoint = CGPoint(), isUserLocation: Bool = false, hidePicker: Bool = false, animated: Bool = false) { let region = MKCoordinateRegion(center: coordinate, span: span) self.ignoreRegionChanges = true @@ -474,6 +401,10 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { } else if let view = view as? LocationPinAnnotationView { view.setZPosition(view.defaultZPosition) } + + if let container = view.superview { + container.insertSubview(self.proximityDimView, at: 0) + } } } @@ -513,11 +444,7 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { } func mapView(_ mapView: MKMapView, rendererFor overlay: MKOverlay) -> MKOverlayRenderer { - if let invertedCircle = overlay as? InvertedProximityCircle { - let renderer = InvertedProximityCircleRenderer(overlay: invertedCircle) - self.currentInvertedCircleRenderer = renderer - return renderer - } else if let circle = overlay as? MKCircle { + if let circle = overlay as? MKCircle { let renderer = ProximityCircleRenderer(circle: circle) renderer.fillColor = .clear renderer.strokeColor = UIColor(rgb: 0xc3baaf) @@ -528,18 +455,7 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { return MKOverlayRenderer() } } - - func mapView(_ mapView: MKMapView, didAdd renderers: [MKOverlayRenderer]) { - for renderer in renderers { - if let renderer = renderer as? InvertedProximityCircleRenderer { - renderer.alpha = 0.0 - UIView.animate(withDuration: 0.3) { - renderer.alpha = 1.0 - } - } - } - } - + var distancesToAllAnnotations: Signal<[Double], NoError> { let poll = Signal<[LocationPinAnnotation], NoError> { [weak self] subscriber in if let strongSelf = self { @@ -676,9 +592,45 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { } if let updatedAnnotation = dict[annotation.id] { + func degToRad(_ degrees: Double) -> Double { + return degrees * Double.pi / 180.0 + } + + func radToDeg(_ radians: Double) -> Double { + return radians / Double.pi * 180.0 + } + + let currentCoordinate = annotation.coordinate + let coordinate = updatedAnnotation.coordinate + var heading = updatedAnnotation.heading + if heading == nil { + let previous = CLLocation(latitude: currentCoordinate.latitude, longitude: currentCoordinate.longitude) + let new = CLLocation(latitude: coordinate.latitude, longitude: coordinate.longitude) + + if new.distance(from: previous) > 10 { + let lat1 = degToRad(currentCoordinate.latitude) + let lon1 = degToRad(currentCoordinate.longitude) + let lat2 = degToRad(coordinate.latitude) + let lon2 = degToRad(coordinate.longitude) + + let dLat = lat2 - lat1 + let dLon = lon2 - lon1 + + if dLat != 0 && dLon != 0 { + let y = sin(dLon) * cos(lat2) + let x = cos(lat1) * sin(lat2) - sin(lat1) * cos(lat2) * cos(dLon) + heading = NSNumber(value: radToDeg(atan2(y, x))) + } + } else { + heading = annotation.heading + } + } + UIView.animate(withDuration: 0.2) { annotation.coordinate = updatedAnnotation.coordinate } + + annotation.heading = heading dict[annotation.id] = nil } else { annotationsToRemove.insert(annotation) @@ -765,6 +717,7 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { } func updateLayout(size: CGSize) { + self.proximityDimView.frame = CGRect(origin: CGPoint(x: 0.0, y: self.mapOffset), size: size) self.pickerAnnotationContainerView.frame = CGRect(x: 0.0, y: floorToScreenPixels((size.height - size.width) / 2.0), width: size.width, height: size.width) if let pickerAnnotationView = self.pickerAnnotationView { pickerAnnotationView.center = CGPoint(x: self.pickerAnnotationContainerView.frame.width / 2.0, y: self.pickerAnnotationContainerView.frame.height / 2.0) diff --git a/submodules/LocationUI/Sources/LocationViewController.swift b/submodules/LocationUI/Sources/LocationViewController.swift index 3a4a08ecf5..1eeab9d9e5 100644 --- a/submodules/LocationUI/Sources/LocationViewController.swift +++ b/submodules/LocationUI/Sources/LocationViewController.swift @@ -20,12 +20,14 @@ public class LocationViewParams { let stopLiveLocation: (MessageId?) -> Void let openUrl: (String) -> Void let openPeer: (Peer) -> Void + let showAll: Bool - public init(sendLiveLocation: @escaping (TelegramMediaMap) -> Void, stopLiveLocation: @escaping (MessageId?) -> Void, openUrl: @escaping (String) -> Void, openPeer: @escaping (Peer) -> Void) { + public init(sendLiveLocation: @escaping (TelegramMediaMap) -> Void, stopLiveLocation: @escaping (MessageId?) -> Void, openUrl: @escaping (String) -> Void, openPeer: @escaping (Peer) -> Void, showAll: Bool = false) { self.sendLiveLocation = sendLiveLocation self.stopLiveLocation = stopLiveLocation self.openUrl = openUrl self.openPeer = openPeer + self.showAll = showAll } } @@ -42,14 +44,14 @@ class LocationViewInteraction { let goToCoordinate: (CLLocationCoordinate2D) -> Void let requestDirections: () -> Void let share: () -> Void - let setupProximityNotification: (Bool, CLLocationCoordinate2D?, MessageId?) -> Void + let setupProximityNotification: (Bool, MessageId?) -> Void let updateSendActionHighlight: (Bool) -> Void - let sendLiveLocation: (CLLocationCoordinate2D, Int32?) -> Void + let sendLiveLocation: (Int32?) -> Void let stopLiveLocation: () -> Void let updateRightBarButton: (LocationViewRightBarButton) -> Void let present: (ViewController) -> Void - init(toggleMapModeSelection: @escaping () -> Void, updateMapMode: @escaping (LocationMapMode) -> Void, toggleTrackingMode: @escaping () -> Void, goToCoordinate: @escaping (CLLocationCoordinate2D) -> Void, requestDirections: @escaping () -> Void, share: @escaping () -> Void, setupProximityNotification: @escaping (Bool, CLLocationCoordinate2D?, MessageId?) -> Void, updateSendActionHighlight: @escaping (Bool) -> Void, sendLiveLocation: @escaping (CLLocationCoordinate2D, Int32?) -> Void, stopLiveLocation: @escaping () -> Void, updateRightBarButton: @escaping (LocationViewRightBarButton) -> Void, present: @escaping (ViewController) -> Void) { + init(toggleMapModeSelection: @escaping () -> Void, updateMapMode: @escaping (LocationMapMode) -> Void, toggleTrackingMode: @escaping () -> Void, goToCoordinate: @escaping (CLLocationCoordinate2D) -> Void, requestDirections: @escaping () -> Void, share: @escaping () -> Void, setupProximityNotification: @escaping (Bool, MessageId?) -> Void, updateSendActionHighlight: @escaping (Bool) -> Void, sendLiveLocation: @escaping (Int32?) -> Void, stopLiveLocation: @escaping () -> Void, updateRightBarButton: @escaping (LocationViewRightBarButton) -> Void, present: @escaping (ViewController) -> Void) { self.toggleMapModeSelection = toggleMapModeSelection self.updateMapMode = updateMapMode self.toggleTrackingMode = toggleTrackingMode @@ -73,6 +75,7 @@ public final class LocationViewController: ViewController { public var subject: Message private var presentationData: PresentationData private var presentationDataDisposable: Disposable? + private var showAll: Bool private let locationManager = LocationManager() private var permissionDisposable: Disposable? @@ -84,6 +87,7 @@ public final class LocationViewController: ViewController { public init(context: AccountContext, subject: Message, params: LocationViewParams) { self.context = context self.subject = subject + self.showAll = params.showAll self.presentationData = context.sharedContext.currentPresentationData.with { $0 } @@ -173,50 +177,89 @@ public final class LocationViewController: ViewController { }) strongSelf.present(OpenInActionSheetController(context: context, item: .location(location: location, withDirections: false), additionalAction: shareAction, openUrl: params.openUrl), in: .window(.root), with: nil) } - }, setupProximityNotification: { [weak self] reset, coordinate, messageId in + }, setupProximityNotification: { [weak self] reset, messageId in guard let strongSelf = self else { return } if reset { if let messageId = messageId { - let _ = requestEditLiveLocation(postbox: context.account.postbox, network: context.account.network, stateManager: context.account.stateManager, messageId: messageId, stop: false, coordinate: nil, heading: nil, proximityNotificationRadius: 0).start() - } - } else { - strongSelf.controllerNode.setProximityIndicator(radius: 0) - - let controller = LocationDistancePickerScreen(context: context, style: .default, distances: strongSelf.controllerNode.headerNode.mapNode.distancesToAllAnnotations, updated: { [weak self] distance in - guard let strongSelf = self else { - return - } - strongSelf.controllerNode.setProximityIndicator(radius: distance) - }, completion: { [weak self] distance, completion in - guard let strongSelf = self else { - return + strongSelf.controllerNode.updateState { state in + var state = state + state.cancellingProximityRadius = true + return state } - if let messageId = messageId { - let _ = requestEditLiveLocation(postbox: context.account.postbox, network: context.account.network, stateManager: context.account.stateManager, messageId: messageId, stop: false, coordinate: nil, heading: nil, proximityNotificationRadius: distance).start() - } else if let coordinate = coordinate { - strongSelf.present(textAlertController(context: strongSelf.context, title: strongSelf.presentationData.strings.Location_LiveLocationRequired_Title, text: strongSelf.presentationData.strings.Location_LiveLocationRequired_Description, actions: [TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Location_LiveLocationRequired_ShareLocation, action: { - completion() - strongSelf.interaction?.sendLiveLocation(coordinate, distance) - }), TextAlertAction(type: .genericAction, title: strongSelf.presentationData.strings.Common_Cancel, action: {})], actionLayout: .vertical), in: .window(.root)) + let _ = requestEditLiveLocation(postbox: context.account.postbox, network: context.account.network, stateManager: context.account.stateManager, messageId: messageId, stop: false, coordinate: nil, heading: nil, proximityNotificationRadius: 0).start(completed: { [weak self] in + guard let strongSelf = self else { + return + } + strongSelf.controllerNode.updateState { state in + var state = state + state.cancellingProximityRadius = false + return state + } + }) + } + } else { + DeviceAccess.authorizeAccess(to: .location(.live), locationManager: strongSelf.locationManager, presentationData: strongSelf.presentationData, present: { c, a in + strongSelf.present(c, in: .window(.root), with: a) + }, openSettings: { + context.sharedContext.applicationBindings.openSettings() + }) { [weak self] authorized in + guard let strongSelf = self, authorized else { + return } - completion() - }, willDismiss: { [weak self] in - if let strongSelf = self { - strongSelf.controllerNode.setProximityIndicator(radius: nil) - } - }) - strongSelf.present(controller, in: .window(.root)) + strongSelf.controllerNode.setProximityIndicator(radius: 0) + + let controller = LocationDistancePickerScreen(context: context, style: .default, distances: strongSelf.controllerNode.headerNode.mapNode.distancesToAllAnnotations, updated: { [weak self] distance in + guard let strongSelf = self else { + return + } + strongSelf.controllerNode.setProximityIndicator(radius: distance) + }, completion: { [weak self] distance, completion in + guard let strongSelf = self else { + return + } + + if let messageId = messageId { + strongSelf.controllerNode.updateState { state in + var state = state + state.updatingProximityRadius = distance + return state + } + + let _ = requestEditLiveLocation(postbox: context.account.postbox, network: context.account.network, stateManager: context.account.stateManager, messageId: messageId, stop: false, coordinate: nil, heading: nil, proximityNotificationRadius: distance).start(completed: { [weak self] in + guard let strongSelf = self else { + return + } + strongSelf.controllerNode.updateState { state in + var state = state + state.updatingProximityRadius = nil + return state + } + }) + } else { + strongSelf.present(textAlertController(context: strongSelf.context, title: strongSelf.presentationData.strings.Location_LiveLocationRequired_Title, text: strongSelf.presentationData.strings.Location_LiveLocationRequired_Description, actions: [TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Location_LiveLocationRequired_ShareLocation, action: { + completion() + strongSelf.interaction?.sendLiveLocation(distance) + }), TextAlertAction(type: .genericAction, title: strongSelf.presentationData.strings.Common_Cancel, action: {})], actionLayout: .vertical), in: .window(.root)) + } + completion() + }, willDismiss: { [weak self] in + if let strongSelf = self { + strongSelf.controllerNode.setProximityIndicator(radius: nil) + } + }) + strongSelf.present(controller, in: .window(.root)) + } } }, updateSendActionHighlight: { [weak self] highlighted in guard let strongSelf = self else { return } strongSelf.controllerNode.updateSendActionHighlight(highlighted) - }, sendLiveLocation: { [weak self] coordinate, distance in + }, sendLiveLocation: { [weak self] distance in guard let strongSelf = self else { return } @@ -230,19 +273,26 @@ public final class LocationViewController: ViewController { } if let distance = distance { - params.sendLiveLocation(TelegramMediaMap(coordinate: coordinate, liveBroadcastingTimeout: 30 * 60, proximityNotificationRadius: distance)) + let _ = (strongSelf.controllerNode.coordinate + |> deliverOnMainQueue).start(next: { coordinate in + params.sendLiveLocation(TelegramMediaMap(coordinate: coordinate, liveBroadcastingTimeout: 30 * 60, proximityNotificationRadius: distance)) + }) } else { let _ = (context.account.postbox.loadedPeerWithId(subject.id.peerId) - |> deliverOnMainQueue).start(next: { [weak self] peer in + |> deliverOnMainQueue).start(next: { peer in let controller = ActionSheetController(presentationData: strongSelf.presentationData) var title = strongSelf.presentationData.strings.Map_LiveLocationGroupDescription if let user = peer as? TelegramUser { title = strongSelf.presentationData.strings.Map_LiveLocationPrivateDescription(user.compactDisplayTitle).0 } - let sendLiveLocationImpl: (Int32) -> Void = { [weak self, weak controller] period in + let sendLiveLocationImpl: (Int32) -> Void = { [weak controller] period in controller?.dismissAnimated() + + let _ = (strongSelf.controllerNode.coordinate + |> deliverOnMainQueue).start(next: { coordinate in params.sendLiveLocation(TelegramMediaMap(coordinate: coordinate, liveBroadcastingTimeout: period)) + }) } controller.setItemGroups([ @@ -313,6 +363,13 @@ public final class LocationViewController: ViewController { self.displayNode = LocationViewControllerNode(context: self.context, presentationData: self.presentationData, subject: self.subject, interaction: interaction, locationManager: self.locationManager) self.displayNodeDidLoad() + + self.controllerNode.onAnnotationsReady = { [weak self] in + guard let strongSelf = self, strongSelf.showAll else { + return + } + strongSelf.controllerNode.showAll() + } } private func updateRightBarButton() { diff --git a/submodules/LocationUI/Sources/LocationViewControllerNode.swift b/submodules/LocationUI/Sources/LocationViewControllerNode.swift index 6c063fccc9..b4d61a8051 100644 --- a/submodules/LocationUI/Sources/LocationViewControllerNode.swift +++ b/submodules/LocationUI/Sources/LocationViewControllerNode.swift @@ -142,8 +142,8 @@ private enum LocationViewEntry: Comparable, Identifiable { return LocationActionListItem(presentationData: ItemListPresentationData(presentationData), account: context.account, title: title, subtitle: subtitle, icon: beginTimeAndTimeout != nil ? .stopLiveLocation : .liveLocation, beginTimeAndTimeout: beginTimeAndTimeout, action: { if beginTimeAndTimeout != nil { interaction?.stopLiveLocation() - } else if let coordinate = coordinate { - interaction?.sendLiveLocation(coordinate, nil) + } else { + interaction?.sendLiveLocation(nil) } }, highlighted: { highlight in interaction?.updateSendActionHighlight(highlight) @@ -176,12 +176,16 @@ struct LocationViewState { var displayingMapModeOptions: Bool var selectedLocation: LocationViewLocation var trackingMode: LocationTrackingMode + var updatingProximityRadius: Int32? + var cancellingProximityRadius: Bool init() { self.mapMode = .map self.displayingMapModeOptions = false self.selectedLocation = .initial self.trackingMode = .none + self.updatingProximityRadius = nil + self.cancellingProximityRadius = false } } @@ -207,6 +211,9 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan private var listOffset: CGFloat? private var displayedProximityAlertTooltip = false + + var reportedAnnotationsReady = false + var onAnnotationsReady: (() -> Void)? init(context: AccountContext, presentationData: PresentationData, subject: Message, interaction: LocationViewInteraction, locationManager: LocationManager) { self.context = context @@ -274,9 +281,6 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan let _ = (liveLocations |> take(1) |> deliverOnMainQueue).start(next: { [weak self] messages in - guard let strongSelf = self else { - return - } var ownMessageId: MessageId? for message in messages { if message.localTags.contains(.OutgoingLiveLocation) { @@ -284,7 +288,7 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan break } } - interaction.setupProximityNotification(reset, strongSelf.headerNode.mapNode.currentUserLocation?.coordinate, ownMessageId) + interaction.setupProximityNotification(reset, ownMessageId) let _ = ApplicationSpecificNotice.incrementLocationProximityAlertTip(accountManager: context.sharedContext.accountManager, count: 4).start() }) @@ -387,29 +391,38 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan } for message in effectiveLiveLocations { - if let channel = message.peers[message.id.peerId] as? TelegramChannel, case .broadcast = channel.info, message.threadId != nil { - continue + if let location = getLocation(from: message) { + if let channel = message.peers[message.id.peerId] as? TelegramChannel, case .broadcast = channel.info, message.threadId != nil { + continue + } + + var liveBroadcastingTimeout: Int32 = 0 + if let timeout = location.liveBroadcastingTimeout { + liveBroadcastingTimeout = timeout + } + let remainingTime = max(0, message.timestamp + liveBroadcastingTimeout - currentTime) + if message.flags.contains(.Incoming) && remainingTime != 0 && proximityNotification == nil { + proximityNotification = false + } + + let subjectLocation = CLLocation(latitude: location.latitude, longitude: location.longitude) + let distance = userLocation.flatMap { subjectLocation.distance(from: $0) } + + if message.localTags.contains(.OutgoingLiveLocation), let selfPeer = selfPeer { + userAnnotation = LocationPinAnnotation(context: context, theme: presentationData.theme, message: message, selfPeer: selfPeer, heading: location.heading) + } else { + annotations.append(LocationPinAnnotation(context: context, theme: presentationData.theme, message: message, selfPeer: selfPeer, heading: location.heading)) + entries.append(.liveLocation(presentationData.theme, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, message, distance, index)) + } + index += 1 } - - var liveBroadcastingTimeout: Int32 = 0 - if let location = getLocation(from: message), let timeout = location.liveBroadcastingTimeout { - liveBroadcastingTimeout = timeout - } - let remainingTime = max(0, message.timestamp + liveBroadcastingTimeout - currentTime) - if message.flags.contains(.Incoming) && remainingTime != 0 && proximityNotification == nil { - proximityNotification = false - } - - let subjectLocation = CLLocation(latitude: location.latitude, longitude: location.longitude) - let distance = userLocation.flatMap { subjectLocation.distance(from: $0) } - - if message.localTags.contains(.OutgoingLiveLocation), let selfPeer = selfPeer { - userAnnotation = LocationPinAnnotation(context: context, theme: presentationData.theme, message: message, selfPeer: selfPeer, heading: location.heading) - } else { - annotations.append(LocationPinAnnotation(context: context, theme: presentationData.theme, message: message, selfPeer: selfPeer, heading: location.heading)) - entries.append(.liveLocation(presentationData.theme, presentationData.dateTimeFormat, presentationData.nameDisplayOrder, message, distance, index)) - } - index += 1 + } + + if let currentProximityNotification = proximityNotification, currentProximityNotification && state.cancellingProximityRadius { + proximityNotification = false + } else if let radius = state.updatingProximityRadius { + proximityNotification = true + proximityNotificationRadius = radius } if subject.id.peerId.namespace != Namespaces.Peer.CloudUser, proximityNotification == nil { @@ -465,6 +478,11 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan } if annotations != previousAnnotations { strongSelf.headerNode.mapNode.annotations = annotations + + if !strongSelf.reportedAnnotationsReady { + strongSelf.reportedAnnotationsReady = true + strongSelf.onAnnotationsReady?() + } } if let _ = proximityNotification { @@ -583,14 +601,32 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan } } + var initialized = false private func dequeueTransition() { guard let _ = self.validLayout, let transition = self.enqueuedTransitions.first else { return } self.enqueuedTransitions.remove(at: 0) + let scrollToItem: ListViewScrollToItem? + if !self.initialized, transition.insertions.count > 0 { + var index: Int = 0 + var offset: CGFloat = 0.0 + if transition.insertions.count > 2 { + index = 2 + offset = 40.0 + } else if transition.insertions.count == 2 { + index = 1 + } + + scrollToItem = ListViewScrollToItem(index: index, position: .bottom(offset), animated: false, curve: .Default(duration: nil), directionHint: .Up) + self.initialized = true + } else { + scrollToItem = nil + } + let options = ListViewDeleteAndInsertOptions() - self.listNode.transaction(deleteIndices: transition.deletions, insertIndicesAndItems: transition.insertions, updateIndicesAndItems: transition.updates, options: options, updateSizeAndInsets: nil, updateOpaqueState: nil, completion: { _ in + self.listNode.transaction(deleteIndices: transition.deletions, insertIndicesAndItems: transition.insertions, updateIndicesAndItems: transition.updates, options: options, scrollToItem: scrollToItem, updateSizeAndInsets: nil, updateOpaqueState: nil, completion: { _ in }) } @@ -599,17 +635,33 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan } func setProximityIndicator(radius: Int32?) { + guard let (layout, navigationBarHeight) = self.validLayout else { + return + } if let radius = radius { self.headerNode.forceIsHidden = true - if var coordinate = self.headerNode.mapNode.currentUserLocation?.coordinate, let span = self.headerNode.mapNode.mapSpan { - coordinate.latitude -= span.latitudeDelta * 0.11 + if let coordinate = self.headerNode.mapNode.currentUserLocation?.coordinate { self.updateState { state in var state = state - state.selectedLocation = .coordinate(coordinate, true) + state.selectedLocation = .custom state.trackingMode = .none return state } + + var contentOffset: CGFloat = 0.0 + if case let .known(offset) = self.listNode.visibleContentOffset() { + contentOffset = offset + } + + let panelHeight: CGFloat = 349.0 + layout.intrinsicInsets.bottom + let inset = (layout.size.width - 260.0) / 2.0 + let offset = panelHeight / 2.0 + 60.0 + inset + navigationBarHeight / 2.0 + + let point = CGPoint(x: layout.size.width / 2.0, y: navigationBarHeight + (layout.size.height - navigationBarHeight - panelHeight) / 2.0) + let convertedPoint = self.view.convert(point, to: self.headerNode.mapNode.view) + + self.headerNode.mapNode.setMapCenter(coordinate: coordinate, radius: Double(radius), insets: UIEdgeInsets(top: navigationBarHeight, left: inset, bottom: offset - contentOffset, right: inset), offset: convertedPoint.y - self.headerNode.mapNode.frame.height / 2.0, animated: true) } self.headerNode.mapNode.proximityIndicatorRadius = Double(radius) @@ -704,4 +756,15 @@ final class LocationViewControllerNode: ViewControllerTracingNode, CLLocationMan self.optionsNode.updateLayout(size: optionsFrame.size, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right, transition: transition) self.optionsNode.isUserInteractionEnabled = self.state.displayingMapModeOptions } + + var coordinate: Signal { + return self.headerNode.mapNode.userLocation + |> filter { location in + return location != nil + } + |> take(1) + |> map { location -> CLLocationCoordinate2D in + return location!.coordinate + } + } } diff --git a/submodules/MediaPlayer/Sources/MediaPlayer.swift b/submodules/MediaPlayer/Sources/MediaPlayer.swift index 07e3ebf9a7..1ac1ab6327 100644 --- a/submodules/MediaPlayer/Sources/MediaPlayer.swift +++ b/submodules/MediaPlayer/Sources/MediaPlayer.swift @@ -111,6 +111,7 @@ private final class MediaPlayerContext { private var baseRate: Double private let fetchAutomatically: Bool private var playAndRecord: Bool + private var ambient: Bool private var keepAudioSessionWhilePaused: Bool private var continuePlayingWithoutSoundOnLostAudioSession: Bool @@ -132,7 +133,7 @@ private final class MediaPlayerContext { private var stoppedAtEnd = false - init(queue: Queue, audioSessionManager: ManagedAudioSession, playerStatus: Promise, audioLevelPipe: ValuePipe, postbox: Postbox, resourceReference: MediaResourceReference, tempFilePath: String?, streamable: MediaPlayerStreaming, video: Bool, preferSoftwareDecoding: Bool, playAutomatically: Bool, enableSound: Bool, baseRate: Double, fetchAutomatically: Bool, playAndRecord: Bool, keepAudioSessionWhilePaused: Bool, continuePlayingWithoutSoundOnLostAudioSession: Bool) { + init(queue: Queue, audioSessionManager: ManagedAudioSession, playerStatus: Promise, audioLevelPipe: ValuePipe, postbox: Postbox, resourceReference: MediaResourceReference, tempFilePath: String?, streamable: MediaPlayerStreaming, video: Bool, preferSoftwareDecoding: Bool, playAutomatically: Bool, enableSound: Bool, baseRate: Double, fetchAutomatically: Bool, playAndRecord: Bool, ambient: Bool, keepAudioSessionWhilePaused: Bool, continuePlayingWithoutSoundOnLostAudioSession: Bool) { assert(queue.isCurrent()) self.queue = queue @@ -149,6 +150,7 @@ private final class MediaPlayerContext { self.baseRate = baseRate self.fetchAutomatically = fetchAutomatically self.playAndRecord = playAndRecord + self.ambient = ambient self.keepAudioSessionWhilePaused = keepAudioSessionWhilePaused self.continuePlayingWithoutSoundOnLostAudioSession = continuePlayingWithoutSoundOnLostAudioSession @@ -292,12 +294,12 @@ private final class MediaPlayerContext { duration = max(duration, CMTimeGetSeconds(audioTrackFrameBuffer.duration)) } loadedDuration = duration - let status = MediaPlayerStatus(generationTimestamp: CACurrentMediaTime(), duration: duration, dimensions: CGSize(), timestamp: min(max(timestamp, 0.0), duration), baseRate: self.baseRate, seekId: self.seekId, status: .buffering(initial: false, whilePlaying: action == .play, progress: 0.0), soundEnabled: self.enableSound) + let status = MediaPlayerStatus(generationTimestamp: CACurrentMediaTime(), duration: duration, dimensions: CGSize(), timestamp: min(max(timestamp, 0.0), duration), baseRate: self.baseRate, seekId: self.seekId, status: .buffering(initial: false, whilePlaying: action == .play, progress: 0.0, display: true), soundEnabled: self.enableSound) self.playerStatus.set(.single(status)) let _ = self.playerStatusValue.swap(status) } else { let duration = seekState?.duration ?? 0.0 - let status = MediaPlayerStatus(generationTimestamp: CACurrentMediaTime(), duration: duration, dimensions: CGSize(), timestamp: min(max(timestamp, 0.0), duration), baseRate: self.baseRate, seekId: self.seekId, status: .buffering(initial: false, whilePlaying: action == .play, progress: 0.0), soundEnabled: self.enableSound) + let status = MediaPlayerStatus(generationTimestamp: CACurrentMediaTime(), duration: duration, dimensions: CGSize(), timestamp: min(max(timestamp, 0.0), duration), baseRate: self.baseRate, seekId: self.seekId, status: .buffering(initial: false, whilePlaying: action == .play, progress: 0.0, display: true), soundEnabled: self.enableSound) self.playerStatus.set(.single(status)) let _ = self.playerStatusValue.swap(status) } @@ -368,7 +370,7 @@ private final class MediaPlayerContext { self.audioRenderer = nil let queue = self.queue - renderer = MediaPlayerAudioRenderer(audioSession: .manager(self.audioSessionManager), playAndRecord: self.playAndRecord, forceAudioToSpeaker: self.forceAudioToSpeaker, baseRate: self.baseRate, audioLevelPipe: self.audioLevelPipe, updatedRate: { [weak self] in + renderer = MediaPlayerAudioRenderer(audioSession: .manager(self.audioSessionManager), playAndRecord: self.playAndRecord, ambient: self.ambient, forceAudioToSpeaker: self.forceAudioToSpeaker, baseRate: self.baseRate, audioLevelPipe: self.audioLevelPipe, updatedRate: { [weak self] in queue.async { if let strongSelf = self { strongSelf.tick() @@ -446,7 +448,7 @@ private final class MediaPlayerContext { self.lastStatusUpdateTimestamp = nil if self.enableSound { let queue = self.queue - let renderer = MediaPlayerAudioRenderer(audioSession: .manager(self.audioSessionManager), playAndRecord: self.playAndRecord, forceAudioToSpeaker: self.forceAudioToSpeaker, baseRate: self.baseRate, audioLevelPipe: self.audioLevelPipe, updatedRate: { [weak self] in + let renderer = MediaPlayerAudioRenderer(audioSession: .manager(self.audioSessionManager), playAndRecord: self.playAndRecord, ambient: self.ambient, forceAudioToSpeaker: self.forceAudioToSpeaker, baseRate: self.baseRate, audioLevelPipe: self.audioLevelPipe, updatedRate: { [weak self] in queue.async { if let strongSelf = self { strongSelf.tick() @@ -873,7 +875,7 @@ private final class MediaPlayerContext { if case .playing = self.state { whilePlaying = true } - playbackStatus = .buffering(initial: false, whilePlaying: whilePlaying, progress: Float(bufferingProgress)) + playbackStatus = .buffering(initial: false, whilePlaying: whilePlaying, progress: Float(bufferingProgress), display: true) } else if !rate.isZero { if reportRate.isZero { //playbackStatus = .buffering(initial: false, whilePlaying: true) @@ -924,7 +926,7 @@ private final class MediaPlayerContext { public enum MediaPlayerPlaybackStatus: Equatable { case playing case paused - case buffering(initial: Bool, whilePlaying: Bool, progress: Float) + case buffering(initial: Bool, whilePlaying: Bool, progress: Float, display: Bool) public static func ==(lhs: MediaPlayerPlaybackStatus, rhs: MediaPlayerPlaybackStatus) -> Bool { switch lhs { @@ -940,8 +942,8 @@ public enum MediaPlayerPlaybackStatus: Equatable { } else { return false } - case let .buffering(initial, whilePlaying, progress): - if case .buffering(initial, whilePlaying, progress) = rhs { + case let .buffering(initial, whilePlaying, progress, display): + if case .buffering(initial, whilePlaying, progress, display) = rhs { return true } else { return false @@ -998,10 +1000,10 @@ public final class MediaPlayer { } } - public init(audioSessionManager: ManagedAudioSession, postbox: Postbox, resourceReference: MediaResourceReference, tempFilePath: String? = nil, streamable: MediaPlayerStreaming, video: Bool, preferSoftwareDecoding: Bool, playAutomatically: Bool = false, enableSound: Bool, baseRate: Double = 1.0, fetchAutomatically: Bool, playAndRecord: Bool = false, keepAudioSessionWhilePaused: Bool = false, continuePlayingWithoutSoundOnLostAudioSession: Bool = false) { + public init(audioSessionManager: ManagedAudioSession, postbox: Postbox, resourceReference: MediaResourceReference, tempFilePath: String? = nil, streamable: MediaPlayerStreaming, video: Bool, preferSoftwareDecoding: Bool, playAutomatically: Bool = false, enableSound: Bool, baseRate: Double = 1.0, fetchAutomatically: Bool, playAndRecord: Bool = false, ambient: Bool = false, keepAudioSessionWhilePaused: Bool = false, continuePlayingWithoutSoundOnLostAudioSession: Bool = false) { let audioLevelPipe = self.audioLevelPipe self.queue.async { - let context = MediaPlayerContext(queue: self.queue, audioSessionManager: audioSessionManager, playerStatus: self.statusValue, audioLevelPipe: audioLevelPipe, postbox: postbox, resourceReference: resourceReference, tempFilePath: tempFilePath, streamable: streamable, video: video, preferSoftwareDecoding: preferSoftwareDecoding, playAutomatically: playAutomatically, enableSound: enableSound, baseRate: baseRate, fetchAutomatically: fetchAutomatically, playAndRecord: playAndRecord, keepAudioSessionWhilePaused: keepAudioSessionWhilePaused, continuePlayingWithoutSoundOnLostAudioSession: continuePlayingWithoutSoundOnLostAudioSession) + let context = MediaPlayerContext(queue: self.queue, audioSessionManager: audioSessionManager, playerStatus: self.statusValue, audioLevelPipe: audioLevelPipe, postbox: postbox, resourceReference: resourceReference, tempFilePath: tempFilePath, streamable: streamable, video: video, preferSoftwareDecoding: preferSoftwareDecoding, playAutomatically: playAutomatically, enableSound: enableSound, baseRate: baseRate, fetchAutomatically: fetchAutomatically, playAndRecord: playAndRecord, ambient: ambient, keepAudioSessionWhilePaused: keepAudioSessionWhilePaused, continuePlayingWithoutSoundOnLostAudioSession: continuePlayingWithoutSoundOnLostAudioSession) self.contextRef = Unmanaged.passRetained(context) } } diff --git a/submodules/MediaPlayer/Sources/MediaPlayerAudioRenderer.swift b/submodules/MediaPlayer/Sources/MediaPlayerAudioRenderer.swift index 30a50a3ede..e531344f15 100644 --- a/submodules/MediaPlayer/Sources/MediaPlayerAudioRenderer.swift +++ b/submodules/MediaPlayer/Sources/MediaPlayerAudioRenderer.swift @@ -239,6 +239,7 @@ private final class AudioPlayerRendererContext { let audioSessionDisposable = MetaDisposable() var audioSessionControl: ManagedAudioSessionControl? let playAndRecord: Bool + let ambient: Bool var forceAudioToSpeaker: Bool { didSet { if self.forceAudioToSpeaker != oldValue { @@ -249,7 +250,7 @@ private final class AudioPlayerRendererContext { } } - init(controlTimebase: CMTimebase, audioSession: MediaPlayerAudioSessionControl, playAndRecord: Bool, forceAudioToSpeaker: Bool, baseRate: Double, audioLevelPipe: ValuePipe, updatedRate: @escaping () -> Void, audioPaused: @escaping () -> Void) { + init(controlTimebase: CMTimebase, audioSession: MediaPlayerAudioSessionControl, playAndRecord: Bool, ambient: Bool, forceAudioToSpeaker: Bool, baseRate: Double, audioLevelPipe: ValuePipe, updatedRate: @escaping () -> Void, audioPaused: @escaping () -> Void) { assert(audioPlayerRendererQueue.isCurrent()) self.audioSession = audioSession @@ -262,6 +263,7 @@ private final class AudioPlayerRendererContext { self.audioPaused = audioPaused self.playAndRecord = playAndRecord + self.ambient = ambient self.audioStreamDescription = audioRendererNativeStreamDescription() @@ -481,7 +483,7 @@ private final class AudioPlayerRendererContext { switch self.audioSession { case let .manager(manager): - self.audioSessionDisposable.set(manager.push(audioSessionType: self.playAndRecord ? .playWithPossiblePortOverride : .play, outputMode: self.forceAudioToSpeaker ? .speakerIfNoHeadphones : .system, once: true, manualActivate: { [weak self] control in + self.audioSessionDisposable.set(manager.push(audioSessionType: self.ambient ? .ambient : (self.playAndRecord ? .playWithPossiblePortOverride : .play), outputMode: self.forceAudioToSpeaker ? .speakerIfNoHeadphones : .system, once: true, manualActivate: { [weak self] control in audioPlayerRendererQueue.async { if let strongSelf = self { strongSelf.audioSessionControl = control @@ -751,7 +753,7 @@ public final class MediaPlayerAudioRenderer { private let audioClock: CMClock public let audioTimebase: CMTimebase - public init(audioSession: MediaPlayerAudioSessionControl, playAndRecord: Bool, forceAudioToSpeaker: Bool, baseRate: Double, audioLevelPipe: ValuePipe, updatedRate: @escaping () -> Void, audioPaused: @escaping () -> Void) { + public init(audioSession: MediaPlayerAudioSessionControl, playAndRecord: Bool, ambient: Bool, forceAudioToSpeaker: Bool, baseRate: Double, audioLevelPipe: ValuePipe, updatedRate: @escaping () -> Void, audioPaused: @escaping () -> Void) { var audioClock: CMClock? CMAudioClockCreate(allocator: nil, clockOut: &audioClock) if audioClock == nil { @@ -764,7 +766,7 @@ public final class MediaPlayerAudioRenderer { self.audioTimebase = audioTimebase! audioPlayerRendererQueue.async { - let context = AudioPlayerRendererContext(controlTimebase: audioTimebase!, audioSession: audioSession, playAndRecord: playAndRecord, forceAudioToSpeaker: forceAudioToSpeaker, baseRate: baseRate, audioLevelPipe: audioLevelPipe, updatedRate: updatedRate, audioPaused: audioPaused) + let context = AudioPlayerRendererContext(controlTimebase: audioTimebase!, audioSession: audioSession, playAndRecord: playAndRecord, ambient: ambient, forceAudioToSpeaker: forceAudioToSpeaker, baseRate: baseRate, audioLevelPipe: audioLevelPipe, updatedRate: updatedRate, audioPaused: audioPaused) self.contextRef = Unmanaged.passRetained(context) } } diff --git a/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift b/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift index bd3a68be34..0e7941cf0a 100644 --- a/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift +++ b/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift @@ -781,7 +781,7 @@ public final class MediaPlayerScrubbingNode: ASDisplayNode { default: break } - if case .buffering(true, _, _) = statusValue.status { + if case .buffering(true, _, _, _) = statusValue.status { //initialBuffering = true } else if Double(0.0).isLess(than: statusValue.duration) { if let scrubbingTimestampValue = self.scrubbingTimestampValue { diff --git a/submodules/PeerInfoUI/Sources/ChannelInfoController.swift b/submodules/PeerInfoUI/Sources/ChannelInfoController.swift index 3efed590b4..47c265fe01 100644 --- a/submodules/PeerInfoUI/Sources/ChannelInfoController.swift +++ b/submodules/PeerInfoUI/Sources/ChannelInfoController.swift @@ -334,7 +334,7 @@ private enum ChannelInfoEntry: ItemListNodeEntry { arguments.tapAvatarAction() }, context: arguments.avatarAndNameInfoContext, updatingImage: updatingAvatar) case let .about(theme, text, value): - return ItemListTextWithLabelItem(presentationData: presentationData, label: text, text: foldMultipleLineBreaks(value), enabledEntityTypes: [.url, .mention, .hashtag], multiline: true, sectionId: self.section, action: nil, longTapAction: { + return ItemListTextWithLabelItem(presentationData: presentationData, label: text, text: foldMultipleLineBreaks(value), enabledEntityTypes: [.allUrl, .mention, .hashtag], multiline: true, sectionId: self.section, action: nil, longTapAction: { arguments.displayContextMenu(ChannelInfoEntryTag.about, value) }, linkItemAction: { action, itemLink in arguments.aboutLinkAction(action, itemLink) diff --git a/submodules/PeerInfoUI/Sources/GroupInfoController.swift b/submodules/PeerInfoUI/Sources/GroupInfoController.swift index 585ba2ecaa..72f2de42d4 100644 --- a/submodules/PeerInfoUI/Sources/GroupInfoController.swift +++ b/submodules/PeerInfoUI/Sources/GroupInfoController.swift @@ -507,7 +507,7 @@ private enum GroupInfoEntry: ItemListNodeEntry { arguments.changeProfilePhoto() }) case let .about(theme, text): - return ItemListMultilineTextItem(presentationData: presentationData, text: foldMultipleLineBreaks(text), enabledEntityTypes: [.url, .mention, .hashtag], sectionId: self.section, style: .blocks, longTapAction: { + return ItemListMultilineTextItem(presentationData: presentationData, text: foldMultipleLineBreaks(text), enabledEntityTypes: [.allUrl, .mention, .hashtag], sectionId: self.section, style: .blocks, longTapAction: { arguments.displayAboutContextMenu(text) }, linkItemAction: { action, itemLink in arguments.aboutLinkAction(action, itemLink) diff --git a/submodules/PeerInfoUI/Sources/UserInfoController.swift b/submodules/PeerInfoUI/Sources/UserInfoController.swift index 5cf6a75cbc..98fc345ac9 100644 --- a/submodules/PeerInfoUI/Sources/UserInfoController.swift +++ b/submodules/PeerInfoUI/Sources/UserInfoController.swift @@ -410,7 +410,7 @@ private enum UserInfoEntry: ItemListNodeEntry { case let .about(theme, peer, text, value): var enabledEntityTypes: EnabledEntityTypes = [] if let peer = peer as? TelegramUser, let _ = peer.botInfo { - enabledEntityTypes = [.url, .mention, .hashtag] + enabledEntityTypes = [.allUrl, .mention, .hashtag] } return ItemListTextWithLabelItem(presentationData: presentationData, label: text, text: foldMultipleLineBreaks(value), enabledEntityTypes: enabledEntityTypes, multiline: true, sectionId: self.section, action: nil, longTapAction: { arguments.displayAboutContextMenu(value) diff --git a/submodules/PhotoResources/Sources/PhotoResources.swift b/submodules/PhotoResources/Sources/PhotoResources.swift index 35ea342569..2827eff05a 100644 --- a/submodules/PhotoResources/Sources/PhotoResources.swift +++ b/submodules/PhotoResources/Sources/PhotoResources.swift @@ -37,8 +37,8 @@ private let progressiveRangeMap: [(Int, [Int])] = [ (Int(Int32.max), [2, 3, 4]) ] -public func representationFetchRangeForDisplayAtSize(representation: TelegramMediaImageRepresentation, dimension: Int) -> Range? { - if representation.progressiveSizes.count > 1 { +public func representationFetchRangeForDisplayAtSize(representation: TelegramMediaImageRepresentation, dimension: Int?) -> Range? { + if representation.progressiveSizes.count > 1, let dimension = dimension { var largestByteSize = Int(representation.progressiveSizes[0]) for (maxDimension, byteSizes) in progressiveRangeMap { largestByteSize = Int(representation.progressiveSizes[byteSizes.last!]) @@ -1684,10 +1684,10 @@ public func standaloneChatMessagePhotoInteractiveFetched(account: Account, photo } } -public func chatMessagePhotoInteractiveFetched(context: AccountContext, photoReference: ImageMediaReference, displayAtSize: Int = 1000, storeToDownloadsPeerType: MediaAutoDownloadPeerType?) -> Signal { +public func chatMessagePhotoInteractiveFetched(context: AccountContext, photoReference: ImageMediaReference, displayAtSize: Int?, storeToDownloadsPeerType: MediaAutoDownloadPeerType?) -> Signal { if let largestRepresentation = largestRepresentationForPhoto(photoReference.media) { var fetchRange: (Range, MediaBoxFetchPriority)? - if let range = representationFetchRangeForDisplayAtSize(representation: largestRepresentation, dimension: displayAtSize) { + if let displayAtSize = displayAtSize, let range = representationFetchRangeForDisplayAtSize(representation: largestRepresentation, dimension: displayAtSize) { fetchRange = (range, .default) } diff --git a/submodules/SlotMachineAnimationNode/Sources/SlotMachineAnimationNode.swift b/submodules/SlotMachineAnimationNode/Sources/SlotMachineAnimationNode.swift index 4c39a9e997..65ecdc0bb7 100644 --- a/submodules/SlotMachineAnimationNode/Sources/SlotMachineAnimationNode.swift +++ b/submodules/SlotMachineAnimationNode/Sources/SlotMachineAnimationNode.swift @@ -146,9 +146,9 @@ public enum ManagedSlotMachineAnimationState: Equatable { public final class SlotMachineAnimationNode: ASDisplayNode { private let backNode: ManagedAnimationNode - private let leftReelNode: ManagedAnimationNode - private let centerReelNode: ManagedAnimationNode - private let rightReelNode: ManagedAnimationNode + private let leftReelNode: DiceAnimatedStickerNode + private let centerReelNode: DiceAnimatedStickerNode + private let rightReelNode: DiceAnimatedStickerNode private let frontNode: ManagedAnimationNode private var diceState: ManagedSlotMachineAnimationState? = nil @@ -161,9 +161,10 @@ public final class SlotMachineAnimationNode: ASDisplayNode { public init(size: CGSize = CGSize(width: 184.0, height: 184.0)) { self.animationSize = size self.backNode = ManagedAnimationNode(size: self.animationSize) - self.leftReelNode = ManagedAnimationNode(size: self.animationSize) - self.centerReelNode = ManagedAnimationNode(size: self.animationSize) - self.rightReelNode = ManagedAnimationNode(size: self.animationSize) + let reelSize = CGSize(width: 384.0, height: 384.0) + self.leftReelNode = DiceAnimatedStickerNode(size: reelSize) + self.centerReelNode = DiceAnimatedStickerNode(size: reelSize) + self.rightReelNode = DiceAnimatedStickerNode(size: reelSize) self.frontNode = ManagedAnimationNode(size: self.animationSize) super.init() @@ -261,7 +262,7 @@ class DiceAnimatedStickerNode: ASDisplayNode { self.intrinsicSize = size self.animationNode = AnimatedStickerNode() - self.animationNode.visibility = true + self.animationNode.autoplay = true super.init() @@ -281,6 +282,15 @@ class DiceAnimatedStickerNode: ASDisplayNode { } } + var initialized = false + override func didLoad() { + super.didLoad() + + self.initialized = true + self.advanceState() + } + + private func advanceState() { guard !self.trackStack.isEmpty else { return @@ -329,7 +339,7 @@ class DiceAnimatedStickerNode: ASDisplayNode { self.trackStack.append(item) self.didTryAdvancingState = false - if !self.animationNode.isPlaying { + if !self.animationNode.isPlaying && self.initialized { self.advanceState() } } diff --git a/submodules/TelegramAudio/Sources/ManagedAudioSession.swift b/submodules/TelegramAudio/Sources/ManagedAudioSession.swift index a1fcb3c8b8..232c13101e 100644 --- a/submodules/TelegramAudio/Sources/ManagedAudioSession.swift +++ b/submodules/TelegramAudio/Sources/ManagedAudioSession.swift @@ -4,6 +4,7 @@ import AVFoundation import UIKit public enum ManagedAudioSessionType: Equatable { + case ambient case play case playWithPossiblePortOverride case record(speaker: Bool) @@ -22,6 +23,8 @@ public enum ManagedAudioSessionType: Equatable { private func nativeCategoryForType(_ type: ManagedAudioSessionType, headphones: Bool, outputMode: AudioSessionOutputMode) -> AVAudioSession.Category { switch type { + case .ambient: + return .ambient case .play: return .playback case .record, .voiceCall, .videoCall: @@ -665,7 +668,7 @@ public final class ManagedAudioSession { print("ManagedAudioSession setting category for \(type) (native: \(nativeCategory))") var options: AVAudioSession.CategoryOptions = [] switch type { - case .play: + case .play, .ambient: break case .playWithPossiblePortOverride: if case .playAndRecord = nativeCategory { diff --git a/submodules/TelegramBaseController/Sources/MediaNavigationAccessoryHeaderNode.swift b/submodules/TelegramBaseController/Sources/MediaNavigationAccessoryHeaderNode.swift index f4f5316a8c..7bf5843296 100644 --- a/submodules/TelegramBaseController/Sources/MediaNavigationAccessoryHeaderNode.swift +++ b/submodules/TelegramBaseController/Sources/MediaNavigationAccessoryHeaderNode.swift @@ -331,7 +331,7 @@ public final class MediaNavigationAccessoryHeaderNode: ASDisplayNode, UIScrollVi switch status { case .paused: paused = true - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, _): paused = !whilePlaying case .playing: paused = false diff --git a/submodules/TelegramCallsUI/Sources/PresentationCall.swift b/submodules/TelegramCallsUI/Sources/PresentationCall.swift index a0b65b282c..3419e7f136 100644 --- a/submodules/TelegramCallsUI/Sources/PresentationCall.swift +++ b/submodules/TelegramCallsUI/Sources/PresentationCall.swift @@ -34,7 +34,7 @@ private final class PresentationCallToneRenderer { self.toneRenderer = MediaPlayerAudioRenderer(audioSession: .custom({ control in return controlImpl?(control) ?? EmptyDisposable - }), playAndRecord: false, forceAudioToSpeaker: false, baseRate: 1.0, audioLevelPipe: self.audioLevelPipe, updatedRate: {}, audioPaused: {}) + }), playAndRecord: false, ambient: false, forceAudioToSpeaker: false, baseRate: 1.0, audioLevelPipe: self.audioLevelPipe, updatedRate: {}, audioPaused: {}) controlImpl = { [weak self] control in queue.async { diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 36e2e8d95a..756649dba1 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -2618,2593 +2618,2597 @@ public final class PresentationStrings: Equatable { public var WallpaperSearch_ColorPurple: String { return self._s[2283]! } public var ChatListFolder_IncludeChatsTitle: String { return self._s[2284]! } public var Group_Username_InvalidTooShort: String { return self._s[2285]! } + public var Location_ProximityNotification_DistanceM: String { return self._s[2286]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2286]!, self._r[2286]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2287]!, self._r[2287]!, [_0, _1, _2]) } - public var Passport_Language_tk: String { return self._s[2287]! } - public var ConvertToSupergroup_Title: String { return self._s[2288]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[2289]! } - public var Cache_KeepMediaHelp: String { return self._s[2290]! } - public var Channel_Management_Title: String { return self._s[2291]! } + public var Passport_Language_tk: String { return self._s[2288]! } + public var ConvertToSupergroup_Title: String { return self._s[2289]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[2290]! } + public var Cache_KeepMediaHelp: String { return self._s[2291]! } + public var Channel_Management_Title: String { return self._s[2292]! } public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2292]!, self._r[2292]!, [_1]) + return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_1]) } - public var Conversation_ForwardChats: String { return self._s[2293]! } - public var Passport_Language_bg: String { return self._s[2294]! } - public var SocksProxySetup_TypeSocks: String { return self._s[2295]! } - public var Permissions_PrivacyPolicy: String { return self._s[2296]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2297]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[2298]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2299]! } - public var Conversation_ContextMenuOpenChannel: String { return self._s[2300]! } - public var Activity_UploadingVideo: String { return self._s[2301]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[2303]! } - public var Wallet_Sending_Text: String { return self._s[2304]! } - public var SocksProxySetup_Credentials: String { return self._s[2306]! } - public var Preview_SaveGif: String { return self._s[2307]! } - public var Cache_Photos: String { return self._s[2308]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[2309]! } - public var Wallet_Intro_NotNow: String { return self._s[2310]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[2311]! } - public var Passport_Language_lt: String { return self._s[2312]! } - public var Passport_DeleteDocument: String { return self._s[2313]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2314]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[2315]! } + public var Conversation_ForwardChats: String { return self._s[2294]! } + public var Passport_Language_bg: String { return self._s[2295]! } + public var SocksProxySetup_TypeSocks: String { return self._s[2296]! } + public var Permissions_PrivacyPolicy: String { return self._s[2297]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2298]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[2299]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2300]! } + public var Conversation_ContextMenuOpenChannel: String { return self._s[2301]! } + public var Activity_UploadingVideo: String { return self._s[2302]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[2304]! } + public var Wallet_Sending_Text: String { return self._s[2305]! } + public var SocksProxySetup_Credentials: String { return self._s[2307]! } + public var Preview_SaveGif: String { return self._s[2308]! } + public var Cache_Photos: String { return self._s[2309]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[2310]! } + public var Wallet_Intro_NotNow: String { return self._s[2311]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[2312]! } + public var Passport_Language_lt: String { return self._s[2313]! } + public var Passport_DeleteDocument: String { return self._s[2314]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2315]! } + public func Location_ProximityNotification_NotifyLong(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_1, _2]) + } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[2317]! } public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_0]) - } - public var AccessDenied_VideoCallCamera: String { return self._s[2317]! } - public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2318]!, self._r[2318]!, [_0]) } - public var PhotoEditor_SharpenTool: String { return self._s[2319]! } - public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2320]!, self._r[2320]!, [_1]) + public var AccessDenied_VideoCallCamera: String { return self._s[2319]! } + public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2320]!, self._r[2320]!, [_0]) } - public var DialogList_Unpin: String { return self._s[2321]! } - public var Stickers_NoStickersFound: String { return self._s[2322]! } - public var UserInfo_AddContact: String { return self._s[2324]! } + public var PhotoEditor_SharpenTool: String { return self._s[2321]! } + public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2322]!, self._r[2322]!, [_1]) + } + public var DialogList_Unpin: String { return self._s[2323]! } + public var Stickers_NoStickersFound: String { return self._s[2324]! } + public var UserInfo_AddContact: String { return self._s[2326]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_0]) + return formatWithArgumentRanges(self._s[2328]!, self._r[2328]!, [_0]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2327]!, self._r[2327]!, [_0]) + return formatWithArgumentRanges(self._s[2329]!, self._r[2329]!, [_0]) } - public var CallFeedback_VideoReasonDistorted: String { return self._s[2328]! } - public var Tour_Text2: String { return self._s[2329]! } + public var CallFeedback_VideoReasonDistorted: String { return self._s[2330]! } + public var Tour_Text2: String { return self._s[2331]! } public func Conversation_TitleCommentsFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2331]!, self._r[2331]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2333]!, self._r[2333]!, [_1, _2]) } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[2332]! } - public var Paint_Delete: String { return self._s[2334]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2335]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[2334]! } + public var Paint_Delete: String { return self._s[2336]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2337]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2337]!, self._r[2337]!, [_0]) + return formatWithArgumentRanges(self._s[2339]!, self._r[2339]!, [_0]) } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[2338]! } - public var Notification_CallOutgoingShort: String { return self._s[2339]! } - public var Checkout_PasswordEntry_Title: String { return self._s[2340]! } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2341]! } - public var Notification_MessageLifetime1m: String { return self._s[2342]! } - public var Wallet_TransactionInfo_CommentHeader: String { return self._s[2344]! } - public var BlockedUsers_AddNew: String { return self._s[2345]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[2346]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2347]! } - public var Settings_SaveEditedPhotos: String { return self._s[2348]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[2349]! } - public var Channel_AboutItem: String { return self._s[2350]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[2351]! } - public var Privacy_Calls_P2PNever: String { return self._s[2353]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2354]! } - public var Passport_Language_uk: String { return self._s[2355]! } - public var NetworkUsageSettings_Wifi: String { return self._s[2356]! } - public var Conversation_Moderate_Report: String { return self._s[2357]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[2358]! } - public var VoiceOver_Chat_SeenByRecipients: String { return self._s[2359]! } - public var Permissions_SiriText_v0: String { return self._s[2360]! } - public var Theme_Colors_Background: String { return self._s[2361]! } - public var Notification_CallMissed: String { return self._s[2362]! } - public var Stats_ZoomOut: String { return self._s[2363]! } - public var Profile_AddToExisting: String { return self._s[2364]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2367]! } - public var Undo_DeletedChannel: String { return self._s[2368]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[2340]! } + public var Notification_CallOutgoingShort: String { return self._s[2341]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2342]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[2343]! } + public var Notification_MessageLifetime1m: String { return self._s[2344]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[2346]! } + public var BlockedUsers_AddNew: String { return self._s[2347]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[2348]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2349]! } + public var Settings_SaveEditedPhotos: String { return self._s[2350]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[2351]! } + public var Channel_AboutItem: String { return self._s[2352]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[2353]! } + public var Privacy_Calls_P2PNever: String { return self._s[2355]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2356]! } + public var Passport_Language_uk: String { return self._s[2357]! } + public var NetworkUsageSettings_Wifi: String { return self._s[2358]! } + public var Conversation_Moderate_Report: String { return self._s[2359]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[2360]! } + public var VoiceOver_Chat_SeenByRecipients: String { return self._s[2361]! } + public var Permissions_SiriText_v0: String { return self._s[2362]! } + public var Theme_Colors_Background: String { return self._s[2363]! } + public var Notification_CallMissed: String { return self._s[2364]! } + public var Stats_ZoomOut: String { return self._s[2365]! } + public var Profile_AddToExisting: String { return self._s[2366]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2369]! } + public var Undo_DeletedChannel: String { return self._s[2370]! } public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2369]!, self._r[2369]!, [_0]) + return formatWithArgumentRanges(self._s[2371]!, self._r[2371]!, [_0]) } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2370]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2371]! } - public var Passport_InfoFAQ_URL: String { return self._s[2372]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2374]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2372]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2373]! } + public var Passport_InfoFAQ_URL: String { return self._s[2374]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2376]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2375]!, self._r[2375]!, [_1]) + return formatWithArgumentRanges(self._s[2377]!, self._r[2377]!, [_1]) } - public var State_connecting: String { return self._s[2376]! } - public var Passport_Identity_Country: String { return self._s[2377]! } - public var Passport_PasswordDescription: String { return self._s[2378]! } - public var ChatList_PsaLabel_covid: String { return self._s[2379]! } + public var State_connecting: String { return self._s[2378]! } + public var Passport_Identity_Country: String { return self._s[2379]! } + public var Passport_PasswordDescription: String { return self._s[2380]! } + public var ChatList_PsaLabel_covid: String { return self._s[2381]! } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2380]!, self._r[2380]!, [_1]) + return formatWithArgumentRanges(self._s[2382]!, self._r[2382]!, [_1]) } - public var Contacts_AddPeopleNearby: String { return self._s[2381]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[2382]! } - public var ClearCache_Description: String { return self._s[2383]! } - public var Localization_LanguageName: String { return self._s[2384]! } + public var Contacts_AddPeopleNearby: String { return self._s[2383]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[2384]! } + public var ClearCache_Description: String { return self._s[2385]! } + public var Localization_LanguageName: String { return self._s[2386]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2385]!, self._r[2385]!, [_0]) + return formatWithArgumentRanges(self._s[2387]!, self._r[2387]!, [_0]) } - public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[2386]! } - public var UserInfo_CreateNewContact: String { return self._s[2387]! } - public var Channel_Stickers_NotFound: String { return self._s[2388]! } - public var Watch_Message_Poll: String { return self._s[2389]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2390]! } + public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[2388]! } + public var UserInfo_CreateNewContact: String { return self._s[2389]! } + public var Channel_Stickers_NotFound: String { return self._s[2390]! } + public var Watch_Message_Poll: String { return self._s[2391]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2392]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2391]!, self._r[2391]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2393]!, self._r[2393]!, [_0, _1]) } - public var Login_InfoDeletePhoto: String { return self._s[2392]! } - public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[2393]! } - public var InstantPage_FeedbackButton: String { return self._s[2394]! } - public var Appearance_PreviewReplyText: String { return self._s[2395]! } - public var Passport_FieldPhoneHelp: String { return self._s[2396]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2397]! } - public var Media_SendingOptionsTooltip: String { return self._s[2398]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[2399]! } - public var Notifications_Badge: String { return self._s[2400]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[2401]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2402]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[2403]! } + public var Login_InfoDeletePhoto: String { return self._s[2394]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[2395]! } + public var InstantPage_FeedbackButton: String { return self._s[2396]! } + public var Appearance_PreviewReplyText: String { return self._s[2397]! } + public var Passport_FieldPhoneHelp: String { return self._s[2398]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2399]! } + public var Media_SendingOptionsTooltip: String { return self._s[2400]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[2401]! } + public var Notifications_Badge: String { return self._s[2402]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[2403]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2404]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[2405]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2405]!, self._r[2405]!, [_0]) + return formatWithArgumentRanges(self._s[2407]!, self._r[2407]!, [_0]) } - public var Wallet_Info_Send: String { return self._s[2406]! } - public var Passport_InfoLearnMore: String { return self._s[2407]! } - public var EnterPasscode_EnterTitle: String { return self._s[2408]! } - public var Appearance_EditTheme: String { return self._s[2409]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[2410]! } - public var Stats_FollowersTitle: String { return self._s[2411]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[2412]! } - public var Channel_Subscribers_Title: String { return self._s[2413]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2414]! } + public var Wallet_Info_Send: String { return self._s[2408]! } + public var Passport_InfoLearnMore: String { return self._s[2409]! } + public var EnterPasscode_EnterTitle: String { return self._s[2410]! } + public var Appearance_EditTheme: String { return self._s[2411]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[2412]! } + public var Stats_FollowersTitle: String { return self._s[2413]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[2414]! } + public var Channel_Subscribers_Title: String { return self._s[2415]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2416]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2415]!, self._r[2415]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2417]!, self._r[2417]!, [_1, _2, _3]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[2416]! } - public var Wallet_Intro_CreateWallet: String { return self._s[2417]! } - public var Conversation_AddToReadingList: String { return self._s[2418]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2419]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[2418]! } + public var Wallet_Intro_CreateWallet: String { return self._s[2419]! } + public var Conversation_AddToReadingList: String { return self._s[2420]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2421]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2420]!, self._r[2420]!, [_0]) + return formatWithArgumentRanges(self._s[2422]!, self._r[2422]!, [_0]) } - public var Group_AdminLog_EmptyText: String { return self._s[2421]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[2422]! } - public var Wallet_Sending_Title: String { return self._s[2424]! } - public var Watch_Location_Current: String { return self._s[2425]! } - public var PrivacyPolicy_Title: String { return self._s[2426]! } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2433]! } - public var Channel_TypeSetup_Title: String { return self._s[2436]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[2437]! } - public var Passport_Language_ja: String { return self._s[2438]! } - public var ReportPeer_ReasonSpam: String { return self._s[2439]! } - public var Widget_GalleryDescription: String { return self._s[2440]! } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2441]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[2443]! } - public var Channel_AdminLog_ChangeInfo: String { return self._s[2444]! } - public var ChatListFolder_NameNonContacts: String { return self._s[2445]! } - public var Call_Audio: String { return self._s[2446]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2447]! } - public var Wallet_Updated_JustNow: String { return self._s[2448]! } - public var ChatList_Search_NoResultsFitlerFiles: String { return self._s[2449]! } - public var Settings_PrivacySettings: String { return self._s[2450]! } - public var Stats_Followers: String { return self._s[2451]! } - public var Notifications_AddExceptionTitle: String { return self._s[2452]! } - public var TwoFactorSetup_Password_Title: String { return self._s[2453]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2454]! } - public var OldChannels_NoticeText: String { return self._s[2455]! } - public var Conversation_SavedMessages: String { return self._s[2456]! } + public var Group_AdminLog_EmptyText: String { return self._s[2423]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[2424]! } + public var Wallet_Sending_Title: String { return self._s[2426]! } + public var Watch_Location_Current: String { return self._s[2427]! } + public var PrivacyPolicy_Title: String { return self._s[2428]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[2435]! } + public var Channel_TypeSetup_Title: String { return self._s[2438]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[2439]! } + public var Passport_Language_ja: String { return self._s[2440]! } + public var ReportPeer_ReasonSpam: String { return self._s[2441]! } + public var Widget_GalleryDescription: String { return self._s[2442]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2443]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[2445]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[2446]! } + public var ChatListFolder_NameNonContacts: String { return self._s[2447]! } + public var Call_Audio: String { return self._s[2448]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2449]! } + public var Wallet_Updated_JustNow: String { return self._s[2450]! } + public var ChatList_Search_NoResultsFitlerFiles: String { return self._s[2451]! } + public var Settings_PrivacySettings: String { return self._s[2452]! } + public var Stats_Followers: String { return self._s[2453]! } + public var Notifications_AddExceptionTitle: String { return self._s[2454]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2455]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[2456]! } + public var OldChannels_NoticeText: String { return self._s[2457]! } + public var Conversation_SavedMessages: String { return self._s[2458]! } public func Conversation_PeerNearbyTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2458]!, self._r[2458]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2460]!, self._r[2460]!, [_1, _2]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2459]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2461]! } public func Wallet_Info_TransactionBlockchainFee(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2460]!, self._r[2460]!, [_0]) + return formatWithArgumentRanges(self._s[2462]!, self._r[2462]!, [_0]) } - public var Appearance_ThemeNightBlue: String { return self._s[2461]! } - public var Notification_ChannelInviterSelf: String { return self._s[2462]! } - public var Watch_UserInfo_Service: String { return self._s[2464]! } - public var ChatList_Context_Back: String { return self._s[2465]! } - public var Passport_Email_Title: String { return self._s[2466]! } - public var Wallet_Month_ShortDecember: String { return self._s[2467]! } - public var Stats_GroupTopAdmin_Promote: String { return self._s[2468]! } + public var Appearance_ThemeNightBlue: String { return self._s[2463]! } + public var Notification_ChannelInviterSelf: String { return self._s[2464]! } + public var Watch_UserInfo_Service: String { return self._s[2466]! } + public var ChatList_Context_Back: String { return self._s[2467]! } + public var Passport_Email_Title: String { return self._s[2468]! } + public var Wallet_Month_ShortDecember: String { return self._s[2469]! } + public var Stats_GroupTopAdmin_Promote: String { return self._s[2470]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2469]!, self._r[2469]!, [_1]) + return formatWithArgumentRanges(self._s[2471]!, self._r[2471]!, [_1]) } - public var Conversation_UnsupportedMedia: String { return self._s[2470]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2471]! } - public var Privacy_TopPeersHelp: String { return self._s[2473]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[2474]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2475]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[2476]! } + public var Conversation_UnsupportedMedia: String { return self._s[2472]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2473]! } + public var Privacy_TopPeersHelp: String { return self._s[2475]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[2476]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2477]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[2478]! } public func Location_ProximityNotification_AlreadyClose(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2477]!, self._r[2477]!, [_0]) + return formatWithArgumentRanges(self._s[2479]!, self._r[2479]!, [_0]) } - public var Notification_PassportValueProofOfAddress: String { return self._s[2478]! } - public var Map_Map: String { return self._s[2479]! } - public var WallpaperSearch_ColorBlue: String { return self._s[2480]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[2481]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2482]! } - public var ChatList_Search_FilterMusic: String { return self._s[2483]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[2484]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2485]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[2487]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[2480]! } + public var Map_Map: String { return self._s[2481]! } + public var WallpaperSearch_ColorBlue: String { return self._s[2482]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[2483]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2484]! } + public var ChatList_Search_FilterMusic: String { return self._s[2485]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[2486]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2487]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[2489]! } public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2488]!, self._r[2488]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2490]!, self._r[2490]!, [_1, _2]) } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2489]!, self._r[2489]!, [_0]) + return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2490]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2491]! } - public var GroupInfo_Location: String { return self._s[2494]! } - public var Passport_Language_ka: String { return self._s[2495]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[2492]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2493]! } + public var GroupInfo_Location: String { return self._s[2496]! } + public var Passport_Language_ka: String { return self._s[2497]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2496]!, self._r[2496]!, [_0]) + return formatWithArgumentRanges(self._s[2498]!, self._r[2498]!, [_0]) } - public var Conversation_ContextMenuOpenChannelProfile: String { return self._s[2497]! } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[2500]! } - public var DialogList_SearchSectionRecent: String { return self._s[2501]! } - public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[2502]! } - public var Conversation_Timer_Send: String { return self._s[2503]! } - public var ChatState_Updating: String { return self._s[2505]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[2506]! } - public var ChannelInfo_DeleteGroup: String { return self._s[2507]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[2508]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2509]! } - public var ChatListFolderSettings_AddRecommended: String { return self._s[2511]! } - public var ChatList_Search_NoResults: String { return self._s[2512]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2513]! } - public var PeerInfo_GroupAboutItem: String { return self._s[2514]! } - public var Wallet_Info_YourBalance: String { return self._s[2516]! } + public var Conversation_ContextMenuOpenChannelProfile: String { return self._s[2499]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[2502]! } + public var DialogList_SearchSectionRecent: String { return self._s[2503]! } + public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[2504]! } + public var Conversation_Timer_Send: String { return self._s[2505]! } + public var ChatState_Updating: String { return self._s[2507]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[2508]! } + public var ChannelInfo_DeleteGroup: String { return self._s[2509]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[2510]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2511]! } + public var ChatListFolderSettings_AddRecommended: String { return self._s[2513]! } + public var ChatList_Search_NoResults: String { return self._s[2514]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2515]! } + public var PeerInfo_GroupAboutItem: String { return self._s[2516]! } + public var Wallet_Info_YourBalance: String { return self._s[2518]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2517]!, self._r[2517]!, [_0]) + return formatWithArgumentRanges(self._s[2519]!, self._r[2519]!, [_0]) } - public var PrivacySettings_AuthSessions: String { return self._s[2518]! } - public var Passport_Address_Postcode: String { return self._s[2519]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2520]! } - public var Passport_Address_Street2Placeholder: String { return self._s[2521]! } - public var Group_Location_Title: String { return self._s[2522]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[2523]! } - public var PeopleNearby_UsersEmpty: String { return self._s[2524]! } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[2526]! } + public var PrivacySettings_AuthSessions: String { return self._s[2520]! } + public var Passport_Address_Postcode: String { return self._s[2521]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2522]! } + public var Passport_Address_Street2Placeholder: String { return self._s[2523]! } + public var Group_Location_Title: String { return self._s[2524]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[2525]! } + public var PeopleNearby_UsersEmpty: String { return self._s[2526]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[2528]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2528]!, self._r[2528]!, [_0]) + return formatWithArgumentRanges(self._s[2530]!, self._r[2530]!, [_0]) } - public var Proxy_TooltipUnavailable: String { return self._s[2529]! } - public var Map_Search: String { return self._s[2530]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[2531]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2532]! } + public var Proxy_TooltipUnavailable: String { return self._s[2531]! } + public var Map_Search: String { return self._s[2532]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[2533]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2534]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2533]!, self._r[2533]!, [_0]) + return formatWithArgumentRanges(self._s[2535]!, self._r[2535]!, [_0]) } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[2534]! } - public var ProfilePhoto_MainPhoto: String { return self._s[2535]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[2536]! } - public var SharedMedia_EmptyMusicText: String { return self._s[2537]! } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[2538]! } - public var NetworkUsageSettings_BytesReceived: String { return self._s[2539]! } - public var Channel_AdminLog_EmptyText: String { return self._s[2540]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2541]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[2542]! } - public var Notifications_GroupNotifications: String { return self._s[2543]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[2544]! } - public var Wallet_AccessDenied_Title: String { return self._s[2545]! } - public var AccessDenied_SaveMedia: String { return self._s[2546]! } - public var GroupInfo_LabelOwner: String { return self._s[2547]! } - public var Passport_Language_id: String { return self._s[2548]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2549]! } - public var Conversation_UnpinMessageAlert: String { return self._s[2550]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[2536]! } + public var ProfilePhoto_MainPhoto: String { return self._s[2537]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[2538]! } + public var SharedMedia_EmptyMusicText: String { return self._s[2539]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[2540]! } + public var NetworkUsageSettings_BytesReceived: String { return self._s[2541]! } + public var Channel_AdminLog_EmptyText: String { return self._s[2542]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2543]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[2544]! } + public var Notifications_GroupNotifications: String { return self._s[2545]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[2546]! } + public var Wallet_AccessDenied_Title: String { return self._s[2547]! } + public var AccessDenied_SaveMedia: String { return self._s[2548]! } + public var GroupInfo_LabelOwner: String { return self._s[2549]! } + public var Passport_Language_id: String { return self._s[2550]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2551]! } + public var Conversation_UnpinMessageAlert: String { return self._s[2552]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2551]!, self._r[2551]!, [_0]) + return formatWithArgumentRanges(self._s[2553]!, self._r[2553]!, [_0]) } public func Call_RemoteVideoPaused(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2552]!, self._r[2552]!, [_0]) - } - public var TwoFactorSetup_Done_Text: String { return self._s[2553]! } - public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2554]!, self._r[2554]!, [_0]) } - public var Wallet_Words_Title: String { return self._s[2555]! } - public var NetworkUsageSettings_BytesSent: String { return self._s[2556]! } - public var OwnershipTransfer_Transfer: String { return self._s[2557]! } + public var TwoFactorSetup_Done_Text: String { return self._s[2555]! } + public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2556]!, self._r[2556]!, [_0]) + } + public var Wallet_Words_Title: String { return self._s[2557]! } + public var NetworkUsageSettings_BytesSent: String { return self._s[2558]! } + public var OwnershipTransfer_Transfer: String { return self._s[2559]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2558]!, self._r[2558]!, [_0]) + return formatWithArgumentRanges(self._s[2560]!, self._r[2560]!, [_0]) } - public var Passport_Language_pt: String { return self._s[2559]! } - public var PrivacySettings_WebSessions: String { return self._s[2560]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[2562]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2563]! } + public var Passport_Language_pt: String { return self._s[2561]! } + public var PrivacySettings_WebSessions: String { return self._s[2562]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[2564]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2565]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2564]!, self._r[2564]!, [_0]) + return formatWithArgumentRanges(self._s[2566]!, self._r[2566]!, [_0]) } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2565]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2566]! } - public var AutoNightTheme_Scheduled: String { return self._s[2567]! } - public var CreatePoll_ExplanationHeader: String { return self._s[2568]! } - public var Calls_TabTitle: String { return self._s[2569]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[2570]! } - public var Notification_VideoCallCanceled: String { return self._s[2571]! } - public var Login_CodeSentInternal: String { return self._s[2572]! } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[2573]! } - public var Call_RecordingDisabledMessage: String { return self._s[2575]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[2577]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[2578]! } - public var Channel_Info_Stickers: String { return self._s[2579]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[2580]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2567]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2568]! } + public var AutoNightTheme_Scheduled: String { return self._s[2569]! } + public var CreatePoll_ExplanationHeader: String { return self._s[2570]! } + public var Calls_TabTitle: String { return self._s[2571]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[2572]! } + public var Notification_VideoCallCanceled: String { return self._s[2573]! } + public var Login_CodeSentInternal: String { return self._s[2574]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[2575]! } + public var Call_RecordingDisabledMessage: String { return self._s[2577]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[2579]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[2580]! } + public var Channel_Info_Stickers: String { return self._s[2581]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[2582]! } public func Conversation_PeerNearbyDistance(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2581]!, self._r[2581]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2583]!, self._r[2583]!, [_1, _2]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[2582]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[2584]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2583]!, self._r[2583]!, [_0]) + return formatWithArgumentRanges(self._s[2585]!, self._r[2585]!, [_0]) } - public var Passport_DiscardMessageTitle: String { return self._s[2584]! } - public var Localization_LanguageOther: String { return self._s[2585]! } - public var Conversation_EncryptionCanceled: String { return self._s[2586]! } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[2587]! } + public var Passport_DiscardMessageTitle: String { return self._s[2586]! } + public var Localization_LanguageOther: String { return self._s[2587]! } + public var Conversation_EncryptionCanceled: String { return self._s[2588]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[2589]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2589]!, self._r[2589]!, [_0]) + return formatWithArgumentRanges(self._s[2591]!, self._r[2591]!, [_0]) } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2591]! } - public var SocksProxySetup_SavedProxies: String { return self._s[2592]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2593]! } + public var SocksProxySetup_SavedProxies: String { return self._s[2594]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2593]!, self._r[2593]!, [_1]) + return formatWithArgumentRanges(self._s[2595]!, self._r[2595]!, [_1]) } - public var Conversation_ScamWarning: String { return self._s[2594]! } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[2595]! } - public var LocalGroup_Title: String { return self._s[2596]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[2597]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[2598]! } - public var Login_PhoneFloodError: String { return self._s[2599]! } - public var Username_InvalidTaken: String { return self._s[2601]! } - public var SocksProxySetup_AddProxy: String { return self._s[2603]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[2604]! } - public var MediaPicker_UngroupDescription: String { return self._s[2605]! } - public var Login_CodeExpired: String { return self._s[2606]! } - public var Localization_ChooseLanguage: String { return self._s[2607]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[2608]! } + public var Conversation_ScamWarning: String { return self._s[2596]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[2597]! } + public var LocalGroup_Title: String { return self._s[2598]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[2599]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[2600]! } + public var Login_PhoneFloodError: String { return self._s[2601]! } + public var Username_InvalidTaken: String { return self._s[2603]! } + public var SocksProxySetup_AddProxy: String { return self._s[2605]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[2606]! } + public var MediaPicker_UngroupDescription: String { return self._s[2607]! } + public var Login_CodeExpired: String { return self._s[2608]! } + public var Localization_ChooseLanguage: String { return self._s[2609]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[2610]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2609]!, self._r[2609]!, [_0]) + return formatWithArgumentRanges(self._s[2611]!, self._r[2611]!, [_0]) } public func Channel_DiscussionGroup_HeaderSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2610]!, self._r[2610]!, [_0]) + return formatWithArgumentRanges(self._s[2612]!, self._r[2612]!, [_0]) } - public var ReportPeer_ReasonOther_Title: String { return self._s[2612]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[2613]! } - public var PeerInfo_ButtonDiscuss: String { return self._s[2614]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[2615]! } - public var Call_StatusNoAnswer: String { return self._s[2616]! } - public var ScheduledMessages_DeleteMany: String { return self._s[2618]! } - public var Channel_DiscussionGroupInfo: String { return self._s[2619]! } - public var Conversation_UnarchiveDone: String { return self._s[2620]! } - public var LogoutOptions_AddAccountText: String { return self._s[2621]! } - public var Message_PinnedContactMessage: String { return self._s[2622]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[2614]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[2615]! } + public var PeerInfo_ButtonDiscuss: String { return self._s[2616]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[2617]! } + public var Call_StatusNoAnswer: String { return self._s[2618]! } + public var ScheduledMessages_DeleteMany: String { return self._s[2620]! } + public var Channel_DiscussionGroupInfo: String { return self._s[2621]! } + public var Conversation_UnarchiveDone: String { return self._s[2622]! } + public var LogoutOptions_AddAccountText: String { return self._s[2623]! } + public var Message_PinnedContactMessage: String { return self._s[2624]! } public func FileSize_GB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2624]!, self._r[2624]!, [_0]) + return formatWithArgumentRanges(self._s[2626]!, self._r[2626]!, [_0]) } - public var Stats_GroupLanguagesTitle: String { return self._s[2625]! } - public var Passport_FieldAddressHelp: String { return self._s[2626]! } + public var Stats_GroupLanguagesTitle: String { return self._s[2627]! } + public var Passport_FieldAddressHelp: String { return self._s[2628]! } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2627]!, self._r[2627]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2629]!, self._r[2629]!, [_1, _2]) } - public var ChatSettings_OpenLinksIn: String { return self._s[2629]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[2630]! } - public var Message_Photo: String { return self._s[2631]! } - public var MediaPicker_AddCaption: String { return self._s[2633]! } - public var LogoutOptions_Title: String { return self._s[2634]! } + public var ChatSettings_OpenLinksIn: String { return self._s[2631]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[2632]! } + public var Message_Photo: String { return self._s[2633]! } + public var MediaPicker_AddCaption: String { return self._s[2635]! } + public var LogoutOptions_Title: String { return self._s[2636]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2635]!, self._r[2635]!, [_1]) + return formatWithArgumentRanges(self._s[2637]!, self._r[2637]!, [_1]) } - public var Conversation_StatusKickedFromGroup: String { return self._s[2636]! } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[2637]! } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2638]! } - public var Channel_AdminLogFilter_Title: String { return self._s[2639]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2640]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[2638]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[2639]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2640]! } + public var Channel_AdminLogFilter_Title: String { return self._s[2641]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[2642]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2641]!, self._r[2641]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2643]!, self._r[2643]!, [_1, _2]) } - public var Compose_GroupTokenListPlaceholder: String { return self._s[2642]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[2643]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2644]! } - public var ChannelIntro_Title: String { return self._s[2645]! } - public var Stats_Message_Views: String { return self._s[2646]! } - public var Stickers_Install: String { return self._s[2647]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[2644]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[2645]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2646]! } + public var ChannelIntro_Title: String { return self._s[2647]! } + public var Stats_Message_Views: String { return self._s[2648]! } + public var Stickers_Install: String { return self._s[2649]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2648]!, self._r[2648]!, [_0]) + return formatWithArgumentRanges(self._s[2650]!, self._r[2650]!, [_0]) } - public var EditTheme_Create_Preview_IncomingReplyText: String { return self._s[2649]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[2651]! } - public var Settings_Username: String { return self._s[2654]! } - public var FastTwoStepSetup_Title: String { return self._s[2655]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2656]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[2657]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2658]! } - public var CallFeedback_ReasonEcho: String { return self._s[2659]! } + public var EditTheme_Create_Preview_IncomingReplyText: String { return self._s[2651]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[2653]! } + public var Settings_Username: String { return self._s[2656]! } + public var FastTwoStepSetup_Title: String { return self._s[2657]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2658]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[2659]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2660]! } + public var CallFeedback_ReasonEcho: String { return self._s[2661]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2660]!, self._r[2660]!, [_0]) + return formatWithArgumentRanges(self._s[2662]!, self._r[2662]!, [_0]) } - public var Conversation_OpenBotLinkTitle: String { return self._s[2661]! } - public var SocksProxySetup_Title: String { return self._s[2662]! } - public var CallFeedback_Success: String { return self._s[2663]! } - public var WallpaperPreview_SwipeTopText: String { return self._s[2665]! } - public var InstantPage_AutoNightTheme: String { return self._s[2667]! } - public var Watch_Conversation_Reply: String { return self._s[2668]! } - public var Chat_PanelUnpinAllMessages: String { return self._s[2670]! } - public var WallpaperPreview_Pattern: String { return self._s[2671]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[2672]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[2673]! } + public var Conversation_OpenBotLinkTitle: String { return self._s[2663]! } + public var SocksProxySetup_Title: String { return self._s[2664]! } + public var CallFeedback_Success: String { return self._s[2665]! } + public var WallpaperPreview_SwipeTopText: String { return self._s[2667]! } + public var InstantPage_AutoNightTheme: String { return self._s[2669]! } + public var Watch_Conversation_Reply: String { return self._s[2670]! } + public var Chat_PanelUnpinAllMessages: String { return self._s[2672]! } + public var WallpaperPreview_Pattern: String { return self._s[2673]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[2674]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[2675]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2674]!, self._r[2674]!, [_0]) + return formatWithArgumentRanges(self._s[2676]!, self._r[2676]!, [_0]) } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[2675]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[2677]! } - public var Update_Title: String { return self._s[2678]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[2679]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[2677]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[2679]! } + public var Update_Title: String { return self._s[2680]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[2681]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2680]!, self._r[2680]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2682]!, self._r[2682]!, [_1, _2, _3]) } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2681]! } - public var WallpaperPreview_CropTopText: String { return self._s[2683]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[2684]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2685]! } - public var ChatListFolder_DiscardCancel: String { return self._s[2686]! } - public var Message_PinnedPhotoMessage: String { return self._s[2687]! } - public var Appearance_ThemeDayClassic: String { return self._s[2688]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[2689]! } - public var AccessDenied_Wallpapers: String { return self._s[2695]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2683]! } + public var WallpaperPreview_CropTopText: String { return self._s[2685]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[2686]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2687]! } + public var ChatListFolder_DiscardCancel: String { return self._s[2688]! } + public var Message_PinnedPhotoMessage: String { return self._s[2689]! } + public var Appearance_ThemeDayClassic: String { return self._s[2690]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[2691]! } + public var AccessDenied_Wallpapers: String { return self._s[2697]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2696]!, self._r[2696]!, [_0]) + return formatWithArgumentRanges(self._s[2698]!, self._r[2698]!, [_0]) } - public var Weekday_Sunday: String { return self._s[2697]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[2699]! } - public var PeopleNearby_MakeVisibleDescription: String { return self._s[2700]! } - public var AccessDenied_LocationDisabled: String { return self._s[2701]! } - public var Tour_Text3: String { return self._s[2702]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2703]! } + public var Weekday_Sunday: String { return self._s[2699]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[2701]! } + public var PeopleNearby_MakeVisibleDescription: String { return self._s[2702]! } + public var AccessDenied_LocationDisabled: String { return self._s[2703]! } + public var Tour_Text3: String { return self._s[2704]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2705]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2704]!, self._r[2704]!, [_0]) + return formatWithArgumentRanges(self._s[2706]!, self._r[2706]!, [_0]) } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2705]! } - public var Conversation_ClearCache: String { return self._s[2706]! } - public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[2707]! } - public var ChatList_Tabs_AllChats: String { return self._s[2708]! } - public var DialogList_RecentTitlePeople: String { return self._s[2709]! } - public var Stickers_AddToFavorites: String { return self._s[2710]! } - public var ChatList_Context_RemoveFromFolder: String { return self._s[2711]! } - public var Settings_RemoveVideo: String { return self._s[2712]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2713]! } - public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[2714]! } - public var VoiceOver_Chat_YourFile: String { return self._s[2715]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[2716]! } - public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[2717]! } - public var Channel_AdminLog_AddMembers: String { return self._s[2718]! } - public var Map_SendThisLocation: String { return self._s[2720]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[2722]! } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2723]! } - public var CloudStorage_Title: String { return self._s[2724]! } - public var TwoFactorSetup_Password_Action: String { return self._s[2725]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[2726]! } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[2728]! } - public var Undo_LeftGroup: String { return self._s[2729]! } - public var Conversation_StopLiveLocation: String { return self._s[2731]! } - public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[2732]! } - public var Message_PinnedInvoice: String { return self._s[2733]! } - public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[2734]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[2707]! } + public var Conversation_ClearCache: String { return self._s[2708]! } + public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[2709]! } + public var ChatList_Tabs_AllChats: String { return self._s[2710]! } + public var DialogList_RecentTitlePeople: String { return self._s[2711]! } + public var Stickers_AddToFavorites: String { return self._s[2712]! } + public var ChatList_Context_RemoveFromFolder: String { return self._s[2713]! } + public var Settings_RemoveVideo: String { return self._s[2714]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2715]! } + public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[2716]! } + public var VoiceOver_Chat_YourFile: String { return self._s[2717]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[2718]! } + public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[2719]! } + public var Channel_AdminLog_AddMembers: String { return self._s[2720]! } + public var Map_SendThisLocation: String { return self._s[2722]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[2724]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2725]! } + public var CloudStorage_Title: String { return self._s[2726]! } + public var TwoFactorSetup_Password_Action: String { return self._s[2727]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[2728]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[2730]! } + public var Undo_LeftGroup: String { return self._s[2731]! } + public var Conversation_StopLiveLocation: String { return self._s[2733]! } + public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[2734]! } + public var Message_PinnedInvoice: String { return self._s[2735]! } + public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[2736]! } public func PUSH_CHAT_MESSAGE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2735]!, self._r[2735]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2737]!, self._r[2737]!, [_1, _2]) } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2736]!, self._r[2736]!, [_0]) + return formatWithArgumentRanges(self._s[2738]!, self._r[2738]!, [_0]) } - public var Weekday_Tuesday: String { return self._s[2737]! } - public var ChangePhoneNumberCode_Code: String { return self._s[2738]! } - public var VoiceOver_Chat_YourMessage: String { return self._s[2739]! } - public var Calls_CallTabDescription: String { return self._s[2740]! } - public var SocksProxySetup_UseProxy: String { return self._s[2742]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[2743]! } - public var PasscodeSettings_AlphanumericCode: String { return self._s[2744]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[2745]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[2747]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2748]! } - public var Exceptions_AddToExceptions: String { return self._s[2749]! } - public var UserInfo_Title: String { return self._s[2750]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[2752]! } - public var ChatList_Unmute: String { return self._s[2754]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[2755]! } - public var Stats_GroupTopPostersTitle: String { return self._s[2756]! } - public var Username_CheckingUsername: String { return self._s[2757]! } - public var WallpaperColors_SetCustomColor: String { return self._s[2758]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[2762]! } - public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[2763]! } - public var Settings_ChangePhoneNumber: String { return self._s[2764]! } - public var PeerInfo_PaneLinks: String { return self._s[2765]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[2768]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[2770]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[2771]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[2772]! } - public var Wallet_RestoreFailed_Title: String { return self._s[2773]! } - public var Stats_FollowersBySourceTitle: String { return self._s[2775]! } + public var Weekday_Tuesday: String { return self._s[2739]! } + public var ChangePhoneNumberCode_Code: String { return self._s[2740]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2741]! } + public var Calls_CallTabDescription: String { return self._s[2742]! } + public var SocksProxySetup_UseProxy: String { return self._s[2744]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[2745]! } + public var PasscodeSettings_AlphanumericCode: String { return self._s[2746]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[2747]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[2749]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2750]! } + public var Exceptions_AddToExceptions: String { return self._s[2751]! } + public var UserInfo_Title: String { return self._s[2752]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[2754]! } + public var ChatList_Unmute: String { return self._s[2756]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[2757]! } + public var Stats_GroupTopPostersTitle: String { return self._s[2758]! } + public var Username_CheckingUsername: String { return self._s[2759]! } + public var WallpaperColors_SetCustomColor: String { return self._s[2760]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[2764]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[2765]! } + public var Settings_ChangePhoneNumber: String { return self._s[2766]! } + public var PeerInfo_PaneLinks: String { return self._s[2767]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[2770]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[2772]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[2773]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[2774]! } + public var Wallet_RestoreFailed_Title: String { return self._s[2775]! } + public var Stats_FollowersBySourceTitle: String { return self._s[2777]! } public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2776]!, self._r[2776]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2778]!, self._r[2778]!, [_0, _1]) } - public var Compose_NewEncryptedChatTitle: String { return self._s[2777]! } - public var Channel_CommentsGroup_Header: String { return self._s[2779]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[2779]! } + public var Channel_CommentsGroup_Header: String { return self._s[2781]! } public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2783]!, self._r[2783]!, [_0]) + return formatWithArgumentRanges(self._s[2785]!, self._r[2785]!, [_0]) } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2784]!, self._r[2784]!, [_1]) + return formatWithArgumentRanges(self._s[2786]!, self._r[2786]!, [_1]) } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[2786]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[2788]! } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2787]!, self._r[2787]!, [_0]) + return formatWithArgumentRanges(self._s[2789]!, self._r[2789]!, [_0]) } - public var Conversation_OpenBotLinkOpen: String { return self._s[2788]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[2789]! } - public var PrivacySettings_LastSeen: String { return self._s[2791]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[2792]! } - public var Theme_Colors_Proceed: String { return self._s[2793]! } - public var UserInfo_ScamBotWarning: String { return self._s[2794]! } - public var LogoutOptions_LogOut: String { return self._s[2796]! } - public var Conversation_SendMessage: String { return self._s[2797]! } - public var Passport_Address_Region: String { return self._s[2799]! } - public var MediaPicker_CameraRoll: String { return self._s[2801]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[2790]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[2791]! } + public var PrivacySettings_LastSeen: String { return self._s[2793]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[2794]! } + public var Theme_Colors_Proceed: String { return self._s[2795]! } + public var UserInfo_ScamBotWarning: String { return self._s[2796]! } + public var LogoutOptions_LogOut: String { return self._s[2798]! } + public var Conversation_SendMessage: String { return self._s[2799]! } + public var Passport_Address_Region: String { return self._s[2801]! } + public var MediaPicker_CameraRoll: String { return self._s[2803]! } public func VoiceOver_Chat_ForwardedFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2803]!, self._r[2803]!, [_0]) + return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_0]) } - public var Call_ReportSend: String { return self._s[2805]! } - public var Month_ShortJune: String { return self._s[2806]! } - public var AutoDownloadSettings_GroupChats: String { return self._s[2807]! } + public var Call_ReportSend: String { return self._s[2807]! } + public var Month_ShortJune: String { return self._s[2808]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[2809]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2810]!, self._r[2810]!, [_0]) + return formatWithArgumentRanges(self._s[2812]!, self._r[2812]!, [_0]) } - public var TwoStepAuth_DisableSuccess: String { return self._s[2811]! } - public var Cache_KeepMedia: String { return self._s[2812]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2813]! } + public var Cache_KeepMedia: String { return self._s[2814]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2813]!, self._r[2813]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2815]!, self._r[2815]!, [_1, _2, _3]) } - public var Wallet_Alert_OK: String { return self._s[2814]! } - public var Appearance_LargeEmoji: String { return self._s[2815]! } + public var Wallet_Alert_OK: String { return self._s[2816]! } + public var Appearance_LargeEmoji: String { return self._s[2817]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2816]!, self._r[2816]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[2818]!, self._r[2818]!, [_1, _2, _3, _4, _5, _6]) } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2817]! } - public var Wallet_Navigation_Close: String { return self._s[2818]! } - public var Call_CameraConfirmationText: String { return self._s[2819]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2819]! } + public var Wallet_Navigation_Close: String { return self._s[2820]! } + public var Call_CameraConfirmationText: String { return self._s[2821]! } public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2821]!, self._r[2821]!, [_0]) + return formatWithArgumentRanges(self._s[2823]!, self._r[2823]!, [_0]) } - public var VoiceOver_MessageContextReport: String { return self._s[2823]! } - public var ChatListFolder_ExcludeChatsTitle: String { return self._s[2824]! } - public var NotificationsSound_Tritone: String { return self._s[2826]! } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[2827]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[2830]! } - public var Stats_GroupTopAdmin_Actions: String { return self._s[2831]! } - public var PeerInfo_AddToContacts: String { return self._s[2832]! } - public var AccessDenied_Title: String { return self._s[2833]! } - public var Tour_Title1: String { return self._s[2834]! } - public var VoiceOver_AttachMedia: String { return self._s[2835]! } + public var VoiceOver_MessageContextReport: String { return self._s[2825]! } + public var ChatListFolder_ExcludeChatsTitle: String { return self._s[2826]! } + public var NotificationsSound_Tritone: String { return self._s[2828]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[2829]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[2832]! } + public var Stats_GroupTopAdmin_Actions: String { return self._s[2833]! } + public var PeerInfo_AddToContacts: String { return self._s[2834]! } + public var AccessDenied_Title: String { return self._s[2835]! } + public var Tour_Title1: String { return self._s[2836]! } + public var VoiceOver_AttachMedia: String { return self._s[2837]! } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2837]!, self._r[2837]!, [_0]) + return formatWithArgumentRanges(self._s[2839]!, self._r[2839]!, [_0]) } - public var Chat_Gifs_SavedSectionHeader: String { return self._s[2838]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2839]! } + public var Chat_Gifs_SavedSectionHeader: String { return self._s[2840]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2841]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2840]!, self._r[2840]!, [_0]) + return formatWithArgumentRanges(self._s[2842]!, self._r[2842]!, [_0]) } - public var Channel_AdminLog_MessagePreviousLink: String { return self._s[2841]! } - public var Wallet_Send_AddressText: String { return self._s[2842]! } - public var OldChannels_Title: String { return self._s[2843]! } - public var LoginPassword_FloodError: String { return self._s[2844]! } - public var Checkout_ErrorPaymentFailed: String { return self._s[2846]! } + public var Channel_AdminLog_MessagePreviousLink: String { return self._s[2843]! } + public var Wallet_Send_AddressText: String { return self._s[2844]! } + public var OldChannels_Title: String { return self._s[2845]! } + public var LoginPassword_FloodError: String { return self._s[2846]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[2848]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2847]!, self._r[2847]!, [_0]) + return formatWithArgumentRanges(self._s[2849]!, self._r[2849]!, [_0]) } - public var VoiceOver_Media_PlaybackPlay: String { return self._s[2850]! } - public var Passport_CorrectErrors: String { return self._s[2852]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[2852]! } + public var Passport_CorrectErrors: String { return self._s[2854]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2853]!, self._r[2853]!, [_1, _2]) - } - public var ChatListFolderSettings_Title: String { return self._s[2854]! } - public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2855]!, self._r[2855]!, [_1, _2]) } - public var PhotoEditor_HighlightsTool: String { return self._s[2856]! } - public var Contacts_NotRegisteredSection: String { return self._s[2859]! } + public var ChatListFolderSettings_Title: String { return self._s[2856]! } + public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2857]!, self._r[2857]!, [_1, _2]) + } + public var PhotoEditor_HighlightsTool: String { return self._s[2858]! } + public var Contacts_NotRegisteredSection: String { return self._s[2861]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2860]!, self._r[2860]!, [_1]) + return formatWithArgumentRanges(self._s[2862]!, self._r[2862]!, [_1]) } - public var User_DeletedAccount: String { return self._s[2861]! } - public var Conversation_ViewContactDetails: String { return self._s[2862]! } - public var WebSearch_GIFs: String { return self._s[2863]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2864]! } - public var Appearance_PreviewOutgoingText: String { return self._s[2865]! } - public var Calls_CallTabTitle: String { return self._s[2866]! } + public var User_DeletedAccount: String { return self._s[2863]! } + public var Conversation_ViewContactDetails: String { return self._s[2864]! } + public var WebSearch_GIFs: String { return self._s[2865]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2866]! } + public var Appearance_PreviewOutgoingText: String { return self._s[2867]! } + public var Calls_CallTabTitle: String { return self._s[2868]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2867]!, self._r[2867]!, [_0]) + return formatWithArgumentRanges(self._s[2869]!, self._r[2869]!, [_0]) } - public var Channel_Status: String { return self._s[2868]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2870]! } - public var VoiceOver_Chat_OptionSelected: String { return self._s[2871]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2872]! } + public var Channel_Status: String { return self._s[2870]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2872]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[2873]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2874]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2875]!, self._r[2875]!, [_0, _1]) } - public var Passport_Identity_ExpiryDateNone: String { return self._s[2875]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2877]! } - public var Month_ShortDecember: String { return self._s[2878]! } - public var Username_Help: String { return self._s[2879]! } - public var Login_InfoAvatarAdd: String { return self._s[2880]! } - public var Month_ShortMay: String { return self._s[2881]! } - public var DialogList_UnknownPinLimitError: String { return self._s[2882]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[2883]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[2884]! } - public var Weekday_ShortSunday: String { return self._s[2885]! } - public var Channel_Username_InvalidTooShort: String { return self._s[2886]! } - public var AuthSessions_TerminateSession: String { return self._s[2887]! } - public var Passport_Identity_FilesTitle: String { return self._s[2888]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[2877]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2879]! } + public var Month_ShortDecember: String { return self._s[2880]! } + public var Username_Help: String { return self._s[2881]! } + public var Login_InfoAvatarAdd: String { return self._s[2882]! } + public var Month_ShortMay: String { return self._s[2883]! } + public var DialogList_UnknownPinLimitError: String { return self._s[2884]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[2885]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[2886]! } + public var Weekday_ShortSunday: String { return self._s[2887]! } + public var Channel_Username_InvalidTooShort: String { return self._s[2888]! } + public var AuthSessions_TerminateSession: String { return self._s[2889]! } + public var Passport_Identity_FilesTitle: String { return self._s[2890]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2889]!, self._r[2889]!, [_0]) + return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, [_0]) } - public var PeopleNearby_MakeVisible: String { return self._s[2891]! } + public var PeopleNearby_MakeVisible: String { return self._s[2893]! } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2892]!, self._r[2892]!, [_0]) - } - public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2893]!, self._r[2893]!, [_1, _2]) - } - public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2894]!, self._r[2894]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2895]! } - public var Conversation_ContextMenuForward: String { return self._s[2896]! } + public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2895]!, self._r[2895]!, [_1, _2]) + } + public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2896]!, self._r[2896]!, [_0]) + } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[2897]! } + public var Conversation_ContextMenuForward: String { return self._s[2898]! } public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2898]!, self._r[2898]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2900]!, self._r[2900]!, [_1, _2, _3]) } - public var Notification_GroupInviterSelf: String { return self._s[2899]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2900]! } - public var AuthSessions_CurrentSession: String { return self._s[2901]! } - public var Passport_Address_EditPassportRegistration: String { return self._s[2902]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2903]! } - public var ChatSearch_ResultsTooltip: String { return self._s[2905]! } - public var CheckoutInfo_Pay: String { return self._s[2906]! } + public var Notification_GroupInviterSelf: String { return self._s[2901]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2902]! } + public var AuthSessions_CurrentSession: String { return self._s[2903]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2904]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[2905]! } + public var ChatSearch_ResultsTooltip: String { return self._s[2907]! } + public var CheckoutInfo_Pay: String { return self._s[2908]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2908]!, self._r[2908]!, [_0]) + return formatWithArgumentRanges(self._s[2910]!, self._r[2910]!, [_0]) } - public var GroupInfo_AddParticipant: String { return self._s[2909]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[2910]! } - public var ChatList_UndoArchiveText1: String { return self._s[2911]! } - public var Localization_LanguageCustom: String { return self._s[2912]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[2913]! } - public var Settings_UsernameEmpty: String { return self._s[2914]! } - public var Settings_FAQ_URL: String { return self._s[2915]! } + public var GroupInfo_AddParticipant: String { return self._s[2911]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[2912]! } + public var ChatList_UndoArchiveText1: String { return self._s[2913]! } + public var Localization_LanguageCustom: String { return self._s[2914]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[2915]! } + public var Settings_UsernameEmpty: String { return self._s[2916]! } + public var Settings_FAQ_URL: String { return self._s[2917]! } public func Conversation_PinMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2916]!, self._r[2916]!, [_0]) + return formatWithArgumentRanges(self._s[2918]!, self._r[2918]!, [_0]) } - public var Common_Select: String { return self._s[2918]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[2919]! } - public var Notification_PassportValueAddress: String { return self._s[2920]! } - public var Conversation_MessageDialogDelete: String { return self._s[2921]! } - public var Map_OpenInYandexNavigator: String { return self._s[2923]! } - public var DialogList_SearchSectionDialogs: String { return self._s[2924]! } - public var AccessDenied_Contacts: String { return self._s[2925]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2927]! } - public var Passport_ScanPassportHelp: String { return self._s[2928]! } - public var Chat_PinnedListPreview_HidePinnedMessages: String { return self._s[2929]! } - public var ChatListFolder_NameChannels: String { return self._s[2930]! } - public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[2931]! } + public var Common_Select: String { return self._s[2920]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[2921]! } + public var Notification_PassportValueAddress: String { return self._s[2922]! } + public var Conversation_MessageDialogDelete: String { return self._s[2923]! } + public var Map_OpenInYandexNavigator: String { return self._s[2925]! } + public var DialogList_SearchSectionDialogs: String { return self._s[2926]! } + public var AccessDenied_Contacts: String { return self._s[2927]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2929]! } + public var Passport_ScanPassportHelp: String { return self._s[2930]! } + public var Chat_PinnedListPreview_HidePinnedMessages: String { return self._s[2931]! } + public var ChatListFolder_NameChannels: String { return self._s[2932]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[2933]! } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2932]!, self._r[2932]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2934]!, self._r[2934]!, [_1, _2]) } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[2933]! } - public var Conversation_GifTooltip: String { return self._s[2934]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2936]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[2937]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2938]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[2939]! } - public var CreatePoll_Quiz: String { return self._s[2940]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[2941]! } - public var Watch_Message_Invoice: String { return self._s[2942]! } - public var Settings_AddAnotherAccount_Help: String { return self._s[2943]! } - public var Watch_Message_Unsupported: String { return self._s[2944]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[2935]! } + public var Conversation_GifTooltip: String { return self._s[2936]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2938]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[2939]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[2940]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[2941]! } + public var CreatePoll_Quiz: String { return self._s[2942]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[2943]! } + public var Watch_Message_Invoice: String { return self._s[2944]! } + public var Settings_AddAnotherAccount_Help: String { return self._s[2945]! } + public var Watch_Message_Unsupported: String { return self._s[2946]! } public func Call_CameraOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2946]!, self._r[2946]!, [_0]) + return formatWithArgumentRanges(self._s[2948]!, self._r[2948]!, [_0]) } - public var AuthSessions_TerminateOtherSessions: String { return self._s[2947]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[2949]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[2950]! } - public var Call_IncomingVoiceCall: String { return self._s[2951]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[2949]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[2951]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[2952]! } + public var Call_IncomingVoiceCall: String { return self._s[2953]! } public func Channel_AdminLog_MessageTransferedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2952]!, self._r[2952]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2954]!, self._r[2954]!, [_1, _2]) } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2953]! } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[2954]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[2955]! } - public var Group_ErrorAccessDenied: String { return self._s[2956]! } - public var PasscodeSettings_HelpTop: String { return self._s[2957]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[2958]! } - public var AddContact_SharedContactException: String { return self._s[2959]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[2960]! } - public var Privacy_TopPeers: String { return self._s[2961]! } - public var Web_OpenExternal: String { return self._s[2962]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2963]! } - public var Channel_Management_LabelAdministrator: String { return self._s[2964]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2955]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[2956]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[2957]! } + public var Group_ErrorAccessDenied: String { return self._s[2958]! } + public var PasscodeSettings_HelpTop: String { return self._s[2959]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[2960]! } + public var AddContact_SharedContactException: String { return self._s[2961]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[2962]! } + public var Privacy_TopPeers: String { return self._s[2963]! } + public var Web_OpenExternal: String { return self._s[2964]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2965]! } + public var Channel_Management_LabelAdministrator: String { return self._s[2966]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2965]!, self._r[2965]!, [_0]) + return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_0]) } - public var Permissions_Skip: String { return self._s[2966]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[2967]! } - public var PeopleNearby_Title: String { return self._s[2968]! } - public var GroupInfo_SharedMediaNone: String { return self._s[2969]! } + public var Permissions_Skip: String { return self._s[2968]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[2969]! } + public var PeopleNearby_Title: String { return self._s[2970]! } + public var GroupInfo_SharedMediaNone: String { return self._s[2971]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2971]!, self._r[2971]!, [_1]) + return formatWithArgumentRanges(self._s[2973]!, self._r[2973]!, [_1]) } - public var Profile_MessageLifetime1w: String { return self._s[2972]! } + public var Profile_MessageLifetime1w: String { return self._s[2974]! } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2973]!, self._r[2973]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2975]!, self._r[2975]!, [_1, _2, _3]) } - public var WebBrowser_DefaultBrowser: String { return self._s[2974]! } - public var Conversation_PinOlderMessageAlertTitle: String { return self._s[2976]! } - public var EditTheme_Edit_BottomInfo: String { return self._s[2977]! } - public var Privacy_Forwards_Preview: String { return self._s[2978]! } - public var Settings_EditAccount: String { return self._s[2979]! } + public var WebBrowser_DefaultBrowser: String { return self._s[2976]! } + public var Conversation_PinOlderMessageAlertTitle: String { return self._s[2978]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[2979]! } + public var Privacy_Forwards_Preview: String { return self._s[2980]! } + public var Settings_EditAccount: String { return self._s[2981]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2980]!, self._r[2980]!, [_0]) + return formatWithArgumentRanges(self._s[2982]!, self._r[2982]!, [_0]) } - public var TwoFactorSetup_Intro_Title: String { return self._s[2981]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[2983]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2983]!, self._r[2983]!, [_1]) + return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_1]) } - public var PeerInfo_ButtonVideoCall: String { return self._s[2984]! } + public var PeerInfo_ButtonVideoCall: String { return self._s[2986]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_0]) + return formatWithArgumentRanges(self._s[2987]!, self._r[2987]!, [_0]) } - public var Login_InfoHelp: String { return self._s[2986]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2987]! } - public var Profile_MessageLifetime1d: String { return self._s[2988]! } - public var Group_UpgradeConfirmation: String { return self._s[2989]! } + public var Login_InfoHelp: String { return self._s[2988]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2989]! } + public var Profile_MessageLifetime1d: String { return self._s[2990]! } + public var Group_UpgradeConfirmation: String { return self._s[2991]! } public func PUSH_PINNED_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2992]!, self._r[2992]!, [_1, _2]) } - public var Appearance_RemoveThemeColor: String { return self._s[2991]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2992]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[2993]! } + public var Appearance_RemoveThemeColor: String { return self._s[2993]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[2994]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[2995]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2994]!, self._r[2994]!, [_0]) + return formatWithArgumentRanges(self._s[2996]!, self._r[2996]!, [_0]) } - public var UserInfo_BotSettings: String { return self._s[2995]! } + public var UserInfo_BotSettings: String { return self._s[2997]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2997]!, self._r[2997]!, [_0]) + return formatWithArgumentRanges(self._s[2999]!, self._r[2999]!, [_0]) } - public var Permissions_ContactsText_v0: String { return self._s[2998]! } - public var Conversation_PinMessagesForMe: String { return self._s[2999]! } - public var Conversation_DiscussionStarted: String { return self._s[3001]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[3002]! } - public var SharedMedia_SearchNoResults: String { return self._s[3004]! } + public var Permissions_ContactsText_v0: String { return self._s[3000]! } + public var Conversation_PinMessagesForMe: String { return self._s[3001]! } + public var Conversation_DiscussionStarted: String { return self._s[3003]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[3004]! } + public var SharedMedia_SearchNoResults: String { return self._s[3006]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3006]!, self._r[3006]!, [_0]) - } - public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3008]!, self._r[3008]!, [_0]) } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[3009]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3010]! } - public var Call_AudioRouteHeadphones: String { return self._s[3011]! } + public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3010]!, self._r[3010]!, [_0]) + } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[3011]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3012]! } + public var Call_AudioRouteHeadphones: String { return self._s[3013]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3012]!, self._r[3012]!, [_1]) + return formatWithArgumentRanges(self._s[3014]!, self._r[3014]!, [_1]) } - public var Passport_Identity_FilesView: String { return self._s[3013]! } - public var TwoStepAuth_SetupEmail: String { return self._s[3014]! } - public var Widget_ApplicationStartRequired: String { return self._s[3015]! } - public var PhotoEditor_Original: String { return self._s[3016]! } - public var Call_YourMicrophoneOff: String { return self._s[3017]! } - public var Permissions_ContactsAllow_v0: String { return self._s[3018]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[3019]! } - public var PrivacyPolicy_Decline: String { return self._s[3020]! } - public var SettingsSearch_Synonyms_ChatFolders: String { return self._s[3021]! } - public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[3022]! } - public var ChatListFolder_IncludeSectionInfo: String { return self._s[3023]! } + public var Passport_Identity_FilesView: String { return self._s[3015]! } + public var TwoStepAuth_SetupEmail: String { return self._s[3016]! } + public var Widget_ApplicationStartRequired: String { return self._s[3017]! } + public var PhotoEditor_Original: String { return self._s[3018]! } + public var Call_YourMicrophoneOff: String { return self._s[3019]! } + public var Permissions_ContactsAllow_v0: String { return self._s[3020]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[3021]! } + public var PrivacyPolicy_Decline: String { return self._s[3022]! } + public var SettingsSearch_Synonyms_ChatFolders: String { return self._s[3023]! } + public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[3024]! } + public var ChatListFolder_IncludeSectionInfo: String { return self._s[3025]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3024]!, self._r[3024]!, [_0]) + return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_0]) } - public var Passport_Identity_Name: String { return self._s[3025]! } - public var WallpaperPreview_PatternTitle: String { return self._s[3027]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[3028]! } - public var WallpaperSearch_ColorOrange: String { return self._s[3030]! } - public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[3031]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[3032]! } - public var Your_cards_security_code_is_invalid: String { return self._s[3033]! } - public var IntentsSettings_ResetAll: String { return self._s[3034]! } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3036]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3037]! } - public var Notification_Exceptions_Add: String { return self._s[3038]! } - public var Cache_Help: String { return self._s[3039]! } - public var Call_AudioRouteMute: String { return self._s[3040]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[3041]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[3042]! } + public var Passport_Identity_Name: String { return self._s[3027]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3029]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[3030]! } + public var WallpaperSearch_ColorOrange: String { return self._s[3032]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[3033]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[3034]! } + public var Your_cards_security_code_is_invalid: String { return self._s[3035]! } + public var IntentsSettings_ResetAll: String { return self._s[3036]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3038]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3039]! } + public var Notification_Exceptions_Add: String { return self._s[3040]! } + public var Cache_Help: String { return self._s[3041]! } + public var Call_AudioRouteMute: String { return self._s[3042]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[3043]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[3044]! } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3043]!, self._r[3043]!, [_1]) + return formatWithArgumentRanges(self._s[3045]!, self._r[3045]!, [_1]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3044]!, self._r[3044]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3046]!, self._r[3046]!, [_1, _2]) } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3045]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[3046]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[3047]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3047]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[3048]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[3049]! } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3048]!, self._r[3048]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3050]!, self._r[3050]!, [_1, _2, _3]) } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3049]! } - public var ClearCache_StorageFree: String { return self._s[3050]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3051]! } + public var ClearCache_StorageFree: String { return self._s[3052]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3051]!, self._r[3051]!, [_0]) + return formatWithArgumentRanges(self._s[3053]!, self._r[3053]!, [_0]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[3052]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[3054]! } - public var DialogList_Typing: String { return self._s[3055]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[3054]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[3056]! } + public var DialogList_Typing: String { return self._s[3057]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3056]!, self._r[3056]!, [_0]) + return formatWithArgumentRanges(self._s[3058]!, self._r[3058]!, [_0]) } - public var Target_SelectGroup: String { return self._s[3057]! } - public var AuthSessions_IncompleteAttempts: String { return self._s[3058]! } + public var Target_SelectGroup: String { return self._s[3059]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3060]! } public func Notification_ProximityReached(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3059]!, self._r[3059]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3061]!, self._r[3061]!, [_1, _2, _3]) } - public var Chat_PinnedListPreview_ShowAllMessages: String { return self._s[3060]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[3061]! } + public var Chat_PinnedListPreview_ShowAllMessages: String { return self._s[3062]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[3063]! } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_0]) + return formatWithArgumentRanges(self._s[3064]!, self._r[3064]!, [_0]) } - public var Channel_AdminLog_CanSendMessages: String { return self._s[3063]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[3064]! } - public var ChatSettings_TextSize: String { return self._s[3065]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[3067]! } - public var Map_SendThisPlace: String { return self._s[3068]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3069]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3070]! } - public var Call_ShareStats: String { return self._s[3071]! } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3073]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[3074]! } - public var Settings_Support: String { return self._s[3075]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3076]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[3065]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[3066]! } + public var ChatSettings_TextSize: String { return self._s[3067]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[3069]! } + public var Map_SendThisPlace: String { return self._s[3070]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3071]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3072]! } + public var Call_ShareStats: String { return self._s[3073]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3075]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[3076]! } + public var Settings_Support: String { return self._s[3077]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3078]! } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3078]!, self._r[3078]!, [_0]) + return formatWithArgumentRanges(self._s[3080]!, self._r[3080]!, [_0]) } - public var Watch_Conversation_GroupInfo: String { return self._s[3079]! } - public var Tour_Text4: String { return self._s[3080]! } - public var PasscodeSettings_AutoLock: String { return self._s[3082]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3083]! } - public var Bot_DescriptionTitle: String { return self._s[3084]! } - public var Map_LocationTitle: String { return self._s[3085]! } - public var ChatListFolder_ExcludeSectionInfo: String { return self._s[3086]! } + public var Watch_Conversation_GroupInfo: String { return self._s[3081]! } + public var Tour_Text4: String { return self._s[3082]! } + public var PasscodeSettings_AutoLock: String { return self._s[3084]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3085]! } + public var Bot_DescriptionTitle: String { return self._s[3086]! } + public var Map_LocationTitle: String { return self._s[3087]! } + public var ChatListFolder_ExcludeSectionInfo: String { return self._s[3088]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3087]!, self._r[3087]!, [_1]) + return formatWithArgumentRanges(self._s[3089]!, self._r[3089]!, [_1]) } - public var Login_EmailNotConfiguredError: String { return self._s[3088]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[3089]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[3090]! } - public var Permissions_CellularDataText_v0: String { return self._s[3091]! } - public var Conversation_EncryptionProcessing: String { return self._s[3092]! } - public var GroupPermission_Delete: String { return self._s[3093]! } - public var Contacts_SortByName: String { return self._s[3094]! } - public var TwoStepAuth_RecoveryUnavailable: String { return self._s[3095]! } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[3096]! } - public var Group_Management_AddModeratorHelp: String { return self._s[3098]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[3099]! } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3100]! } + public var Login_EmailNotConfiguredError: String { return self._s[3090]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[3091]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[3092]! } + public var Permissions_CellularDataText_v0: String { return self._s[3093]! } + public var Conversation_EncryptionProcessing: String { return self._s[3094]! } + public var GroupPermission_Delete: String { return self._s[3095]! } + public var Contacts_SortByName: String { return self._s[3096]! } + public var TwoStepAuth_RecoveryUnavailable: String { return self._s[3097]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[3098]! } + public var Group_Management_AddModeratorHelp: String { return self._s[3100]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[3101]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3102]! } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3102]!, self._r[3102]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3104]!, self._r[3104]!, [_1, _2, _3]) } - public var CallFeedback_IncludeLogsInfo: String { return self._s[3103]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[3105]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3104]!, self._r[3104]!, [_1]) + return formatWithArgumentRanges(self._s[3106]!, self._r[3106]!, [_1]) } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3105]!, self._r[3105]!, [_0]) + return formatWithArgumentRanges(self._s[3107]!, self._r[3107]!, [_0]) } - public var ChatList_Context_Delete: String { return self._s[3106]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[3107]! } - public var Conversation_Processing: String { return self._s[3108]! } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[3109]! } - public var ChatSettings_Stickers: String { return self._s[3110]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3111]! } - public var Passport_Language_cs: String { return self._s[3112]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3114]! } - public var Conversation_Contact: String { return self._s[3115]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[3116]! } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[3117]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[3118]! } - public var Theme_Unsupported: String { return self._s[3119]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[3120]! } - public var Privacy_TopPeersWarning: String { return self._s[3121]! } + public var ChatList_Context_Delete: String { return self._s[3108]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[3109]! } + public var Conversation_Processing: String { return self._s[3110]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[3111]! } + public var ChatSettings_Stickers: String { return self._s[3112]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3113]! } + public var Passport_Language_cs: String { return self._s[3114]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3116]! } + public var Conversation_Contact: String { return self._s[3117]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[3118]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[3119]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[3120]! } + public var Theme_Unsupported: String { return self._s[3121]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[3122]! } + public var Privacy_TopPeersWarning: String { return self._s[3123]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3123]!, self._r[3123]!, [_0]) + return formatWithArgumentRanges(self._s[3125]!, self._r[3125]!, [_0]) } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3124]! } - public var TwoStepAuth_RemovePassword: String { return self._s[3125]! } - public var Settings_CheckPhoneNumberText: String { return self._s[3126]! } - public var PeopleNearby_Users: String { return self._s[3127]! } - public var Appearance_TextSize_UseSystem: String { return self._s[3128]! } - public var Settings_SetProfilePhoto: String { return self._s[3129]! } - public var Conversation_ContextMenuBan: String { return self._s[3130]! } - public var KeyCommand_ScrollUp: String { return self._s[3131]! } - public var Settings_ChatSettings: String { return self._s[3133]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3126]! } + public var TwoStepAuth_RemovePassword: String { return self._s[3127]! } + public var Settings_CheckPhoneNumberText: String { return self._s[3128]! } + public var PeopleNearby_Users: String { return self._s[3129]! } + public var Appearance_TextSize_UseSystem: String { return self._s[3130]! } + public var Settings_SetProfilePhoto: String { return self._s[3131]! } + public var Conversation_ContextMenuBan: String { return self._s[3132]! } + public var KeyCommand_ScrollUp: String { return self._s[3133]! } + public var Settings_ChatSettings: String { return self._s[3135]! } public func PUSH_CHAT_MESSAGE_VIDEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3134]!, self._r[3134]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3136]!, self._r[3136]!, [_1, _2]) } - public var Stats_GroupTopInvitersTitle: String { return self._s[3135]! } - public var Passport_Phone_EnterOtherNumber: String { return self._s[3136]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[3138]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3139]! } - public var Stats_GroupTopPoster_Promote: String { return self._s[3140]! } - public var Cache_Title: String { return self._s[3141]! } - public var Clipboard_SendPhoto: String { return self._s[3142]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[3144]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3145]! } - public var WatchRemote_AlertTitle: String { return self._s[3146]! } - public var Appearance_ReduceMotion: String { return self._s[3147]! } + public var Stats_GroupTopInvitersTitle: String { return self._s[3137]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[3138]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[3140]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3141]! } + public var Stats_GroupTopPoster_Promote: String { return self._s[3142]! } + public var Cache_Title: String { return self._s[3143]! } + public var Clipboard_SendPhoto: String { return self._s[3144]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[3146]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3147]! } + public var WatchRemote_AlertTitle: String { return self._s[3148]! } + public var Appearance_ReduceMotion: String { return self._s[3149]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3150]!, self._r[3150]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3152]!, self._r[3152]!, [_1, _2]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[3151]! } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[3152]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[3153]! } - public var Wallet_TransactionInfo_CopyAddress: String { return self._s[3155]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[3153]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[3154]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[3155]! } + public var Wallet_TransactionInfo_CopyAddress: String { return self._s[3157]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3156]!, self._r[3156]!, [_0]) - } - public var ChatListFolder_DiscardConfirmation: String { return self._s[3157]! } - public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3158]!, self._r[3158]!, [_0]) } - public var ChatState_WaitingForNetwork: String { return self._s[3159]! } - public var GroupInfo_Sound: String { return self._s[3160]! } - public var NotificationsSound_Telegraph: String { return self._s[3161]! } - public var NotificationsSound_Hello: String { return self._s[3162]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[3163]! } - public var Wallet_Settings_BackupWallet: String { return self._s[3164]! } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[3165]! } - public var Conversation_HoldForVideo: String { return self._s[3166]! } - public var Conversation_PinOlderMessageAlertText: String { return self._s[3167]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[3168]! } - public var Wallet_RestoreFailed_EnterWords: String { return self._s[3169]! } - public var Appearance_ShareTheme: String { return self._s[3170]! } - public var TwoStepAuth_SetupHint: String { return self._s[3171]! } - public var Wallet_Created_Text: String { return self._s[3174]! } - public var Stats_GrowthTitle: String { return self._s[3175]! } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3176]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[3177]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[3178]! } - public var GroupPermission_NoSendMessages: String { return self._s[3180]! } - public var Conversation_SetReminder_Title: String { return self._s[3181]! } - public var Privacy_Calls_CustomHelp: String { return self._s[3182]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3183]! } + public var ChatListFolder_DiscardConfirmation: String { return self._s[3159]! } + public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3160]!, self._r[3160]!, [_0]) + } + public var ChatState_WaitingForNetwork: String { return self._s[3161]! } + public var GroupInfo_Sound: String { return self._s[3162]! } + public var NotificationsSound_Telegraph: String { return self._s[3163]! } + public var NotificationsSound_Hello: String { return self._s[3164]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[3165]! } + public var Wallet_Settings_BackupWallet: String { return self._s[3166]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[3167]! } + public var Conversation_HoldForVideo: String { return self._s[3168]! } + public var Conversation_PinOlderMessageAlertText: String { return self._s[3169]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[3170]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[3171]! } + public var Appearance_ShareTheme: String { return self._s[3172]! } + public var TwoStepAuth_SetupHint: String { return self._s[3173]! } + public var Wallet_Created_Text: String { return self._s[3176]! } + public var Stats_GrowthTitle: String { return self._s[3177]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3178]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[3179]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[3180]! } + public var GroupPermission_NoSendMessages: String { return self._s[3182]! } + public var Conversation_SetReminder_Title: String { return self._s[3183]! } + public var Privacy_Calls_CustomHelp: String { return self._s[3184]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3185]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3184]!, self._r[3184]!, [_0]) + return formatWithArgumentRanges(self._s[3186]!, self._r[3186]!, [_0]) } - public var Undo_SecretChatDeleted: String { return self._s[3186]! } - public var PhotoEditor_ContrastTool: String { return self._s[3187]! } - public var Privacy_Forwards: String { return self._s[3188]! } - public var AuthSessions_LoggedInWithTelegram: String { return self._s[3189]! } - public var KeyCommand_SendMessage: String { return self._s[3191]! } + public var Undo_SecretChatDeleted: String { return self._s[3188]! } + public var PhotoEditor_ContrastTool: String { return self._s[3189]! } + public var Privacy_Forwards: String { return self._s[3190]! } + public var AuthSessions_LoggedInWithTelegram: String { return self._s[3191]! } + public var KeyCommand_SendMessage: String { return self._s[3193]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3192]!, self._r[3192]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3194]!, self._r[3194]!, [_1, _2]) } - public var GroupPermission_NoSendGifs: String { return self._s[3193]! } - public var Wallet_Month_ShortJune: String { return self._s[3194]! } - public var Notification_MessageLifetime2s: String { return self._s[3195]! } - public var Message_Theme: String { return self._s[3196]! } - public var Conversation_Dice_u1F3AF: String { return self._s[3199]! } + public var GroupPermission_NoSendGifs: String { return self._s[3195]! } + public var Wallet_Month_ShortJune: String { return self._s[3196]! } + public var Notification_MessageLifetime2s: String { return self._s[3197]! } + public var Message_Theme: String { return self._s[3198]! } + public var Conversation_Dice_u1F3AF: String { return self._s[3201]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3200]!, self._r[3200]!, [_0]) + return formatWithArgumentRanges(self._s[3202]!, self._r[3202]!, [_0]) } - public var Group_UpgradeNoticeHeader: String { return self._s[3202]! } - public var PeerInfo_BioExpand: String { return self._s[3203]! } - public var Passport_DeletePersonalDetails: String { return self._s[3204]! } - public var Widget_NoUsers: String { return self._s[3205]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[3206]! } - public var Login_TermsOfServiceDecline: String { return self._s[3207]! } - public var CreatePoll_QuizTip: String { return self._s[3209]! } - public var Watch_LastSeen_WithinAWeek: String { return self._s[3210]! } - public var MessagePoll_SubmitVote: String { return self._s[3212]! } - public var ChatSettings_AutoDownloadEnabled: String { return self._s[3213]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[3214]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3215]! } - public var Conversation_UpdateTelegram: String { return self._s[3216]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3204]! } + public var PeerInfo_BioExpand: String { return self._s[3205]! } + public var Passport_DeletePersonalDetails: String { return self._s[3206]! } + public var Widget_NoUsers: String { return self._s[3207]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[3208]! } + public var Login_TermsOfServiceDecline: String { return self._s[3209]! } + public var CreatePoll_QuizTip: String { return self._s[3211]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[3212]! } + public var MessagePoll_SubmitVote: String { return self._s[3214]! } + public var ChatSettings_AutoDownloadEnabled: String { return self._s[3215]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[3216]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3217]! } + public var Conversation_UpdateTelegram: String { return self._s[3218]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3217]!, self._r[3217]!, [_0]) + return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3218]! } - public var CallSettings_Always: String { return self._s[3219]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[3220]! } - public var Login_TermsOfServiceHeader: String { return self._s[3221]! } - public var KeyCommand_ChatInfo: String { return self._s[3222]! } - public var MessagePoll_LabelPoll: String { return self._s[3223]! } - public var Paint_Clear: String { return self._s[3224]! } - public var PeerInfo_ButtonMute: String { return self._s[3225]! } - public var LastSeen_WithinAWeek: String { return self._s[3226]! } - public var Passport_Identity_FrontSide: String { return self._s[3227]! } - public var Stickers_GroupStickers: String { return self._s[3228]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[3229]! } + public var UserInfo_About_Placeholder: String { return self._s[3220]! } + public var CallSettings_Always: String { return self._s[3221]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[3222]! } + public var Login_TermsOfServiceHeader: String { return self._s[3223]! } + public var KeyCommand_ChatInfo: String { return self._s[3224]! } + public var MessagePoll_LabelPoll: String { return self._s[3225]! } + public var Paint_Clear: String { return self._s[3226]! } + public var PeerInfo_ButtonMute: String { return self._s[3227]! } + public var LastSeen_WithinAWeek: String { return self._s[3228]! } + public var Passport_Identity_FrontSide: String { return self._s[3229]! } + public var Stickers_GroupStickers: String { return self._s[3230]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[3231]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3230]!, self._r[3230]!, [_0]) + return formatWithArgumentRanges(self._s[3232]!, self._r[3232]!, [_0]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3233]!, self._r[3233]!, [_1]) + return formatWithArgumentRanges(self._s[3235]!, self._r[3235]!, [_1]) } - public var SocksProxySetup_ProxyStatusConnected: String { return self._s[3234]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[3235]! } + public var SocksProxySetup_ProxyStatusConnected: String { return self._s[3236]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[3237]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3236]!, self._r[3236]!, [_0]) + return formatWithArgumentRanges(self._s[3238]!, self._r[3238]!, [_0]) } - public var Wallet_Send_AmountText: String { return self._s[3237]! } - public var WebSearch_SearchNoResults: String { return self._s[3239]! } - public var Channel_DiscussionGroup_Create: String { return self._s[3240]! } - public var Passport_Language_es: String { return self._s[3241]! } - public var EnterPasscode_EnterCurrentPasscode: String { return self._s[3242]! } - public var Wallet_Intro_Title: String { return self._s[3243]! } - public var Map_LiveLocationShowAll: String { return self._s[3244]! } - public var Cache_MaximumCacheSizeHelp: String { return self._s[3246]! } - public var Map_OpenInGoogleMaps: String { return self._s[3247]! } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[3249]! } - public var EditTheme_Create_BottomInfo: String { return self._s[3250]! } - public var PhotoEditor_BlurToolLinear: String { return self._s[3251]! } + public var Wallet_Send_AmountText: String { return self._s[3239]! } + public var WebSearch_SearchNoResults: String { return self._s[3241]! } + public var Channel_DiscussionGroup_Create: String { return self._s[3242]! } + public var Passport_Language_es: String { return self._s[3243]! } + public var EnterPasscode_EnterCurrentPasscode: String { return self._s[3244]! } + public var Wallet_Intro_Title: String { return self._s[3245]! } + public var Map_LiveLocationShowAll: String { return self._s[3246]! } + public var Cache_MaximumCacheSizeHelp: String { return self._s[3248]! } + public var Map_OpenInGoogleMaps: String { return self._s[3249]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[3251]! } + public var EditTheme_Create_BottomInfo: String { return self._s[3252]! } + public var PhotoEditor_BlurToolLinear: String { return self._s[3253]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3252]!, self._r[3252]!, [_0]) + return formatWithArgumentRanges(self._s[3254]!, self._r[3254]!, [_0]) } - public var Passport_Phone_Delete: String { return self._s[3253]! } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[3254]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[3255]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3256]! } + public var Passport_Phone_Delete: String { return self._s[3255]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[3256]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[3257]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3258]! } public func EncryptionKey_Description(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3257]!, self._r[3257]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3259]!, self._r[3259]!, [_1, _2]) } - public var LogoutOptions_LogOutInfo: String { return self._s[3258]! } - public var Wallet_Month_GenAugust: String { return self._s[3259]! } - public var Cache_ByPeerHeader: String { return self._s[3260]! } - public var Username_InvalidCharacters: String { return self._s[3261]! } - public var Wallet_Qr_Title: String { return self._s[3263]! } - public var Checkout_ShippingAddress: String { return self._s[3264]! } + public var LogoutOptions_LogOutInfo: String { return self._s[3260]! } + public var Wallet_Month_GenAugust: String { return self._s[3261]! } + public var Cache_ByPeerHeader: String { return self._s[3262]! } + public var Username_InvalidCharacters: String { return self._s[3263]! } + public var Wallet_Qr_Title: String { return self._s[3265]! } + public var Checkout_ShippingAddress: String { return self._s[3266]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3265]!, self._r[3265]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[3267]!, self._r[3267]!, [_1, _2, _3, _4]) } - public var Conversation_AddContact: String { return self._s[3267]! } - public var Passport_Address_EditUtilityBill: String { return self._s[3268]! } - public var Message_Video: String { return self._s[3269]! } + public var Conversation_AddContact: String { return self._s[3269]! } + public var Passport_Address_EditUtilityBill: String { return self._s[3270]! } + public var Message_Video: String { return self._s[3271]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3270]!, self._r[3270]!, [_0]) + return formatWithArgumentRanges(self._s[3272]!, self._r[3272]!, [_0]) } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3271]!, self._r[3271]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[3273]!, self._r[3273]!, ["\(_0)"]) } - public var Passport_Language_km: String { return self._s[3272]! } + public var Passport_Language_km: String { return self._s[3274]! } public func PUSH_MESSAGE_CHANNEL_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3273]!, self._r[3273]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3275]!, self._r[3275]!, [_1, _2, _3]) } - public var EmptyGroupInfo_Line4: String { return self._s[3274]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3276]! } - public var Notification_CallCanceledShort: String { return self._s[3277]! } - public var PhotoEditor_FadeTool: String { return self._s[3278]! } - public var Group_PublicLink_Info: String { return self._s[3279]! } - public var Contacts_DeselectAll: String { return self._s[3280]! } - public var Conversation_Moderate_Delete: String { return self._s[3281]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3282]! } - public var NotificationsSound_Note: String { return self._s[3285]! } + public var EmptyGroupInfo_Line4: String { return self._s[3276]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3278]! } + public var Notification_CallCanceledShort: String { return self._s[3279]! } + public var PhotoEditor_FadeTool: String { return self._s[3280]! } + public var Group_PublicLink_Info: String { return self._s[3281]! } + public var Contacts_DeselectAll: String { return self._s[3282]! } + public var Conversation_Moderate_Delete: String { return self._s[3283]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3284]! } + public var NotificationsSound_Note: String { return self._s[3287]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3286]!, self._r[3286]!, [_0]) + return formatWithArgumentRanges(self._s[3288]!, self._r[3288]!, [_0]) } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3287]! } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3288]! } - public var DialogList_SearchSectionGlobal: String { return self._s[3289]! } - public var AccessDenied_Settings: String { return self._s[3290]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3291]! } - public var AuthSessions_EmptyTitle: String { return self._s[3292]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[3293]! } - public var GroupInfo_GroupType: String { return self._s[3294]! } - public var Calls_Missed: String { return self._s[3295]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[3296]! } - public var Passport_Language_uz: String { return self._s[3297]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[3298]! } - public var PhotoEditor_BlurToolPortrait: String { return self._s[3299]! } - public var Map_ChooseLocationTitle: String { return self._s[3300]! } - public var Checkout_EnterPassword: String { return self._s[3301]! } - public var GroupInfo_ConvertToSupergroup: String { return self._s[3302]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3303]! } - public var NetworkUsageSettings_Title: String { return self._s[3304]! } - public var SettingsSearch_Synonyms_ChatSettings_IntentsSettings: String { return self._s[3305]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[3306]! } - public var Compose_NewChannel: String { return self._s[3307]! } - public var Privacy_PaymentsClearInfo: String { return self._s[3309]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3289]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[3290]! } + public var DialogList_SearchSectionGlobal: String { return self._s[3291]! } + public var AccessDenied_Settings: String { return self._s[3292]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3293]! } + public var AuthSessions_EmptyTitle: String { return self._s[3294]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[3295]! } + public var GroupInfo_GroupType: String { return self._s[3296]! } + public var Calls_Missed: String { return self._s[3297]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[3298]! } + public var Passport_Language_uz: String { return self._s[3299]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[3300]! } + public var PhotoEditor_BlurToolPortrait: String { return self._s[3301]! } + public var Map_ChooseLocationTitle: String { return self._s[3302]! } + public var Checkout_EnterPassword: String { return self._s[3303]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[3304]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3305]! } + public var NetworkUsageSettings_Title: String { return self._s[3306]! } + public var SettingsSearch_Synonyms_ChatSettings_IntentsSettings: String { return self._s[3307]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[3308]! } + public var Compose_NewChannel: String { return self._s[3309]! } + public var Privacy_PaymentsClearInfo: String { return self._s[3311]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3310]!, self._r[3310]!, [_1]) + return formatWithArgumentRanges(self._s[3312]!, self._r[3312]!, [_1]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3311]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3312]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[3315]! } - public var WallpaperSearch_ColorBrown: String { return self._s[3316]! } - public var Appearance_AppIconDefault: String { return self._s[3317]! } - public var Wallet_Month_GenJune: String { return self._s[3320]! } - public var StickerSettings_ContextInfo: String { return self._s[3321]! } - public var Channel_AddBotErrorNoRights: String { return self._s[3322]! } - public var Passport_FieldPhone: String { return self._s[3324]! } - public var Contacts_PermissionsTitle: String { return self._s[3325]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3326]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3313]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3314]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[3317]! } + public var WallpaperSearch_ColorBrown: String { return self._s[3318]! } + public var Appearance_AppIconDefault: String { return self._s[3319]! } + public var Wallet_Month_GenJune: String { return self._s[3322]! } + public var StickerSettings_ContextInfo: String { return self._s[3323]! } + public var Channel_AddBotErrorNoRights: String { return self._s[3324]! } + public var Passport_FieldPhone: String { return self._s[3326]! } + public var Contacts_PermissionsTitle: String { return self._s[3327]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3328]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3327]!, self._r[3327]!, [_0]) + return formatWithArgumentRanges(self._s[3329]!, self._r[3329]!, [_0]) } - public var Bot_Unblock: String { return self._s[3328]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[3329]! } - public var Passport_PasswordHelp: String { return self._s[3330]! } - public var Watch_Conversation_UserInfo: String { return self._s[3331]! } + public var Bot_Unblock: String { return self._s[3330]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[3331]! } + public var Passport_PasswordHelp: String { return self._s[3332]! } + public var Watch_Conversation_UserInfo: String { return self._s[3333]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3335]!, self._r[3335]!, [_0]) + return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_0]) } - public var State_Connecting: String { return self._s[3337]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3338]! } - public var TextFormat_AddLinkPlaceholder: String { return self._s[3339]! } - public var Conversation_Dice_u1F3B2: String { return self._s[3340]! } + public var State_Connecting: String { return self._s[3339]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3340]! } + public var TextFormat_AddLinkPlaceholder: String { return self._s[3341]! } + public var Conversation_Dice_u1F3B2: String { return self._s[3342]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3341]!, self._r[3341]!, [_0]) + return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) } - public var Conversation_SendingOptionsTooltip: String { return self._s[3342]! } - public var ChatList_UndoArchiveTitle: String { return self._s[3343]! } - public var ChatList_EmptyChatListNewMessage: String { return self._s[3344]! } - public var WallpaperSearch_ColorGreen: String { return self._s[3346]! } - public var PhotoEditor_BlurToolOff: String { return self._s[3347]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[3348]! } - public var Weekday_Saturday: String { return self._s[3349]! } - public var DialogList_Unread: String { return self._s[3350]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[3351]! } - public var Stats_GroupPosters: String { return self._s[3352]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[3344]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3345]! } + public var ChatList_EmptyChatListNewMessage: String { return self._s[3346]! } + public var WallpaperSearch_ColorGreen: String { return self._s[3348]! } + public var PhotoEditor_BlurToolOff: String { return self._s[3349]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[3350]! } + public var Weekday_Saturday: String { return self._s[3351]! } + public var DialogList_Unread: String { return self._s[3352]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[3353]! } + public var Stats_GroupPosters: String { return self._s[3354]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3353]!, self._r[3353]!, [_1]) + return formatWithArgumentRanges(self._s[3355]!, self._r[3355]!, [_1]) } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3356]!, self._r[3356]!, [_0]) + return formatWithArgumentRanges(self._s[3358]!, self._r[3358]!, [_0]) } - public var ReportPeer_ReasonChildAbuse: String { return self._s[3357]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[3359]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3358]!, self._r[3358]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3360]!, self._r[3360]!, [_1, _2]) } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[3359]! } - public var AutoNightTheme_UseSunsetSunrise: String { return self._s[3361]! } - public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[3362]! } - public var Passport_Language_dv: String { return self._s[3363]! } - public var GroupPermission_AddSuccess: String { return self._s[3366]! } - public var Passport_Email_Help: String { return self._s[3367]! } - public var Call_ReportPlaceholder: String { return self._s[3368]! } - public var CreatePoll_AddOption: String { return self._s[3369]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3370]! } - public var PeerInfo_ButtonLeave: String { return self._s[3371]! } - public var PhotoEditor_TiltShift: String { return self._s[3374]! } - public var SecretGif_Title: String { return self._s[3376]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[3377]! } - public var SocksProxySetup_Connecting: String { return self._s[3378]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3379]! } - public var ContactInfo_PhoneLabelWork: String { return self._s[3380]! } - public var Stats_GroupTopHoursTitle: String { return self._s[3381]! } - public var Compose_NewMessage: String { return self._s[3382]! } - public var NotificationsSound_Synth: String { return self._s[3383]! } - public var Conversation_FileOpenIn: String { return self._s[3384]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[3385]! } - public var UserInfo_SendMessage: String { return self._s[3386]! } - public var Checkout_PayWithFaceId: String { return self._s[3387]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[3361]! } + public var AutoNightTheme_UseSunsetSunrise: String { return self._s[3363]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[3364]! } + public var Passport_Language_dv: String { return self._s[3365]! } + public var GroupPermission_AddSuccess: String { return self._s[3368]! } + public var Passport_Email_Help: String { return self._s[3369]! } + public var Call_ReportPlaceholder: String { return self._s[3370]! } + public var CreatePoll_AddOption: String { return self._s[3371]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3372]! } + public var PeerInfo_ButtonLeave: String { return self._s[3373]! } + public var PhotoEditor_TiltShift: String { return self._s[3376]! } + public var SecretGif_Title: String { return self._s[3378]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[3379]! } + public var SocksProxySetup_Connecting: String { return self._s[3380]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3381]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[3382]! } + public var Stats_GroupTopHoursTitle: String { return self._s[3383]! } + public var Compose_NewMessage: String { return self._s[3384]! } + public var NotificationsSound_Synth: String { return self._s[3385]! } + public var Conversation_FileOpenIn: String { return self._s[3386]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[3387]! } + public var UserInfo_SendMessage: String { return self._s[3388]! } + public var Checkout_PayWithFaceId: String { return self._s[3389]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3388]!, self._r[3388]!, [_0]) + return formatWithArgumentRanges(self._s[3390]!, self._r[3390]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[3389]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[3390]! } - public var Conversation_ViewChannel: String { return self._s[3391]! } + public var TextFormat_Strikethrough: String { return self._s[3391]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[3392]! } + public var Conversation_ViewChannel: String { return self._s[3393]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3392]!, self._r[3392]!, [_0]) + return formatWithArgumentRanges(self._s[3394]!, self._r[3394]!, [_0]) } - public var Channel_Stickers_Placeholder: String { return self._s[3393]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3394]! } - public var Camera_FlashAuto: String { return self._s[3395]! } - public var Conversation_EncryptedDescription1: String { return self._s[3396]! } - public var LocalGroup_Text: String { return self._s[3397]! } - public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[3398]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[3399]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[3400]! } - public var Conversation_EncryptedDescription2: String { return self._s[3401]! } - public var Notification_GroupActivated: String { return self._s[3402]! } - public var LastSeen_Lately: String { return self._s[3403]! } - public var Conversation_EncryptedDescription3: String { return self._s[3404]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[3405]! } - public var Conversation_SwipeToReplyHintText: String { return self._s[3406]! } - public var Conversation_EncryptedDescription4: String { return self._s[3407]! } - public var SharedMedia_EmptyTitle: String { return self._s[3408]! } - public var Wallet_Configuration_Apply: String { return self._s[3409]! } - public var Appearance_CreateTheme: String { return self._s[3410]! } - public var Stats_SharesPerPost: String { return self._s[3411]! } - public var Contacts_TabTitle: String { return self._s[3412]! } - public var Weekday_ShortThursday: String { return self._s[3413]! } - public var MessageTimer_Forever: String { return self._s[3414]! } - public var ChatListFolder_CategoryArchived: String { return self._s[3415]! } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3416]! } - public var EditTheme_Create_TopInfo: String { return self._s[3418]! } - public var Month_GenDecember: String { return self._s[3419]! } - public var EnterPasscode_EnterPasscode: String { return self._s[3420]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3421]! } - public var PeopleNearby_CreateGroup: String { return self._s[3423]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3424]! } - public var Paint_ClearConfirm: String { return self._s[3425]! } - public var ChatList_ReadAll: String { return self._s[3426]! } - public var ChatSettings_IntentsSettings: String { return self._s[3427]! } - public var Passport_PassportInformation: String { return self._s[3429]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3431]! } - public var Location_ProximityNotification_DistanceMI: String { return self._s[3434]! } - public var PhotoEditor_ExposureTool: String { return self._s[3435]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[3436]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[3437]! } - public var Stats_GroupTopPoster_History: String { return self._s[3438]! } - public var UserInfo_AddPhone: String { return self._s[3439]! } - public var Media_SendWithTimer: String { return self._s[3441]! } - public var SettingsSearch_Synonyms_Notifications_Title: String { return self._s[3442]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3443]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[3444]! } - public var ChatList_Context_Unarchive: String { return self._s[3446]! } + public var Channel_Stickers_Placeholder: String { return self._s[3395]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3396]! } + public var Camera_FlashAuto: String { return self._s[3397]! } + public var Conversation_EncryptedDescription1: String { return self._s[3398]! } + public var LocalGroup_Text: String { return self._s[3399]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[3400]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[3401]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[3402]! } + public var Conversation_EncryptedDescription2: String { return self._s[3403]! } + public var Notification_GroupActivated: String { return self._s[3404]! } + public var LastSeen_Lately: String { return self._s[3405]! } + public var Conversation_EncryptedDescription3: String { return self._s[3406]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[3407]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3408]! } + public var Conversation_EncryptedDescription4: String { return self._s[3409]! } + public var SharedMedia_EmptyTitle: String { return self._s[3410]! } + public var Wallet_Configuration_Apply: String { return self._s[3411]! } + public var Appearance_CreateTheme: String { return self._s[3412]! } + public var Stats_SharesPerPost: String { return self._s[3413]! } + public var Contacts_TabTitle: String { return self._s[3414]! } + public var Weekday_ShortThursday: String { return self._s[3415]! } + public var MessageTimer_Forever: String { return self._s[3416]! } + public var ChatListFolder_CategoryArchived: String { return self._s[3417]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3418]! } + public var EditTheme_Create_TopInfo: String { return self._s[3420]! } + public var Month_GenDecember: String { return self._s[3421]! } + public var EnterPasscode_EnterPasscode: String { return self._s[3422]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3423]! } + public var PeopleNearby_CreateGroup: String { return self._s[3425]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3426]! } + public var Paint_ClearConfirm: String { return self._s[3427]! } + public var ChatList_ReadAll: String { return self._s[3428]! } + public var ChatSettings_IntentsSettings: String { return self._s[3429]! } + public var Passport_PassportInformation: String { return self._s[3431]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3433]! } + public var Location_ProximityNotification_DistanceMI: String { return self._s[3436]! } + public var PhotoEditor_ExposureTool: String { return self._s[3437]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[3438]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[3439]! } + public var Stats_GroupTopPoster_History: String { return self._s[3440]! } + public var UserInfo_AddPhone: String { return self._s[3441]! } + public var Media_SendWithTimer: String { return self._s[3443]! } + public var SettingsSearch_Synonyms_Notifications_Title: String { return self._s[3444]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3445]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[3446]! } + public var ChatList_Context_Unarchive: String { return self._s[3448]! } public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3447]!, self._r[3447]!, [_0]) + return formatWithArgumentRanges(self._s[3449]!, self._r[3449]!, [_0]) } - public var BlockedUsers_Title: String { return self._s[3449]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[3450]! } - public var Media_ShareThisPhoto: String { return self._s[3451]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[3452]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[3453]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[3457]! } + public var BlockedUsers_Title: String { return self._s[3451]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[3452]! } + public var Media_ShareThisPhoto: String { return self._s[3453]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[3454]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[3455]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[3459]! } public func PUSH_CHAT_MESSAGE_DOCS(_ _1: String, _ _2: String, _ _3: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3458]!, self._r[3458]!, [_1, _2, "\(_3)"]) + return formatWithArgumentRanges(self._s[3460]!, self._r[3460]!, [_1, _2, "\(_3)"]) } - public var CallFeedback_ReasonNoise: String { return self._s[3459]! } - public var WebBrowser_Title: String { return self._s[3461]! } + public var CallFeedback_ReasonNoise: String { return self._s[3461]! } + public var WebBrowser_Title: String { return self._s[3463]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3462]!, self._r[3462]!, [_0]) + return formatWithArgumentRanges(self._s[3464]!, self._r[3464]!, [_0]) } - public var Notification_MessageLifetime5s: String { return self._s[3463]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3464]! } - public var Profile_MessageLifetime1m: String { return self._s[3465]! } - public var Stats_LoadingTitle: String { return self._s[3467]! } - public var Passport_ScanPassport: String { return self._s[3468]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3471]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[3472]! } - public var Login_InvalidFirstNameError: String { return self._s[3473]! } - public var Undo_ChatCleared: String { return self._s[3475]! } + public var Notification_MessageLifetime5s: String { return self._s[3465]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3466]! } + public var Profile_MessageLifetime1m: String { return self._s[3467]! } + public var Stats_LoadingTitle: String { return self._s[3469]! } + public var Passport_ScanPassport: String { return self._s[3470]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3473]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[3474]! } + public var Login_InvalidFirstNameError: String { return self._s[3475]! } + public var Undo_ChatCleared: String { return self._s[3477]! } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3477]!, self._r[3477]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_1, _2]) } - public var Conversation_PinMessageAlertPin: String { return self._s[3478]! } + public var Conversation_PinMessageAlertPin: String { return self._s[3480]! } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[3481]!, self._r[3481]!, [_1, _2, _3, _4, _5]) } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3480]!, self._r[3480]!, [_1]) + return formatWithArgumentRanges(self._s[3482]!, self._r[3482]!, [_1]) } - public var Share_MultipleMessagesDisabled: String { return self._s[3481]! } - public var TwoStepAuth_EmailInvalid: String { return self._s[3482]! } - public var EnterPasscode_ChangeTitle: String { return self._s[3484]! } + public var Share_MultipleMessagesDisabled: String { return self._s[3483]! } + public var TwoStepAuth_EmailInvalid: String { return self._s[3484]! } + public var EnterPasscode_ChangeTitle: String { return self._s[3486]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3485]!, self._r[3485]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3487]!, self._r[3487]!, [_1, _2, _3]) } - public var CallSettings_RecentCalls: String { return self._s[3486]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[3487]! } - public var AuthSessions_OtherSessions: String { return self._s[3488]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3489]! } - public var Tour_Text5: String { return self._s[3490]! } - public var Login_PadPhoneHelp: String { return self._s[3491]! } - public var Wallpaper_PhotoLibrary: String { return self._s[3493]! } - public var Conversation_ViewGroup: String { return self._s[3494]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3496]! } - public var VoiceOver_Chat_YourContact: String { return self._s[3497]! } - public var Watch_AuthRequired: String { return self._s[3498]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3499]! } - public var Conversation_ForwardContacts: String { return self._s[3500]! } - public var Conversation_InputTextPlaceholder: String { return self._s[3501]! } + public var CallSettings_RecentCalls: String { return self._s[3488]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[3489]! } + public var AuthSessions_OtherSessions: String { return self._s[3490]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3491]! } + public var Tour_Text5: String { return self._s[3492]! } + public var Login_PadPhoneHelp: String { return self._s[3493]! } + public var Wallpaper_PhotoLibrary: String { return self._s[3495]! } + public var Conversation_ViewGroup: String { return self._s[3496]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3498]! } + public var VoiceOver_Chat_YourContact: String { return self._s[3499]! } + public var Watch_AuthRequired: String { return self._s[3500]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3501]! } + public var Conversation_ForwardContacts: String { return self._s[3502]! } + public var Conversation_InputTextPlaceholder: String { return self._s[3503]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3502]!, self._r[3502]!, [_1]) + return formatWithArgumentRanges(self._s[3504]!, self._r[3504]!, [_1]) } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3503]!, self._r[3503]!, [_0]) - } - public var Channel_Setup_TypePrivate: String { return self._s[3504]! } - public func Conversation_NoticeInvitedByInChannel(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3505]!, self._r[3505]!, [_0]) } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[3506]! } - public var Wallet_ContextMenuCopy: String { return self._s[3507]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[3508]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[3509]! } - public var UserInfo_StartSecretChatStart: String { return self._s[3510]! } + public var Channel_Setup_TypePrivate: String { return self._s[3506]! } + public func Conversation_NoticeInvitedByInChannel(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3507]!, self._r[3507]!, [_0]) + } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[3508]! } + public var Wallet_ContextMenuCopy: String { return self._s[3509]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[3510]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[3511]! } + public var UserInfo_StartSecretChatStart: String { return self._s[3512]! } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3511]!, self._r[3511]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_1, _2]) } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3512]!, self._r[3512]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_0, _1, _2]) } - public var PrivacySettings_AutoArchiveTitle: String { return self._s[3513]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[3514]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[3515]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3516]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[3518]! } - public var NewContact_Title: String { return self._s[3521]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3522]! } - public var Notifications_PermissionsKeepDisabled: String { return self._s[3523]! } + public var PrivacySettings_AutoArchiveTitle: String { return self._s[3515]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[3516]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[3517]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3518]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[3520]! } + public var NewContact_Title: String { return self._s[3523]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3524]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[3525]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3524]!, self._r[3524]!, [_0]) + return formatWithArgumentRanges(self._s[3526]!, self._r[3526]!, [_0]) } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3525]!, self._r[3525]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3527]!, self._r[3527]!, [_0, _1]) } - public var Chat_SlowmodeTooltipPending: String { return self._s[3526]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3527]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3529]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[3530]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[3531]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[3528]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3529]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3531]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[3532]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[3533]! } public func PUSH_MESSAGE_DOCS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3533]!, self._r[3533]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3535]!, self._r[3535]!, [_1, "\(_2)"]) } - public var Conversation_MessageEditedLabel: String { return self._s[3534]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3535]! } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3536]! } - public var ChatList_Context_AddToContacts: String { return self._s[3537]! } - public var Passport_Language_is: String { return self._s[3538]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[3539]! } - public var Wallet_Month_ShortOctober: String { return self._s[3540]! } - public var PhotoEditor_CurvesBlue: String { return self._s[3541]! } + public var Conversation_MessageEditedLabel: String { return self._s[3536]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3537]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3538]! } + public var ChatList_Context_AddToContacts: String { return self._s[3539]! } + public var Passport_Language_is: String { return self._s[3540]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[3541]! } + public var Wallet_Month_ShortOctober: String { return self._s[3542]! } + public var PhotoEditor_CurvesBlue: String { return self._s[3543]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3542]!, self._r[3542]!, [_0]) + return formatWithArgumentRanges(self._s[3544]!, self._r[3544]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[3543]! } - public var Login_SmsRequestState3: String { return self._s[3544]! } - public var Message_PinnedVideoMessage: String { return self._s[3545]! } - public var SharedMedia_TitleLink: String { return self._s[3546]! } - public var Passport_FieldIdentity: String { return self._s[3547]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[3548]! } + public var SocksProxySetup_Username: String { return self._s[3545]! } + public var Login_SmsRequestState3: String { return self._s[3546]! } + public var Message_PinnedVideoMessage: String { return self._s[3547]! } + public var SharedMedia_TitleLink: String { return self._s[3548]! } + public var Passport_FieldIdentity: String { return self._s[3549]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[3550]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3552]!, self._r[3552]!, [_0]) + return formatWithArgumentRanges(self._s[3554]!, self._r[3554]!, [_0]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[3555]! } - public var ReportSpam_DeleteThisChat: String { return self._s[3556]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3557]! } - public var Passport_Identity_DateOfBirth: String { return self._s[3558]! } - public var Call_StatusIncoming: String { return self._s[3559]! } - public var Wallet_TransactionInfo_NoAddress: String { return self._s[3560]! } - public var ChatAdmins_AdminLabel: String { return self._s[3561]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[3562]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[3557]! } + public var ReportSpam_DeleteThisChat: String { return self._s[3558]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3559]! } + public var Passport_Identity_DateOfBirth: String { return self._s[3560]! } + public var Call_StatusIncoming: String { return self._s[3561]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[3562]! } + public var ChatAdmins_AdminLabel: String { return self._s[3563]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[3564]! } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3564]!, self._r[3564]!, [_0]) + return formatWithArgumentRanges(self._s[3566]!, self._r[3566]!, [_0]) } - public var Message_PinnedAnimationMessage: String { return self._s[3565]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[3566]! } - public var Preview_CopyAddress: String { return self._s[3567]! } - public var MediaPlayer_UnknownTrack: String { return self._s[3568]! } - public var Login_CancelSignUpConfirmation: String { return self._s[3569]! } - public var Map_OpenInYandexMaps: String { return self._s[3571]! } + public var Message_PinnedAnimationMessage: String { return self._s[3567]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[3568]! } + public var Preview_CopyAddress: String { return self._s[3569]! } + public var MediaPlayer_UnknownTrack: String { return self._s[3570]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3571]! } + public var Map_OpenInYandexMaps: String { return self._s[3573]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3574]!, self._r[3574]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3576]!, self._r[3576]!, [_1, _2, _3]) } - public var GroupRemoved_Remove: String { return self._s[3575]! } - public var ChatListFolder_TitleCreate: String { return self._s[3576]! } + public var GroupRemoved_Remove: String { return self._s[3577]! } + public var ChatListFolder_TitleCreate: String { return self._s[3578]! } public func InstantPage_AuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3578]!, self._r[3578]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3580]!, self._r[3580]!, [_1, _2]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[3579]! } - public var Group_UpgradeNoticeText2: String { return self._s[3581]! } - public var Stats_GroupGrowthTitle: String { return self._s[3582]! } - public var CreatePoll_CancelConfirmation: String { return self._s[3585]! } - public var Month_GenOctober: String { return self._s[3586]! } - public var Conversation_TitleCommentsEmpty: String { return self._s[3587]! } - public var Settings_Appearance: String { return self._s[3588]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[3581]! } + public var Group_UpgradeNoticeText2: String { return self._s[3583]! } + public var Stats_GroupGrowthTitle: String { return self._s[3584]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3587]! } + public var Month_GenOctober: String { return self._s[3588]! } + public var Conversation_TitleCommentsEmpty: String { return self._s[3589]! } + public var Settings_Appearance: String { return self._s[3590]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3589]!, self._r[3589]!, [_0]) + return formatWithArgumentRanges(self._s[3591]!, self._r[3591]!, [_0]) } - public var Wallet_Completed_Title: String { return self._s[3590]! } - public var UserInfo_AddToExisting: String { return self._s[3591]! } - public var Call_PhoneCallInProgressMessage: String { return self._s[3592]! } - public var Map_HomeAndWorkInfo: String { return self._s[3593]! } - public var Paint_Arrow: String { return self._s[3594]! } - public var CancelResetAccount_Title: String { return self._s[3595]! } - public var NotificationsSound_Circles: String { return self._s[3596]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[3597]! } - public var ChatState_Connecting: String { return self._s[3599]! } - public var Profile_MessageLifetime5s: String { return self._s[3600]! } + public var Wallet_Completed_Title: String { return self._s[3592]! } + public var UserInfo_AddToExisting: String { return self._s[3593]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3594]! } + public var Map_HomeAndWorkInfo: String { return self._s[3595]! } + public var Paint_Arrow: String { return self._s[3596]! } + public var CancelResetAccount_Title: String { return self._s[3597]! } + public var NotificationsSound_Circles: String { return self._s[3598]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[3599]! } + public var ChatState_Connecting: String { return self._s[3601]! } + public var Profile_MessageLifetime5s: String { return self._s[3602]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3601]!, self._r[3601]!, [_0]) + return formatWithArgumentRanges(self._s[3603]!, self._r[3603]!, [_0]) } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[3602]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[3603]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3604]! } - public var Conversation_DefaultRestrictedStickers: String { return self._s[3605]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[3606]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[3604]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[3605]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3606]! } + public var Conversation_DefaultRestrictedStickers: String { return self._s[3607]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[3608]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3607]!, self._r[3607]!, [_0]) + return formatWithArgumentRanges(self._s[3609]!, self._r[3609]!, [_0]) } - public var Passport_Phone_Help: String { return self._s[3608]! } - public var Privacy_ContactsSync: String { return self._s[3609]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3610]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[3611]! } - public var Map_SendMyCurrentLocation: String { return self._s[3612]! } - public var Map_AddressOnMap: String { return self._s[3613]! } + public var Passport_Phone_Help: String { return self._s[3610]! } + public var Privacy_ContactsSync: String { return self._s[3611]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3612]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[3613]! } + public var Map_SendMyCurrentLocation: String { return self._s[3614]! } + public var Map_AddressOnMap: String { return self._s[3615]! } public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3614]!, self._r[3614]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3616]!, self._r[3616]!, [_1, _2, _3]) } - public var DialogList_SearchLabel: String { return self._s[3616]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3617]! } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3618]! } - public var ChatList_Search_ShowMore: String { return self._s[3619]! } - public var DialogList_EncryptionRejected: String { return self._s[3620]! } - public var Wallet_WordImport_Text: String { return self._s[3621]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[3622]! } - public var Privacy_TopPeersDelete: String { return self._s[3623]! } - public var AttachmentMenu_SendAsFile: String { return self._s[3624]! } - public var ChatList_GenericPsaAlert: String { return self._s[3626]! } - public var SecretTimer_ImageDescription: String { return self._s[3628]! } + public var DialogList_SearchLabel: String { return self._s[3618]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3619]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3620]! } + public var ChatList_Search_ShowMore: String { return self._s[3621]! } + public var DialogList_EncryptionRejected: String { return self._s[3622]! } + public var Wallet_WordImport_Text: String { return self._s[3623]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[3624]! } + public var Privacy_TopPeersDelete: String { return self._s[3625]! } + public var AttachmentMenu_SendAsFile: String { return self._s[3626]! } + public var ChatList_GenericPsaAlert: String { return self._s[3628]! } + public var SecretTimer_ImageDescription: String { return self._s[3630]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3631]!, self._r[3631]!, [_0, _1]) } - public var ChatSettings_TextSizeUnits: String { return self._s[3630]! } - public var Notification_RenamedGroup: String { return self._s[3631]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3632]! } - public var Tour_Title2: String { return self._s[3633]! } - public var Settings_CopyUsername: String { return self._s[3634]! } - public var Compose_NewEncryptedChat: String { return self._s[3635]! } - public var Conversation_CloudStorageInfo_Title: String { return self._s[3636]! } - public var Month_ShortSeptember: String { return self._s[3637]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[3638]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[3639]! } - public var Settings_Wallet: String { return self._s[3640]! } - public var Call_StatusConnecting: String { return self._s[3642]! } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[3643]! } - public var Map_ShareLiveLocationHelp: String { return self._s[3644]! } - public var Cache_Files: String { return self._s[3645]! } - public var Notifications_Reset: String { return self._s[3646]! } + public var ChatSettings_TextSizeUnits: String { return self._s[3632]! } + public var Notification_RenamedGroup: String { return self._s[3633]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3634]! } + public var Tour_Title2: String { return self._s[3635]! } + public var Settings_CopyUsername: String { return self._s[3636]! } + public var Compose_NewEncryptedChat: String { return self._s[3637]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[3638]! } + public var Month_ShortSeptember: String { return self._s[3639]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[3640]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[3641]! } + public var Settings_Wallet: String { return self._s[3642]! } + public var Call_StatusConnecting: String { return self._s[3644]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[3645]! } + public var Map_ShareLiveLocationHelp: String { return self._s[3646]! } + public var Cache_Files: String { return self._s[3647]! } + public var Notifications_Reset: String { return self._s[3648]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3647]!, self._r[3647]!, [_0]) + return formatWithArgumentRanges(self._s[3649]!, self._r[3649]!, [_0]) } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[3648]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[3650]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3649]!, self._r[3649]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3651]!, self._r[3651]!, [_1, _2]) } - public var Notification_CallIncomingShort: String { return self._s[3650]! } - public var UserInfo_BotPrivacy: String { return self._s[3652]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[3653]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3654]! } - public var Conversation_ContextMenuLookUp: String { return self._s[3655]! } - public var Calls_RatingTitle: String { return self._s[3656]! } - public var SecretImage_Title: String { return self._s[3657]! } - public var Weekday_Monday: String { return self._s[3658]! } + public var Notification_CallIncomingShort: String { return self._s[3652]! } + public var UserInfo_BotPrivacy: String { return self._s[3654]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[3655]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3656]! } + public var Conversation_ContextMenuLookUp: String { return self._s[3657]! } + public var Calls_RatingTitle: String { return self._s[3658]! } + public var SecretImage_Title: String { return self._s[3659]! } + public var Weekday_Monday: String { return self._s[3660]! } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3660]!, self._r[3660]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3662]!, self._r[3662]!, [_1, _2]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3661]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3663]! } public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3662]!, self._r[3662]!, [_0]) + return formatWithArgumentRanges(self._s[3664]!, self._r[3664]!, [_0]) } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3663]!, self._r[3663]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3665]!, self._r[3665]!, [_1, _2]) } - public var Stats_GroupMembers: String { return self._s[3664]! } - public var Camera_Retake: String { return self._s[3665]! } - public var Conversation_SearchPlaceholder: String { return self._s[3667]! } + public var Stats_GroupMembers: String { return self._s[3666]! } + public var Camera_Retake: String { return self._s[3667]! } + public var Conversation_SearchPlaceholder: String { return self._s[3669]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3668]!, self._r[3668]!, [_0]) + return formatWithArgumentRanges(self._s[3670]!, self._r[3670]!, [_0]) } - public var Channel_DiscussionGroup_Info: String { return self._s[3669]! } - public var SocksProxySetup_Hostname: String { return self._s[3670]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3671]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3672]! } - public var Privacy_DeleteDrafts: String { return self._s[3673]! } + public var Channel_DiscussionGroup_Info: String { return self._s[3671]! } + public var SocksProxySetup_Hostname: String { return self._s[3672]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3673]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3674]! } + public var Privacy_DeleteDrafts: String { return self._s[3675]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3674]!, self._r[3674]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3676]!, self._r[3676]!, [_1, _1, _1, _2]) } - public var Wallet_RestoreFailed_Text: String { return self._s[3675]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[3676]! } - public var Login_CancelPhoneVerification: String { return self._s[3677]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3679]! } + public var Wallet_RestoreFailed_Text: String { return self._s[3677]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[3678]! } + public var Login_CancelPhoneVerification: String { return self._s[3679]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3681]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3680]!, self._r[3680]!, [_0]) + return formatWithArgumentRanges(self._s[3682]!, self._r[3682]!, [_0]) } - public var TwoStepAuth_EmailSent: String { return self._s[3681]! } - public var Cache_Indexing: String { return self._s[3682]! } - public var Notifications_ExceptionsNone: String { return self._s[3683]! } - public var MessagePoll_LabelQuiz: String { return self._s[3684]! } - public var Call_EncryptionKey_Title: String { return self._s[3685]! } - public var Common_Yes: String { return self._s[3686]! } - public var Channel_ErrorAddBlocked: String { return self._s[3687]! } - public var Month_GenJanuary: String { return self._s[3688]! } - public var Checkout_NewCard_Title: String { return self._s[3689]! } - public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[3690]! } + public var TwoStepAuth_EmailSent: String { return self._s[3683]! } + public var Cache_Indexing: String { return self._s[3684]! } + public var Notifications_ExceptionsNone: String { return self._s[3685]! } + public var MessagePoll_LabelQuiz: String { return self._s[3686]! } + public var Call_EncryptionKey_Title: String { return self._s[3687]! } + public var Common_Yes: String { return self._s[3688]! } + public var Channel_ErrorAddBlocked: String { return self._s[3689]! } + public var Month_GenJanuary: String { return self._s[3690]! } + public var Checkout_NewCard_Title: String { return self._s[3691]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[3692]! } public func TwoStepAuth_EnterPasswordHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3691]!, self._r[3691]!, [_0]) + return formatWithArgumentRanges(self._s[3693]!, self._r[3693]!, [_0]) } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3693]! } - public var Conversation_SendDice: String { return self._s[3694]! } - public var Conversation_InputTextPlaceholderReply: String { return self._s[3695]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3695]! } + public var Conversation_SendDice: String { return self._s[3696]! } + public var Conversation_InputTextPlaceholderReply: String { return self._s[3697]! } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3696]!, self._r[3696]!, [_0]) + return formatWithArgumentRanges(self._s[3698]!, self._r[3698]!, [_0]) } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3697]!, self._r[3697]!, [_0]) + return formatWithArgumentRanges(self._s[3699]!, self._r[3699]!, [_0]) } - public var Weekday_Wednesday: String { return self._s[3698]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[3699]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[3700]! } - public var PrivacyLastSeenSettings_CustomShareSettingsHelp: String { return self._s[3701]! } - public var OldChannels_NoticeTitle: String { return self._s[3702]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[3703]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[3704]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[3705]! } - public var Passport_Address_AddUtilityBill: String { return self._s[3706]! } + public var Weekday_Wednesday: String { return self._s[3700]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[3701]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[3702]! } + public var PrivacyLastSeenSettings_CustomShareSettingsHelp: String { return self._s[3703]! } + public var OldChannels_NoticeTitle: String { return self._s[3704]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[3705]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[3706]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[3707]! } + public var Passport_Address_AddUtilityBill: String { return self._s[3708]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3708]!, self._r[3708]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3710]!, self._r[3710]!, [_1, _2, _3]) } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[3710]! } - public var Stats_GroupTopAdminsTitle: String { return self._s[3711]! } - public var Paint_Regular: String { return self._s[3712]! } - public var Message_Contact: String { return self._s[3713]! } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[3714]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[3715]! } - public var Notification_Mute1hMin: String { return self._s[3716]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[3712]! } + public var Stats_GroupTopAdminsTitle: String { return self._s[3713]! } + public var Paint_Regular: String { return self._s[3714]! } + public var Message_Contact: String { return self._s[3715]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[3716]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[3717]! } + public var Notification_Mute1hMin: String { return self._s[3718]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3717]!, self._r[3717]!, [_0]) + return formatWithArgumentRanges(self._s[3719]!, self._r[3719]!, [_0]) } - public var Profile_MessageLifetime1h: String { return self._s[3718]! } - public var TwoStepAuth_GenericHelp: String { return self._s[3719]! } - public var TextFormat_Monospace: String { return self._s[3720]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[3722]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3723]! } - public var ChatList_DeleteChat: String { return self._s[3724]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[3727]! } + public var Profile_MessageLifetime1h: String { return self._s[3720]! } + public var TwoStepAuth_GenericHelp: String { return self._s[3721]! } + public var TextFormat_Monospace: String { return self._s[3722]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[3724]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3725]! } + public var ChatList_DeleteChat: String { return self._s[3726]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[3729]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3728]!, self._r[3728]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[3730]!, self._r[3730]!, [_1, _2, _3, _4]) } - public var Login_CancelPhoneVerificationStop: String { return self._s[3729]! } - public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[3730]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[3731]! } - public var Wallet_Settings_Configuration: String { return self._s[3732]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[3733]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[3731]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[3732]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[3733]! } + public var Wallet_Settings_Configuration: String { return self._s[3734]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[3735]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3734]!, self._r[3734]!, [_0]) + return formatWithArgumentRanges(self._s[3736]!, self._r[3736]!, [_0]) } - public var Wallet_Sent_ViewWallet: String { return self._s[3735]! } - public var StickerPack_ViewPack: String { return self._s[3738]! } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[3740]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[3741]! } - public var Notifications_Title: String { return self._s[3742]! } - public var Wallet_WordImport_Continue: String { return self._s[3743]! } - public var GroupInfo_PublicLink: String { return self._s[3744]! } - public var Conversation_InputTextPlaceholderComment: String { return self._s[3745]! } - public var VoiceOver_DiscardPreparedContent: String { return self._s[3746]! } - public var Conversation_Moderate_Ban: String { return self._s[3750]! } + public var Wallet_Sent_ViewWallet: String { return self._s[3737]! } + public var StickerPack_ViewPack: String { return self._s[3740]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[3742]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[3743]! } + public var Notifications_Title: String { return self._s[3744]! } + public var Wallet_WordImport_Continue: String { return self._s[3745]! } + public var GroupInfo_PublicLink: String { return self._s[3746]! } + public var Conversation_InputTextPlaceholderComment: String { return self._s[3747]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[3748]! } + public var Conversation_Moderate_Ban: String { return self._s[3752]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3751]!, self._r[3751]!, [_0]) + return formatWithArgumentRanges(self._s[3753]!, self._r[3753]!, [_0]) } - public var TextFormat_Underline: String { return self._s[3752]! } + public var TextFormat_Underline: String { return self._s[3754]! } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3753]!, self._r[3753]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3755]!, self._r[3755]!, [_0, _1]) } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3754]!, self._r[3754]!, [_1]) + return formatWithArgumentRanges(self._s[3756]!, self._r[3756]!, [_1]) } - public var PollResults_Collapse: String { return self._s[3756]! } - public var Contacts_GlobalSearch: String { return self._s[3757]! } + public var PollResults_Collapse: String { return self._s[3758]! } + public var Contacts_GlobalSearch: String { return self._s[3759]! } public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3758]!, self._r[3758]!, [_0]) + return formatWithArgumentRanges(self._s[3760]!, self._r[3760]!, [_0]) } - public var Channel_Management_LabelEditor: String { return self._s[3759]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[3761]! } - public var Conversation_Theme: String { return self._s[3762]! } + public var Channel_Management_LabelEditor: String { return self._s[3761]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[3763]! } + public var Conversation_Theme: String { return self._s[3764]! } public func PUSH_CHANNEL_MESSAGE_DOCS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3763]!, self._r[3763]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3765]!, self._r[3765]!, [_1, "\(_2)"]) } - public var Conversation_LinkDialogSave: String { return self._s[3764]! } - public var EnterPasscode_TouchId: String { return self._s[3765]! } - public var Stats_MessageOverview: String { return self._s[3766]! } - public var Privacy_Calls_P2PAlways: String { return self._s[3768]! } - public var Message_Sticker: String { return self._s[3769]! } - public var Conversation_Mute: String { return self._s[3771]! } - public var ContactInfo_Title: String { return self._s[3772]! } + public var Conversation_LinkDialogSave: String { return self._s[3766]! } + public var EnterPasscode_TouchId: String { return self._s[3767]! } + public var Stats_MessageOverview: String { return self._s[3768]! } + public var Privacy_Calls_P2PAlways: String { return self._s[3770]! } + public var Message_Sticker: String { return self._s[3771]! } + public var Conversation_Mute: String { return self._s[3773]! } + public var ContactInfo_Title: String { return self._s[3774]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3773]!, self._r[3773]!, [_1]) + return formatWithArgumentRanges(self._s[3775]!, self._r[3775]!, [_1]) } - public var Channel_Setup_TypeHeader: String { return self._s[3774]! } - public var AuthSessions_LogOut: String { return self._s[3775]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3776]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3777]! } - public var ChatListFolderSettings_NewFolder: String { return self._s[3779]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3780]! } - public var CreatePoll_Title: String { return self._s[3781]! } - public var EditTheme_EditTitle: String { return self._s[3782]! } - public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[3783]! } - public var TwoStepAuth_SetPassword: String { return self._s[3784]! } - public var Wallet_Words_Done: String { return self._s[3785]! } + public var Channel_Setup_TypeHeader: String { return self._s[3776]! } + public var AuthSessions_LogOut: String { return self._s[3777]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3778]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3779]! } + public var ChatListFolderSettings_NewFolder: String { return self._s[3781]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3782]! } + public var CreatePoll_Title: String { return self._s[3783]! } + public var EditTheme_EditTitle: String { return self._s[3784]! } + public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[3785]! } + public var TwoStepAuth_SetPassword: String { return self._s[3786]! } + public var Wallet_Words_Done: String { return self._s[3787]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3786]!, self._r[3786]!, [_0]) + return formatWithArgumentRanges(self._s[3788]!, self._r[3788]!, [_0]) } - public var BlockedUsers_Info: String { return self._s[3787]! } - public var AuthSessions_Sessions: String { return self._s[3788]! } - public var Group_EditAdmin_RankTitle: String { return self._s[3789]! } + public var BlockedUsers_Info: String { return self._s[3789]! } + public var AuthSessions_Sessions: String { return self._s[3790]! } + public var Group_EditAdmin_RankTitle: String { return self._s[3791]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3790]!, self._r[3790]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3792]!, self._r[3792]!, [_1, _2, _3]) } - public var Common_ActionNotAllowedError: String { return self._s[3791]! } - public var WebPreview_GettingLinkInfo: String { return self._s[3792]! } - public var Appearance_AppIconFilledX: String { return self._s[3793]! } - public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[3794]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[3795]! } - public var FeaturedStickers_OtherSection: String { return self._s[3796]! } - public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[3797]! } - public var Profile_Username: String { return self._s[3798]! } - public var Appearance_RemoveTheme: String { return self._s[3799]! } - public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[3800]! } - public var Message_PinnedStickerMessage: String { return self._s[3801]! } - public var AccessDenied_VideoMicrophone: String { return self._s[3802]! } - public var WallpaperPreview_CustomColorBottomText: String { return self._s[3803]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3804]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[3805]! } - public var TwoStepAuth_Title: String { return self._s[3806]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3807]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[3808]! } - public var ChatListFolder_CategoryGroups: String { return self._s[3810]! } - public var Stats_GroupTopInviter_Promote: String { return self._s[3811]! } - public var Month_GenJuly: String { return self._s[3812]! } - public var Passport_Identity_Gender: String { return self._s[3813]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3814]! } - public var Notification_Exceptions_DeleteAll: String { return self._s[3815]! } + public var Common_ActionNotAllowedError: String { return self._s[3793]! } + public var WebPreview_GettingLinkInfo: String { return self._s[3794]! } + public var Appearance_AppIconFilledX: String { return self._s[3795]! } + public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[3796]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[3797]! } + public var FeaturedStickers_OtherSection: String { return self._s[3798]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[3799]! } + public var Profile_Username: String { return self._s[3800]! } + public var Appearance_RemoveTheme: String { return self._s[3801]! } + public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[3802]! } + public var Message_PinnedStickerMessage: String { return self._s[3803]! } + public var AccessDenied_VideoMicrophone: String { return self._s[3804]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[3805]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3806]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[3807]! } + public var TwoStepAuth_Title: String { return self._s[3808]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3809]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[3810]! } + public var ChatListFolder_CategoryGroups: String { return self._s[3812]! } + public var Stats_GroupTopInviter_Promote: String { return self._s[3813]! } + public var Month_GenJuly: String { return self._s[3814]! } + public var Passport_Identity_Gender: String { return self._s[3815]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3816]! } + public var Notification_Exceptions_DeleteAll: String { return self._s[3817]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3816]!, self._r[3816]!, [_0]) + return formatWithArgumentRanges(self._s[3818]!, self._r[3818]!, [_0]) } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3817]!, self._r[3817]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[3819]!, self._r[3819]!, [_0, _1, _2]) } - public var Login_CodeSentSms: String { return self._s[3818]! } + public var Login_CodeSentSms: String { return self._s[3820]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3820]!, self._r[3820]!, [_0]) + return formatWithArgumentRanges(self._s[3822]!, self._r[3822]!, [_0]) } - public var Login_CallRequestState2: String { return self._s[3821]! } - public var Channel_DiscussionGroup_Header: String { return self._s[3822]! } + public var Login_CallRequestState2: String { return self._s[3823]! } + public var Channel_DiscussionGroup_Header: String { return self._s[3824]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3823]!, self._r[3823]!, [_0]) + return formatWithArgumentRanges(self._s[3825]!, self._r[3825]!, [_0]) } - public var Passport_Language_ms: String { return self._s[3824]! } - public var PeopleNearby_MakeInvisible: String { return self._s[3826]! } - public var ChatList_Search_FilterVoice: String { return self._s[3828]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3830]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3831]! } + public var Passport_Language_ms: String { return self._s[3826]! } + public var PeopleNearby_MakeInvisible: String { return self._s[3828]! } + public var ChatList_Search_FilterVoice: String { return self._s[3830]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3832]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3833]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3832]!, self._r[3832]!, [_0]) + return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_0]) } public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3833]!, self._r[3833]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3835]!, self._r[3835]!, [_1, _2, _3]) } - public var Wallet_Info_TransactionTo: String { return self._s[3834]! } - public var Map_Locating: String { return self._s[3835]! } + public var Wallet_Info_TransactionTo: String { return self._s[3836]! } + public var Map_Locating: String { return self._s[3837]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3837]!, self._r[3837]!, [_0]) + return formatWithArgumentRanges(self._s[3839]!, self._r[3839]!, [_0]) } - public var Passport_Identity_TypeInternalPassport: String { return self._s[3839]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3840]! } - public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[3841]! } - public var Stickers_Installed: String { return self._s[3842]! } - public var Notifications_PermissionsAllowInSettings: String { return self._s[3843]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3844]! } - public var CallSettings_Never: String { return self._s[3846]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3847]! } - public var Channel_Setup_TypePublicHelp: String { return self._s[3848]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[3841]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3842]! } + public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[3843]! } + public var Stickers_Installed: String { return self._s[3844]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[3845]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3846]! } + public var CallSettings_Never: String { return self._s[3848]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3849]! } + public var Channel_Setup_TypePublicHelp: String { return self._s[3850]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3850]!, self._r[3850]!, [_0]) + return formatWithArgumentRanges(self._s[3852]!, self._r[3852]!, [_0]) } - public var Message_Game: String { return self._s[3851]! } - public var Call_Message: String { return self._s[3852]! } + public var Message_Game: String { return self._s[3853]! } + public var Call_Message: String { return self._s[3854]! } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3853]!, self._r[3853]!, [_1]) + return formatWithArgumentRanges(self._s[3855]!, self._r[3855]!, [_1]) } - public var ChannelIntro_Text: String { return self._s[3854]! } - public var StickerPack_Send: String { return self._s[3855]! } - public var Share_AuthDescription: String { return self._s[3856]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[3857]! } - public var CallFeedback_WhatWentWrong: String { return self._s[3858]! } - public var Common_Create: String { return self._s[3861]! } - public var Passport_Language_hy: String { return self._s[3862]! } - public var CreatePoll_Explanation: String { return self._s[3863]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[3864]! } - public var Undo_ChatClearedForBothSides: String { return self._s[3865]! } - public var DialogList_NoMessagesTitle: String { return self._s[3866]! } - public var GroupInfo_Title: String { return self._s[3868]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[3869]! } - public var PhoneNumberHelp_Help: String { return self._s[3870]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[3871]! } - public var Settings_Logout: String { return self._s[3872]! } - public var Privacy_PaymentsTitle: String { return self._s[3873]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[3874]! } - public var Tour_Text6: String { return self._s[3875]! } - public var Channel_Username_Help: String { return self._s[3877]! } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[3878]! } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[3879]! } - public var AttachmentMenu_Poll: String { return self._s[3880]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[3881]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[3882]! } - public var Passport_DeletePassport: String { return self._s[3883]! } - public var Login_Code: String { return self._s[3884]! } - public var Notification_SecretChatScreenshot: String { return self._s[3885]! } - public var Login_CodeFloodError: String { return self._s[3886]! } + public var ChannelIntro_Text: String { return self._s[3856]! } + public var StickerPack_Send: String { return self._s[3857]! } + public var Share_AuthDescription: String { return self._s[3858]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[3859]! } + public var CallFeedback_WhatWentWrong: String { return self._s[3860]! } + public var Common_Create: String { return self._s[3863]! } + public var Passport_Language_hy: String { return self._s[3864]! } + public var CreatePoll_Explanation: String { return self._s[3865]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[3866]! } + public var Undo_ChatClearedForBothSides: String { return self._s[3867]! } + public var DialogList_NoMessagesTitle: String { return self._s[3868]! } + public var GroupInfo_Title: String { return self._s[3870]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[3871]! } + public var PhoneNumberHelp_Help: String { return self._s[3872]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[3873]! } + public var Settings_Logout: String { return self._s[3874]! } + public var Privacy_PaymentsTitle: String { return self._s[3875]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[3876]! } + public var Tour_Text6: String { return self._s[3877]! } + public var Channel_Username_Help: String { return self._s[3879]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[3880]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[3881]! } + public var AttachmentMenu_Poll: String { return self._s[3882]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[3883]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[3884]! } + public var Passport_DeletePassport: String { return self._s[3885]! } + public var Login_Code: String { return self._s[3886]! } + public var Notification_SecretChatScreenshot: String { return self._s[3887]! } + public var Login_CodeFloodError: String { return self._s[3888]! } public func Notification_PinnedAnimationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3887]!, self._r[3887]!, [_0]) + return formatWithArgumentRanges(self._s[3889]!, self._r[3889]!, [_0]) } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3888]!, self._r[3888]!, [_0]) + return formatWithArgumentRanges(self._s[3890]!, self._r[3890]!, [_0]) } - public var Watch_Stickers_Recents: String { return self._s[3889]! } - public var Generic_ErrorMoreInfo: String { return self._s[3890]! } + public var Watch_Stickers_Recents: String { return self._s[3891]! } + public var Generic_ErrorMoreInfo: String { return self._s[3892]! } public func Call_AccountIsLoggedOnCurrentDevice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3891]!, self._r[3891]!, [_0]) + return formatWithArgumentRanges(self._s[3893]!, self._r[3893]!, [_0]) } - public var AutoDownloadSettings_DataUsage: String { return self._s[3892]! } - public var Conversation_ViewTheme: String { return self._s[3893]! } - public var Contacts_InviteSearchLabel: String { return self._s[3894]! } - public var Settings_CancelUpload: String { return self._s[3896]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[3897]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[3894]! } + public var Conversation_ViewTheme: String { return self._s[3895]! } + public var Contacts_InviteSearchLabel: String { return self._s[3896]! } + public var Settings_CancelUpload: String { return self._s[3898]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[3899]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3898]!, self._r[3898]!, [_0]) + return formatWithArgumentRanges(self._s[3900]!, self._r[3900]!, [_0]) } - public var ChatList_AddFolder: String { return self._s[3899]! } - public var Conversation_Location: String { return self._s[3901]! } - public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[3902]! } - public var DialogList_AdLabel: String { return self._s[3903]! } + public var ChatList_AddFolder: String { return self._s[3901]! } + public var Conversation_Location: String { return self._s[3903]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[3904]! } + public var DialogList_AdLabel: String { return self._s[3905]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3905]!, self._r[3905]!, [_0]) + return formatWithArgumentRanges(self._s[3907]!, self._r[3907]!, [_0]) } - public var Message_InvoiceLabel: String { return self._s[3906]! } - public var Channel_TooMuchBots: String { return self._s[3907]! } + public var Message_InvoiceLabel: String { return self._s[3908]! } + public var Channel_TooMuchBots: String { return self._s[3909]! } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3908]!, self._r[3908]!, [_0]) + return formatWithArgumentRanges(self._s[3910]!, self._r[3910]!, [_0]) } - public var Wallet_Month_ShortAugust: String { return self._s[3909]! } - public var Call_IncomingVideoCall: String { return self._s[3910]! } - public var Conversation_LiveLocation: String { return self._s[3911]! } - public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[3912]! } - public var Passport_Identity_EditPassport: String { return self._s[3913]! } - public var Permissions_CellularDataTitle_v0: String { return self._s[3915]! } - public var ChatList_Search_NoResultsFitlerVoice: String { return self._s[3916]! } - public var GroupInfo_Permissions_AddException: String { return self._s[3917]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[3919]! } - public var Channel_MessageVideoUpdated: String { return self._s[3920]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[3921]! } - public var AccessDenied_Camera: String { return self._s[3924]! } + public var Wallet_Month_ShortAugust: String { return self._s[3911]! } + public var Call_IncomingVideoCall: String { return self._s[3912]! } + public var Conversation_LiveLocation: String { return self._s[3913]! } + public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[3914]! } + public var Passport_Identity_EditPassport: String { return self._s[3915]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[3917]! } + public var ChatList_Search_NoResultsFitlerVoice: String { return self._s[3918]! } + public var GroupInfo_Permissions_AddException: String { return self._s[3919]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[3921]! } + public var Channel_MessageVideoUpdated: String { return self._s[3922]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[3923]! } + public var AccessDenied_Camera: String { return self._s[3926]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3925]!, self._r[3925]!, [_0]) + return formatWithArgumentRanges(self._s[3927]!, self._r[3927]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[3926]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[3927]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[3928]! } - public var Login_CodeExpiredError: String { return self._s[3929]! } - public var State_ConnectingToProxy: String { return self._s[3930]! } - public var TextFormat_Link: String { return self._s[3931]! } - public var Passport_Language_lv: String { return self._s[3932]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3933]! } - public var WallpaperPreview_SwipeBottomText: String { return self._s[3934]! } - public var ProfilePhoto_SetMainVideo: String { return self._s[3935]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3937]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[3938]! } + public var Theme_Context_ChangeColors: String { return self._s[3928]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[3929]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[3930]! } + public var Login_CodeExpiredError: String { return self._s[3931]! } + public var State_ConnectingToProxy: String { return self._s[3932]! } + public var TextFormat_Link: String { return self._s[3933]! } + public var Passport_Language_lv: String { return self._s[3934]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3935]! } + public var WallpaperPreview_SwipeBottomText: String { return self._s[3936]! } + public var ProfilePhoto_SetMainVideo: String { return self._s[3937]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3939]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[3940]! } public func Channel_AdminLog_MessageKickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3939]!, self._r[3939]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3941]!, self._r[3941]!, [_1, _2]) } - public var ChatList_EmptyChatListFilterTitle: String { return self._s[3940]! } - public var Checkout_PayNone: String { return self._s[3941]! } - public var NotificationsSound_Complete: String { return self._s[3943]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[3944]! } - public var AuthSessions_DevicesTitle: String { return self._s[3945]! } + public var ChatList_EmptyChatListFilterTitle: String { return self._s[3942]! } + public var Checkout_PayNone: String { return self._s[3943]! } + public var NotificationsSound_Complete: String { return self._s[3945]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[3946]! } + public var AuthSessions_DevicesTitle: String { return self._s[3947]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3946]!, self._r[3946]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3948]!, self._r[3948]!, [_0, _1]) } - public var Message_LiveLocation: String { return self._s[3947]! } - public var Watch_Suggestion_BRB: String { return self._s[3948]! } - public var Channel_BanUser_Title: String { return self._s[3949]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3950]! } - public var Conversation_Dice_u1F3C0: String { return self._s[3951]! } - public var Conversation_ClearSelfHistory: String { return self._s[3952]! } - public var ProfilePhoto_OpenGallery: String { return self._s[3953]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[3954]! } - public var Weekday_Thursday: String { return self._s[3955]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[3956]! } - public var Privacy_ProfilePhoto: String { return self._s[3958]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[3959]! } + public var Message_LiveLocation: String { return self._s[3949]! } + public var Watch_Suggestion_BRB: String { return self._s[3950]! } + public var Channel_BanUser_Title: String { return self._s[3951]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3952]! } + public var Conversation_Dice_u1F3C0: String { return self._s[3953]! } + public var Conversation_ClearSelfHistory: String { return self._s[3954]! } + public var ProfilePhoto_OpenGallery: String { return self._s[3955]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[3956]! } + public var Weekday_Thursday: String { return self._s[3957]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[3958]! } + public var Privacy_ProfilePhoto: String { return self._s[3960]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[3961]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3960]!, self._r[3960]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3962]!, self._r[3962]!, [_1, _2]) } - public var Message_Audio: String { return self._s[3961]! } - public var Conversation_Info: String { return self._s[3962]! } - public var Cache_Videos: String { return self._s[3963]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3964]! } - public var Channel_ErrorAddTooMuch: String { return self._s[3965]! } + public var Message_Audio: String { return self._s[3963]! } + public var Conversation_Info: String { return self._s[3964]! } + public var Cache_Videos: String { return self._s[3965]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3966]! } + public var Channel_ErrorAddTooMuch: String { return self._s[3967]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3966]!, self._r[3966]!, [_0]) + return formatWithArgumentRanges(self._s[3968]!, self._r[3968]!, [_0]) } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[3968]! } - public var ScheduledMessages_Title: String { return self._s[3970]! } - public var ShareFileTip_Title: String { return self._s[3973]! } - public var Chat_Gifs_TrendingSectionHeader: String { return self._s[3974]! } - public var ChatList_RemoveFolderConfirmation: String { return self._s[3975]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[3970]! } + public var ScheduledMessages_Title: String { return self._s[3972]! } + public var ShareFileTip_Title: String { return self._s[3975]! } + public var Chat_Gifs_TrendingSectionHeader: String { return self._s[3976]! } + public var ChatList_RemoveFolderConfirmation: String { return self._s[3977]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3976]!, self._r[3976]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3978]!, self._r[3978]!, [_1, _2]) } - public var Conversation_ContextViewStats: String { return self._s[3978]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3979]! } - public var PasscodeSettings_Title: String { return self._s[3980]! } - public var Channel_AdminLog_SendPolls: String { return self._s[3981]! } - public var LastSeen_ALongTimeAgo: String { return self._s[3982]! } + public var Conversation_ContextViewStats: String { return self._s[3980]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3981]! } + public var PasscodeSettings_Title: String { return self._s[3982]! } + public var Channel_AdminLog_SendPolls: String { return self._s[3983]! } + public var LastSeen_ALongTimeAgo: String { return self._s[3984]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3983]!, self._r[3983]!, [_1]) + return formatWithArgumentRanges(self._s[3985]!, self._r[3985]!, [_1]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3984]! } - public var CallFeedback_VideoReasonLowQuality: String { return self._s[3985]! } - public var Conversation_PinnedPreviousMessage: String { return self._s[3986]! } - public var SocksProxySetup_AddProxyTitle: String { return self._s[3987]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[3988]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3986]! } + public var CallFeedback_VideoReasonLowQuality: String { return self._s[3987]! } + public var Conversation_PinnedPreviousMessage: String { return self._s[3988]! } + public var SocksProxySetup_AddProxyTitle: String { return self._s[3989]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[3990]! } public func ChatList_RemovedFromFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3989]!, self._r[3989]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3991]!, self._r[3991]!, [_1, _2]) } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3990]!, self._r[3990]!, [_0]) + return formatWithArgumentRanges(self._s[3992]!, self._r[3992]!, [_0]) } - public var Passport_Identity_GenderFemale: String { return self._s[3991]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3994]! } - public var Location_ProximityNotification_DistanceKM: String { return self._s[3995]! } - public var SharedMedia_TitleAll: String { return self._s[3996]! } - public var Settings_Context_Logout: String { return self._s[3997]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[3999]! } - public var Settings_About_Title: String { return self._s[4000]! } - public var StickerSettings_ContextHide: String { return self._s[4001]! } + public var Passport_Identity_GenderFemale: String { return self._s[3993]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3996]! } + public var Location_ProximityNotification_DistanceKM: String { return self._s[3997]! } + public var SharedMedia_TitleAll: String { return self._s[3998]! } + public var Settings_Context_Logout: String { return self._s[3999]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[4001]! } + public var Settings_About_Title: String { return self._s[4002]! } + public var StickerSettings_ContextHide: String { return self._s[4003]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4002]!, self._r[4002]!, [_0]) + return formatWithArgumentRanges(self._s[4004]!, self._r[4004]!, [_0]) } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4003]!, self._r[4003]!, [_0]) + return formatWithArgumentRanges(self._s[4005]!, self._r[4005]!, [_0]) } - public var Common_Cancel: String { return self._s[4005]! } - public var CallFeedback_Title: String { return self._s[4007]! } + public var Common_Cancel: String { return self._s[4007]! } + public var CallFeedback_Title: String { return self._s[4009]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4008]!, self._r[4008]!, [_0]) + return formatWithArgumentRanges(self._s[4010]!, self._r[4010]!, [_0]) } - public var Activity_UploadingVideoMessage: String { return self._s[4009]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[4010]! } - public var MediaPicker_Send: String { return self._s[4011]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[4012]! } - public var Conversation_LiveLocationYou: String { return self._s[4013]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[4014]! } + public var Activity_UploadingVideoMessage: String { return self._s[4011]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[4012]! } + public var MediaPicker_Send: String { return self._s[4013]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[4014]! } + public var Conversation_LiveLocationYou: String { return self._s[4015]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[4016]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4015]!, self._r[4015]!, [_0]) + return formatWithArgumentRanges(self._s[4017]!, self._r[4017]!, [_0]) } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4016]!, self._r[4016]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4018]!, self._r[4018]!, [_1, _2]) } - public var Conversation_ViewBackground: String { return self._s[4017]! } - public var ChatSettings_PrivateChats: String { return self._s[4020]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[4021]! } - public var Wallet_Receive_AmountInfo: String { return self._s[4022]! } - public var Appearance_ThemeNight: String { return self._s[4023]! } - public var Common_Search: String { return self._s[4024]! } - public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[4025]! } - public var ChangePhoneNumberNumber_Help: String { return self._s[4027]! } - public var Stickers_SuggestAdded: String { return self._s[4028]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[4031]! } - public var NetworkUsageSettings_Cellular: String { return self._s[4032]! } - public var CheckoutInfo_Title: String { return self._s[4033]! } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[4034]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[4035]! } + public var Conversation_ViewBackground: String { return self._s[4019]! } + public var ChatSettings_PrivateChats: String { return self._s[4022]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[4023]! } + public var Wallet_Receive_AmountInfo: String { return self._s[4024]! } + public var Appearance_ThemeNight: String { return self._s[4025]! } + public var Common_Search: String { return self._s[4026]! } + public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[4027]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[4029]! } + public var Stickers_SuggestAdded: String { return self._s[4030]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[4033]! } + public var NetworkUsageSettings_Cellular: String { return self._s[4034]! } + public var CheckoutInfo_Title: String { return self._s[4035]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[4036]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[4037]! } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4036]!, self._r[4036]!, [_0]) + return formatWithArgumentRanges(self._s[4038]!, self._r[4038]!, [_0]) } - public var MaskStickerSettings_Info: String { return self._s[4037]! } - public var GroupRemoved_DeleteUser: String { return self._s[4038]! } - public var Contacts_ShareTelegram: String { return self._s[4039]! } - public var Group_UpgradeNoticeText1: String { return self._s[4040]! } + public var MaskStickerSettings_Info: String { return self._s[4039]! } + public var GroupRemoved_DeleteUser: String { return self._s[4040]! } + public var Contacts_ShareTelegram: String { return self._s[4041]! } + public var Group_UpgradeNoticeText1: String { return self._s[4042]! } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4041]!, self._r[4041]!, [_1]) + return formatWithArgumentRanges(self._s[4043]!, self._r[4043]!, [_1]) } - public var PrivacyLastSeenSettings_Title: String { return self._s[4042]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[4046]! } - public var PhotoEditor_TintTool: String { return self._s[4047]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[4049]! } - public var GroupPermission_NoSendPolls: String { return self._s[4050]! } - public var NotificationsSound_None: String { return self._s[4051]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[4044]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[4048]! } + public var PhotoEditor_TintTool: String { return self._s[4049]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[4051]! } + public var GroupPermission_NoSendPolls: String { return self._s[4052]! } + public var NotificationsSound_None: String { return self._s[4053]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4052]!, self._r[4052]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[4054]!, self._r[4054]!, [_1, "\(_2)"]) } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[4054]! } - public var ExplicitContent_AlertChannel: String { return self._s[4056]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[4057]! } - public var Contacts_SortedByPresence: String { return self._s[4058]! } - public var WallpaperSearch_ColorGray: String { return self._s[4059]! } - public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[4060]! } - public var Conversation_ReportSpam: String { return self._s[4061]! } - public var ChatList_Search_NoResultsFilter: String { return self._s[4064]! } - public var WallpaperSearch_ColorBlack: String { return self._s[4065]! } - public var ArchivedChats_IntroTitle3: String { return self._s[4066]! } - public var Conversation_DefaultRestrictedText: String { return self._s[4067]! } - public var Settings_Devices: String { return self._s[4068]! } - public var Call_AudioRouteSpeaker: String { return self._s[4069]! } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[4070]! } - public var Passport_Address_Country: String { return self._s[4072]! } - public var Cache_MaximumCacheSize: String { return self._s[4073]! } - public var Chat_PanelHidePinnedMessages: String { return self._s[4074]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[4075]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[4077]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[4078]! } - public var Login_TermsOfServiceLabel: String { return self._s[4079]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[4080]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[4081]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[4082]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[4083]! } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[4084]! } - public var ConvertToSupergroup_Note: String { return self._s[4086]! } - public var Settings_SetNewProfilePhotoOrVideo: String { return self._s[4087]! } - public var PrivacySettings_PasscodeAndTouchId: String { return self._s[4088]! } - public var Common_More: String { return self._s[4089]! } - public var ShareMenu_SelectChats: String { return self._s[4091]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[4056]! } + public var ExplicitContent_AlertChannel: String { return self._s[4058]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[4059]! } + public var Contacts_SortedByPresence: String { return self._s[4060]! } + public var WallpaperSearch_ColorGray: String { return self._s[4061]! } + public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[4062]! } + public var Conversation_ReportSpam: String { return self._s[4063]! } + public var ChatList_Search_NoResultsFilter: String { return self._s[4066]! } + public var WallpaperSearch_ColorBlack: String { return self._s[4067]! } + public var ArchivedChats_IntroTitle3: String { return self._s[4068]! } + public var Conversation_DefaultRestrictedText: String { return self._s[4069]! } + public var Settings_Devices: String { return self._s[4070]! } + public var Call_AudioRouteSpeaker: String { return self._s[4071]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[4072]! } + public var Passport_Address_Country: String { return self._s[4074]! } + public var Cache_MaximumCacheSize: String { return self._s[4075]! } + public var Chat_PanelHidePinnedMessages: String { return self._s[4076]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[4077]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[4079]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[4080]! } + public var Login_TermsOfServiceLabel: String { return self._s[4081]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[4082]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[4083]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[4084]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[4085]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[4086]! } + public var ConvertToSupergroup_Note: String { return self._s[4088]! } + public var Settings_SetNewProfilePhotoOrVideo: String { return self._s[4089]! } + public var PrivacySettings_PasscodeAndTouchId: String { return self._s[4090]! } + public var Common_More: String { return self._s[4091]! } + public var ShareMenu_SelectChats: String { return self._s[4093]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4093]!, self._r[4093]!, [_0]) + return formatWithArgumentRanges(self._s[4095]!, self._r[4095]!, [_0]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4094]!, self._r[4094]!, [_0]) + return formatWithArgumentRanges(self._s[4096]!, self._r[4096]!, [_0]) } - public var Contacts_PermissionsKeepDisabled: String { return self._s[4096]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[4098]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4097]!, self._r[4097]!, [_0]) + return formatWithArgumentRanges(self._s[4099]!, self._r[4099]!, [_0]) } - public var WatchRemote_AlertOpen: String { return self._s[4098]! } + public var WatchRemote_AlertOpen: String { return self._s[4100]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4099]!, self._r[4099]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4101]!, self._r[4101]!, [_1, _2, _3]) } - public var Channel_Members_AddMembersHelp: String { return self._s[4100]! } - public var Shortcut_SwitchAccount: String { return self._s[4101]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4102]! } + public var Channel_Members_AddMembersHelp: String { return self._s[4102]! } + public var Shortcut_SwitchAccount: String { return self._s[4103]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4104]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4103]!, self._r[4103]!, [_0]) + return formatWithArgumentRanges(self._s[4105]!, self._r[4105]!, [_0]) } - public var Compose_NewGroupTitle: String { return self._s[4104]! } - public var DialogList_You: String { return self._s[4105]! } - public var ReportPeer_ReasonViolence: String { return self._s[4106]! } + public var Compose_NewGroupTitle: String { return self._s[4106]! } + public var DialogList_You: String { return self._s[4107]! } + public var ReportPeer_ReasonViolence: String { return self._s[4108]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4107]!, self._r[4107]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4109]!, self._r[4109]!, [_1, _2]) } - public var KeyCommand_ScrollDown: String { return self._s[4111]! } - public var ChatSettings_DownloadInBackground: String { return self._s[4112]! } - public var Wallpaper_ResetWallpapers: String { return self._s[4113]! } - public var Channel_BanList_RestrictedTitle: String { return self._s[4114]! } - public var ArchivedChats_IntroText3: String { return self._s[4115]! } - public var HashtagSearch_AllChats: String { return self._s[4117]! } - public var Channel_Info_BlackList: String { return self._s[4119]! } - public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[4120]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[4121]! } - public var Paint_Neon: String { return self._s[4123]! } - public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[4124]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[4125]! } + public var KeyCommand_ScrollDown: String { return self._s[4113]! } + public var ChatSettings_DownloadInBackground: String { return self._s[4114]! } + public var Wallpaper_ResetWallpapers: String { return self._s[4115]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[4116]! } + public var ArchivedChats_IntroText3: String { return self._s[4117]! } + public var HashtagSearch_AllChats: String { return self._s[4119]! } + public var Channel_Info_BlackList: String { return self._s[4121]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[4122]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[4123]! } + public var Paint_Neon: String { return self._s[4125]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[4126]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[4127]! } public func Notification_PinnedVideoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4127]!, self._r[4127]!, [_0]) + return formatWithArgumentRanges(self._s[4129]!, self._r[4129]!, [_0]) } - public var Map_StopLiveLocation: String { return self._s[4128]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[4129]! } - public var Channel_Username_InvalidCharacters: String { return self._s[4130]! } - public var InstantPage_Reference: String { return self._s[4131]! } - public var ChatList_HideAction: String { return self._s[4133]! } - public var Conversation_FileICloudDrive: String { return self._s[4135]! } + public var Map_StopLiveLocation: String { return self._s[4130]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[4131]! } + public var Channel_Username_InvalidCharacters: String { return self._s[4132]! } + public var InstantPage_Reference: String { return self._s[4133]! } + public var ChatList_HideAction: String { return self._s[4135]! } + public var Conversation_FileICloudDrive: String { return self._s[4137]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4136]!, self._r[4136]!, [_1]) + return formatWithArgumentRanges(self._s[4138]!, self._r[4138]!, [_1]) } - public var Passport_PasswordReset: String { return self._s[4138]! } - public var ChatList_Context_UnhideArchive: String { return self._s[4140]! } - public var ConvertToSupergroup_HelpText: String { return self._s[4141]! } - public var Calls_AddTab: String { return self._s[4142]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[4143]! } - public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[4144]! } - public var Privacy_GroupsAndChannels: String { return self._s[4146]! } - public var AutoNightTheme_Disabled: String { return self._s[4147]! } - public var CreatePoll_MultipleChoice: String { return self._s[4148]! } + public var Passport_PasswordReset: String { return self._s[4140]! } + public var ChatList_Context_UnhideArchive: String { return self._s[4142]! } + public var ConvertToSupergroup_HelpText: String { return self._s[4143]! } + public var Calls_AddTab: String { return self._s[4144]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[4145]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[4146]! } + public var Privacy_GroupsAndChannels: String { return self._s[4148]! } + public var AutoNightTheme_Disabled: String { return self._s[4149]! } + public var CreatePoll_MultipleChoice: String { return self._s[4150]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4149]!, self._r[4149]!, [_1]) + return formatWithArgumentRanges(self._s[4151]!, self._r[4151]!, [_1]) } - public var Watch_Bot_Restart: String { return self._s[4151]! } + public var Watch_Bot_Restart: String { return self._s[4153]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4152]!, self._r[4152]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[4154]!, self._r[4154]!, ["\(_0)"]) } - public var GroupInfo_ScamGroupWarning: String { return self._s[4153]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[4154]! } - public var Appearance_PreviewIncomingText: String { return self._s[4155]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[4156]! } - public var ChatList_UndoArchiveRevealedTitle: String { return self._s[4158]! } - public var Stats_GroupOverview: String { return self._s[4160]! } - public var ScheduledMessages_EditTime: String { return self._s[4163]! } - public var Month_GenFebruary: String { return self._s[4164]! } - public var ChatList_AutoarchiveSuggestion_OpenSettings: String { return self._s[4165]! } - public var Stickers_ClearRecent: String { return self._s[4166]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[4167]! } - public var Stats_Message_PublicShares: String { return self._s[4168]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[4155]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[4156]! } + public var Appearance_PreviewIncomingText: String { return self._s[4157]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[4158]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[4160]! } + public var Stats_GroupOverview: String { return self._s[4162]! } + public var ScheduledMessages_EditTime: String { return self._s[4165]! } + public var Month_GenFebruary: String { return self._s[4166]! } + public var ChatList_AutoarchiveSuggestion_OpenSettings: String { return self._s[4167]! } + public var Stickers_ClearRecent: String { return self._s[4168]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[4169]! } + public var Stats_Message_PublicShares: String { return self._s[4170]! } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4169]!, self._r[4169]!, [_0]) + return formatWithArgumentRanges(self._s[4171]!, self._r[4171]!, [_0]) } - public var Login_TermsOfServiceSignupDecline: String { return self._s[4170]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[4171]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[4172]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[4173]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[4175]! } - public var CreatePoll_Create: String { return self._s[4176]! } - public var ChatList_Search_FilterLinks: String { return self._s[4177]! } - public var Your_cards_number_is_invalid: String { return self._s[4178]! } - public var Month_ShortApril: String { return self._s[4179]! } - public var SocksProxySetup_UseForCalls: String { return self._s[4180]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[4181]! } - public var SocksProxySetup_Status: String { return self._s[4182]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[4183]! } - public var ChatListFolder_CategoryBots: String { return self._s[4184]! } - public var Passport_FieldIdentitySelfieHelp: String { return self._s[4186]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[4187]! } - public var Chat_PinnedListPreview_UnpinAllMessages: String { return self._s[4188]! } - public var Wallpaper_ResetWallpapersInfo: String { return self._s[4189]! } - public var Conversation_TitleUnmute: String { return self._s[4190]! } - public var Group_Setup_TypeHeader: String { return self._s[4191]! } - public var Stats_ViewsPerPost: String { return self._s[4192]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[4193]! } - public var Passport_Identity_TranslationHelp: String { return self._s[4194]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[4172]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[4173]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[4174]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[4175]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[4177]! } + public var CreatePoll_Create: String { return self._s[4178]! } + public var ChatList_Search_FilterLinks: String { return self._s[4179]! } + public var Your_cards_number_is_invalid: String { return self._s[4180]! } + public var Month_ShortApril: String { return self._s[4181]! } + public var SocksProxySetup_UseForCalls: String { return self._s[4182]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[4183]! } + public var SocksProxySetup_Status: String { return self._s[4184]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[4185]! } + public var ChatListFolder_CategoryBots: String { return self._s[4186]! } + public var Passport_FieldIdentitySelfieHelp: String { return self._s[4188]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[4189]! } + public var Chat_PinnedListPreview_UnpinAllMessages: String { return self._s[4190]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[4191]! } + public var Conversation_TitleUnmute: String { return self._s[4192]! } + public var Group_Setup_TypeHeader: String { return self._s[4193]! } + public var Stats_ViewsPerPost: String { return self._s[4194]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[4195]! } + public var Passport_Identity_TranslationHelp: String { return self._s[4196]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4195]!, self._r[4195]!, [_1]) + return formatWithArgumentRanges(self._s[4197]!, self._r[4197]!, [_1]) } - public var GroupInfo_Administrators_Title: String { return self._s[4196]! } + public var GroupInfo_Administrators_Title: String { return self._s[4198]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4197]!, self._r[4197]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4199]!, self._r[4199]!, [_1, _2]) } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4198]!, self._r[4198]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4200]!, self._r[4200]!, [_1, _2, _3]) } - public var Wallet_Receive_Title: String { return self._s[4199]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[4200]! } - public var Passport_Language_my: String { return self._s[4202]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[4203]! } - public var Map_PlacesNearby: String { return self._s[4204]! } - public var Channel_About_Help: String { return self._s[4205]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[4206]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[4207]! } - public var Channel_Username_Title: String { return self._s[4208]! } - public var Activity_RecordingVideoMessage: String { return self._s[4209]! } + public var Wallet_Receive_Title: String { return self._s[4201]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[4202]! } + public var Passport_Language_my: String { return self._s[4204]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[4205]! } + public var Map_PlacesNearby: String { return self._s[4206]! } + public var Channel_About_Help: String { return self._s[4207]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[4208]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[4209]! } + public var Channel_Username_Title: String { return self._s[4210]! } + public var Activity_RecordingVideoMessage: String { return self._s[4211]! } public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4210]!, self._r[4210]!, [_0]) + return formatWithArgumentRanges(self._s[4212]!, self._r[4212]!, [_0]) } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[4211]! } - public var Passport_DiscardMessageDescription: String { return self._s[4212]! } - public var Conversation_LinkDialogOpen: String { return self._s[4213]! } - public var ChatList_Context_HideArchive: String { return self._s[4214]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[4213]! } + public var Passport_DiscardMessageDescription: String { return self._s[4214]! } + public var Conversation_LinkDialogOpen: String { return self._s[4215]! } + public var ChatList_Context_HideArchive: String { return self._s[4216]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4215]!, self._r[4215]!, [_0]) + return formatWithArgumentRanges(self._s[4217]!, self._r[4217]!, [_0]) } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[4216]! } - public var Conversation_Admin: String { return self._s[4217]! } - public var DialogList_TabTitle: String { return self._s[4218]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[4218]! } + public var Conversation_Admin: String { return self._s[4219]! } + public var DialogList_TabTitle: String { return self._s[4220]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4219]!, self._r[4219]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4221]!, self._r[4221]!, [_1, _2]) } - public var Notifications_PermissionsUnreachableText: String { return self._s[4220]! } - public var Passport_Identity_GenderMale: String { return self._s[4222]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4224]! } - public var PhoneNumberHelp_Alert: String { return self._s[4225]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[4226]! } - public var Notifications_InAppNotifications: String { return self._s[4227]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[4222]! } + public var Passport_Identity_GenderMale: String { return self._s[4224]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4226]! } + public var PhoneNumberHelp_Alert: String { return self._s[4227]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[4228]! } + public var Notifications_InAppNotifications: String { return self._s[4229]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4228]!, self._r[4228]!, [_0]) + return formatWithArgumentRanges(self._s[4230]!, self._r[4230]!, [_0]) } - public var Notification_VideoCallOutgoing: String { return self._s[4229]! } - public var Login_InvalidCodeError: String { return self._s[4230]! } - public var Conversation_PrivateChannelTimeLimitedAlertJoin: String { return self._s[4231]! } + public var Notification_VideoCallOutgoing: String { return self._s[4231]! } + public var Login_InvalidCodeError: String { return self._s[4232]! } + public var Conversation_PrivateChannelTimeLimitedAlertJoin: String { return self._s[4233]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4232]!, self._r[4232]!, [_0]) + return formatWithArgumentRanges(self._s[4234]!, self._r[4234]!, [_0]) } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[4234]! } - public var ReportPeer_Report: String { return self._s[4235]! } - public var Camera_FlashOff: String { return self._s[4238]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[4241]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[4244]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[4245]! } - public var Passport_FieldEmail: String { return self._s[4246]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[4236]! } + public var ReportPeer_Report: String { return self._s[4237]! } + public var Camera_FlashOff: String { return self._s[4240]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[4243]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[4246]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[4247]! } + public var Passport_FieldEmail: String { return self._s[4248]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4247]!, self._r[4247]!, [_1]) + return formatWithArgumentRanges(self._s[4249]!, self._r[4249]!, [_1]) } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[4248]! } - public var PeerInfo_PaneVoiceAndVideo: String { return self._s[4249]! } - public var Group_OwnershipTransfer_Title: String { return self._s[4250]! } - public var Conversation_DefaultRestrictedInline: String { return self._s[4251]! } - public var Login_PhoneNumberHelp: String { return self._s[4253]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[4254]! } - public var Conversation_PinnedQuiz: String { return self._s[4255]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[4256]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[4257]! } - public var Group_MessagePhotoUpdated: String { return self._s[4258]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[4259]! } - public var Passport_Identity_Translations: String { return self._s[4261]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[4262]! } - public var ChannelInfo_DeleteChannel: String { return self._s[4264]! } - public var PasscodeSettings_HelpBottom: String { return self._s[4265]! } - public var Channel_Members_AddMembers: String { return self._s[4266]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[4267]! } - public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[4269]! } - public var Conversation_HoldForAudio: String { return self._s[4270]! } - public var Watch_LastSeen_Lately: String { return self._s[4272]! } - public var ChatList_Context_MarkAsRead: String { return self._s[4273]! } - public var Conversation_PinnedMessage: String { return self._s[4274]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[4275]! } - public var Passport_UpdateRequiredError: String { return self._s[4277]! } - public var PrivacySettings_Passcode: String { return self._s[4278]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[4250]! } + public var PeerInfo_PaneVoiceAndVideo: String { return self._s[4251]! } + public var Group_OwnershipTransfer_Title: String { return self._s[4252]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[4253]! } + public var Login_PhoneNumberHelp: String { return self._s[4255]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[4256]! } + public var Conversation_PinnedQuiz: String { return self._s[4257]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[4258]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[4259]! } + public var Group_MessagePhotoUpdated: String { return self._s[4260]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[4261]! } + public var Passport_Identity_Translations: String { return self._s[4263]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[4264]! } + public var ChannelInfo_DeleteChannel: String { return self._s[4266]! } + public var PasscodeSettings_HelpBottom: String { return self._s[4267]! } + public var Channel_Members_AddMembers: String { return self._s[4268]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[4269]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[4271]! } + public var Conversation_HoldForAudio: String { return self._s[4272]! } + public var Watch_LastSeen_Lately: String { return self._s[4274]! } + public var ChatList_Context_MarkAsRead: String { return self._s[4275]! } + public var Conversation_PinnedMessage: String { return self._s[4276]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[4277]! } + public var Passport_UpdateRequiredError: String { return self._s[4279]! } + public var PrivacySettings_Passcode: String { return self._s[4280]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4279]!, self._r[4279]!, [_0]) + return formatWithArgumentRanges(self._s[4281]!, self._r[4281]!, [_0]) } - public var AutoNightTheme_NotAvailable: String { return self._s[4280]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[4281]! } - public var LoginPassword_InvalidPasswordError: String { return self._s[4282]! } - public var ChatListFolder_IncludedSectionHeader: String { return self._s[4283]! } - public var Channel_SignMessages_Help: String { return self._s[4284]! } - public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[4285]! } - public var Conversation_TitleNoComments: String { return self._s[4286]! } - public var MediaPicker_LivePhotoDescription: String { return self._s[4287]! } - public var GroupInfo_Permissions: String { return self._s[4288]! } - public var GroupPermission_NoSendLinks: String { return self._s[4291]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[4292]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[4294]! } - public var ChatList_ArchiveAction: String { return self._s[4295]! } + public var AutoNightTheme_NotAvailable: String { return self._s[4282]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[4283]! } + public var LoginPassword_InvalidPasswordError: String { return self._s[4284]! } + public var ChatListFolder_IncludedSectionHeader: String { return self._s[4285]! } + public var Channel_SignMessages_Help: String { return self._s[4286]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[4287]! } + public var Conversation_TitleNoComments: String { return self._s[4288]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[4289]! } + public var GroupInfo_Permissions: String { return self._s[4290]! } + public var GroupPermission_NoSendLinks: String { return self._s[4293]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[4294]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[4296]! } + public var ChatList_ArchiveAction: String { return self._s[4297]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4296]!, self._r[4296]!, [_0]) + return formatWithArgumentRanges(self._s[4298]!, self._r[4298]!, [_0]) } - public var GroupInfo_GroupHistory: String { return self._s[4297]! } + public var GroupInfo_GroupHistory: String { return self._s[4299]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4299]!, self._r[4299]!, [_0]) + return formatWithArgumentRanges(self._s[4301]!, self._r[4301]!, [_0]) } - public var Privacy_Forwards_LinkIfAllowed: String { return self._s[4301]! } - public var Channel_Info_Banned: String { return self._s[4302]! } - public var Paint_RecentStickers: String { return self._s[4303]! } - public var VoiceOver_MessageContextSend: String { return self._s[4304]! } - public var Group_ErrorNotMutualContact: String { return self._s[4305]! } - public var ReportPeer_ReasonOther: String { return self._s[4307]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[4308]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[4310]! } - public var KeyCommand_Find: String { return self._s[4311]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[4303]! } + public var Channel_Info_Banned: String { return self._s[4304]! } + public var Paint_RecentStickers: String { return self._s[4305]! } + public var VoiceOver_MessageContextSend: String { return self._s[4306]! } + public var Group_ErrorNotMutualContact: String { return self._s[4307]! } + public var ReportPeer_ReasonOther: String { return self._s[4309]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[4310]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[4312]! } + public var KeyCommand_Find: String { return self._s[4313]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4312]!, self._r[4312]!, [_0]) + return formatWithArgumentRanges(self._s[4314]!, self._r[4314]!, [_0]) } - public var ChatList_Context_Unmute: String { return self._s[4313]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[4314]! } - public var Stickers_GroupStickersHelp: String { return self._s[4315]! } - public var Wallet_Configuration_BlockchainIdPlaceholder: String { return self._s[4316]! } - public var Checkout_Title: String { return self._s[4317]! } - public var Activity_RecordingAudio: String { return self._s[4318]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[4319]! } - public var BlockedUsers_BlockTitle: String { return self._s[4320]! } - public var Wallet_Month_ShortFebruary: String { return self._s[4322]! } - public var Calls_All: String { return self._s[4323]! } - public var DialogList_SavedMessagesHelp: String { return self._s[4325]! } - public var Settings_FAQ_Button: String { return self._s[4326]! } - public var Conversation_Dice_u1F3B0: String { return self._s[4328]! } + public var ChatList_Context_Unmute: String { return self._s[4315]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[4316]! } + public var Stickers_GroupStickersHelp: String { return self._s[4317]! } + public var Wallet_Configuration_BlockchainIdPlaceholder: String { return self._s[4318]! } + public var Checkout_Title: String { return self._s[4319]! } + public var Activity_RecordingAudio: String { return self._s[4320]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[4321]! } + public var BlockedUsers_BlockTitle: String { return self._s[4322]! } + public var Wallet_Month_ShortFebruary: String { return self._s[4324]! } + public var Calls_All: String { return self._s[4325]! } + public var DialogList_SavedMessagesHelp: String { return self._s[4327]! } + public var Settings_FAQ_Button: String { return self._s[4328]! } + public var Conversation_Dice_u1F3B0: String { return self._s[4330]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4329]!, self._r[4329]!, [_0]) + return formatWithArgumentRanges(self._s[4331]!, self._r[4331]!, [_0]) } - public var Conversation_ReportGroupLocation: String { return self._s[4330]! } - public var Passport_Scans_Upload: String { return self._s[4331]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[4333]! } - public var ChatList_UnarchiveAction: String { return self._s[4334]! } - public var Stats_GroupTopInviter_History: String { return self._s[4335]! } - public var GroupInfo_Permissions_Title: String { return self._s[4336]! } - public var Passport_Language_el: String { return self._s[4337]! } + public var Conversation_ReportGroupLocation: String { return self._s[4332]! } + public var Passport_Scans_Upload: String { return self._s[4333]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[4335]! } + public var ChatList_UnarchiveAction: String { return self._s[4336]! } + public var Stats_GroupTopInviter_History: String { return self._s[4337]! } + public var GroupInfo_Permissions_Title: String { return self._s[4338]! } + public var Passport_Language_el: String { return self._s[4339]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4338]!, self._r[4338]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4340]!, self._r[4340]!, [_1, _2, _3]) } - public var Channel_DiscussionMessageUnavailable: String { return self._s[4339]! } - public var GroupInfo_ActionPromote: String { return self._s[4340]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[4341]! } + public var Channel_DiscussionMessageUnavailable: String { return self._s[4341]! } + public var GroupInfo_ActionPromote: String { return self._s[4342]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[4343]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4342]!, self._r[4342]!, [_0]) + return formatWithArgumentRanges(self._s[4344]!, self._r[4344]!, [_0]) } - public var VoiceOver_Chat_Reply: String { return self._s[4343]! } - public var Month_GenMay: String { return self._s[4344]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[4345]! } - public var Chat_PsaTooltip_covid: String { return self._s[4346]! } - public var Watch_Suggestion_CantTalk: String { return self._s[4347]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[4348]! } - public var AppUpgrade_Running: String { return self._s[4349]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[4352]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[4353]! } - public var SharedMedia_EmptyText: String { return self._s[4354]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[4355]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[4356]! } - public var Message_PinnedGame: String { return self._s[4357]! } - public var KeyCommand_SearchInChat: String { return self._s[4358]! } - public var Appearance_ThemeCarouselNewNight: String { return self._s[4359]! } - public var ChatList_Search_FilterMedia: String { return self._s[4360]! } - public var Message_PinnedAudioMessage: String { return self._s[4361]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[4362]! } + public var VoiceOver_Chat_Reply: String { return self._s[4345]! } + public var Month_GenMay: String { return self._s[4346]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[4347]! } + public var Chat_PsaTooltip_covid: String { return self._s[4348]! } + public var Watch_Suggestion_CantTalk: String { return self._s[4349]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[4350]! } + public var AppUpgrade_Running: String { return self._s[4351]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[4354]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[4355]! } + public var SharedMedia_EmptyText: String { return self._s[4356]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[4357]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[4358]! } + public var Message_PinnedGame: String { return self._s[4359]! } + public var KeyCommand_SearchInChat: String { return self._s[4360]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[4361]! } + public var ChatList_Search_FilterMedia: String { return self._s[4362]! } + public var Message_PinnedAudioMessage: String { return self._s[4363]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[4364]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4363]!, self._r[4363]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4365]!, self._r[4365]!, [_1, _2]) } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4364]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4366]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4365]!, self._r[4365]!, [_0]) - } - public var Wallet_Receive_AddressCopied: String { return self._s[4366]! } - public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4367]!, self._r[4367]!, [_0]) } - public var Settings_AddAccount: String { return self._s[4368]! } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[4369]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[4370]! } - public var Channel_JoinChannel: String { return self._s[4371]! } - public var Watch_UserInfo_Unblock: String { return self._s[4372]! } - public var PhoneLabel_Title: String { return self._s[4373]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[4375]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[4376]! } + public var Wallet_Receive_AddressCopied: String { return self._s[4368]! } + public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4369]!, self._r[4369]!, [_0]) + } + public var Settings_AddAccount: String { return self._s[4370]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[4371]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[4372]! } + public var Channel_JoinChannel: String { return self._s[4373]! } + public var Watch_UserInfo_Unblock: String { return self._s[4374]! } + public var PhoneLabel_Title: String { return self._s[4375]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[4377]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[4378]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4377]!, self._r[4377]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[4379]!, self._r[4379]!, [_1, _2, _3, _4, _5, _6]) } - public var Wallet_Month_GenOctober: String { return self._s[4378]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[4379]! } - public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[4380]! } - public var DialogList_EncryptionProcessing: String { return self._s[4381]! } - public var ChatList_Search_FilterChats: String { return self._s[4382]! } - public var WatchRemote_NotificationText: String { return self._s[4383]! } - public var EditTheme_ChangeColors: String { return self._s[4384]! } - public var GroupRemoved_ViewUserInfo: String { return self._s[4385]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[4386]! } - public var CallSettings_OnMobile: String { return self._s[4388]! } - public var Month_ShortFebruary: String { return self._s[4390]! } - public var VoiceOver_MessageContextReply: String { return self._s[4391]! } + public var Wallet_Month_GenOctober: String { return self._s[4380]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[4381]! } + public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[4382]! } + public var DialogList_EncryptionProcessing: String { return self._s[4383]! } + public var ChatList_Search_FilterChats: String { return self._s[4384]! } + public var WatchRemote_NotificationText: String { return self._s[4385]! } + public var EditTheme_ChangeColors: String { return self._s[4386]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[4387]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[4388]! } + public var CallSettings_OnMobile: String { return self._s[4390]! } + public var Month_ShortFebruary: String { return self._s[4392]! } + public var VoiceOver_MessageContextReply: String { return self._s[4393]! } public func PUSH_VIDEO_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4392]!, self._r[4392]!, [_1]) + return formatWithArgumentRanges(self._s[4394]!, self._r[4394]!, [_1]) } - public var Group_Location_ChangeLocation: String { return self._s[4393]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[4394]! } - public var Wallet_Send_EncryptComment: String { return self._s[4395]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[4396]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[4397]! } + public var Group_Location_ChangeLocation: String { return self._s[4395]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[4396]! } + public var Wallet_Send_EncryptComment: String { return self._s[4397]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[4398]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[4399]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4399]!, self._r[4399]!, [_0]) + return formatWithArgumentRanges(self._s[4401]!, self._r[4401]!, [_0]) } - public var PhotoEditor_WarmthTool: String { return self._s[4400]! } - public var Login_InfoAvatarPhoto: String { return self._s[4401]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[4402]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[4403]! } - public var Map_PlacesInThisArea: String { return self._s[4404]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[4405]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[4406]! } + public var PhotoEditor_WarmthTool: String { return self._s[4402]! } + public var Login_InfoAvatarPhoto: String { return self._s[4403]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[4404]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[4405]! } + public var Map_PlacesInThisArea: String { return self._s[4406]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[4407]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[4408]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4407]!, self._r[4407]!, [_1]) + return formatWithArgumentRanges(self._s[4409]!, self._r[4409]!, [_1]) } - public var ShareMenu_Send: String { return self._s[4408]! } - public var Username_InvalidStartsWithNumber: String { return self._s[4409]! } - public var Appearance_AppIconClassicX: String { return self._s[4410]! } + public var ShareMenu_Send: String { return self._s[4410]! } + public var Username_InvalidStartsWithNumber: String { return self._s[4411]! } + public var Appearance_AppIconClassicX: String { return self._s[4412]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4411]!, self._r[4411]!, [_1]) + return formatWithArgumentRanges(self._s[4413]!, self._r[4413]!, [_1]) } - public var Conversation_StopPoll: String { return self._s[4412]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[4414]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[4415]! } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[4416]! } - public var Wallet_WordCheck_Title: String { return self._s[4417]! } - public var Conversation_Timer_Title: String { return self._s[4418]! } - public var Common_Next: String { return self._s[4419]! } - public var Notification_Exceptions_NewException: String { return self._s[4420]! } + public var Conversation_StopPoll: String { return self._s[4414]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[4416]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[4417]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[4418]! } + public var Wallet_WordCheck_Title: String { return self._s[4419]! } + public var Conversation_Timer_Title: String { return self._s[4420]! } + public var Common_Next: String { return self._s[4421]! } + public var Notification_Exceptions_NewException: String { return self._s[4422]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4421]!, self._r[4421]!, [_0]) + return formatWithArgumentRanges(self._s[4423]!, self._r[4423]!, [_0]) } - public var AccessDenied_CallMicrophone: String { return self._s[4422]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[4423]! } - public var ChangePhoneNumberCode_Help: String { return self._s[4424]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[4425]! } - public var Channel_AdminLogFilter_EventsLeaving: String { return self._s[4426]! } - public var BlockedUsers_LeavePrefix: String { return self._s[4427]! } + public var AccessDenied_CallMicrophone: String { return self._s[4424]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[4425]! } + public var ChangePhoneNumberCode_Help: String { return self._s[4426]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[4427]! } + public var Channel_AdminLogFilter_EventsLeaving: String { return self._s[4428]! } + public var BlockedUsers_LeavePrefix: String { return self._s[4429]! } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4428]!, self._r[4428]!, [_0]) + return formatWithArgumentRanges(self._s[4430]!, self._r[4430]!, [_0]) } - public var Group_About_Help: String { return self._s[4429]! } - public var TwoStepAuth_ChangePasswordDescription: String { return self._s[4430]! } - public var Tour_Title3: String { return self._s[4431]! } - public var Watch_Conversation_Unblock: String { return self._s[4432]! } - public var Watch_UserInfo_Block: String { return self._s[4433]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[4434]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[4435]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[4436]! } - public var Wallet_Alert_Cancel: String { return self._s[4437]! } - public var TextFormat_AddLinkTitle: String { return self._s[4438]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[4439]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[4440]! } - public var FastTwoStepSetup_PasswordSection: String { return self._s[4441]! } - public var Compose_ChannelMembers: String { return self._s[4442]! } - public var Conversation_ForwardTitle: String { return self._s[4443]! } + public var Group_About_Help: String { return self._s[4431]! } + public var TwoStepAuth_ChangePasswordDescription: String { return self._s[4432]! } + public var Tour_Title3: String { return self._s[4433]! } + public var Watch_Conversation_Unblock: String { return self._s[4434]! } + public var Watch_UserInfo_Block: String { return self._s[4435]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[4436]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[4437]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[4438]! } + public var Wallet_Alert_Cancel: String { return self._s[4439]! } + public var TextFormat_AddLinkTitle: String { return self._s[4440]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[4441]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[4442]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[4443]! } + public var Compose_ChannelMembers: String { return self._s[4444]! } + public var Conversation_ForwardTitle: String { return self._s[4445]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4444]!, self._r[4444]!, [_0]) + return formatWithArgumentRanges(self._s[4446]!, self._r[4446]!, [_0]) } - public var Conversation_PinnedPoll: String { return self._s[4446]! } + public var Conversation_PinnedPoll: String { return self._s[4448]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4447]!, self._r[4447]!, [_0]) + return formatWithArgumentRanges(self._s[4449]!, self._r[4449]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4448]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4449]! } - public var Stats_Overview: String { return self._s[4450]! } - public var Map_HomeAndWorkTitle: String { return self._s[4451]! } - public var Wallet_Intro_Terms: String { return self._s[4452]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4450]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4451]! } + public var Stats_Overview: String { return self._s[4452]! } + public var Map_HomeAndWorkTitle: String { return self._s[4453]! } + public var Wallet_Intro_Terms: String { return self._s[4454]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4453]!, self._r[4453]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4455]!, self._r[4455]!, [_1, _2, _3]) } - public var Passport_Address_CityPlaceholder: String { return self._s[4454]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[4455]! } - public var Privacy_PhoneNumber: String { return self._s[4456]! } - public var ChatList_Search_FilterFiles: String { return self._s[4457]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[4458]! } - public var ChannelIntro_CreateChannel: String { return self._s[4459]! } - public var Conversation_InputTextAnonymousPlaceholder: String { return self._s[4460]! } + public var Passport_Address_CityPlaceholder: String { return self._s[4456]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[4457]! } + public var Privacy_PhoneNumber: String { return self._s[4458]! } + public var ChatList_Search_FilterFiles: String { return self._s[4459]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[4460]! } + public var ChannelIntro_CreateChannel: String { return self._s[4461]! } + public var Conversation_InputTextAnonymousPlaceholder: String { return self._s[4462]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4461]!, self._r[4461]!, [_0]) + return formatWithArgumentRanges(self._s[4463]!, self._r[4463]!, [_0]) } - public var Weekday_ShortMonday: String { return self._s[4462]! } - public var Passport_Language_ar: String { return self._s[4464]! } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[4465]! } - public var TwoFactorSetup_Done_Title: String { return self._s[4466]! } - public var Calls_RatingFeedback: String { return self._s[4467]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[4468]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[4471]! } - public var Watch_Compose_Send: String { return self._s[4472]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[4473]! } - public var WebSearch_RecentSectionClear: String { return self._s[4474]! } + public var Weekday_ShortMonday: String { return self._s[4464]! } + public var Passport_Language_ar: String { return self._s[4466]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[4467]! } + public var TwoFactorSetup_Done_Title: String { return self._s[4468]! } + public var Calls_RatingFeedback: String { return self._s[4469]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[4470]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[4473]! } + public var Watch_Compose_Send: String { return self._s[4474]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[4475]! } + public var WebSearch_RecentSectionClear: String { return self._s[4476]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4475]!, self._r[4475]!, [_0]) + return formatWithArgumentRanges(self._s[4477]!, self._r[4477]!, [_0]) } - public var WallpaperSearch_ColorTeal: String { return self._s[4476]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[4477]! } - public var Permissions_ContactsTitle_v0: String { return self._s[4478]! } - public var Checkout_PasswordEntry_Pay: String { return self._s[4480]! } - public var Settings_SavedMessages: String { return self._s[4481]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[4482]! } - public var Month_ShortMarch: String { return self._s[4483]! } - public var Message_Location: String { return self._s[4484]! } + public var WallpaperSearch_ColorTeal: String { return self._s[4478]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[4479]! } + public var Permissions_ContactsTitle_v0: String { return self._s[4480]! } + public var Checkout_PasswordEntry_Pay: String { return self._s[4482]! } + public var Settings_SavedMessages: String { return self._s[4483]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[4484]! } + public var Month_ShortMarch: String { return self._s[4485]! } + public var Message_Location: String { return self._s[4486]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4485]!, self._r[4485]!, [_1]) + return formatWithArgumentRanges(self._s[4487]!, self._r[4487]!, [_1]) } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4486]!, self._r[4486]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4488]!, self._r[4488]!, [_1, _2]) } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[4488]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[4490]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4489]!, self._r[4489]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4491]!, self._r[4491]!, [_1, _2]) } - public var GroupPermission_NoSendMedia: String { return self._s[4490]! } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[4491]! } - public var SharedMedia_CategoryDocs: String { return self._s[4492]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[4493]! } - public var Paint_Framed: String { return self._s[4494]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[4495]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[4496]! } - public var Channel_SignMessages: String { return self._s[4497]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[4498]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[4499]! } + public var GroupPermission_NoSendMedia: String { return self._s[4492]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[4493]! } + public var SharedMedia_CategoryDocs: String { return self._s[4494]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[4495]! } + public var Paint_Framed: String { return self._s[4496]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[4497]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[4498]! } + public var Channel_SignMessages: String { return self._s[4499]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[4500]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[4501]! } public func PUSH_CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4500]!, self._r[4500]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4502]!, self._r[4502]!, [_1, _2]) } - public var GroupInfo_UpgradeButton: String { return self._s[4501]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[4502]! } - public var AutoDownloadSettings_Files: String { return self._s[4503]! } + public var GroupInfo_UpgradeButton: String { return self._s[4503]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[4504]! } + public var AutoDownloadSettings_Files: String { return self._s[4505]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4504]!, self._r[4504]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4506]!, self._r[4506]!, [_0, _1]) } - public var Login_SendCodeViaSms: String { return self._s[4506]! } - public var Update_UpdateApp: String { return self._s[4507]! } - public var Channel_Setup_TypePublic: String { return self._s[4508]! } - public var Watch_Compose_CreateMessage: String { return self._s[4509]! } + public var Login_SendCodeViaSms: String { return self._s[4508]! } + public var Update_UpdateApp: String { return self._s[4509]! } + public var Channel_Setup_TypePublic: String { return self._s[4510]! } + public var Watch_Compose_CreateMessage: String { return self._s[4511]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4510]!, self._r[4510]!, [_1, _2, _3]) - } - public var StickerPacksSettings_ManagingHelp: String { return self._s[4511]! } - public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4512]!, self._r[4512]!, [_1, _2, _3]) } - public var VoiceOver_Chat_Video: String { return self._s[4513]! } - public var Forward_ChannelReadOnly: String { return self._s[4514]! } - public var StickerPack_HideStickers: String { return self._s[4515]! } - public var ChatListFolder_NameContacts: String { return self._s[4516]! } - public var Profile_BotInfo: String { return self._s[4517]! } - public var Document_TargetConfirmationFormat: String { return self._s[4518]! } - public var GroupInfo_InviteByLink: String { return self._s[4519]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[4520]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[4521]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[4522]! } - public var Passport_NotLoggedInMessage: String { return self._s[4523]! } - public var Conversation_StopQuizConfirmation: String { return self._s[4524]! } - public var Checkout_PaymentMethod: String { return self._s[4525]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[4529]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[4530]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[4531]! } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[4532]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[4533]! } - public var Camera_Title: String { return self._s[4534]! } - public var Map_Directions: String { return self._s[4535]! } - public var Wallet_Intro_ImportExisting: String { return self._s[4536]! } - public var Stats_MessagePublicForwardsTitle: String { return self._s[4537]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[4539]! } - public var Profile_EncryptionKey: String { return self._s[4540]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[4513]! } + public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4514]!, self._r[4514]!, [_1, _2, _3]) + } + public var VoiceOver_Chat_Video: String { return self._s[4515]! } + public var Forward_ChannelReadOnly: String { return self._s[4516]! } + public var StickerPack_HideStickers: String { return self._s[4517]! } + public var ChatListFolder_NameContacts: String { return self._s[4518]! } + public var Profile_BotInfo: String { return self._s[4519]! } + public var Document_TargetConfirmationFormat: String { return self._s[4520]! } + public var GroupInfo_InviteByLink: String { return self._s[4521]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[4522]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[4523]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[4524]! } + public var Passport_NotLoggedInMessage: String { return self._s[4525]! } + public var Conversation_StopQuizConfirmation: String { return self._s[4526]! } + public var Checkout_PaymentMethod: String { return self._s[4527]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[4531]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[4532]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[4533]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[4534]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[4535]! } + public var Camera_Title: String { return self._s[4536]! } + public var Map_Directions: String { return self._s[4537]! } + public var Wallet_Intro_ImportExisting: String { return self._s[4538]! } + public var Stats_MessagePublicForwardsTitle: String { return self._s[4539]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[4541]! } + public var Profile_EncryptionKey: String { return self._s[4542]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4541]!, self._r[4541]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[4543]!, self._r[4543]!, [_1, "\(_2)"]) } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4542]!, self._r[4542]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4544]!, self._r[4544]!, [_0, _1]) } - public var Passport_Identity_TypePassport: String { return self._s[4543]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[4545]! } - public var Common_No: String { return self._s[4546]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[4547]! } - public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[4548]! } - public var Settings_AboutEmpty: String { return self._s[4549]! } - public var TwoStepAuth_FloodError: String { return self._s[4551]! } - public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[4552]! } + public var Passport_Identity_TypePassport: String { return self._s[4545]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[4547]! } + public var Common_No: String { return self._s[4548]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[4549]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[4550]! } + public var Settings_AboutEmpty: String { return self._s[4551]! } + public var TwoStepAuth_FloodError: String { return self._s[4553]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[4554]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4554]!, self._r[4554]!, [_1]) + return formatWithArgumentRanges(self._s[4556]!, self._r[4556]!, [_1]) } - public var Conversation_Edit: String { return self._s[4557]! } - public var CheckoutInfo_SaveInfo: String { return self._s[4558]! } - public var VoiceOver_Chat_AnonymousPoll: String { return self._s[4559]! } - public var Call_CameraTooltip: String { return self._s[4561]! } - public var InstantPage_FeedbackButtonShort: String { return self._s[4562]! } - public var Contacts_InviteToTelegram: String { return self._s[4563]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[4564]! } - public var Notifications_ResetAllNotifications: String { return self._s[4565]! } - public var Calls_NewCall: String { return self._s[4566]! } - public var VoiceOver_Chat_Music: String { return self._s[4569]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[4570]! } - public var Channel_Edit_AboutItem: String { return self._s[4571]! } - public var Message_VideoExpired: String { return self._s[4572]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[4573]! } + public var Conversation_Edit: String { return self._s[4559]! } + public var CheckoutInfo_SaveInfo: String { return self._s[4560]! } + public var VoiceOver_Chat_AnonymousPoll: String { return self._s[4561]! } + public var Call_CameraTooltip: String { return self._s[4563]! } + public var InstantPage_FeedbackButtonShort: String { return self._s[4564]! } + public var Contacts_InviteToTelegram: String { return self._s[4565]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[4566]! } + public var Notifications_ResetAllNotifications: String { return self._s[4567]! } + public var Calls_NewCall: String { return self._s[4568]! } + public var VoiceOver_Chat_Music: String { return self._s[4571]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[4572]! } + public var Channel_Edit_AboutItem: String { return self._s[4573]! } + public var Message_VideoExpired: String { return self._s[4574]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[4575]! } public func PUSH_CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4574]!, self._r[4574]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4576]!, self._r[4576]!, [_1, _2]) } - public var NotificationsSound_Input: String { return self._s[4576]! } - public var Notifications_ClassicTones: String { return self._s[4577]! } - public var Conversation_StatusTyping: String { return self._s[4578]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[4579]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[4580]! } - public var Wallet_Month_ShortSeptember: String { return self._s[4581]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4582]! } - public var Conversation_MessageLeaveComment: String { return self._s[4583]! } - public var UserInfo_TapToCall: String { return self._s[4584]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[4585]! } - public var Conversation_ClearAll: String { return self._s[4587]! } - public var UserInfo_NotificationsDefault: String { return self._s[4588]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[4589]! } - public var Location_ProximityGroupTip: String { return self._s[4590]! } - public var Map_ChooseAPlace: String { return self._s[4591]! } + public var NotificationsSound_Input: String { return self._s[4578]! } + public var Notifications_ClassicTones: String { return self._s[4579]! } + public var Conversation_StatusTyping: String { return self._s[4580]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[4581]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[4582]! } + public var Wallet_Month_ShortSeptember: String { return self._s[4583]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4584]! } + public var Conversation_MessageLeaveComment: String { return self._s[4585]! } + public var UserInfo_TapToCall: String { return self._s[4586]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[4587]! } + public var Conversation_ClearAll: String { return self._s[4589]! } + public var UserInfo_NotificationsDefault: String { return self._s[4590]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[4591]! } + public var Location_ProximityGroupTip: String { return self._s[4592]! } + public var Map_ChooseAPlace: String { return self._s[4593]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4592]!, self._r[4592]!, [_0]) + return formatWithArgumentRanges(self._s[4594]!, self._r[4594]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[4593]! } - public var ChatList_PeerTypeNonContact: String { return self._s[4594]! } - public var Conversation_SlideToCancel: String { return self._s[4595]! } - public var Month_ShortJuly: String { return self._s[4596]! } - public var SocksProxySetup_ProxyType: String { return self._s[4597]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[4595]! } + public var ChatList_PeerTypeNonContact: String { return self._s[4596]! } + public var Conversation_SlideToCancel: String { return self._s[4597]! } + public var Month_ShortJuly: String { return self._s[4598]! } + public var SocksProxySetup_ProxyType: String { return self._s[4599]! } public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4598]!, self._r[4598]!, [_0]) + return formatWithArgumentRanges(self._s[4600]!, self._r[4600]!, [_0]) } - public var ChatList_EditFolders: String { return self._s[4599]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[4600]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[4602]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[4603]! } + public var ChatList_EditFolders: String { return self._s[4601]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[4602]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[4604]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[4605]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4604]!, self._r[4604]!, [_0]) + return formatWithArgumentRanges(self._s[4606]!, self._r[4606]!, [_0]) } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[4605]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[4606]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[4607]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[4609]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[4610]! } - public var Passport_DeleteAddress: String { return self._s[4612]! } - public var Passport_DeletePassportConfirmation: String { return self._s[4613]! } - public var Passport_Identity_ReverseSide: String { return self._s[4614]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[4615]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4616]! } - public var Passport_FieldAddress: String { return self._s[4617]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[4618]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[4620]! } - public var Map_Home: String { return self._s[4622]! } - public var PollResults_Title: String { return self._s[4623]! } - public var ArchivedChats_IntroText2: String { return self._s[4625]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[4626]! } - public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[4627]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[4629]! } - public var Passport_Identity_AddPersonalDetails: String { return self._s[4631]! } - public var Group_Info_AdminLog: String { return self._s[4633]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4634]! } - public var Appearance_Animations: String { return self._s[4635]! } - public var Appearance_TextSizeSetting: String { return self._s[4636]! } - public func Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[4607]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[4608]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[4609]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[4611]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[4612]! } + public var Passport_DeleteAddress: String { return self._s[4614]! } + public var Passport_DeletePassportConfirmation: String { return self._s[4615]! } + public var Passport_Identity_ReverseSide: String { return self._s[4616]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[4617]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4618]! } + public var Passport_FieldAddress: String { return self._s[4619]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[4620]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[4622]! } + public var Map_Home: String { return self._s[4624]! } + public var PollResults_Title: String { return self._s[4625]! } + public var ArchivedChats_IntroText2: String { return self._s[4627]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[4628]! } + public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[4629]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[4631]! } + public var Passport_Identity_AddPersonalDetails: String { return self._s[4633]! } + public var Group_Info_AdminLog: String { return self._s[4635]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4636]! } + public var Appearance_Animations: String { return self._s[4637]! } + public var Appearance_TextSizeSetting: String { return self._s[4638]! } + public func PrivacyLastSeenSettings_AddUsers(_ 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 StickerPack_RemoveStickerCount(_ 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[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedLocations(_ 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[2 * 6 + Int(form.rawValue)]!, stringValue) } - public func Stats_GroupTopAdminKicks(_ 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[3 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_GroupFormat(_ value: Int32) -> String { + public func Stats_MessageForwards(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareItem(_ value: Int32) -> String { + public func InstantPage_Views(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ 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[6 * 6 + Int(form.rawValue)]!, _1, _2) } - public func ForwardedContacts(_ value: Int32) -> String { + public func Stats_MessageViews(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_TitleReplies(_ 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_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, _1, _2) } - public func ForwardedPolls(_ value: Int32) -> String { + public func OldChannels_GroupFormat(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Days(_ value: Int32) -> String { + public func Chat_TitlePinnedMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, _2, _1, _3) + public func Theme_UsersCount(_ 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 ForwardedAudios(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_StickerCount(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSimple(_ 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 GroupInfo_ShowMoreMembers(_ 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[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Minutes(_ value: Int32) -> String { + public func Map_ETAMinutes(_ 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 Passport_Scans(_ 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[17 * 6 + Int(form.rawValue)]!, stringValue) @@ -5214,61 +5218,59 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_TitleComments(_ 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 PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Stats_GroupShowMoreTopPosters(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_SelectedChats(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Link(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_SharePhoto(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedVideos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[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) + return String(format: self._ps[19 * 6 + Int(form.rawValue)]!, _1, _2) } public func ChatList_MessageVideos(_ 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) + return String(format: self._ps[20 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_AddMaskCount(_ 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[21 * 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[22 * 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[23 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PollResults_ShowMore(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_DOCS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Notification_GameScoreSimple(_ 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 ChatListFilter_ShowMoreChats(_ 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 StickerPack_StickerCount(_ 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 PUSH_MESSAGE_DOCS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Map_ETAHours(_ 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) @@ -5278,601 +5280,603 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Video(_ 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[32 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ 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[33 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessagePoll_QuizCount(_ value: Int32) -> String { + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[34 * 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[35 * 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[36 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 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[39 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Months(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[40 * 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[41 * 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[42 * 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[43 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Years(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[44 * 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[45 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortDays(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_MessageViewComments(_ 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 Stats_GroupTopAdminBans(_ 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 Notifications_ExceptionMuteExpires_Hours(_ 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 ChatList_MessagePhotos(_ 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 Conversation_StatusOnline(_ 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 Media_ShareVideo(_ 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 Call_Seconds(_ 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 Map_ETAHours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[55 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_GroupTopPosterMessages(_ 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 MessageTimer_ShortHours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) + public func PUSH_CHANNEL_MESSAGE_DOCS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[35 * 6 + Int(form.rawValue)]!, _1, _2) } 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) + return String(format: self._ps[36 * 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[60 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_ShortWeeks(_ 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[61 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[37 * 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 ServiceMessage_GameScoreExtended(_ value: Int32) -> String { + public func Stats_GroupTopInviterInvites(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) } - public func CreatePoll_AddMoreOptions(_ 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[64 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Chat_TitlePinnedMessages(_ 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 QuickSend_Photos(_ 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 LastSeen_HoursAgo(_ 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 Notification_GameScoreSelfSimple(_ 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 VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_MessageViews(_ 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 InviteText_ContactsCountText(_ 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 UserCount(_ 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 LiveLocation_MenuChatsCount(_ 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 Contacts_ImportersCount(_ 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 Theme_UsersCount(_ 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 SharedMedia_Photo(_ 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 ChatList_MessageMusic(_ 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_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, _1, _2) - } - 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[80 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendGif(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[81 * 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[82 * 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[83 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Conversation_ContextViewReplies(_ 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 GroupInfo_ParticipantCount(_ 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 Notification_GameScoreExtended(_ 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 MessageTimer_Seconds(_ 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 OldChannels_InactiveYear(_ 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 Stats_GroupShowMoreTopInviters(_ 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_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Hours(_ 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 PUSH_CHANNEL_MESSAGE_DOCS(_ 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 Contacts_InviteContacts(_ 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 MuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[94 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Minutes(_ 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) + return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, stringValue) } public func Stats_GroupTopAdminDeletions(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_LiveLocationMembersCount(_ 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[97 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendItem(_ 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[98 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[42 * 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[43 * 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[44 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_SelectedChats(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[45 * 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[46 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Contacts_ImportersCount(_ 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 StickerPack_AddMaskCount(_ 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 MuteExpires_Days(_ 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_FWDS(_ 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) + } + 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[51 * 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[52 * 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[53 * 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[54 * 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[55 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Stats_GroupTopPosterMessages(_ 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 Conversation_SelectedMessages(_ 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_MESSAGES(_ 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 Call_ShortSeconds(_ 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 OldChannels_InactiveMonth(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Video(_ 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 StickerPack_AddStickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[63 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupShowMoreTopAdmins(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) } public func Call_ShortMinutes(_ 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 SharedMedia_Link(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_MessageViewComments(_ 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 OldChannels_Leave(_ 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 MessageTimer_ShortSeconds(_ 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 Conversation_TitleComments(_ 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 Conversation_StatusMembers(_ 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 MessagePoll_QuizCount(_ 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 Conversation_ContextViewReplies(_ 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 Watch_LastSeen_MinutesAgo(_ 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 PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[76 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func GroupInfo_ParticipantCount(_ 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 Notification_GameScoreSelfExtended(_ 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 LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Wallpaper_DeleteConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortDays(_ 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 Notification_GameScoreExtended(_ 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 MessageTimer_Days(_ 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 ForwardedPolls(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_File(_ 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 MessageTimer_ShortHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupShowMoreTopInviters(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendVideo(_ 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_MessageMusic(_ 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 InviteText_ContactsCountText(_ 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 SharedMedia_Generic(_ 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 ChatList_DeleteConfirmation(_ 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 Conversation_StatusSubscribers(_ 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 Conversation_LiveLocationMembersCount(_ 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 Media_ShareVideo(_ 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 LastSeen_HoursAgo(_ 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 LiveLocation_MenuChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[98 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_GroupShowMoreTopPosters(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[99 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, _1, _2) + public func Passport_Scans(_ 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 MuteFor_Hours(_ 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 InstantPage_Views(_ 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[102 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + public func StickerPack_RemoveMaskCount(_ 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_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, _0, _1) } - public func PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PollResults_ShowMore(_ 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 Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveMonth(_ 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 StickerPack_AddStickerCount(_ 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 ForwardedPhotos(_ 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 ServiceMessage_GameScoreSelfExtended(_ 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 Conversation_SelectedMessages(_ 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 MessagePoll_VotedCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_GroupTopInviterInvites(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, _1, _2) } public func ChatList_MessageFiles(_ 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 Stats_MessageForwards(_ 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 SharedMedia_Generic(_ 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 ForwardedVideoMessages(_ 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 Conversation_StatusSubscribers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) } public func ChatList_Search_Messages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[123 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedFiles(_ 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[124 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, stringValue) } - public func Forward_ConfirmMultipleFiles(_ 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[125 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[126 * 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[127 * 6 + Int(form.rawValue)]!, _1, _2) - } - 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[128 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedStickers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[130 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_DOCS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[131 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessageTimer_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[132 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_File(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[133 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_DOCS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[134 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Stats_GroupShowMoreTopAdmins(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[135 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[136 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[137 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Stats_GroupTopPosterChars(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[138 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) } public func LastSeen_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[139 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[140 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveWeek(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[141 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[142 * 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[143 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MuteExpires_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[144 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_ContextMenuSelectAll(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[145 * 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[146 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[147 * 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[148 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[149 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[110 * 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[150 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteFor_Days(_ value: 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[112 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_Hours(_ 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_Months(_ 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 Conversation_ContextMenuSelectAll(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func OldChannels_InactiveYear(_ 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 Media_SharePhoto(_ 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 Watch_UserInfo_Mute(_ 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 Stats_GroupTopAdminBans(_ 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 Chat_DeleteMessagesConfirmation(_ 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 GroupInfo_ShowMoreMembers(_ 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 MessageTimer_Years(_ 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 PeopleNearby_ShowMorePeople(_ 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 MessageTimer_Weeks(_ 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 PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Call_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[127 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[128 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_DeleteItemsConfirmation(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusOnline(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[130 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[131 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Invitation_Members(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[132 * 6 + Int(form.rawValue)]!, stringValue) + } + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[133 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Call_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[134 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessagePoll_VotedCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[135 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[136 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + 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[137 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[138 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedLocations(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[139 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[140 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[141 * 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[142 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[143 * 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[144 * 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[145 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func ChatList_MessagePhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[146 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendPhoto(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[147 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideoMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[148 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_TitleReplies(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[149 * 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[150 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Stats_GroupTopPosterChars(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[151 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSimple(_ 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[152 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatListFilter_ShowMoreChats(_ value: Int32) -> String { + public func Stats_GroupTopAdminKicks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[153 * 6 + Int(form.rawValue)]!, stringValue) } - public func DialogList_LiveLocationChatsCount(_ 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[154 * 6 + Int(form.rawValue)]!, stringValue) diff --git a/submodules/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Resources/PresentationStrings.mapping index eae422738c..59a654965f 100644 Binary files a/submodules/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TelegramUI/Sources/ChatController.swift b/submodules/TelegramUI/Sources/ChatController.swift index 9a4318b5cc..8ba77a354d 100644 --- a/submodules/TelegramUI/Sources/ChatController.swift +++ b/submodules/TelegramUI/Sources/ChatController.swift @@ -5232,62 +5232,106 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G } } } - }, unpinMessage: { [weak self] id, askForConfirmation in - if let strongSelf = self { - if let peer = strongSelf.presentationInterfaceState.renderedPeer?.peer { - if strongSelf.canManagePin() { - let action: () -> Void = { - if let strongSelf = self { - let disposable: MetaDisposable - if let current = strongSelf.unpinMessageDisposable { - disposable = current - } else { - disposable = MetaDisposable() - strongSelf.unpinMessageDisposable = disposable - } - - if askForConfirmation { - strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = true - strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { - return $0.updatedPendingUnpinnedAllMessages(true) - }) - + }, unpinMessage: { [weak self] id, askForConfirmation, contextController in + let impl: () -> Void = { + guard let strongSelf = self else { + return + } + guard let peer = strongSelf.presentationInterfaceState.renderedPeer?.peer else { + return + } + + if strongSelf.canManagePin() { + let action: () -> Void = { + if let strongSelf = self { + let disposable: MetaDisposable + if let current = strongSelf.unpinMessageDisposable { + disposable = current + } else { + disposable = MetaDisposable() + strongSelf.unpinMessageDisposable = disposable + } + + if askForConfirmation { + strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = true + strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { + return $0.updatedPendingUnpinnedAllMessages(true) + }) + + strongSelf.present( + UndoOverlayController( + presentationData: strongSelf.presentationData, + content: .messagesUnpinned( + title: strongSelf.presentationData.strings.Chat_MessagesUnpinned(1), + text: "", + undo: askForConfirmation, + isHidden: false + ), + elevatedLayout: false, + action: { action in + switch action { + case .commit: + disposable.set((requestUpdatePinnedMessage(account: strongSelf.context.account, peerId: peer.id, update: .clear(id: id)) + |> deliverOnMainQueue).start(error: { _ in + guard let strongSelf = self else { + return + } + strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = false + strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { + return $0.updatedPendingUnpinnedAllMessages(false) + }) + }, completed: { + guard let strongSelf = self else { + return + } + strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = false + strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { + return $0.updatedPendingUnpinnedAllMessages(false) + }) + })) + case .undo: + strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = false + strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { + return $0.updatedPendingUnpinnedAllMessages(false) + }) + default: + break + } + return true + } + ), + in: .current + ) + } else { + if case .pinnedMessages = strongSelf.presentationInterfaceState.subject { + strongSelf.chatDisplayNode.historyNode.pendingRemovedMessages.insert(id) strongSelf.present( UndoOverlayController( presentationData: strongSelf.presentationData, content: .messagesUnpinned( title: strongSelf.presentationData.strings.Chat_MessagesUnpinned(1), text: "", - undo: askForConfirmation, + undo: true, isHidden: false ), elevatedLayout: false, action: { action in + guard let strongSelf = self else { + return true + } switch action { case .commit: - disposable.set((requestUpdatePinnedMessage(account: strongSelf.context.account, peerId: peer.id, update: .clear(id: id)) - |> deliverOnMainQueue).start(error: { _ in - guard let strongSelf = self else { - return - } - strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = false - strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { - return $0.updatedPendingUnpinnedAllMessages(false) + let _ = (requestUpdatePinnedMessage(account: strongSelf.context.account, peerId: peer.id, update: .clear(id: id)) + |> deliverOnMainQueue).start(completed: { + Queue.mainQueue().after(1.0, { + guard let strongSelf = self else { + return + } + strongSelf.chatDisplayNode.historyNode.pendingRemovedMessages.remove(id) }) - }, completed: { - guard let strongSelf = self else { - return - } - strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = false - strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { - return $0.updatedPendingUnpinnedAllMessages(false) - }) - })) - case .undo: - strongSelf.chatDisplayNode.historyNode.pendingUnpinnedAllMessages = false - strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { - return $0.updatedPendingUnpinnedAllMessages(false) }) + case .undo: + strongSelf.chatDisplayNode.historyNode.pendingRemovedMessages.remove(id) default: break } @@ -5302,62 +5346,70 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G } } } - if askForConfirmation { - strongSelf.present(textAlertController(context: strongSelf.context, title: nil, text: strongSelf.presentationData.strings.Conversation_UnpinMessageAlert, actions: [TextAlertAction(type: .genericAction, title: strongSelf.presentationData.strings.Conversation_Unpin, action: { - action() - }), TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Common_Cancel, action: {})], actionLayout: .vertical), in: .window(.root)) - } else { + } + if askForConfirmation { + strongSelf.present(textAlertController(context: strongSelf.context, title: nil, text: strongSelf.presentationData.strings.Conversation_UnpinMessageAlert, actions: [TextAlertAction(type: .genericAction, title: strongSelf.presentationData.strings.Conversation_Unpin, action: { action() - } + }), TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Common_Cancel, action: {})], actionLayout: .vertical), in: .window(.root)) } else { - if let pinnedMessage = strongSelf.presentationInterfaceState.pinnedMessage { - let previousClosedPinnedMessageId = strongSelf.presentationInterfaceState.interfaceState.messageActionsState.closedPinnedMessageId - - strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { - return $0.updatedInterfaceState({ $0.withUpdatedMessageActionsState({ value in - var value = value - value.closedPinnedMessageId = pinnedMessage.topMessageId - return value - }) }) - }) - strongSelf.present( - UndoOverlayController( - presentationData: strongSelf.presentationData, - content: .messagesUnpinned( - title: strongSelf.presentationData.strings.Chat_PinnedMessagesHiddenTitle, - text: strongSelf.presentationData.strings.Chat_PinnedMessagesHiddenText, - undo: true, - isHidden: false - ), - elevatedLayout: false, - action: { action in - guard let strongSelf = self else { - return true - } - switch action { - case .commit: - break - case .undo: - strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { - return $0.updatedInterfaceState({ $0.withUpdatedMessageActionsState({ value in - var value = value - value.closedPinnedMessageId = previousClosedPinnedMessageId - return value - }) }) - }) - default: - break - } + action() + } + } else { + if let pinnedMessage = strongSelf.presentationInterfaceState.pinnedMessage { + let previousClosedPinnedMessageId = strongSelf.presentationInterfaceState.interfaceState.messageActionsState.closedPinnedMessageId + + strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { + return $0.updatedInterfaceState({ $0.withUpdatedMessageActionsState({ value in + var value = value + value.closedPinnedMessageId = pinnedMessage.topMessageId + return value + }) }) + }) + strongSelf.present( + UndoOverlayController( + presentationData: strongSelf.presentationData, + content: .messagesUnpinned( + title: strongSelf.presentationData.strings.Chat_PinnedMessagesHiddenTitle, + text: strongSelf.presentationData.strings.Chat_PinnedMessagesHiddenText, + undo: true, + isHidden: false + ), + elevatedLayout: false, + action: { action in + guard let strongSelf = self else { return true } - ), - in: .current - ) - strongSelf.updatedClosedPinnedMessageId?(pinnedMessage.topMessageId) - } + switch action { + case .commit: + break + case .undo: + strongSelf.updateChatPresentationInterfaceState(animated: true, interactive: true, { + return $0.updatedInterfaceState({ $0.withUpdatedMessageActionsState({ value in + var value = value + value.closedPinnedMessageId = previousClosedPinnedMessageId + return value + }) }) + }) + default: + break + } + return true + } + ), + in: .current + ) + strongSelf.updatedClosedPinnedMessageId?(pinnedMessage.topMessageId) } } } + + if let contextController = contextController { + contextController.dismiss(completion: { + impl() + }) + } else { + impl() + } }, unpinAllMessages: { [weak self] in guard let strongSelf = self else { return @@ -8094,7 +8146,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G public func displayPromoAnnouncement(text: String) { let psaText: String = text - let psaEntities: [MessageTextEntity] = generateTextEntities(psaText, enabledTypes: .url) + let psaEntities: [MessageTextEntity] = generateTextEntities(psaText, enabledTypes: .allUrl) var found = false self.forEachController({ controller in @@ -8187,7 +8239,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G psaText = string } - let psaEntities: [MessageTextEntity] = generateTextEntities(psaText, enabledTypes: .url) + let psaEntities: [MessageTextEntity] = generateTextEntities(psaText, enabledTypes: .allUrl) let messageId = item.message.id diff --git a/submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift b/submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift index 52274d6575..4d408b82f5 100644 --- a/submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift +++ b/submodules/TelegramUI/Sources/ChatHistoryEntriesForView.swift @@ -8,7 +8,7 @@ import AccountContext import TelegramPresentationData -func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, includeUnreadEntry: Bool, includeEmptyEntry: Bool, includeChatInfoEntry: Bool, includeSearchEntry: Bool, reverse: Bool, groupMessages: Bool, selectedMessages: Set?, presentationData: ChatPresentationData, historyAppearsCleared: Bool, pendingUnpinnedAllMessages: Bool, associatedData: ChatMessageItemAssociatedData, updatingMedia: [MessageId: ChatUpdatingMessageMedia], customChannelDiscussionReadState: MessageId?, customThreadOutgoingReadState: MessageId?) -> [ChatHistoryEntry] { +func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, includeUnreadEntry: Bool, includeEmptyEntry: Bool, includeChatInfoEntry: Bool, includeSearchEntry: Bool, reverse: Bool, groupMessages: Bool, selectedMessages: Set?, presentationData: ChatPresentationData, historyAppearsCleared: Bool, pendingUnpinnedAllMessages: Bool, pendingRemovedMessages: Set, associatedData: ChatMessageItemAssociatedData, updatingMedia: [MessageId: ChatUpdatingMessageMedia], customChannelDiscussionReadState: MessageId?, customThreadOutgoingReadState: MessageId?) -> [ChatHistoryEntry] { if historyAppearsCleared { return [] } @@ -34,6 +34,10 @@ func chatHistoryEntriesForView(location: ChatLocation, view: MessageHistoryView, var message = entry.message var isRead = entry.isRead + if pendingRemovedMessages.contains(message.id) { + continue + } + if let customThreadOutgoingReadState = customThreadOutgoingReadState { isRead = customThreadOutgoingReadState >= message.id } diff --git a/submodules/TelegramUI/Sources/ChatHistoryListNode.swift b/submodules/TelegramUI/Sources/ChatHistoryListNode.swift index 3d8c2f6446..e9ad7ee563 100644 --- a/submodules/TelegramUI/Sources/ChatHistoryListNode.swift +++ b/submodules/TelegramUI/Sources/ChatHistoryListNode.swift @@ -565,6 +565,15 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { } } + private let pendingRemovedMessagesPromise = ValuePromise>(Set()) + var pendingRemovedMessages: Set = Set() { + didSet { + if self.pendingRemovedMessages != oldValue { + self.pendingRemovedMessagesPromise.set(self.pendingRemovedMessages) + } + } + } + private(set) var isScrollAtBottomPosition = false public var isScrollAtBottomPositionUpdated: (() -> Void)? @@ -846,10 +855,11 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { automaticDownloadNetworkType, self.historyAppearsClearedPromise.get(), self.pendingUnpinnedAllMessagesPromise.get(), + self.pendingRemovedMessagesPromise.get(), animatedEmojiStickers, customChannelDiscussionReadState, customThreadOutgoingReadState - ).start(next: { [weak self] update, chatPresentationData, selectedMessages, updatingMedia, networkType, historyAppearsCleared, pendingUnpinnedAllMessages, animatedEmojiStickers, customChannelDiscussionReadState, customThreadOutgoingReadState in + ).start(next: { [weak self] update, chatPresentationData, selectedMessages, updatingMedia, networkType, historyAppearsCleared, pendingUnpinnedAllMessages, pendingRemovedMessages, animatedEmojiStickers, customChannelDiscussionReadState, customThreadOutgoingReadState in func applyHole() { Queue.mainQueue().async { if let strongSelf = self { @@ -930,7 +940,7 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { let associatedData = extractAssociatedData(chatLocation: chatLocation, view: view, automaticDownloadNetworkType: networkType, animatedEmojiStickers: animatedEmojiStickers, subject: subject) - 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, pendingUnpinnedAllMessages: pendingUnpinnedAllMessages, associatedData: associatedData, updatingMedia: updatingMedia, customChannelDiscussionReadState: customChannelDiscussionReadState, customThreadOutgoingReadState: customThreadOutgoingReadState) + 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, pendingUnpinnedAllMessages: pendingUnpinnedAllMessages, pendingRemovedMessages: pendingRemovedMessages, associatedData: associatedData, updatingMedia: updatingMedia, customChannelDiscussionReadState: customChannelDiscussionReadState, customThreadOutgoingReadState: customThreadOutgoingReadState) 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)) @@ -1149,6 +1159,15 @@ public final class ChatHistoryListNode: ListView, ChatHistoryNode { } let selectionRecognizer = ChatHistoryListSelectionRecognizer(target: self, action: #selector(self.selectionPanGesture(_:))) + selectionRecognizer.shouldBegin = { [weak self] in + guard let strongSelf = self else { + return false + } + if case .pinnedMessages = strongSelf.subject { + return false + } + return true + } self.view.addGestureRecognizer(selectionRecognizer) } diff --git a/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift b/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift index a68301a3a3..7a7c16a30a 100644 --- a/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift +++ b/submodules/TelegramUI/Sources/ChatInterfaceStateContextMenus.swift @@ -111,6 +111,9 @@ private func canEditMessage(accountPeerId: PeerId, limitsConfiguration: LimitsCo } else if let _ = media as? TelegramMediaPoll { hasUneditableAttributes = true break + } else if let _ = media as? TelegramMediaDice { + hasUneditableAttributes = true + break } } @@ -687,9 +690,8 @@ func contextMenuForChatPresentationIntefaceState(chatPresentationInterfaceState: if let pinnedSelectedMessageId = pinnedSelectedMessageId { actions.append(.action(ContextMenuActionItem(text: chatPresentationInterfaceState.strings.Conversation_Unpin, icon: { theme in return generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Unpin"), color: theme.actionSheet.primaryTextColor) - }, action: { _, f in - interfaceInteraction.unpinMessage(pinnedSelectedMessageId, false) - f(.default) + }, action: { c, _ in + interfaceInteraction.unpinMessage(pinnedSelectedMessageId, false, c) }))) } else { actions.append(.action(ContextMenuActionItem(text: chatPresentationInterfaceState.strings.Conversation_Pin, icon: { theme in diff --git a/submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift index 0b20f0adef..f824386195 100644 --- a/submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageActionItemNode.swift @@ -201,7 +201,7 @@ class ChatMessageActionBubbleContentNode: ChatMessageBubbleContentNode { strongSelf.insertSubnode(imageNode, at: 0) strongSelf.insertSubnode(strongSelf.mediaBackgroundNode, at: 0) } - strongSelf.fetchDisposable.set(chatMessagePhotoInteractiveFetched(context: item.context, photoReference: .message(message: MessageReference(item.message), media: image), storeToDownloadsPeerType: nil).start()) + strongSelf.fetchDisposable.set(chatMessagePhotoInteractiveFetched(context: item.context, photoReference: .message(message: MessageReference(item.message), media: image), displayAtSize: nil, storeToDownloadsPeerType: nil).start()) let updateImageSignal = chatMessagePhoto(postbox: item.context.account.postbox, photoReference: .message(message: MessageReference(item.message), media: image), synchronousLoad: synchronousLoads) imageNode.setSignal(updateImageSignal, attemptSynchronously: synchronousLoads) diff --git a/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift index f1f856a7ad..9b895fd2d8 100644 --- a/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift @@ -722,7 +722,12 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { let dateText = stringForMessageTimestampStatus(accountPeerId: item.context.account.peerId, message: item.message, dateTimeFormat: item.presentationData.dateTimeFormat, nameDisplayOrder: item.presentationData.nameDisplayOrder, strings: item.presentationData.strings, format: .minimal, reactionCount: dateReactionCount) - let (dateAndStatusSize, dateAndStatusApply) = makeDateAndStatusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: params.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (dateAndStatusSize, dateAndStatusApply) = makeDateAndStatusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: params.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) var viaBotApply: (TextNodeLayout, () -> TextNode)? var replyInfoApply: (CGSize, () -> ChatMessageReplyInfoNode)? @@ -1274,7 +1279,7 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { return .optionalAction({ if shouldPlay { let _ = (appConfiguration - |> deliverOnMainQueue).start(next: { [weak self] appConfiguration in + |> deliverOnMainQueue).start(next: { [weak self, weak animationNode] appConfiguration in guard let strongSelf = self else { return } @@ -1282,7 +1287,7 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { for (emoji, file) in emojiSounds.sounds { if emoji.unicodeScalars.first == firstScalar { let mediaManager = item.context.sharedContext.mediaManager - let mediaPlayer = MediaPlayer(audioSessionManager: mediaManager.audioSession, postbox: item.context.account.postbox, resourceReference: .standalone(resource: file.resource), streamable: .none, video: false, preferSoftwareDecoding: false, enableSound: true, fetchAutomatically: true) + let mediaPlayer = MediaPlayer(audioSessionManager: mediaManager.audioSession, postbox: item.context.account.postbox, resourceReference: .standalone(resource: file.resource), streamable: .none, video: false, preferSoftwareDecoding: false, enableSound: true, fetchAutomatically: true, ambient: true) mediaPlayer.togglePlayPause() mediaPlayer.actionAtEnd = .action({ [weak self] in self?.mediaPlayer = nil @@ -1315,9 +1320,10 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { } } })) - break + return } } + animationNode?.play() }) } }) diff --git a/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift index a65d83d1be..c04817bb99 100644 --- a/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageAttachedContentNode.swift @@ -416,6 +416,11 @@ final class ChatMessageAttachedContentNode: ASDisplayNode { var skipStandardStatus = false + var isReplyThread = false + if case .replyThread = chatLocation { + isReplyThread = true + } + if let (media, flags) = mediaAndFlags { if let file = media as? TelegramMediaFile { if file.mimeType == "application/x-tgtheme-ios", let size = file.size, size < 16 * 1024 { @@ -424,7 +429,7 @@ final class ChatMessageAttachedContentNode: ASDisplayNode { refineContentImageLayout = refineLayout } else if file.isInstantVideo { let automaticDownload = shouldDownloadMediaAutomatically(settings: automaticDownloadSettings, peerType: associatedData.automaticDownloadPeerType, networkType: associatedData.automaticDownloadNetworkType, authorPeerId: message.author?.id, contactsPeerIds: associatedData.contactsPeerIds, media: file) - let (videoLayout, apply) = contentInstantVideoLayout(ChatMessageBubbleContentItem(context: context, controllerInteraction: controllerInteraction, message: message, read: messageRead, chatLocation: chatLocation, presentationData: presentationData, associatedData: associatedData, attributes: attributes, isItemPinned: message.tags.contains(.pinned), isItemEdited: false), constrainedSize.width - horizontalInsets.left - horizontalInsets.right, CGSize(width: 212.0, height: 212.0), .bubble, automaticDownload) + let (videoLayout, apply) = contentInstantVideoLayout(ChatMessageBubbleContentItem(context: context, controllerInteraction: controllerInteraction, message: message, read: messageRead, chatLocation: chatLocation, presentationData: presentationData, associatedData: associatedData, attributes: attributes, isItemPinned: message.tags.contains(.pinned) && !isReplyThread, isItemEdited: false), constrainedSize.width - horizontalInsets.left - horizontalInsets.right, CGSize(width: 212.0, height: 212.0), .bubble, automaticDownload) initialWidth = videoLayout.contentSize.width + videoLayout.overflowLeft + videoLayout.overflowRight contentInstantVideoSizeAndApply = (videoLayout, apply) } else if file.isVideo { @@ -474,7 +479,7 @@ final class ChatMessageAttachedContentNode: ASDisplayNode { } } - let (_, refineLayout) = contentFileLayout(context, presentationData, message, associatedData, chatLocation, attributes, message.tags.contains(.pinned) && !associatedData.isInPinnedListMode, false, file, automaticDownload, message.effectivelyIncoming(context.account.peerId), false, associatedData.forcedResourceStatus, statusType, nil, CGSize(width: constrainedSize.width - horizontalInsets.left - horizontalInsets.right, height: constrainedSize.height)) + let (_, refineLayout) = contentFileLayout(context, presentationData, message, associatedData, chatLocation, attributes, message.tags.contains(.pinned) && !associatedData.isInPinnedListMode && !isReplyThread, false, file, automaticDownload, message.effectivelyIncoming(context.account.peerId), false, associatedData.forcedResourceStatus, statusType, nil, CGSize(width: constrainedSize.width - horizontalInsets.left - horizontalInsets.right, height: constrainedSize.height)) refineContentFileLayout = refineLayout } } else if let image = media as? TelegramMediaImage { @@ -572,7 +577,7 @@ final class ChatMessageAttachedContentNode: ASDisplayNode { } } - statusSizeAndApply = statusLayout(context, presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, message.tags.contains(.pinned) && !associatedData.isInPinnedListMode) + statusSizeAndApply = statusLayout(context, presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, message.tags.contains(.pinned) && !associatedData.isInPinnedListMode && !isReplyThread) } default: break diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift index 6e15f77894..effd6a8f2d 100644 --- a/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift @@ -1088,6 +1088,12 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePreviewItemNode var needShareButton = false if case .pinnedMessages = item.associatedData.subject { needShareButton = true + for media in item.message.media { + if let _ = media as? TelegramMediaExpiredContent { + needShareButton = false + break + } + } } else if case let .replyThread(replyThreadMessage) = item.chatLocation, replyThreadMessage.effectiveTopId == item.message.id { needShareButton = false allowFullWidth = true @@ -1287,6 +1293,10 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePreviewItemNode } } + if case .replyThread = item.chatLocation { + isItemPinned = false + } + var mosaicStartIndex: Int? var mosaicRange: Range? for i in 0 ..< contentPropertiesAndPrepareLayouts.count { @@ -1526,7 +1536,12 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePreviewItemNode } } - mosaicStatusSizeAndApply = mosaicStatusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: 200.0, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + mosaicStatusSizeAndApply = mosaicStatusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: 200.0, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) } } diff --git a/submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift index e7bd4e7408..e153d05b9e 100644 --- a/submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageContactBubbleContentNode.swift @@ -196,7 +196,12 @@ class ChatMessageContactBubbleContentNode: ChatMessageBubbleContentNode { var statusApply: ((Bool) -> Void)? if let statusType = statusType { - let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: constrainedSize.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: constrainedSize.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) statusSize = size statusApply = apply } diff --git a/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift index 45caac741f..2adad28a7f 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift @@ -278,7 +278,12 @@ class ChatMessageInstantVideoItemNode: ChatMessageItemView { } } - let (videoLayout, videoApply) = makeVideoLayout(ChatMessageBubbleContentItem(context: item.context, controllerInteraction: item.controllerInteraction, message: item.message, read: item.read, chatLocation: item.chatLocation, presentationData: item.presentationData, associatedData: item.associatedData, attributes: item.content.firstMessageAttributes, isItemPinned: item.message.tags.contains(.pinned), isItemEdited: false), params.width - params.leftInset - params.rightInset - avatarInset, displaySize, .free, automaticDownload) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (videoLayout, videoApply) = makeVideoLayout(ChatMessageBubbleContentItem(context: item.context, controllerInteraction: item.controllerInteraction, message: item.message, read: item.read, chatLocation: item.chatLocation, presentationData: item.presentationData, associatedData: item.associatedData, attributes: item.content.firstMessageAttributes, isItemPinned: item.message.tags.contains(.pinned) && !isReplyThread, isItemEdited: false), params.width - params.leftInset - params.rightInset - avatarInset, displaySize, .free, automaticDownload) let videoFrame = CGRect(origin: CGPoint(x: (incoming ? (params.leftInset + layoutConstants.bubble.edgeInset + avatarInset + layoutConstants.bubble.contentInsets.left) : (params.width - params.rightInset - videoLayout.contentSize.width - layoutConstants.bubble.edgeInset - layoutConstants.bubble.contentInsets.left - deliveryFailedInset)), y: 0.0), size: videoLayout.contentSize) diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift index 562f70d5cc..02b79c940c 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInteractiveFileNode.swift @@ -832,7 +832,7 @@ final class ChatMessageInteractiveFileNode: ASDisplayNode { if isAudio && !isVoice { state = .play } else { - if adjustedProgress.isEqual(to: 1.0), (message.flags.contains(.Unsent) || wasCheck) { + if message.groupingKey != nil, adjustedProgress.isEqual(to: 1.0), (message.flags.contains(.Unsent) || wasCheck) { state = .check(appearance: nil) } else { state = .progress(value: CGFloat(adjustedProgress), cancelEnabled: true, appearance: nil) diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift index 555386be08..049f8beacd 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInteractiveInstantVideoNode.swift @@ -285,7 +285,13 @@ class ChatMessageInteractiveInstantVideoNode: ASDisplayNode { } else { maxDateAndStatusWidth = width - videoFrame.midX - 85.0 } - let (dateAndStatusSize, dateAndStatusApply) = makeDateAndStatusLayout(item.context, item.presentationData, edited && !sentViaBot, viewCount, dateText, statusType, CGSize(width: max(1.0, maxDateAndStatusWidth), height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (dateAndStatusSize, dateAndStatusApply) = makeDateAndStatusLayout(item.context, item.presentationData, edited && !sentViaBot, viewCount, dateText, statusType, CGSize(width: max(1.0, maxDateAndStatusWidth), height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) var contentSize = imageSize var dateAndStatusOverflow = false diff --git a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift b/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift index b99d2a3502..a5c1b5107e 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInteractiveMediaNode.swift @@ -486,9 +486,9 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode, GalleryItemTransitio updatedFetchControls = FetchControls(fetch: { manual in if let strongSelf = self { if !manual { - strongSelf.fetchDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: .message(message: MessageReference(message), media: image), displayAtSize: 600, storeToDownloadsPeerType: storeToDownloadsPeerType).start()) + strongSelf.fetchDisposable.set(chatMessagePhotoInteractiveFetched(context: context, photoReference: .message(message: MessageReference(message), media: image), displayAtSize: isSecretMedia ? nil : 600, storeToDownloadsPeerType: storeToDownloadsPeerType).start()) } else if let representation = largestRepresentationForPhoto(image) { - strongSelf.fetchDisposable.set(messageMediaImageInteractiveFetched(context: context, message: message, image: image, resource: representation.resource, range: representationFetchRangeForDisplayAtSize(representation: representation, dimension: 600), storeToDownloadsPeerType: storeToDownloadsPeerType).start()) + strongSelf.fetchDisposable.set(messageMediaImageInteractiveFetched(context: context, message: message, image: image, resource: representation.resource, range: representationFetchRangeForDisplayAtSize(representation: representation, dimension: isSecretMedia ? nil : 600), storeToDownloadsPeerType: storeToDownloadsPeerType).start()) } } }, cancel: { diff --git a/submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift index 210d21fde0..704fca0d38 100644 --- a/submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageMapBubbleContentNode.swift @@ -246,7 +246,12 @@ class ChatMessageMapBubbleContentNode: ChatMessageBubbleContentNode { var statusApply: ((Bool) -> Void)? if let statusType = statusType { - let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: constrainedSize.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: constrainedSize.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) statusSize = size statusApply = apply } diff --git a/submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift index c77d7457c1..2f738b6262 100644 --- a/submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageMediaBubbleContentNode.swift @@ -231,7 +231,12 @@ class ChatMessageMediaBubbleContentNode: ChatMessageBubbleContentNode { var statusApply: ((Bool) -> Void)? if let statusType = statusType { - let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: imageSize.width - 30.0, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: imageSize.width - 30.0, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) statusSize = size statusApply = apply } diff --git a/submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift index a79a1f00ce..e6962f8c09 100644 --- a/submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessagePollBubbleContentNode.swift @@ -1074,7 +1074,12 @@ class ChatMessagePollBubbleContentNode: ChatMessageBubbleContentNode { var statusApply: ((Bool) -> Void)? if let statusType = statusType { - let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) statusSize = size statusApply = apply } diff --git a/submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift index 2ea622f604..43b0b2a7bd 100644 --- a/submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageRestrictedBubbleContentNode.swift @@ -105,7 +105,12 @@ class ChatMessageRestrictedBubbleContentNode: ChatMessageBubbleContentNode { var statusApply: ((Bool) -> Void)? if let statusType = statusType { - let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && isReplyThread) statusSize = size statusApply = apply } diff --git a/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift index 6943596335..2afa4c3362 100644 --- a/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift @@ -384,7 +384,12 @@ class ChatMessageStickerItemNode: ChatMessageItemView { let dateText = stringForMessageTimestampStatus(accountPeerId: item.context.account.peerId, message: item.message, dateTimeFormat: item.presentationData.dateTimeFormat, nameDisplayOrder: item.presentationData.nameDisplayOrder, strings: item.presentationData.strings, format: .regular, reactionCount: dateReactionCount) - let (dateAndStatusSize, dateAndStatusApply) = makeDateAndStatusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: params.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (dateAndStatusSize, dateAndStatusApply) = makeDateAndStatusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, CGSize(width: params.width, height: CGFloat.greatestFiniteMagnitude), dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) var viaBotApply: (TextNodeLayout, () -> TextNode)? var replyInfoApply: (CGSize, () -> ChatMessageReplyInfoNode)? diff --git a/submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift index 57c16014f5..91dc7b9678 100644 --- a/submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageTextBubbleContentNode.swift @@ -169,7 +169,12 @@ class ChatMessageTextBubbleContentNode: ChatMessageBubbleContentNode { var statusApply: ((Bool) -> Void)? if let statusType = statusType { - let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode) + var isReplyThread = false + if case .replyThread = item.chatLocation { + isReplyThread = true + } + + let (size, apply) = statusLayout(item.context, item.presentationData, edited, viewCount, dateText, statusType, textConstrainedSize, dateReactions, dateReplies, item.message.tags.contains(.pinned) && !item.associatedData.isInPinnedListMode && !isReplyThread) statusSize = size statusApply = apply } diff --git a/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift b/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift index e8068b2e85..dccfe0125d 100644 --- a/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageWebpageBubbleContentNode.swift @@ -122,7 +122,7 @@ final class ChatMessageWebpageBubbleContentNode: ChatMessageBubbleContentNode { if let textValue = webpage.text, !textValue.isEmpty { text = textValue - var entityTypes: EnabledEntityTypes = [.url] + var entityTypes: EnabledEntityTypes = [.allUrl] switch type { case .twitter, .instagram: entityTypes.insert(.mention) diff --git a/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift b/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift index 829ab1145f..5b7b604d99 100644 --- a/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift +++ b/submodules/TelegramUI/Sources/ChatPanelInterfaceInteraction.swift @@ -95,7 +95,7 @@ final class ChatPanelInterfaceInteraction { let sendSticker: (FileMediaReference, ASDisplayNode, CGRect) -> Bool let unblockPeer: () -> Void let pinMessage: (MessageId, ContextController?) -> Void - let unpinMessage: (MessageId, Bool) -> Void + let unpinMessage: (MessageId, Bool, ContextController?) -> Void let unpinAllMessages: () -> Void let openPinnedList: (MessageId) -> Void let shareAccountContact: () -> Void @@ -174,7 +174,7 @@ final class ChatPanelInterfaceInteraction { sendSticker: @escaping (FileMediaReference, ASDisplayNode, CGRect) -> Bool, unblockPeer: @escaping () -> Void, pinMessage: @escaping (MessageId, ContextController?) -> Void, - unpinMessage: @escaping (MessageId, Bool) -> Void, + unpinMessage: @escaping (MessageId, Bool, ContextController?) -> Void, unpinAllMessages: @escaping () -> Void, openPinnedList: @escaping (MessageId) -> Void, shareAccountContact: @escaping () -> Void, diff --git a/submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift b/submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift index 0561245ff2..829513eae6 100644 --- a/submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift +++ b/submodules/TelegramUI/Sources/ChatPinnedMessageTitlePanelNode.swift @@ -325,27 +325,22 @@ final class ChatPinnedMessageTitlePanelNode: ChatTitleAccessoryPanelNode { titleStrings.append(.text(0, NSAttributedString(string: "\(strings.Conversation_PinnedMessage) ", font: Font.medium(15.0), textColor: theme.chat.inputPanel.panelControlAccentColor))) } - for media in message.media { - if let image = media as? TelegramMediaImage { - updatedMediaReference = .message(message: MessageReference(message), media: image) - if let representation = largestRepresentationForPhoto(image) { - imageDimensions = representation.dimensions.cgSize + if !message.containsSecretMedia { + for media in message.media { + if let image = media as? TelegramMediaImage { + updatedMediaReference = .message(message: MessageReference(message), media: image) + if let representation = largestRepresentationForPhoto(image) { + imageDimensions = representation.dimensions.cgSize + } + break + } else if let file = media as? TelegramMediaFile { + updatedMediaReference = .message(message: MessageReference(message), media: file) + if !file.isInstantVideo, let representation = largestImageRepresentation(file.previewRepresentations), !file.isSticker { + imageDimensions = representation.dimensions.cgSize + } + break } - break - } else if let file = media as? TelegramMediaFile { - updatedMediaReference = .message(message: MessageReference(message), media: file) - if !file.isInstantVideo, let representation = largestImageRepresentation(file.previewRepresentations), !file.isSticker { - imageDimensions = representation.dimensions.cgSize - } - break - }/* else if let poll = media as? TelegramMediaPoll { - switch poll.kind { - case .poll: - titleString = strings.Conversation_PinnedPoll - case .quiz: - titleString = strings.Conversation_PinnedQuiz - } - }*/ + } } if isReplyThread { @@ -462,7 +457,7 @@ final class ChatPinnedMessageTitlePanelNode: ChatTitleAccessoryPanelNode { @objc func closePressed() { if let interfaceInteraction = self.interfaceInteraction, let message = self.currentMessage { - interfaceInteraction.unpinMessage(message.message.id, true) + interfaceInteraction.unpinMessage(message.message.id, true, nil) } } diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsController.swift b/submodules/TelegramUI/Sources/ChatRecentActionsController.swift index f92dab1d5b..b350a848f9 100644 --- a/submodules/TelegramUI/Sources/ChatRecentActionsController.swift +++ b/submodules/TelegramUI/Sources/ChatRecentActionsController.swift @@ -100,7 +100,7 @@ final class ChatRecentActionsController: TelegramBaseController { return false }, unblockPeer: { }, pinMessage: { _, _ in - }, unpinMessage: { _, _ in + }, unpinMessage: { _, _, _ in }, unpinAllMessages: { }, openPinnedList: { _ in }, shareAccountContact: { diff --git a/submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift b/submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift index e3d815934e..b4c5fd7b3a 100644 --- a/submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift +++ b/submodules/TelegramUI/Sources/ChatRecordingPreviewInputPanelNode.swift @@ -176,7 +176,7 @@ final class ChatRecordingPreviewInputPanelNode: ChatInputPanelNode { |> deliverOnMainQueue).start(next: { [weak self] status in if let strongSelf = self { switch status.status { - case .playing, .buffering(_, true, _): + case .playing, .buffering(_, true, _, _): strongSelf.playButton.isHidden = true default: strongSelf.playButton.isHidden = false diff --git a/submodules/TelegramUI/Sources/ManagedAudioRecorder.swift b/submodules/TelegramUI/Sources/ManagedAudioRecorder.swift index a01bc652a3..58c481129a 100644 --- a/submodules/TelegramUI/Sources/ManagedAudioRecorder.swift +++ b/submodules/TelegramUI/Sources/ManagedAudioRecorder.swift @@ -214,7 +214,7 @@ final class ManagedAudioRecorderContext { } return ActionDisposable { } - }), playAndRecord: true, forceAudioToSpeaker: false, baseRate: 1.0, audioLevelPipe: ValuePipe(), updatedRate: { + }), playAndRecord: true, ambient: false, forceAudioToSpeaker: false, baseRate: 1.0, audioLevelPipe: ValuePipe(), updatedRate: { }, audioPaused: {}) self.toneRenderer = toneRenderer diff --git a/submodules/TelegramUI/Sources/MediaManager.swift b/submodules/TelegramUI/Sources/MediaManager.swift index 988498fede..eddeac9ad9 100644 --- a/submodules/TelegramUI/Sources/MediaManager.swift +++ b/submodules/TelegramUI/Sources/MediaManager.swift @@ -150,7 +150,7 @@ public final class MediaManagerImpl: NSObject, MediaManager { switch value.status.status { case .playing: isPlaying = true - case .buffering(_, true, _): + case .buffering(_, true, _, _): isPlaying = true default: break @@ -230,7 +230,7 @@ public final class MediaManagerImpl: NSObject, MediaManager { updatedGlobalControlOptions.insert(.next) updatedGlobalControlOptions.insert(.seek) switch state.status.status { - case .playing, .buffering(_, true, _): + case .playing, .buffering(_, true, _, _): updatedGlobalControlOptions.insert(.pause) default: updatedGlobalControlOptions.insert(.play) @@ -384,7 +384,7 @@ public final class MediaManagerImpl: NSObject, MediaManager { switch state.status.status { case .playing: isPlaying = true - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, _): isPlaying = whilePlaying default: break diff --git a/submodules/TelegramUI/Sources/OpenChatMessage.swift b/submodules/TelegramUI/Sources/OpenChatMessage.swift index 14dd37df87..99d23e3b4b 100644 --- a/submodules/TelegramUI/Sources/OpenChatMessage.swift +++ b/submodules/TelegramUI/Sources/OpenChatMessage.swift @@ -73,7 +73,7 @@ func openChatMessageImpl(_ params: OpenChatMessageParams) -> Bool { params.context.liveLocationManager?.cancelLiveLocation(peerId: messageId?.peerId ?? params.message.id.peerId) }, openUrl: params.openUrl, openPeer: { peer in params.openPeer(peer, .info) - }) + }, showAll: params.modal) let controller = LocationViewController(context: params.context, subject: params.message, params: controllerParams) controller.navigationPresentation = .modal params.navigationController?.pushViewController(controller) diff --git a/submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift b/submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift index f513a740b7..a6147e20ff 100644 --- a/submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift +++ b/submodules/TelegramUI/Sources/OverlayPlayerControlsNode.swift @@ -304,7 +304,7 @@ final class OverlayPlayerControlsNode: ASDisplayNode { isPaused = false case .paused: isPaused = true - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, _): isPaused = !whilePlaying } if strongSelf.currentIsPaused != isPaused { diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift index cd6d5b2961..f96aa5d52f 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift @@ -311,7 +311,7 @@ final class PeerInfoAvatarListItemNode: ASDisplayNode { var bufferingProgress: Float? if isMediaStreamable(resource: videoContent.fileReference.media.resource) { if let playerStatus = self.playerStatus { - if case let .buffering(_, _, progress) = playerStatus.status { + if case let .buffering(_, _, progress, _) = playerStatus.status { bufferingProgress = progress } else if case .playing = playerStatus.status { bufferingProgress = nil diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift index e7f55c474e..a536be47e3 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift @@ -406,7 +406,7 @@ final class PeerInfoSelectionPanelNode: ASDisplayNode { return false }, unblockPeer: { }, pinMessage: { _, _ in - }, unpinMessage: { _, _ in + }, unpinMessage: { _, _, _ in }, unpinAllMessages: { }, openPinnedList: { _ in }, shareAccountContact: { @@ -621,7 +621,8 @@ private final class PeerInfoInteraction { } } -private let enabledBioEntities: EnabledEntityTypes = [.url, .mention, .hashtag] +private let enabledPublicBioEntities: EnabledEntityTypes = [.allUrl, .mention, .hashtag] +private let enabledPrivateBioEntities: EnabledEntityTypes = [.internalUrl, .mention, .hashtag] private enum SettingsSection: Int, CaseIterable { case edit @@ -927,11 +928,11 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese } 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.Profile_BotInfo, 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: { + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: user.botInfo == nil ? presentationData.strings.Profile_About : presentationData.strings.Profile_BotInfo, text: user.botInfo != nil ? presentationData.strings.UserInfo_ScamBotWarning : presentationData.strings.UserInfo_ScamUserWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: user.botInfo != nil ? enabledPrivateBioEntities : []), 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.Profile_BotInfo, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: user.botInfo == nil ? presentationData.strings.Profile_About : presentationData.strings.Profile_BotInfo, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledPrivateBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { interaction.requestLayout() })) } @@ -1015,11 +1016,11 @@ private func infoItems(data: PeerInfoScreenData?, context: AccountContext, prese } 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, requestLayout: { + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: ItemAbout, label: presentationData.strings.Channel_AboutItem, text: presentationData.strings.GroupInfo_ScamGroupWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledPublicBioEntities), 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, requestLayout: { + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: ItemAbout, label: presentationData.strings.Channel_AboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledPublicBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { interaction.requestLayout() })) } @@ -1051,11 +1052,11 @@ 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.PeerInfo_GroupAboutItem, text: presentationData.strings.GroupInfo_ScamGroupWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, requestLayout: { + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: presentationData.strings.PeerInfo_GroupAboutItem, text: presentationData.strings.GroupInfo_ScamGroupWarning, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledPublicBioEntities), action: nil, requestLayout: { interaction.requestLayout() })) } else if let about = cachedData.about, !about.isEmpty { - items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: presentationData.strings.PeerInfo_GroupAboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { + items[.peerInfo]!.append(PeerInfoScreenLabeledValueItem(id: 0, label: presentationData.strings.PeerInfo_GroupAboutItem, text: about, textColor: .primary, textBehavior: .multiLine(maxLines: 100, enabledEntities: enabledPublicBioEntities), action: nil, longTapAction: bioContextAction, linkItemAction: bioLinkAction, requestLayout: { interaction.requestLayout() })) } diff --git a/submodules/TelegramUniversalVideoContent/Sources/GenericEmbedImplementation.swift b/submodules/TelegramUniversalVideoContent/Sources/GenericEmbedImplementation.swift index 65dae43824..ce2f67df30 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/GenericEmbedImplementation.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/GenericEmbedImplementation.swift @@ -14,7 +14,7 @@ final class GenericEmbedImplementation: WebEmbedImplementation { init(url: String) { self.url = url - self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0), soundEnabled: true) + self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0, display: true), soundEnabled: true) } func setup(_ webView: WKWebView, userContentController: WKUserContentController, evaluateJavaScript: @escaping (String, ((Any?) -> Void)?) -> Void, updateStatus: @escaping (MediaPlayerStatus) -> Void, onPlaybackStarted: @escaping () -> Void) { diff --git a/submodules/TelegramUniversalVideoContent/Sources/NativeVideoContent.swift b/submodules/TelegramUniversalVideoContent/Sources/NativeVideoContent.swift index 50b894e390..672c0e7060 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/NativeVideoContent.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/NativeVideoContent.swift @@ -451,4 +451,7 @@ private final class NativeVideoContentNode: ASDisplayNode, UniversalVideoContent self.postbox.mediaBox.cancelInteractiveResourceFetch(self.fileReference.media.resource) } } + + func notifyPlaybackControlsHidden(_ hidden: Bool) { + } } diff --git a/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift b/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift index fd483dae68..e3be01867d 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/PictureInPictureVideoControlsNode.swift @@ -37,7 +37,7 @@ final class PictureInPictureVideoControlsNode: ASDisplayNode { case .playing: self.playButton.isHidden = true self.pauseButton.isHidden = false - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, _): if whilePlaying { self.playButton.isHidden = true self.pauseButton.isHidden = false diff --git a/submodules/TelegramUniversalVideoContent/Sources/PlatformVideoContent.swift b/submodules/TelegramUniversalVideoContent/Sources/PlatformVideoContent.swift index 517a7fef05..d648892809 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/PlatformVideoContent.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/PlatformVideoContent.swift @@ -315,7 +315,7 @@ private final class PlatformVideoContentNode: ASDisplayNode, UniversalVideoConte self.isBuffering = false } if self.isBuffering { - status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0) + status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0, display: true) } else { status = isPlaying ? .playing : .paused } @@ -326,7 +326,7 @@ private final class PlatformVideoContentNode: ASDisplayNode, UniversalVideoConte let status: MediaPlayerPlaybackStatus self.isBuffering = true if self.isBuffering { - status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0) + status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0, display: true) } else { status = isPlaying ? .playing : .paused } @@ -337,7 +337,7 @@ private final class PlatformVideoContentNode: ASDisplayNode, UniversalVideoConte let status: MediaPlayerPlaybackStatus self.isBuffering = false if self.isBuffering { - status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0) + status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0, display: true) } else { status = isPlaying ? .playing : .paused } @@ -381,7 +381,7 @@ private final class PlatformVideoContentNode: ASDisplayNode, UniversalVideoConte func play() { assert(Queue.mainQueue().isCurrent()) if !self.initializedStatus { - self._status.set(MediaPlayerStatus(generationTimestamp: 0.0, duration: Double(self.approximateDuration), dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0), soundEnabled: true)) + self._status.set(MediaPlayerStatus(generationTimestamp: 0.0, duration: Double(self.approximateDuration), dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0, display: true), soundEnabled: true)) } if !self.hasAudioSession { self.audioSessionDisposable.set(self.audioSessionManager.push(audioSessionType: .play, activate: { [weak self] _ in @@ -448,4 +448,7 @@ private final class PlatformVideoContentNode: ASDisplayNode, UniversalVideoConte func fetchControl(_ control: UniversalVideoNodeFetchControl) { } + + func notifyPlaybackControlsHidden(_ hidden: Bool) { + } } diff --git a/submodules/TelegramUniversalVideoContent/Sources/SystemVideoContent.swift b/submodules/TelegramUniversalVideoContent/Sources/SystemVideoContent.swift index 629adfe05a..71182c06ab 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/SystemVideoContent.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/SystemVideoContent.swift @@ -44,7 +44,7 @@ private final class SystemVideoContentNode: ASDisplayNode, UniversalVideoContent private let playbackCompletedListeners = Bag<() -> Void>() private var initializedStatus = false - private var statusValue = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: false, progress: 0.0), soundEnabled: true) + private var statusValue = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: false, progress: 0.0, display: true), soundEnabled: true) private var isBuffering = true private let _status = ValuePromise() var status: Signal { @@ -169,7 +169,7 @@ private final class SystemVideoContentNode: ASDisplayNode, UniversalVideoContent let isPlaying = !self.player.rate.isZero let status: MediaPlayerPlaybackStatus if self.isBuffering { - status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0) + status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0, display: true) } else { status = isPlaying ? .playing : .paused } @@ -180,7 +180,7 @@ private final class SystemVideoContentNode: ASDisplayNode, UniversalVideoContent let status: MediaPlayerPlaybackStatus self.isBuffering = true if self.isBuffering { - status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0) + status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0, display: true) } else { status = isPlaying ? .playing : .paused } @@ -191,7 +191,7 @@ private final class SystemVideoContentNode: ASDisplayNode, UniversalVideoContent let status: MediaPlayerPlaybackStatus self.isBuffering = false if self.isBuffering { - status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0) + status = .buffering(initial: false, whilePlaying: isPlaying, progress: 0.0, display: true) } else { status = isPlaying ? .playing : .paused } @@ -219,7 +219,7 @@ private final class SystemVideoContentNode: ASDisplayNode, UniversalVideoContent func play() { assert(Queue.mainQueue().isCurrent()) if !self.initializedStatus { - self._status.set(MediaPlayerStatus(generationTimestamp: 0.0, duration: Double(self.approximateDuration), dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: self.seekId, status: .buffering(initial: true, whilePlaying: true, progress: 0.0), soundEnabled: true)) + self._status.set(MediaPlayerStatus(generationTimestamp: 0.0, duration: Double(self.approximateDuration), dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: self.seekId, status: .buffering(initial: true, whilePlaying: true, progress: 0.0, display: true), soundEnabled: true)) } if !self.hasAudioSession { self.audioSessionDisposable.set(self.audioSessionManager.push(audioSessionType: .play, activate: { [weak self] _ in @@ -287,5 +287,8 @@ private final class SystemVideoContentNode: ASDisplayNode, UniversalVideoContent func fetchControl(_ control: UniversalVideoNodeFetchControl) { } + + func notifyPlaybackControlsHidden(_ hidden: Bool) { + } } diff --git a/submodules/TelegramUniversalVideoContent/Sources/TwitchEmbedImplementation.swift b/submodules/TelegramUniversalVideoContent/Sources/TwitchEmbedImplementation.swift index 4c4041c36e..85fb56e6ba 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/TwitchEmbedImplementation.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/TwitchEmbedImplementation.swift @@ -20,7 +20,7 @@ final class TwitchEmbedImplementation: WebEmbedImplementation { init(url: String) { self.url = url - self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0), soundEnabled: true) + self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: 0.0, baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0, display: true), soundEnabled: true) } func setup(_ webView: WKWebView, userContentController: WKUserContentController, evaluateJavaScript: @escaping (String, ((Any?) -> Void)?) -> Void, updateStatus: @escaping (MediaPlayerStatus) -> Void, onPlaybackStarted: @escaping () -> Void) { diff --git a/submodules/TelegramUniversalVideoContent/Sources/VimeoEmbedImplementation.swift b/submodules/TelegramUniversalVideoContent/Sources/VimeoEmbedImplementation.swift index a1af6625ff..bd0db6638f 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/VimeoEmbedImplementation.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/VimeoEmbedImplementation.swift @@ -97,7 +97,7 @@ final class VimeoEmbedImplementation: WebEmbedImplementation { init(videoId: String, timestamp: Int = 0) { self.videoId = videoId self.timestamp = timestamp - self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: Double(timestamp), baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0), soundEnabled: true) + self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: Double(timestamp), baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0, display: true), soundEnabled: true) } func setup(_ webView: WKWebView, userContentController: WKUserContentController, evaluateJavaScript: @escaping (String, ((Any?) -> Void)?) -> Void, updateStatus: @escaping (MediaPlayerStatus) -> Void, onPlaybackStarted: @escaping () -> Void) { @@ -221,7 +221,7 @@ final class VimeoEmbedImplementation: WebEmbedImplementation { playbackStatus = .paused newTimestamp = 0.0 default: - playbackStatus = .buffering(initial: true, whilePlaying: false, progress: 0.0) + playbackStatus = .buffering(initial: true, whilePlaying: false, progress: 0.0, display: true) } self.status = MediaPlayerStatus(generationTimestamp: self.status.generationTimestamp, duration: Double(duration), dimensions: self.status.dimensions, timestamp: newTimestamp, baseRate: 1.0, seekId: self.status.seekId, status: playbackStatus, soundEnabled: true) diff --git a/submodules/TelegramUniversalVideoContent/Sources/WebEmbedPlayerNode.swift b/submodules/TelegramUniversalVideoContent/Sources/WebEmbedPlayerNode.swift index a1befcddf1..fb7c4e070e 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/WebEmbedPlayerNode.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/WebEmbedPlayerNode.swift @@ -211,4 +211,10 @@ final class WebEmbedPlayerNode: ASDisplayNode, WKNavigationDelegate { } } } + + func notifyPlaybackControlsHidden(_ hidden: Bool) { + if impl is YoutubeEmbedImplementation { + self.webView.isUserInteractionEnabled = !hidden + } + } } diff --git a/submodules/TelegramUniversalVideoContent/Sources/WebEmbedVideoContent.swift b/submodules/TelegramUniversalVideoContent/Sources/WebEmbedVideoContent.swift index 705ad529b6..d5aa2686a0 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/WebEmbedVideoContent.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/WebEmbedVideoContent.swift @@ -184,4 +184,8 @@ final class WebEmbedVideoContentNode: ASDisplayNode, UniversalVideoContentNode { func fetchControl(_ control: UniversalVideoNodeFetchControl) { } + + func notifyPlaybackControlsHidden(_ hidden: Bool) { + self.playerNode.notifyPlaybackControlsHidden(hidden) + } } diff --git a/submodules/TelegramUniversalVideoContent/Sources/YoutubeEmbedImplementation.swift b/submodules/TelegramUniversalVideoContent/Sources/YoutubeEmbedImplementation.swift index 7bb56feac0..c9140d8af9 100644 --- a/submodules/TelegramUniversalVideoContent/Sources/YoutubeEmbedImplementation.swift +++ b/submodules/TelegramUniversalVideoContent/Sources/YoutubeEmbedImplementation.swift @@ -101,7 +101,7 @@ final class YoutubeEmbedImplementation: WebEmbedImplementation { private var timestamp: Int private var ignoreEarlierTimestamps = false - private var status : MediaPlayerStatus + private var status: MediaPlayerStatus private var ready = false private var started = false @@ -117,11 +117,11 @@ final class YoutubeEmbedImplementation: WebEmbedImplementation { init(videoId: String, timestamp: Int = 0) { self.videoId = videoId - self.timestamp = 0 + self.timestamp = timestamp if self.timestamp > 0 { self.ignoreEarlierTimestamps = true } - self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: Double(timestamp), baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0), soundEnabled: true) + self.status = MediaPlayerStatus(generationTimestamp: 0.0, duration: 0.0, dimensions: CGSize(), timestamp: Double(timestamp), baseRate: 1.0, seekId: 0, status: .buffering(initial: true, whilePlaying: true, progress: 0.0, display: true), soundEnabled: true) self.benchmarkStartTime = CFAbsoluteTimeGetCurrent() } @@ -286,16 +286,16 @@ final class YoutubeEmbedImplementation: WebEmbedImplementation { playbackStatus = .paused newTimestamp = 0.0 } else { - playbackStatus = .buffering(initial: false, whilePlaying: true, progress: 0.0) + playbackStatus = .buffering(initial: false, whilePlaying: true, progress: 0.0, display: false) } case 1: playbackStatus = .playing case 2: playbackStatus = .paused case 3: - playbackStatus = .buffering(initial: false, whilePlaying: true, progress: 0.0) + playbackStatus = .buffering(initial: false, whilePlaying: true, progress: 0.0, display: false) default: - playbackStatus = .buffering(initial: true, whilePlaying: false, progress: 0.0) + playbackStatus = .buffering(initial: true, whilePlaying: false, progress: 0.0, display: false) } if case .playing = playbackStatus, !self.started { diff --git a/submodules/TextFormat/Sources/GenerateTextEntities.swift b/submodules/TextFormat/Sources/GenerateTextEntities.swift index 6fa025aa5d..8121c86b23 100644 --- a/submodules/TextFormat/Sources/GenerateTextEntities.swift +++ b/submodules/TextFormat/Sources/GenerateTextEntities.swift @@ -85,12 +85,13 @@ public struct EnabledEntityTypes: OptionSet { public static let command = EnabledEntityTypes(rawValue: 1 << 0) public static let mention = EnabledEntityTypes(rawValue: 1 << 1) public static let hashtag = EnabledEntityTypes(rawValue: 1 << 2) - public static let url = EnabledEntityTypes(rawValue: 1 << 3) + public static let allUrl = EnabledEntityTypes(rawValue: 1 << 3) public static let phoneNumber = EnabledEntityTypes(rawValue: 1 << 4) public static let timecode = EnabledEntityTypes(rawValue: 1 << 5) public static let external = EnabledEntityTypes(rawValue: 1 << 6) + public static let internalUrl = EnabledEntityTypes(rawValue: 1 << 7) - public static let all: EnabledEntityTypes = [.command, .mention, .hashtag, .url, .phoneNumber] + public static let all: EnabledEntityTypes = [.command, .mention, .hashtag, .allUrl, .phoneNumber] } private func commitEntity(_ utf16: String.UTF16View, _ type: CurrentEntityType, _ range: Range, _ enabledTypes: EnabledEntityTypes, _ entities: inout [MessageTextEntity], mediaDuration: Double? = nil) { @@ -160,11 +161,11 @@ public func generateTextEntities(_ text: String, enabledTypes: EnabledEntityType let utf16 = text.utf16 var detector: NSDataDetector? - if enabledTypes.contains(.phoneNumber) && enabledTypes.contains(.url) { + if enabledTypes.contains(.phoneNumber) && (enabledTypes.contains(.allUrl) || enabledTypes.contains(.internalUrl)) { detector = dataAndPhoneNumberDetector } else if enabledTypes.contains(.phoneNumber) { detector = phoneNumberDetector - } else if enabledTypes.contains(.url) { + } else if enabledTypes.contains(.allUrl) || enabledTypes.contains(.internalUrl) { detector = dataDetector } @@ -179,6 +180,21 @@ public func generateTextEntities(_ text: String, enabledTypes: EnabledEntityType if let lowerBound = lowerBound, let upperBound = upperBound { let type: MessageTextEntityType if result.resultType == NSTextCheckingResult.CheckingType.link { + if !enabledTypes.contains(.allUrl) && enabledTypes.contains(.internalUrl) { + guard let url = result.url else { + return + } + if url.scheme != "tg" { + guard let host = url.host?.lowercased() else { + return + } + if host == "telegram.org" || host == "t.me" { + } else { + return + } + } + } + type = .Url } else { type = .PhoneNumber diff --git a/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift b/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift index 4ce6a36057..739053cb79 100644 --- a/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift +++ b/submodules/WebSearchUI/Sources/WebSearchVideoGalleryItem.swift @@ -198,7 +198,7 @@ final class WebSearchVideoGalleryItemNode: ZoomableContentGalleryItemNode { switch value.status { case .playing: isPaused = false - case let .buffering(_, whilePlaying, _): + case let .buffering(_, whilePlaying, _, _): initialBuffering = true isPaused = !whilePlaying var isStreaming = false