diff --git a/Telegram-iOS/en.lproj/Localizable.strings b/Telegram-iOS/en.lproj/Localizable.strings index 6c0b192097..d386bc8889 100644 --- a/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram-iOS/en.lproj/Localizable.strings @@ -5186,4 +5186,10 @@ Any member of this group will be able to see messages in the channel."; "AuthSessions.AddDevice.UrlLoginHint" = "This code can be used to allow someone to log in to your Telegram account.\n\nTo confirm Telegram login, please go to Settings > Devices > Scan QR and scan the code."; +"Appearance.RemoveThemeColor" = "Remove Color"; + +"WallpaperPreview.PatternTitle" = "Choose Pattern"; +"WallpaperPreview.PatternPaternDiscard" = "Discard"; +"WallpaperPreview.PatternPaternApply" = "Apply"; + "ChatContextMenu.TextSelectionTip" = "Hold a word, then move cursor to select more| text to copy."; diff --git a/submodules/AvatarNode/Sources/AvatarNode.swift b/submodules/AvatarNode/Sources/AvatarNode.swift index ed3b966b9f..4b8924e900 100644 --- a/submodules/AvatarNode/Sources/AvatarNode.swift +++ b/submodules/AvatarNode/Sources/AvatarNode.swift @@ -449,7 +449,12 @@ public final class AvatarNode: ASDisplayNode { colorsArray = grayscaleColors } } else if colorIndex == -1 { - colorsArray = grayscaleColors + if let parameters = parameters as? AvatarNodeParameters, let theme = parameters.theme { + let colors = theme.chatList.unpinnedArchiveAvatarColor.backgroundColors.colors + colorsArray = [colors.1.cgColor, colors.0.cgColor] + } else { + colorsArray = grayscaleColors + } } else { colorsArray = gradientColors[colorIndex % gradientColors.count] } diff --git a/submodules/Display/Display/ListView.swift b/submodules/Display/Display/ListView.swift index 70ad620f7f..ea7a37522d 100644 --- a/submodules/Display/Display/ListView.swift +++ b/submodules/Display/Display/ListView.swift @@ -3799,9 +3799,9 @@ open class ListView: ASDisplayNode, UIScrollViewAccessibilityDelegate, UIGesture if node.apparentHeight > self.visibleSize.height - self.insets.top - self.insets.bottom { if node.frame.maxY > self.visibleSize.height - self.insets.bottom { self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: ListViewScrollToItem(index: index, position: ListViewScrollPosition.bottom(-overflow), animated: animated, curve: ListViewAnimationCurve.Default(duration: 0.25), directionHint: ListViewScrollToItemDirectionHint.Down), updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) - }/* else if node.frame.minY < self.insets.top { - self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: ListViewScrollToItem(index: index, position: ListViewScrollPosition.top(0.0), animated: true, curve: ListViewAnimationCurve.Default(duration: 0.25), directionHint: ListViewScrollToItemDirectionHint.Up), updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) - }*/ + } else if node.frame.minY < self.insets.top && overflow > 0.0 { + self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: ListViewScrollToItem(index: index, position: ListViewScrollPosition.top(-overflow), animated: true, curve: ListViewAnimationCurve.Default(duration: 0.25), directionHint: ListViewScrollToItemDirectionHint.Up), updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) + } } else { if self.experimentalSnapScrollToItem { self.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: ListViewDeleteAndInsertOptions(), scrollToItem: ListViewScrollToItem(index: index, position: ListViewScrollPosition.visible, animated: animated, curve: ListViewAnimationCurve.Default(duration: nil), directionHint: ListViewScrollToItemDirectionHint.Up), updateSizeAndInsets: nil, stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) diff --git a/submodules/Display/Display/TransformImageArguments.swift b/submodules/Display/Display/TransformImageArguments.swift index a7b1f64d25..122de00a10 100644 --- a/submodules/Display/Display/TransformImageArguments.swift +++ b/submodules/Display/Display/TransformImageArguments.swift @@ -7,6 +7,10 @@ public enum TransformImageResizeMode { case blurBackground } +public protocol TransformImageCustomArguments { + func serialized() -> NSArray +} + public struct TransformImageArguments: Equatable { public let corners: ImageCorners @@ -15,15 +19,17 @@ public struct TransformImageArguments: Equatable { public let intrinsicInsets: UIEdgeInsets public let resizeMode: TransformImageResizeMode public let emptyColor: UIColor? + public let custom: TransformImageCustomArguments? public let scale: CGFloat? - public init(corners: ImageCorners, imageSize: CGSize, boundingSize: CGSize, intrinsicInsets: UIEdgeInsets, resizeMode: TransformImageResizeMode = .fill(.black), emptyColor: UIColor? = nil, scale: CGFloat? = nil) { + public init(corners: ImageCorners, imageSize: CGSize, boundingSize: CGSize, intrinsicInsets: UIEdgeInsets, resizeMode: TransformImageResizeMode = .fill(.black), emptyColor: UIColor? = nil, custom: TransformImageCustomArguments? = nil, scale: CGFloat? = nil) { self.corners = corners self.imageSize = imageSize self.boundingSize = boundingSize self.intrinsicInsets = intrinsicInsets self.resizeMode = resizeMode self.emptyColor = emptyColor + self.custom = custom self.scale = scale } @@ -43,6 +49,14 @@ public struct TransformImageArguments: Equatable { } public static func ==(lhs: TransformImageArguments, rhs: TransformImageArguments) -> Bool { - return lhs.imageSize == rhs.imageSize && lhs.boundingSize == rhs.boundingSize && lhs.corners == rhs.corners && lhs.emptyColor == rhs.emptyColor + var result = lhs.imageSize == rhs.imageSize && lhs.boundingSize == rhs.boundingSize && lhs.corners == rhs.corners && lhs.emptyColor == rhs.emptyColor + if result { + if let lhsCustom = lhs.custom, let rhsCustom = rhs.custom { + return lhsCustom.serialized().isEqual(rhsCustom.serialized()) + } else { + return (lhs.custom != nil) == (rhs.custom != nil) + } + } + return result } } diff --git a/submodules/Display/Display/WallpaperBackgroundNode.swift b/submodules/Display/Display/WallpaperBackgroundNode.swift index fb3f47874a..203f3632de 100644 --- a/submodules/Display/Display/WallpaperBackgroundNode.swift +++ b/submodules/Display/Display/WallpaperBackgroundNode.swift @@ -81,7 +81,7 @@ public final class WallpaperBackgroundNode: ASDisplayNode { } public func updateLayout(size: CGSize, transition: ContainedViewLayoutTransition) { - let isFirstLayout = self.frame.isEmpty + let isFirstLayout = self.contentNode.frame.isEmpty transition.updatePosition(node: self.contentNode, position: CGPoint(x: size.width / 2.0, y: size.height / 2.0)) transition.updateBounds(node: self.contentNode, bounds: CGRect(origin: CGPoint(), size: size)) diff --git a/submodules/ItemListPeerItem/Sources/ItemListPeerItem.swift b/submodules/ItemListPeerItem/Sources/ItemListPeerItem.swift index 8f168ee150..c8018f245a 100644 --- a/submodules/ItemListPeerItem/Sources/ItemListPeerItem.swift +++ b/submodules/ItemListPeerItem/Sources/ItemListPeerItem.swift @@ -563,8 +563,8 @@ public class ItemListPeerItemNode: ItemListRevealOptionsItemNode, ItemListItemNo let (labelLayout, labelApply) = makeLabelLayout(TextNodeLayoutArguments(attributedString: labelAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - 16.0 - editingOffset - rightInset, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) - let (titleLayout, titleApply) = makeTitleLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - 12.0 - editingOffset - rightInset - labelLayout.size.width, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) - let (statusLayout, statusApply) = makeStatusLayout(TextNodeLayoutArguments(attributedString: statusAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - 8.0 - editingOffset - rightInset - labelLayout.size.width, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let (titleLayout, titleApply) = makeTitleLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - 12.0 - editingOffset - rightInset - labelLayout.size.width - labelInset, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) + let (statusLayout, statusApply) = makeStatusLayout(TextNodeLayoutArguments(attributedString: statusAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width - leftInset - 8.0 - editingOffset - rightInset - labelLayout.size.width - labelInset, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) var insets = itemListNeighborsGroupedInsets(neighbors) if !item.hasTopGroupInset { diff --git a/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift b/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift index a0b99ae1b0..ce9b4ead41 100644 --- a/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift +++ b/submodules/LiveLocationPositionNode/Sources/ChatMessageLiveLocationPositionNode.swift @@ -148,8 +148,10 @@ public final class ChatMessageLiveLocationPositionNode: ASDisplayNode { strongSelf.iconNode.setSignal(venueIcon(postbox: context.account.postbox, type: updatedVenueType, background: false)) } + + let arguments = VenueIconArguments(defaultForegroundColor: theme.chat.inputPanel.actionControlForegroundColor) let iconSize = CGSize(width: 44.0, height: 44.0) - let apply = iconLayout(TransformImageArguments(corners: ImageCorners(), imageSize: iconSize, boundingSize: iconSize, intrinsicInsets: UIEdgeInsets())) + let apply = iconLayout(TransformImageArguments(corners: ImageCorners(), imageSize: iconSize, boundingSize: iconSize, intrinsicInsets: UIEdgeInsets(), custom: arguments)) apply() strongSelf.iconNode.frame = CGRect(origin: CGPoint(x: 9.0, y: 14.0), size: iconSize) diff --git a/submodules/LocationResources/Sources/VenueIconResources.swift b/submodules/LocationResources/Sources/VenueIconResources.swift index e4261cb88e..4384acda86 100644 --- a/submodules/LocationResources/Sources/VenueIconResources.swift +++ b/submodules/LocationResources/Sources/VenueIconResources.swift @@ -154,6 +154,20 @@ public func venueIconColor(type: String) -> UIColor { return randomColors[index] } +public struct VenueIconArguments: TransformImageCustomArguments { + let defaultForegroundColor: UIColor + + public init(defaultForegroundColor: UIColor) { + self.defaultForegroundColor = defaultForegroundColor + } + + public func serialized() -> NSArray { + let array = NSMutableArray() + array.add(self.defaultForegroundColor) + return array + } +} + public func venueIcon(postbox: Postbox, type: String, background: Bool) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { let isBuiltinIcon = ["", "home", "work"].contains(type) let data: Signal = isBuiltinIcon ? .single(nil) : venueIconData(postbox: postbox, resource: VenueIconResource(type: type)) @@ -167,8 +181,13 @@ public func venueIcon(postbox: Postbox, type: String, background: Bool) -> Signa } let backgroundColor = venueIconColor(type: type) - let foregroundColor = UIColor.white - + let foregroundColor: UIColor + if type.isEmpty, let customArguments = arguments.custom as? VenueIconArguments { + foregroundColor = customArguments.defaultForegroundColor + } else { + foregroundColor = UIColor.white + } + context.withFlippedContext { c in if background { c.setFillColor(backgroundColor.cgColor) diff --git a/submodules/LocationUI/Sources/LocationActionListItem.swift b/submodules/LocationUI/Sources/LocationActionListItem.swift index 20082b8dcd..52ac179b82 100644 --- a/submodules/LocationUI/Sources/LocationActionListItem.swift +++ b/submodules/LocationUI/Sources/LocationActionListItem.swift @@ -73,7 +73,7 @@ private func generateLiveLocationIcon(theme: PresentationTheme) -> UIImage { 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/SendLiveLocationIcon"), color: theme.chat.inputPanel.actionControlForegroundColor) { + if let image = generateTintedImage(image: UIImage(bundleImageName: "Location/SendLiveLocationIcon"), color: .white) { 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 490994ab4c..4dd1184bac 100644 --- a/submodules/LocationUI/Sources/LocationAnnotation.swift +++ b/submodules/LocationUI/Sources/LocationAnnotation.swift @@ -97,6 +97,7 @@ class LocationPinAnnotationView: MKAnnotationView { var strokeLabelNode: ImmediateTextNode? var labelNode: ImmediateTextNode? + var initialized = false var appeared = false var animating = false @@ -203,6 +204,11 @@ class LocationPinAnnotationView: MKAnnotationView { if annotation.forcedSelection { self.setSelected(true, animated: false) } + + if self.initialized && !self.appeared { + self.appeared = true + self.animateAppearance() + } } } } @@ -211,6 +217,7 @@ class LocationPinAnnotationView: MKAnnotationView { override func prepareForReuse() { self.smallNode.isHidden = true self.backgroundNode.isHidden = false + self.appeared = false } override func setSelected(_ selected: Bool, animated: Bool) { @@ -516,6 +523,10 @@ class LocationPinAnnotationView: MKAnnotationView { } func animateAppearance() { + guard let annotation = self.annotation as? LocationPinAnnotation, annotation.location != nil && !annotation.forcedSelection else { + return + } + self.smallNode.transform = CATransform3DMakeScale(0.1, 0.1, 1.0) let avatarNodeTransform = self.avatarNode?.transform @@ -546,8 +557,13 @@ class LocationPinAnnotationView: MKAnnotationView { let smallIconApply = smallIconLayout(TransformImageArguments(corners: ImageCorners(), imageSize: self.smallIconNode.bounds.size, boundingSize: self.smallIconNode.bounds.size, intrinsicInsets: UIEdgeInsets())) smallIconApply() + var arguments: VenueIconArguments? + if let annotation = self.annotation as? LocationPinAnnotation { + arguments = VenueIconArguments(defaultForegroundColor: annotation.theme.chat.inputPanel.actionControlForegroundColor) + } + let iconLayout = self.iconNode.asyncLayout() - let iconApply = iconLayout(TransformImageArguments(corners: ImageCorners(), imageSize: self.iconNode.bounds.size, boundingSize: self.iconNode.bounds.size, intrinsicInsets: UIEdgeInsets())) + let iconApply = iconLayout(TransformImageArguments(corners: ImageCorners(), imageSize: self.iconNode.bounds.size, boundingSize: self.iconNode.bounds.size, intrinsicInsets: UIEdgeInsets(), custom: arguments)) iconApply() if let avatarNode = self.avatarNode { @@ -558,10 +574,8 @@ class LocationPinAnnotationView: MKAnnotationView { if !self.appeared { self.appeared = true - - if let annotation = annotation as? LocationPinAnnotation, annotation.location != nil && !annotation.forcedSelection { - self.animateAppearance() - } + self.initialized = true + self.animateAppearance() } } } diff --git a/submodules/LocationUI/Sources/LocationMapNode.swift b/submodules/LocationUI/Sources/LocationMapNode.swift index 9b5a11475b..7fd7152b2f 100644 --- a/submodules/LocationUI/Sources/LocationMapNode.swift +++ b/submodules/LocationUI/Sources/LocationMapNode.swift @@ -120,7 +120,7 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { } } - func setMapCenter(coordinate: CLLocationCoordinate2D, span: MKCoordinateSpan = defaultMapSpan, offset: CGPoint = CGPoint(), isUserLocation: Bool = false, animated: Bool = false) { + 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 if offset == CGPoint() { @@ -136,7 +136,7 @@ final class LocationMapNode: ASDisplayNode, MKMapViewDelegate { self.returnedToUserLocation = true self.pickerAnnotationView?.setRaised(true, animated: true) } - } else if self.hasPickerAnnotation, let customUserLocationAnnotationView = self.customUserLocationAnnotationView, customUserLocationAnnotationView.isHidden { + } else if self.hasPickerAnnotation, let customUserLocationAnnotationView = self.customUserLocationAnnotationView, customUserLocationAnnotationView.isHidden, hidePicker { self.pickerAnnotationContainerView.isHidden = true customUserLocationAnnotationView.setSelected(false, animated: false) customUserLocationAnnotationView.isHidden = false diff --git a/submodules/LocationUI/Sources/LocationPickerController.swift b/submodules/LocationUI/Sources/LocationPickerController.swift index e60f9e19ba..1a150f9c18 100644 --- a/submodules/LocationUI/Sources/LocationPickerController.swift +++ b/submodules/LocationUI/Sources/LocationPickerController.swift @@ -196,13 +196,7 @@ public final class LocationPickerController: ViewController { guard let strongSelf = self else { return } - strongSelf.controllerNode.updateState { state in - var state = state - state.displayingMapModeOptions = false - state.selectedLocation = .none - state.searchingVenuesAround = false - return state - } + strongSelf.controllerNode.goToUserLocation() }, goToCoordinate: { [weak self] coordinate in guard let strongSelf = self else { return diff --git a/submodules/LocationUI/Sources/LocationPickerControllerNode.swift b/submodules/LocationUI/Sources/LocationPickerControllerNode.swift index a7fc4e163c..e94d1847b4 100644 --- a/submodules/LocationUI/Sources/LocationPickerControllerNode.swift +++ b/submodules/LocationUI/Sources/LocationPickerControllerNode.swift @@ -412,16 +412,18 @@ final class LocationPickerControllerNode: ViewControllerTracingNode { } ) - let foundVenues: Signal<[TelegramMediaMap]?, NoError> = .single(nil) + let foundVenues: Signal<([TelegramMediaMap], CLLocation)?, NoError> = .single(nil) |> then( self.searchVenuesPromise.get() |> distinctUntilChanged - |> mapToSignal { coordinate -> Signal<[TelegramMediaMap]?, NoError> in + |> mapToSignal { coordinate -> Signal<([TelegramMediaMap], CLLocation)?, NoError> in if let coordinate = coordinate { return (.single(nil) |> then( nearbyVenues(account: context.account, latitude: coordinate.latitude, longitude: coordinate.longitude) - |> map (Optional.init) + |> map { venues -> ([TelegramMediaMap], CLLocation)? in + return (venues, CLLocation(latitude: coordinate.latitude, longitude: coordinate.longitude)) + } )) } else { return .single(nil) @@ -435,8 +437,10 @@ final class LocationPickerControllerNode: ViewControllerTracingNode { let previousEntries = Atomic<[LocationPickerEntry]?>(value: nil) self.disposable = (combineLatest(self.presentationDataPromise.get(), self.statePromise.get(), userLocation, venues, foundVenues) - |> deliverOnMainQueue).start(next: { [weak self] presentationData, state, userLocation, venues, foundVenues in + |> deliverOnMainQueue).start(next: { [weak self] presentationData, state, userLocation, venues, foundVenuesAndLocation in if let strongSelf = self { + let (foundVenues, foundVenuesLocation) = foundVenuesAndLocation ?? (nil, nil) + var entries: [LocationPickerEntry] = [] switch state.selectedLocation { case let .location(coordinate, address): @@ -483,7 +487,7 @@ final class LocationPickerControllerNode: ViewControllerTracingNode { entries.append(.header(presentationData.theme, presentationData.strings.Map_ChooseAPlace.uppercased())) - var displayedVenues = state.searchingVenuesAround ? foundVenues : venues + var displayedVenues = foundVenues != nil || state.searchingVenuesAround ? foundVenues : venues if let venues = displayedVenues { var index: Int = 0 for venue in venues { @@ -513,10 +517,8 @@ final class LocationPickerControllerNode: ViewControllerTracingNode { strongSelf.headerNode.mapNode.setMapCenter(coordinate: userLocation.coordinate, isUserLocation: true, animated: previousUserLocation != nil) } strongSelf.headerNode.mapNode.resetAnnotationSelection() - strongSelf.searchVenuesPromise.set(.single(nil)) case .selecting: strongSelf.headerNode.mapNode.resetAnnotationSelection() - strongSelf.searchVenuesPromise.set(.single(nil)) case let .location(coordinate, address): var updateMap = false switch previousState.selectedLocation { @@ -530,16 +532,22 @@ final class LocationPickerControllerNode: ViewControllerTracingNode { break } if updateMap { - strongSelf.headerNode.mapNode.setMapCenter(coordinate: coordinate, isUserLocation: false, animated: true) + strongSelf.headerNode.mapNode.setMapCenter(coordinate: coordinate, isUserLocation: false, hidePicker: false, animated: true) strongSelf.headerNode.mapNode.switchToPicking(animated: false) } if address != nil { - displayingPlacesButton = foundVenues == nil + if foundVenues == nil { + displayingPlacesButton = true + } else if let previousLocation = foundVenuesLocation { + let currentLocation = CLLocation(latitude: coordinate.latitude, longitude: coordinate.longitude) + if currentLocation.distance(from: previousLocation) > 500 { + displayingPlacesButton = true + } + } } case let .venue(venue): - strongSelf.headerNode.mapNode.setMapCenter(coordinate: venue.coordinate, animated: true) - strongSelf.searchVenuesPromise.set(.single(nil)) + strongSelf.headerNode.mapNode.setMapCenter(coordinate: venue.coordinate, hidePicker: true, animated: true) } strongSelf.headerNode.updateState(mapMode: state.mapMode, displayingMapModeOptions: state.displayingMapModeOptions, displayingPlacesButton: displayingPlacesButton, animated: true) @@ -656,21 +664,16 @@ final class LocationPickerControllerNode: ViewControllerTracingNode { var state = state state.displayingMapModeOptions = false state.selectedLocation = annotation?.location.flatMap { .venue($0) } ?? .none - state.searchingVenuesAround = false + if annotation == nil { + state.searchingVenuesAround = false + } return state } } self.headerNode.mapNode.userLocationAnnotationSelected = { [weak self] in - guard let strongSelf = self else { - return - } - strongSelf.updateState { state in - var state = state - state.displayingMapModeOptions = false - state.selectedLocation = .none - state.searchingVenuesAround = false - return state + if let strongSelf = self { + strongSelf.goToUserLocation() } } } @@ -856,8 +859,20 @@ final class LocationPickerControllerNode: ViewControllerTracingNode { self.shadeNode.backgroundColor = highlighted ? self.presentationData.theme.list.itemHighlightedBackgroundColor : self.presentationData.theme.list.plainBackgroundColor } + func goToUserLocation() { + self.searchVenuesPromise.set(.single(nil)) + self.updateState { state in + var state = state + state.displayingMapModeOptions = false + state.selectedLocation = .none + state.searchingVenuesAround = false + return state + } + } + func requestPlacesAtSelectedLocation() { if case let .location(coordinate, _) = self.state.selectedLocation { + self.headerNode.mapNode.setMapCenter(coordinate: coordinate, animated: true) self.searchVenuesPromise.set(.single(coordinate)) self.updateState { state in var state = state diff --git a/submodules/MapResourceToAvatarSizes/Sources/MapResourceToAvatarSizes.swift b/submodules/MapResourceToAvatarSizes/Sources/MapResourceToAvatarSizes.swift index 9c4963d8dd..c42f510e76 100644 --- a/submodules/MapResourceToAvatarSizes/Sources/MapResourceToAvatarSizes.swift +++ b/submodules/MapResourceToAvatarSizes/Sources/MapResourceToAvatarSizes.swift @@ -15,7 +15,13 @@ public func mapResourceToAvatarSizes(postbox: Postbox, resource: MediaResource, } var result: [Int: Data] = [:] for i in 0 ..< representations.count { - if let scaledImage = generateScaledImage(image: image, size: representations[i].dimensions.cgSize, scale: 1.0), let scaledData = scaledImage.jpegData(compressionQuality: 0.8) { + let size: CGSize + if representations[i].dimensions.width == 80 { + size = CGSize(width: 160.0, height: 160.0) + } else { + size = representations[i].dimensions.cgSize + } + if let scaledImage = generateScaledImage(image: image, size: size, scale: 1.0), let scaledData = scaledImage.jpegData(compressionQuality: 0.8) { result[i] = scaledData } } diff --git a/submodules/MediaResources/Sources/CachedResourceRepresentations.swift b/submodules/MediaResources/Sources/CachedResourceRepresentations.swift index 4c4b6b8270..da317b350c 100644 --- a/submodules/MediaResources/Sources/CachedResourceRepresentations.swift +++ b/submodules/MediaResources/Sources/CachedResourceRepresentations.swift @@ -148,20 +148,33 @@ public final class CachedPatternWallpaperRepresentation: CachedMediaResourceRepr public let keepDuration: CachedMediaRepresentationKeepDuration = .general public let color: Int32 + public let bottomColor: Int32? public let intensity: Int32 + public let rotation: Int32? public var uniqueId: String { - return "pattern-wallpaper-\(self.color)-\(self.intensity)" + var id: String + if let bottomColor = self.bottomColor { + id = "pattern-wallpaper-\(self.color)-\(bottomColor)-\(self.intensity)" + } else { + id = "pattern-wallpaper-\(self.color)-\(self.intensity)" + } + if let rotation = self.rotation, rotation != 0 { + id += "-\(rotation)deg" + } + return id } - public init(color: Int32, intensity: Int32) { + public init(color: Int32, bottomColor: Int32?, intensity: Int32, rotation: Int32?) { self.color = color + self.bottomColor = bottomColor self.intensity = intensity + self.rotation = rotation } public func isEqual(to: CachedMediaResourceRepresentation) -> Bool { if let to = to as? CachedPatternWallpaperRepresentation { - return self.color == to.color && self.intensity == intensity + return self.color == to.color && self.bottomColor == to.bottomColor && self.intensity == intensity && self.rotation == to.rotation } else { return false } diff --git a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift index 791832af8b..324d9aa1fc 100644 --- a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift +++ b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift @@ -126,11 +126,15 @@ private final class TextSizeSelectionControllerNode: ASDisplayNode, UIScrollView self.toolbarNode.cancel = { dismiss() } + var dismissed = false self.toolbarNode.done = { [weak self] in guard let strongSelf = self else { return } - apply(strongSelf.presentationThemeSettings.useSystemFont, strongSelf.presentationThemeSettings.fontSize) + if !dismissed { + dismissed = true + apply(strongSelf.presentationThemeSettings.useSystemFont, strongSelf.presentationThemeSettings.fontSize) + } } self.toolbarNode.updateUseSystemFont = { [weak self] value in guard let strongSelf = self else { diff --git a/submodules/SettingsUI/Sources/Themes/EditThemeController.swift b/submodules/SettingsUI/Sources/Themes/EditThemeController.swift index 7cf1ff0d94..57735a1003 100644 --- a/submodules/SettingsUI/Sources/Themes/EditThemeController.swift +++ b/submodules/SettingsUI/Sources/Themes/EditThemeController.swift @@ -315,6 +315,7 @@ public func editThemeController(context: AccountContext, mode: EditThemeControll let _ = (previewThemePromise.get() |> take(1) |> deliverOnMainQueue).start(next: { theme in + var controllerDismissImpl: (() -> Void)? let controller = ThemeAccentColorController(context: context, mode: .edit(theme: theme, wallpaper: nil, defaultThemeReference: nil, create: false, completion: { updatedTheme in updateState { current in var state = current @@ -322,7 +323,11 @@ public func editThemeController(context: AccountContext, mode: EditThemeControll state.updatedTheme = updatedTheme return state } + controllerDismissImpl?() })) + controllerDismissImpl = { [weak controller] in + controller?.dismiss() + } pushControllerImpl?(controller) }) }, openFile: { diff --git a/submodules/SettingsUI/Sources/Themes/SettingsThemeWallpaperNode.swift b/submodules/SettingsUI/Sources/Themes/SettingsThemeWallpaperNode.swift index a927943e2e..1208ef23e0 100644 --- a/submodules/SettingsUI/Sources/Themes/SettingsThemeWallpaperNode.swift +++ b/submodules/SettingsUI/Sources/Themes/SettingsThemeWallpaperNode.swift @@ -30,8 +30,8 @@ private func whiteColorImage(theme: PresentationTheme, color: UIColor) -> Signal } final class SettingsThemeWallpaperNode: ASDisplayNode { - private var wallpaper: TelegramWallpaper? - private var color: UIColor? + var wallpaper: TelegramWallpaper? + private var arguments: PatternWallpaperArguments? let buttonNode = HighlightTrackingButtonNode() let backgroundNode = ASDisplayNode() @@ -39,7 +39,7 @@ final class SettingsThemeWallpaperNode: ASDisplayNode { private let statusNode: RadialStatusNode var pressed: (() -> Void)? - + init(overlayBackgroundColor: UIColor = UIColor(white: 0.0, alpha: 0.3)) { self.imageNode.contentAnimations = [.subsequentUpdates] @@ -63,6 +63,10 @@ final class SettingsThemeWallpaperNode: ASDisplayNode { self.statusNode.transitionToState(state, animated: animated, completion: {}) } + func setOverlayBackgroundColor(_ color: UIColor) { + self.statusNode.backgroundNodeColor = color + } + func setWallpaper(context: AccountContext, wallpaper: TelegramWallpaper, selected: Bool, size: CGSize, cornerRadius: CGFloat = 0.0, synchronousLoad: Bool = false) { self.buttonNode.frame = CGRect(origin: CGPoint(), size: size) self.backgroundNode.frame = CGRect(origin: CGPoint(), size: size) @@ -125,6 +129,7 @@ final class SettingsThemeWallpaperNode: ASDisplayNode { if file.isPattern { self.backgroundNode.isHidden = false + var patternColors: [UIColor] = [] var patternColor = UIColor(rgb: 0xd6e2ee, alpha: 0.5) var patternIntensity: CGFloat = 0.5 if let color = file.settings.color { @@ -132,9 +137,15 @@ final class SettingsThemeWallpaperNode: ASDisplayNode { patternIntensity = CGFloat(intensity) / 100.0 } patternColor = UIColor(rgb: UInt32(bitPattern: color), alpha: patternIntensity) + patternColors.append(patternColor) + + if let bottomColor = file.settings.bottomColor { + patternColors.append(UIColor(rgb: UInt32(bitPattern: bottomColor), alpha: patternIntensity)) + } } + self.backgroundNode.backgroundColor = patternColor - self.color = patternColor + self.arguments = PatternWallpaperArguments(colors: patternColors, rotation: file.settings.rotation) imageSignal = patternWallpaperImage(account: context.account, accountManager: context.sharedContext.accountManager, representations: convertedRepresentations, mode: .thumbnail, autoFetchFullSize: true) } else { self.backgroundNode.isHidden = true @@ -144,7 +155,7 @@ final class SettingsThemeWallpaperNode: ASDisplayNode { self.imageNode.setSignal(imageSignal, attemptSynchronously: synchronousLoad) let dimensions = file.file.dimensions ?? PixelDimensions(width: 100, height: 100) - let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: corners, imageSize: dimensions.cgSize.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets(), emptyColor: self.color)) + let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: corners, imageSize: dimensions.cgSize.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets(), custom: self.arguments)) apply() } } else if let wallpaper = self.wallpaper { @@ -157,7 +168,7 @@ final class SettingsThemeWallpaperNode: ASDisplayNode { apply() case let .file(file): let dimensions = file.file.dimensions ?? PixelDimensions(width: 100, height: 100) - let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: corners, imageSize: dimensions.cgSize.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets(), emptyColor: self.color)) + let apply = self.imageNode.asyncLayout()(TransformImageArguments(corners: corners, imageSize: dimensions.cgSize.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets(), custom: self.arguments)) apply() } } diff --git a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorController.swift b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorController.swift index 2608b5e0e6..3040fedb0c 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorController.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorController.swift @@ -10,8 +10,9 @@ import TelegramPresentationData import TelegramUIPreferences import AccountContext import PresentationDataUtils +import MediaResources -private let colors: [Int32] = [0x007aff, 0x00c2ed, 0x29b327, 0xeb6ca4, 0xf08200, 0x9472ee, 0xd33213, 0xedb400, 0x6d839e] +private let randomBackgroundColors: [Int32] = [0x007aff, 0x00c2ed, 0x29b327, 0xeb6ca4, 0xf08200, 0x9472ee, 0xd33213, 0xedb400, 0x6d839e] enum ThemeAccentColorControllerMode { case colors(themeReference: PresentationThemeReference) @@ -64,7 +65,7 @@ final class ThemeAccentColorController: ViewController { self.segmentedTitleView = ThemeColorSegmentedTitleView(theme: self.presentationData.theme, strings: self.presentationData.strings, selectedSection: section) if case .background = mode { - self.initialBackgroundColor = colors.randomElement().flatMap { UIColor(rgb: UInt32(bitPattern: $0)) } + self.initialBackgroundColor = randomBackgroundColors.randomElement().flatMap { UIColor(rgb: UInt32(bitPattern: $0)) } } else { self.initialBackgroundColor = nil } @@ -104,11 +105,7 @@ final class ThemeAccentColorController: ViewController { } } - if case .background = mode { - self.title = self.presentationData.strings.Wallpaper_Title - } else { - self.navigationItem.titleView = self.segmentedTitleView - } + self.navigationItem.titleView = self.segmentedTitleView self.navigationItem.leftBarButtonItem = UIBarButtonItem(customView: UIView()) } @@ -136,17 +133,63 @@ final class ThemeAccentColorController: ViewController { }, apply: { [weak self] state, serviceBackgroundColor in if let strongSelf = self { let context = strongSelf.context - if case let .edit(theme, _, themeReference, _, completion) = strongSelf.mode { - let updatedTheme: PresentationTheme - if let themeReference = themeReference { - updatedTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: themeReference, accentColor: state.accentColor, bubbleColors: state.messagesColors, backgroundColors: state.backgroundColors, serviceBackgroundColor: serviceBackgroundColor) ?? defaultPresentationTheme + + var coloredWallpaper: TelegramWallpaper? + if let backgroundColors = state.backgroundColors { + let color = Int32(bitPattern: backgroundColors.0.rgb) + let bottomColor = backgroundColors.1.flatMap { Int32(bitPattern: $0.rgb) } + + if let patternWallpaper = state.patternWallpaper { + coloredWallpaper = patternWallpaper.withUpdatedSettings(WallpaperSettings(motion: state.motion, color: color, bottomColor: bottomColor, intensity: state.patternIntensity, rotation: state.rotation)) + } else if let bottomColor = bottomColor { + coloredWallpaper = .gradient(color, bottomColor, WallpaperSettings(motion: state.motion, rotation: state.rotation)) } else { - updatedTheme = customizePresentationTheme(theme, editing: false, accentColor: state.accentColor, backgroundColors: state.backgroundColors, bubbleColors: state.messagesColors) + coloredWallpaper = .color(color) + } + } + + let prepare: Signal + if let patternWallpaper = state.patternWallpaper, case let .file(file) = patternWallpaper, let backgroundColors = state.backgroundColors { + let resource = file.file.resource + let representation = CachedPatternWallpaperRepresentation(color: Int32(bitPattern: backgroundColors.0.rgb), bottomColor: backgroundColors.1.flatMap { Int32(bitPattern: $0.rgb) }, intensity: state.patternIntensity, rotation: state.rotation) + + var data: Data? + if let path = strongSelf.context.account.postbox.mediaBox.completedResourcePath(resource), let maybeData = try? Data(contentsOf: URL(fileURLWithPath: path), options: .mappedRead) { + data = maybeData + } else if let path = strongSelf.context.sharedContext.accountManager.mediaBox.completedResourcePath(resource), let maybeData = try? Data(contentsOf: URL(fileURLWithPath: path), options: .mappedRead) { + data = maybeData } - completion(updatedTheme) + if let data = data { + strongSelf.context.sharedContext.accountManager.mediaBox.storeResourceData(resource.id, data: data, synchronous: true) + prepare = (strongSelf.context.sharedContext.accountManager.mediaBox.cachedResourceRepresentation(resource, representation: representation, complete: true, fetch: true) + |> filter({ $0.complete }) + |> take(1) + |> mapToSignal { _ -> Signal in + return .complete() + }) + } else { + prepare = .complete() + } } else { - let _ = (updatePresentationThemeSettingsInteractively(accountManager: context.sharedContext.accountManager, { current in + prepare = .complete() + } + + if case let .edit(theme, _, themeReference, _, completion) = strongSelf.mode { + let _ = (prepare + |> deliverOnMainQueue).start(completed: { [weak self] in + let updatedTheme: PresentationTheme + if let themeReference = themeReference { + updatedTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: themeReference, accentColor: state.accentColor, backgroundColors: state.backgroundColors, bubbleColors: state.messagesColors, wallpaper: state.initialWallpaper ?? coloredWallpaper, serviceBackgroundColor: serviceBackgroundColor) ?? defaultPresentationTheme + } else { + updatedTheme = customizePresentationTheme(theme, editing: false, accentColor: state.accentColor, backgroundColors: state.backgroundColors, bubbleColors: state.messagesColors, wallpaper: state.initialWallpaper ?? coloredWallpaper) + } + + completion(updatedTheme) + }) + } else { + let _ = (prepare + |> then(updatePresentationThemeSettingsInteractively(accountManager: context.sharedContext.accountManager, { current in let autoNightModeTriggered = context.sharedContext.currentPresentationData.with { $0 }.autoNightModeTriggered var currentTheme = current.theme if autoNightModeTriggered { @@ -169,17 +212,13 @@ final class ThemeAccentColorController: ViewController { themeSpecificAccentColors[currentTheme.index] = color var wallpaper = themeSpecificChatWallpapers[currentTheme.index] - if let backgroundColors = state.backgroundColors { - if let bottomColor = backgroundColors.1 { - wallpaper = .gradient(Int32(bitPattern: backgroundColors.0.rgb), Int32(bitPattern: bottomColor.rgb), WallpaperSettings()) - } else { - wallpaper = .color(Int32(bitPattern: backgroundColors.0.rgb)) - } + if let coloredWallpaper = coloredWallpaper { + wallpaper = coloredWallpaper } themeSpecificChatWallpapers[currentTheme.index] = wallpaper return PresentationThemeSettings(theme: current.theme, themeSpecificAccentColors: themeSpecificAccentColors, themeSpecificChatWallpapers: themeSpecificChatWallpapers, useSystemFont: current.useSystemFont, fontSize: current.fontSize, automaticThemeSwitchSetting: current.automaticThemeSwitchSetting, largeEmoji: current.largeEmoji, disableAnimations: current.disableAnimations) - }) |> deliverOnMainQueue).start(completed: { [weak self] in + })) |> deliverOnMainQueue).start(completed: { [weak self] in if let strongSelf = self { strongSelf.completion?() strongSelf.dismiss() @@ -195,8 +234,11 @@ final class ThemeAccentColorController: ViewController { } } - let _ = (self.context.sharedContext.accountManager.sharedData(keys: [ApplicationSpecificSharedDataKeys.presentationThemeSettings]) - |> deliverOnMainQueue).start(next: { [weak self] sharedData in + let _ = (combineLatest( + self.context.sharedContext.accountManager.sharedData(keys: [ApplicationSpecificSharedDataKeys.presentationThemeSettings]) |> take(1), + telegramWallpapers(postbox: context.account.postbox, network: context.account.network) |> take(1) + ) + |> deliverOnMainQueue).start(next: { [weak self] sharedData, wallpapers in guard let strongSelf = self else { return } @@ -204,19 +246,54 @@ final class ThemeAccentColorController: ViewController { let accentColor: UIColor var initialWallpaper: TelegramWallpaper? - let backgroundColors: (UIColor, UIColor?)? + var backgroundColors: (UIColor, UIColor?)? + var patternWallpaper: TelegramWallpaper? + var patternIntensity: Int32 = 40 + var motion = false let messageColors: (UIColor, UIColor?)? var defaultMessagesColor: UIColor? + var rotation: Int32 = 0 var ignoreDefaultWallpaper = false + func extractWallpaperParameters(_ wallpaper: TelegramWallpaper?) { + guard let wallpaper = wallpaper else { + return + } + if case let .file(file) = wallpaper, file.isPattern { + var patternColor = UIColor(rgb: 0xd6e2ee, alpha: 0.4) + var bottomColor: UIColor? + if let color = file.settings.color { + if let intensity = file.settings.intensity { + patternIntensity = intensity + } + patternColor = UIColor(rgb: UInt32(bitPattern: color)) + if let bottomColorValue = file.settings.bottomColor { + bottomColor = UIColor(rgb: UInt32(bitPattern: bottomColorValue)) + } + } + patternWallpaper = wallpaper + backgroundColors = (patternColor, bottomColor) + motion = file.settings.motion + rotation = file.settings.rotation ?? 0 + } else if case let .color(color) = wallpaper { + backgroundColors = (UIColor(rgb: UInt32(bitPattern: color)), nil) + } else if case let .gradient(topColor, bottomColor, settings) = wallpaper { + backgroundColors = (UIColor(rgb: UInt32(bitPattern: topColor)), UIColor(rgb: UInt32(bitPattern: bottomColor))) + motion = settings.motion + rotation = settings.rotation ?? 0 + } else { + backgroundColors = nil + } + } + if let themeReference = strongSelf.mode.themeReference { accentColor = settings.themeSpecificAccentColors[themeReference.index]?.color ?? defaultDayAccentColor - let wallpaper: TelegramWallpaper + var wallpaper: TelegramWallpaper if let customWallpaper = settings.themeSpecificChatWallpapers[themeReference.index] { wallpaper = customWallpaper } else { - let theme = makePresentationTheme(mediaBox: strongSelf.context.sharedContext.accountManager.mediaBox, themeReference: themeReference, accentColor: nil, bubbleColors: nil) ?? defaultPresentationTheme + let theme = makePresentationTheme(mediaBox: strongSelf.context.sharedContext.accountManager.mediaBox, themeReference: themeReference, accentColor: nil) ?? defaultPresentationTheme if case let .builtin(themeName) = themeReference { if case .dayClassic = themeName, settings.themeSpecificAccentColors[themeReference.index] != nil { ignoreDefaultWallpaper = true @@ -228,6 +305,21 @@ final class ThemeAccentColorController: ViewController { wallpaper = theme.chat.defaultWallpaper } + if case let .builtin(settings) = wallpaper { + var defaultPatternWallpaper: TelegramWallpaper? + + for wallpaper in wallpapers { + if case let .file(file) = wallpaper, file.slug == "JqSUrO0-mFIBAAAAWwTvLzoWGQI" { + defaultPatternWallpaper = wallpaper + break + } + } + + if let defaultPatternWallpaper = defaultPatternWallpaper { + wallpaper = defaultPatternWallpaper.withUpdatedSettings(WallpaperSettings(blur: settings.blur, motion: settings.motion, color: 0xd6e2ee, bottomColor: nil, intensity: 25, rotation: nil)) + } + } + if !wallpaper.isColorOrGradient && !ignoreDefaultWallpaper { initialWallpaper = wallpaper } @@ -235,13 +327,7 @@ final class ThemeAccentColorController: ViewController { if let initialBackgroundColor = strongSelf.initialBackgroundColor { backgroundColors = (initialBackgroundColor, nil) } else if !ignoreDefaultWallpaper { - if case let .color(color) = wallpaper { - backgroundColors = (UIColor(rgb: UInt32(bitPattern: color)), nil) - } else if case let .gradient(topColor, bottomColor, _) = wallpaper { - backgroundColors = (UIColor(rgb: UInt32(bitPattern: topColor)), UIColor(rgb: UInt32(bitPattern: bottomColor))) - } else { - backgroundColors = nil - } + extractWallpaperParameters(wallpaper) } else { backgroundColors = nil } @@ -261,13 +347,14 @@ final class ThemeAccentColorController: ViewController { } } else if case let .edit(theme, wallpaper, _, _, _) = strongSelf.mode { accentColor = theme.rootController.navigationBar.accentTextColor - if case let .color(color) = theme.chat.defaultWallpaper { - backgroundColors = (UIColor(rgb: UInt32(bitPattern: color)), nil) - } else if case let .gradient(topColor, bottomColor, _) = theme.chat.defaultWallpaper { - backgroundColors = (UIColor(rgb: UInt32(bitPattern: topColor)), UIColor(rgb: UInt32(bitPattern: bottomColor))) - } else { - backgroundColors = nil + + let wallpaper = wallpaper ?? theme.chat.defaultWallpaper + extractWallpaperParameters(wallpaper) + + if !wallpaper.isColorOrGradient { + initialWallpaper = wallpaper } + let topMessageColor = theme.chat.message.outgoing.bubble.withWallpaper.fill let bottomMessageColor = theme.chat.message.outgoing.bubble.withWallpaper.gradientFill @@ -277,12 +364,12 @@ final class ThemeAccentColorController: ViewController { messageColors = (topMessageColor, bottomMessageColor) } } else { - accentColor = UIColor(rgb: 0x007ee5) + accentColor = defaultDayAccentColor backgroundColors = nil messageColors = nil } - let initialState = ThemeColorState(section: strongSelf.section, accentColor: accentColor, initialWallpaper: initialWallpaper, backgroundColors: backgroundColors, defaultMessagesColor: defaultMessagesColor, messagesColors: messageColors) + let initialState = ThemeColorState(section: strongSelf.section, accentColor: accentColor, initialWallpaper: initialWallpaper, backgroundColors: backgroundColors, patternWallpaper: patternWallpaper, patternIntensity: patternIntensity, motion: motion, defaultMessagesColor: defaultMessagesColor, messagesColors: messageColors, rotation: rotation) strongSelf.controllerNode.updateState({ _ in return initialState diff --git a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift index 1d92b92145..4e71b8e8bf 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift @@ -10,10 +10,7 @@ import TelegramPresentationData import TelegramUIPreferences import ChatListUI import AccountContext - -private func radiansToDegrees(_ radians: CGFloat) -> CGFloat { - return radians * 180.0 / CGFloat.pi -} +import WallpaperResources private func generateMaskImage(color: UIColor) -> UIImage? { return generateImage(CGSize(width: 1.0, height: 80.0), opaque: false, rotatedContext: { size, context in @@ -39,38 +36,73 @@ enum ThemeColorSection: Int { struct ThemeColorState { fileprivate var section: ThemeColorSection? fileprivate var colorPanelCollapsed: Bool + fileprivate var displayPatternPanel: Bool + var accentColor: UIColor var initialWallpaper: TelegramWallpaper? var backgroundColors: (UIColor, UIColor?)? + + fileprivate var preview: Bool + fileprivate var previousPatternWallpaper: TelegramWallpaper? + var patternWallpaper: TelegramWallpaper? + var patternIntensity: Int32 + var motion: Bool + var defaultMessagesColor: UIColor? var messagesColors: (UIColor, UIColor?)? - var rotation: CGFloat + + var rotation: Int32 init() { self.section = nil self.colorPanelCollapsed = false + self.displayPatternPanel = false self.accentColor = .clear self.initialWallpaper = nil self.backgroundColors = nil + self.preview = false + self.previousPatternWallpaper = nil + self.patternWallpaper = nil + self.patternIntensity = 40 + self.motion = false + self.defaultMessagesColor = nil self.messagesColors = nil - self.rotation = 0.0 + self.rotation = 0 } - init(section: ThemeColorSection, accentColor: UIColor, initialWallpaper: TelegramWallpaper?, backgroundColors: (UIColor, UIColor?)?, defaultMessagesColor: UIColor?, messagesColors: (UIColor, UIColor?)?, rotation: CGFloat = 0.0) { + init(section: ThemeColorSection, accentColor: UIColor, initialWallpaper: TelegramWallpaper?, backgroundColors: (UIColor, UIColor?)?, patternWallpaper: TelegramWallpaper?, patternIntensity: Int32, motion: Bool, defaultMessagesColor: UIColor?, messagesColors: (UIColor, UIColor?)?, rotation: Int32 = 0) { self.section = section self.colorPanelCollapsed = false + self.displayPatternPanel = false self.accentColor = accentColor self.initialWallpaper = initialWallpaper self.backgroundColors = backgroundColors + self.preview = false + self.previousPatternWallpaper = nil + self.patternWallpaper = patternWallpaper + self.patternIntensity = patternIntensity + self.motion = motion self.defaultMessagesColor = defaultMessagesColor self.messagesColors = messagesColors self.rotation = rotation } - func areColorsEqual(to otherState: ThemeColorState) -> Bool { + func isEqual(to otherState: ThemeColorState) -> Bool { if self.accentColor != otherState.accentColor { return false } + if self.preview != otherState.preview { + return false + } + if self.patternWallpaper != otherState.patternWallpaper { + return false + } + if self.patternIntensity != otherState.patternIntensity { + return false + } + if self.rotation != otherState.rotation { + return false + } if let lhsBackgroundColors = self.backgroundColors, let rhsBackgroundColors = otherState.backgroundColors { if lhsBackgroundColors.0 != rhsBackgroundColors.0 { return false @@ -103,6 +135,22 @@ struct ThemeColorState { } } +private func calcPatternColors(for state: ThemeColorState) -> [UIColor] { + if let backgroundColors = state.backgroundColors { + let patternIntensity = CGFloat(state.patternIntensity) / 100.0 + let topPatternColor = backgroundColors.0.withAlphaComponent(patternIntensity) + if let bottomColor = backgroundColors.1 { + let bottomPatternColor = bottomColor.withAlphaComponent(patternIntensity) + return [topPatternColor, bottomPatternColor] + } else { + return [topPatternColor, topPatternColor] + } + } else { + let patternColor = UIColor(rgb: 0xd6e2ee, alpha: 0.5) + return [patternColor, patternColor] + } +} + final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate { private let context: AccountContext private var theme: PresentationTheme @@ -115,23 +163,38 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate private let scrollNode: ASScrollNode private let pageControlBackgroundNode: ASDisplayNode private let pageControlNode: PageControlNode + private var motionButtonNode: WallpaperOptionButtonNode + private var patternButtonNode: WallpaperOptionButtonNode private let chatListBackgroundNode: ASDisplayNode private var chatNodes: [ListViewItemNode]? private let maskNode: ASImageNode - private let chatBackgroundNode: WallpaperBackgroundNode + private let backgroundContainerNode: ASDisplayNode + private let backgroundWrapperNode: ASDisplayNode + private let immediateBackgroundNode: ASImageNode + private let signalBackgroundNode: TransformImageNode private let messagesContainerNode: ASDisplayNode private var dateHeaderNode: ListViewItemHeaderNode? private var messageNodes: [ListViewItemNode]? - private var colorPanelNode: WallpaperColorPanelNode + private let colorPanelNode: WallpaperColorPanelNode + private let patternPanelNode: WallpaperPatternPanelNode private let toolbarNode: WallpaperGalleryToolbarNode private var serviceColorDisposable: Disposable? - private var colorsDisposable: Disposable? - private let colors = Promise<(UIColor, (UIColor, UIColor?)?, (UIColor, UIColor?)?, TelegramWallpaper?, CGFloat)>() + private var stateDisposable: Disposable? + private let statePromise = Promise() private let themePromise = Promise() private var wallpaper: TelegramWallpaper private var serviceBackgroundColor: UIColor? private let serviceBackgroundColorPromise = Promise() + private var wallpaperDisposable = MetaDisposable() + + private var currentBackgroundColors: (UIColor, UIColor?)? + private var currentBackgroundPromise = Promise<(UIColor, UIColor?)?>() + + private var patternWallpaper: TelegramWallpaper? + private var patternArguments: PatternWallpaperArguments? + private var patternArgumentsPromise = Promise() + private var patternArgumentsDisposable: Disposable? private var tapGestureRecognizer: UITapGestureRecognizer? @@ -141,8 +204,10 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate var requiresWallpaperChange: Bool { switch self.wallpaper { - case .image, .file: + case .image, .builtin: return true + case let .file(file): + return !file.isPattern default: return false } @@ -170,21 +235,24 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate self.pageControlNode = PageControlNode(dotSpacing: 7.0, dotColor: .white, inactiveDotColor: UIColor.white.withAlphaComponent(0.4)) + self.motionButtonNode = WallpaperOptionButtonNode(title: self.presentationData.strings.WallpaperPreview_Motion, value: .check(false)) + self.patternButtonNode = WallpaperOptionButtonNode(title: self.presentationData.strings.WallpaperPreview_Pattern, value: .check(false)) + self.chatListBackgroundNode = ASDisplayNode() - self.chatBackgroundNode = WallpaperBackgroundNode() - self.chatBackgroundNode.displaysAsynchronously = false + + self.backgroundContainerNode = ASDisplayNode() + self.backgroundContainerNode.clipsToBounds = true + self.backgroundWrapperNode = ASDisplayNode() + self.immediateBackgroundNode = ASImageNode() + self.signalBackgroundNode = TransformImageNode() + self.signalBackgroundNode.displaysAsynchronously = false self.messagesContainerNode = ASDisplayNode() self.messagesContainerNode.clipsToBounds = true self.messagesContainerNode.transform = CATransform3DMakeScale(1.0, -1.0, 1.0) - if case .color = wallpaper { - } else { - self.chatBackgroundNode.image = chatControllerBackgroundImage(theme: theme, wallpaper: wallpaper, mediaBox: context.sharedContext.accountManager.mediaBox, knockoutMode: false) - self.chatBackgroundNode.motionEnabled = wallpaper.settings?.motion ?? false - } - self.colorPanelNode = WallpaperColorPanelNode(theme: self.theme, strings: self.presentationData.strings) + self.patternPanelNode = WallpaperPatternPanelNode(context: self.context, theme: self.theme, strings: self.presentationData.strings) let doneButtonType: WallpaperGalleryToolbarDoneButtonType if case .edit(_, _, _, true, _) = self.mode { @@ -215,45 +283,48 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate self.chatListBackgroundNode.addSubnode(self.maskNode) self.addSubnode(self.pageControlBackgroundNode) self.addSubnode(self.pageControlNode) + self.addSubnode(self.motionButtonNode) + self.addSubnode(self.patternButtonNode) self.addSubnode(self.colorPanelNode) + self.addSubnode(self.patternPanelNode) self.addSubnode(self.toolbarNode) self.scrollNode.addSubnode(self.chatListBackgroundNode) - self.scrollNode.addSubnode(self.chatBackgroundNode) + self.scrollNode.addSubnode(self.backgroundContainerNode) self.scrollNode.addSubnode(self.messagesContainerNode) + + self.backgroundContainerNode.addSubnode(self.backgroundWrapperNode) + self.backgroundWrapperNode.addSubnode(self.immediateBackgroundNode) + self.backgroundWrapperNode.addSubnode(self.signalBackgroundNode) + + self.motionButtonNode.addTarget(self, action: #selector(self.toggleMotion), forControlEvents: .touchUpInside) + self.patternButtonNode.addTarget(self, action: #selector(self.togglePattern), forControlEvents: .touchUpInside) - self.colorPanelNode.colorsChanged = { [weak self] firstColor, secondColor, _ in + self.colorPanelNode.colorsChanged = { [weak self] firstColor, secondColor, ended in if let strongSelf = self, let section = strongSelf.state.section { - switch section { - case .accent: - strongSelf.updateState({ current in - var updated = current + strongSelf.updateState({ current in + var updated = current + updated.preview = !ended + switch section { + case .accent: if let firstColor = firstColor { updated.accentColor = firstColor } - return updated - }) - case .background: - strongSelf.updateState({ current in - var updated = current + case .background: if let firstColor = firstColor { updated.backgroundColors = (firstColor, secondColor) } else { updated.backgroundColors = nil } - return updated - }) - case .messages: - strongSelf.updateState({ current in - var updated = current + case .messages: if let firstColor = firstColor { updated.messagesColors = (firstColor, secondColor) } else { updated.messagesColors = nil } - return updated - }) - } + } + return updated + }) } } @@ -271,9 +342,9 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate if let strongSelf = self { strongSelf.updateState({ current in var updated = current - var newRotation = updated.rotation + CGFloat.pi / 4.0 - if newRotation >= CGFloat.pi * 2.0 { - newRotation = 0.0 + var newRotation = updated.rotation + 45 + if newRotation >= 360 { + newRotation = 0 } updated.rotation = newRotation return updated @@ -281,35 +352,92 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate } } - self.toolbarNode.cancel = { - dismiss() - } - self.toolbarNode.done = { [weak self] in + self.patternPanelNode.patternChanged = { [weak self] wallpaper, intensity, preview in if let strongSelf = self { - apply(strongSelf.state, strongSelf.serviceBackgroundColor) + strongSelf.updateState({ current in + var updated = current + updated.patternWallpaper = wallpaper + updated.patternIntensity = intensity ?? 50 + updated.preview = preview + return updated + }, animated: true) } } - self.colorsDisposable = (self.colors.get() + self.toolbarNode.cancel = { [weak self] in + if let strongSelf = self { + if strongSelf.state.displayPatternPanel { + strongSelf.updateState({ current in + var updated = current + updated.displayPatternPanel = false + updated.patternWallpaper = nil + return updated + }, animated: true) + } else { + dismiss() + } + } + } + + var dismissed = false + self.toolbarNode.done = { [weak self] in + if let strongSelf = self { + if strongSelf.state.displayPatternPanel { + strongSelf.updateState({ current in + var updated = current + updated.displayPatternPanel = false + return updated + }, animated: true) + } else { + if !dismissed { + dismissed = true + apply(strongSelf.state, strongSelf.serviceBackgroundColor) + } + } + } + } + + self.stateDisposable = (self.statePromise.get() |> deliverOn(Queue.concurrentDefaultQueue()) - |> map { accentColor, backgroundColors, messagesColors, initialWallpaper, rotation -> (PresentationTheme, (TelegramWallpaper, UIImage?), UIColor) in + |> map { state -> (PresentationTheme, (TelegramWallpaper, UIImage?, Signal<(TransformImageArguments) -> DrawingContext?, NoError>?), UIColor, (UIColor, UIColor?)?, [UIColor], Bool) in + let accentColor = state.accentColor + var backgroundColors = state.backgroundColors + let messagesColors = state.messagesColors + var wallpaper: TelegramWallpaper var wallpaperImage: UIImage? - var backgroundColors = backgroundColors + var wallpaperSignal: Signal<(TransformImageArguments) -> DrawingContext?, NoError>? + + var singleBackgroundColor: UIColor? + if let backgroundColors = backgroundColors { - if let bottomColor = backgroundColors.1 { - wallpaper = .gradient(Int32(bitPattern: backgroundColors.0.rgb), Int32(bitPattern: bottomColor.rgb), WallpaperSettings(rotation: Int32(radiansToDegrees(rotation)))) - wallpaperImage = chatControllerBackgroundImage(theme: nil, wallpaper: wallpaper, mediaBox: context.sharedContext.accountManager.mediaBox, knockoutMode: false) + if let patternWallpaper = state.patternWallpaper, case let .file(file) = patternWallpaper { + let color = Int32(bitPattern: backgroundColors.0.rgb) + let bottomColor = backgroundColors.1.flatMap { Int32(bitPattern: $0.rgb) } + wallpaper = patternWallpaper.withUpdatedSettings(WallpaperSettings(motion: state.motion, color: color, bottomColor: bottomColor, intensity: state.patternIntensity, rotation: state.rotation)) + + let dimensions = file.file.dimensions ?? PixelDimensions(width: 100, height: 100) + var convertedRepresentations: [ImageRepresentationWithReference] = [] + for representation in file.file.previewRepresentations { + convertedRepresentations.append(ImageRepresentationWithReference(representation: representation, reference: .wallpaper(resource: representation.resource))) + } + convertedRepresentations.append(ImageRepresentationWithReference(representation: .init(dimensions: dimensions, resource: file.file.resource), reference: .wallpaper(resource: file.file.resource))) + + wallpaperSignal = patternWallpaperImage(account: context.account, accountManager: context.sharedContext.accountManager, representations: convertedRepresentations, mode: .screen, autoFetchFullSize: true) + } else if let bottomColor = backgroundColors.1 { + wallpaper = .gradient(Int32(bitPattern: backgroundColors.0.rgb), Int32(bitPattern: bottomColor.rgb), WallpaperSettings(rotation: state.rotation)) + wallpaperSignal = gradientImage([backgroundColors.0, bottomColor], rotation: state.rotation) } else { wallpaper = .color(Int32(bitPattern: backgroundColors.0.rgb)) } - } else if let themeReference = mode.themeReference, case let .builtin(theme) = themeReference, initialWallpaper == nil { + } else if let themeReference = mode.themeReference, case let .builtin(theme) = themeReference, state.initialWallpaper == nil { var suggestedWallpaper: TelegramWallpaper switch theme { case .dayClassic: let topColor = accentColor.withMultiplied(hue: 1.010, saturation: 0.414, brightness: 0.957) let bottomColor = accentColor.withMultiplied(hue: 1.019, saturation: 0.867, brightness: 0.965) suggestedWallpaper = .gradient(Int32(bitPattern: topColor.rgb), Int32(bitPattern: bottomColor.rgb), WallpaperSettings()) + wallpaperSignal = gradientImage([topColor, bottomColor], rotation: state.rotation) backgroundColors = (topColor, bottomColor) case .nightAccent: let color = accentColor.withMultiplied(hue: 1.024, saturation: 0.573, brightness: 0.18) @@ -318,16 +446,16 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate default: suggestedWallpaper = .builtin(WallpaperSettings()) } - wallpaperImage = chatControllerBackgroundImage(theme: nil, wallpaper: suggestedWallpaper, mediaBox: context.sharedContext.accountManager.mediaBox, knockoutMode: false) wallpaper = suggestedWallpaper } else { - wallpaper = initialWallpaper ?? .builtin(WallpaperSettings()) + wallpaper = state.initialWallpaper ?? .builtin(WallpaperSettings()) + wallpaperImage = chatControllerBackgroundImage(theme: nil, wallpaper: wallpaper, mediaBox: context.sharedContext.accountManager.mediaBox, knockoutMode: false) } let serviceBackgroundColor = serviceColor(for: (wallpaper, wallpaperImage)) let updatedTheme: PresentationTheme if let themeReference = mode.themeReference { - updatedTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: themeReference, accentColor: accentColor, bubbleColors: messagesColors, backgroundColors: backgroundColors, serviceBackgroundColor: serviceBackgroundColor, preview: true) ?? defaultPresentationTheme + updatedTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: themeReference, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: messagesColors, serviceBackgroundColor: serviceBackgroundColor, preview: true) ?? defaultPresentationTheme } else if case let .edit(theme, _, _, _, _) = mode { updatedTheme = customizePresentationTheme(theme, editing: false, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: messagesColors) } else { @@ -336,13 +464,15 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate let _ = PresentationResourcesChat.principalGraphics(mediaBox: context.account.postbox.mediaBox, knockoutWallpaper: context.sharedContext.immediateExperimentalUISettings.knockoutWallpaper, theme: updatedTheme, wallpaper: wallpaper) - return (updatedTheme, (wallpaper, wallpaperImage), serviceBackgroundColor) + let patternColors = calcPatternColors(for: state) + + return (updatedTheme, (wallpaper, wallpaperImage, wallpaperSignal), serviceBackgroundColor, backgroundColors, patternColors, state.preview) } - |> deliverOnMainQueue).start(next: { [weak self] theme, wallpaperAndImage, serviceBackgroundColor in + |> deliverOnMainQueue).start(next: { [weak self] theme, wallpaperImageAndSignal, serviceBackgroundColor, backgroundColors, patternColors, preview in guard let strongSelf = self else { return } - let (wallpaper, wallpaperImage) = wallpaperAndImage + let (wallpaper, wallpaperImage, wallpaperSignal) = wallpaperImageAndSignal strongSelf.theme = theme strongSelf.themeUpdated?(theme) @@ -356,16 +486,73 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate strongSelf.chatListBackgroundNode.backgroundColor = theme.chatList.backgroundColor strongSelf.maskNode.image = generateMaskImage(color: theme.chatList.backgroundColor) + let patternArguments = PatternWallpaperArguments(colors: patternColors, rotation: wallpaper.settings?.rotation ?? 0, preview: preview) if case let .color(value) = wallpaper { - strongSelf.backgroundColor = UIColor(rgb: UInt32(bitPattern: value)) - strongSelf.chatBackgroundNode.backgroundColor = UIColor(rgb: UInt32(bitPattern: value)) - strongSelf.chatBackgroundNode.image = nil + strongSelf.backgroundColor = UIColor(rgb: UInt32(bitPattern: value)) + strongSelf.immediateBackgroundNode.backgroundColor = UIColor(rgb: UInt32(bitPattern: value)) + strongSelf.immediateBackgroundNode.image = nil + strongSelf.signalBackgroundNode.isHidden = true + + strongSelf.patternWallpaper = nil } else if let wallpaperImage = wallpaperImage { - strongSelf.chatBackgroundNode.imageContentMode = .scaleToFill - strongSelf.chatBackgroundNode.image = wallpaperImage + strongSelf.immediateBackgroundNode.image = wallpaperImage + strongSelf.signalBackgroundNode.isHidden = true + + strongSelf.patternWallpaper = nil + } else if let wallpaperSignal = wallpaperSignal { + strongSelf.signalBackgroundNode.contentMode = .scaleToFill + strongSelf.signalBackgroundNode.isHidden = false + + if case let .file(file) = wallpaper, let (layout, _, _) = strongSelf.validLayout { + var dispatch = false + if let previousWallpaper = strongSelf.patternWallpaper, case let .file(previousFile) = previousWallpaper, file.id == previousFile.id { + dispatch = true + } + + if dispatch { + if let _ = strongSelf.patternArgumentsDisposable { + } else { + let throttledSignal = strongSelf.patternArgumentsPromise.get() + |> mapToThrottled { next -> Signal in + return .single(next) |> then(.complete() |> delay(0.016667, queue: Queue.concurrentDefaultQueue())) + } + + strongSelf.patternArgumentsDisposable = (throttledSignal).start(next: { [weak self] arguments in + if let strongSelf = self { + let makeImageLayout = strongSelf.signalBackgroundNode.asyncLayout() + let imageApply = makeImageLayout(arguments) + let _ = imageApply() + } + }) + } + + strongSelf.patternArgumentsPromise.set(.single(TransformImageArguments(corners: ImageCorners(), imageSize: layout.size, boundingSize: layout.size, intrinsicInsets: UIEdgeInsets(), custom: patternArguments))) + } else { + strongSelf.patternArgumentsDisposable?.dispose() + strongSelf.patternArgumentsDisposable = nil + + let makeImageLayout = strongSelf.signalBackgroundNode.asyncLayout() + let imageApply = makeImageLayout(TransformImageArguments(corners: ImageCorners(), imageSize: layout.size, boundingSize: layout.size, intrinsicInsets: UIEdgeInsets(), custom: patternArguments)) + let _ = imageApply() + } + + if !dispatch { + strongSelf.signalBackgroundNode.setSignal(wallpaperSignal) + strongSelf.patternWallpaper = wallpaper + } + } else { + strongSelf.signalBackgroundNode.setSignal(wallpaperSignal) + strongSelf.patternWallpaper = nil + } } strongSelf.wallpaper = wallpaper - + strongSelf.patternArguments = patternArguments + + if !preview { + strongSelf.currentBackgroundColors = backgroundColors + strongSelf.patternPanelNode.backgroundColors = backgroundColors + } + if let (layout, navigationBarHeight, messagesBottomInset) = strongSelf.validLayout { strongSelf.updateChatsLayout(layout: layout, topInset: navigationBarHeight, transition: .immediate) strongSelf.updateMessagesLayout(layout: layout, bottomInset: messagesBottomInset, transition: .immediate) @@ -380,14 +567,19 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate |> then(self.serviceBackgroundColorPromise.get())) |> deliverOnMainQueue).start(next: { [weak self] color in if let strongSelf = self { + strongSelf.patternPanelNode.serviceBackgroundColor = color strongSelf.pageControlBackgroundNode.backgroundColor = color + strongSelf.patternButtonNode.buttonColor = color + strongSelf.motionButtonNode.buttonColor = color } }) } deinit { - self.colorsDisposable?.dispose() + self.stateDisposable?.dispose() self.serviceColorDisposable?.dispose() + self.wallpaperDisposable.dispose() + self.patternArgumentsDisposable?.dispose() } override func didLoad() { @@ -400,6 +592,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate self.scrollNode.view.delegate = self self.pageControlNode.setPage(0.0) self.colorPanelNode.view.disablesInteractiveTransitionGestureRecognizer = true + self.patternPanelNode.view.disablesInteractiveTransitionGestureRecognizer = true let tapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(self.chatTapped)) self.scrollNode.view.addGestureRecognizer(tapGestureRecognizer) @@ -421,13 +614,22 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate var animationCurve = ContainedViewLayoutTransitionCurve.easeInOut var animationDuration: Double = 0.3 - let colorsChanged = !previousState.areColorsEqual(to: self.state) - if colorsChanged { - self.colors.set(.single((self.state.accentColor, self.state.backgroundColors, self.state.messagesColors, self.state.initialWallpaper, self.state.rotation))) + let visibleStateChange = !previousState.isEqual(to: self.state) + if visibleStateChange { + self.statePromise.set(.single(self.state)) } let colorPanelCollapsed = self.state.colorPanelCollapsed - + + if (previousState.patternWallpaper != nil) != (self.state.patternWallpaper != nil) { + self.patternButtonNode.setSelected(self.state.patternWallpaper != nil, animated: animated) + } + + if previousState.motion != self.state.motion { + self.motionButtonNode.setSelected(self.state.motion, animated: animated) + self.setMotionEnabled(self.state.motion, animated: animated) + } + let sectionChanged = previousState.section != self.state.section if sectionChanged, let section = self.state.section { self.view.endEditing(true) @@ -437,7 +639,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate var defaultColor: UIColor? switch section { case .accent: - firstColor = self.state.accentColor ?? .blue + firstColor = self.state.accentColor ?? defaultDayAccentColor secondColor = nil case .background: if let themeReference = self.mode.themeReference, case let .builtin(theme) = themeReference { @@ -453,7 +655,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate if let backgroundColors = self.state.backgroundColors { firstColor = backgroundColors.0 secondColor = backgroundColors.1 - } else if let image = self.chatBackgroundNode.image, previousState.initialWallpaper != nil { + } else if previousState.initialWallpaper != nil, let image = self.immediateBackgroundNode.image { firstColor = averageColor(from: image) secondColor = nil } else { @@ -461,7 +663,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate secondColor = nil } case .messages: - defaultColor = self.state.defaultMessagesColor ?? (self.state.accentColor ?? UIColor(rgb: 0x007ee5)) + defaultColor = self.state.defaultMessagesColor ?? (self.state.accentColor ?? defaultDayAccentColor) if let messagesColors = self.state.messagesColors { firstColor = messagesColors.0 secondColor = messagesColors.1 @@ -472,7 +674,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate } self.colorPanelNode.updateState({ _ in - return WallpaperColorPanelNodeState(selection: colorPanelCollapsed ? .none : .first, firstColor: firstColor, defaultColor: defaultColor, secondColor: secondColor, secondColorAvailable: self.state.section != .accent) + return WallpaperColorPanelNodeState(selection: colorPanelCollapsed ? .none : .first, firstColor: firstColor, defaultColor: defaultColor, secondColor: secondColor, secondColorAvailable: self.state.section != .accent, preview: false) }, animated: animated) needsLayout = true @@ -490,6 +692,29 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate }, animated: animated) } + if previousState.displayPatternPanel != self.state.displayPatternPanel { + let cancelButtonType: WallpaperGalleryToolbarCancelButtonType + let doneButtonType: WallpaperGalleryToolbarDoneButtonType + if self.state.displayPatternPanel { + doneButtonType = .apply + cancelButtonType = .discard + } else { + if case .edit(_, _, _, true, _) = self.mode { + doneButtonType = .proceed + } else { + doneButtonType = .set + } + cancelButtonType = .cancel + } + + self.toolbarNode.cancelButtonType = cancelButtonType + self.toolbarNode.doneButtonType = doneButtonType + + animationCurve = .easeInOut + animationDuration = 0.3 + needsLayout = true + } + if needsLayout, let (layout, navigationBarHeight, _) = self.validLayout { self.containerLayoutUpdated(layout, navigationBarHeight: navigationBarHeight, transition: animated ? .animated(duration: animationDuration, curve: animationCurve) : .immediate) } @@ -502,6 +727,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate updated.initialWallpaper = nil } updated.section = section + updated.displayPatternPanel = false return updated }, animated: true) } @@ -667,22 +893,18 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate } func containerLayoutUpdated(_ layout: ContainerViewLayout, navigationBarHeight: CGFloat, transition: ContainedViewLayoutTransition) { + let isFirstLayout = self.validLayout == nil + let bounds = CGRect(origin: CGPoint(), size: layout.size) + + let chatListPreviewAvailable = self.state.section == .accent + self.scrollNode.frame = bounds - - let toolbarHeight = 49.0 + layout.intrinsicInsets.bottom - self.chatListBackgroundNode.frame = CGRect(x: bounds.width, y: 0.0, width: bounds.width, height: bounds.height) - self.scrollNode.view.contentSize = CGSize(width: bounds.width * 2.0, height: bounds.height) - - var pageControlAlpha: CGFloat = 1.0 - if self.state.section != .accent { - pageControlAlpha = 0.0 - } - self.scrollNode.view.isScrollEnabled = pageControlAlpha > 0.0 + self.scrollNode.view.isScrollEnabled = chatListPreviewAvailable var messagesTransition = transition - if !self.scrollNode.view.isScrollEnabled && self.scrollNode.view.contentOffset.x > 0.0 { + if !chatListPreviewAvailable && self.scrollNode.view.contentOffset.x > 0.0 { var bounds = self.scrollNode.bounds bounds.origin.x = 0.0 transition.updateBounds(node: scrollNode, bounds: bounds) @@ -690,6 +912,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate self.pageControlNode.setPage(0.0) } + let toolbarHeight = 49.0 + layout.intrinsicInsets.bottom transition.updateFrame(node: self.toolbarNode, frame: CGRect(origin: CGPoint(x: 0.0, y: layout.size.height - toolbarHeight), size: CGSize(width: layout.size.width, height: 49.0 + layout.intrinsicInsets.bottom))) self.toolbarNode.updateLayout(size: CGSize(width: layout.size.width, height: 49.0), layout: layout, transition: transition) @@ -712,14 +935,36 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate transition.updateFrame(node: self.colorPanelNode, frame: colorPanelFrame) self.colorPanelNode.updateLayout(size: colorPanelFrame.size, transition: transition) + var patternPanelAlpha: CGFloat = self.state.displayPatternPanel ? 1.0 : 0.0 + var patternPanelFrame = colorPanelFrame + transition.updateFrame(node: self.patternPanelNode, frame: patternPanelFrame) + self.patternPanelNode.updateLayout(size: patternPanelFrame.size, transition: transition) + self.patternPanelNode.isUserInteractionEnabled = self.state.displayPatternPanel + transition.updateAlpha(node: self.patternPanelNode, alpha: patternPanelAlpha) + + self.chatListBackgroundNode.frame = CGRect(x: bounds.width, y: 0.0, width: bounds.width, height: bounds.height) + transition.updateFrame(node: self.messagesContainerNode, frame: CGRect(x: 0.0, y: navigationBarHeight, width: bounds.width, height: bounds.height - bottomInset - navigationBarHeight)) let backgroundSize = CGSize(width: bounds.width, height: bounds.height - (colorPanelHeight - colorPanelOffset)) - transition.updateFrame(node: self.chatBackgroundNode, frame: CGRect(origin: CGPoint(), size: backgroundSize)) - self.chatBackgroundNode.updateLayout(size: backgroundSize, transition: transition) + transition.updateFrame(node: self.backgroundContainerNode, frame: CGRect(origin: CGPoint(), size: backgroundSize)) + let makeImageLayout = self.signalBackgroundNode.asyncLayout() + let imageApply = makeImageLayout(TransformImageArguments(corners: ImageCorners(), imageSize: layout.size, boundingSize: layout.size, intrinsicInsets: UIEdgeInsets(), custom: self.patternArguments)) + let _ = imageApply() + + transition.updatePosition(node: self.backgroundWrapperNode, position: CGPoint(x: backgroundSize.width / 2.0, y: backgroundSize.height / 2.0)) + + transition.updateBounds(node: self.backgroundWrapperNode, bounds: CGRect(origin: CGPoint(), size: layout.size)) + transition.updateFrame(node: self.immediateBackgroundNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + transition.updateFrame(node: self.signalBackgroundNode, frame: CGRect(origin: CGPoint(), size: layout.size)) + + let displayOptionButtons = self.state.section == .background var messagesBottomInset: CGFloat = 0.0 - if pageControlAlpha > 0.0 { + + if displayOptionButtons { + messagesBottomInset = 46.0 + } else if chatListPreviewAvailable { messagesBottomInset = 37.0 } self.updateChatsLayout(layout: layout, topInset: navigationBarHeight, transition: transition) @@ -727,6 +972,7 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate self.validLayout = (layout, navigationBarHeight, messagesBottomInset) + let pageControlAlpha: CGFloat = chatListPreviewAvailable ? 1.0 : 0.0 let pageControlSize = self.pageControlNode.measure(CGSize(width: bounds.width, height: 100.0)) let pageControlFrame = CGRect(origin: CGPoint(x: floor((bounds.width - pageControlSize.width) / 2.0), y: layout.size.height - bottomInset - 28.0), size: pageControlSize) transition.updateFrame(node: self.pageControlNode, frame: pageControlFrame) @@ -735,13 +981,128 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate transition.updateAlpha(node: self.pageControlNode, alpha: pageControlAlpha) transition.updateAlpha(node: self.pageControlBackgroundNode, alpha: pageControlAlpha) transition.updateFrame(node: self.maskNode, frame: CGRect(x: 0.0, y: layout.size.height - bottomInset - 80.0, width: bounds.width, height: 80.0)) + + let patternButtonSize = self.patternButtonNode.measure(layout.size) + let motionButtonSize = self.motionButtonNode.measure(layout.size) + let maxButtonWidth = max(patternButtonSize.width, motionButtonSize.width) + let buttonSize = CGSize(width: maxButtonWidth, height: 30.0) + + let leftButtonFrame = CGRect(origin: CGPoint(x: floor(layout.size.width / 2.0 - buttonSize.width - 10.0), y: layout.size.height - bottomInset - 44.0), size: buttonSize) + let centerButtonFrame = CGRect(origin: CGPoint(x: floor((layout.size.width - buttonSize.width) / 2.0), y: layout.size.height - bottomInset - 44.0), size: buttonSize) + let rightButtonFrame = CGRect(origin: CGPoint(x: ceil(layout.size.width / 2.0 + 10.0), y: layout.size.height - bottomInset - 44.0), size: buttonSize) + + var hasMotion: Bool = self.state.backgroundColors?.1 != nil || self.state.patternWallpaper != nil || self.state.displayPatternPanel + + var patternAlpha: CGFloat = displayOptionButtons ? 1.0 : 0.0 + var motionAlpha: CGFloat = displayOptionButtons && hasMotion ? 1.0 : 0.0 + + var patternFrame = hasMotion ? leftButtonFrame : centerButtonFrame + var motionFrame = hasMotion ? rightButtonFrame : centerButtonFrame + + transition.updateFrame(node: self.patternButtonNode, frame: patternFrame) + transition.updateAlpha(node: self.patternButtonNode, alpha: patternAlpha) + + transition.updateFrame(node: self.motionButtonNode, frame: motionFrame) + transition.updateAlpha(node: self.motionButtonNode, alpha: motionAlpha) + + if isFirstLayout { + self.setMotionEnabled(self.state.motion, animated: false) + } } @objc private func chatTapped() { self.updateState({ current in var updated = current - updated.colorPanelCollapsed = !updated.colorPanelCollapsed + if updated.displayPatternPanel { + updated.displayPatternPanel = false + } else { + updated.colorPanelCollapsed = !updated.colorPanelCollapsed + } return updated }, animated: true) } + + @objc private func toggleMotion() { + self.updateState({ current in + var updated = current + updated.motion = !updated.motion + return updated + }, animated: true) + } + + @objc private func togglePattern() { + let wallpaper = self.state.previousPatternWallpaper ?? self.patternPanelNode.wallpapers.first + let backgroundColors = self.currentBackgroundColors + + var appeared = false + self.updateState({ current in + var updated = current + if updated.patternWallpaper != nil { + updated.previousPatternWallpaper = updated.patternWallpaper + updated.patternWallpaper = nil + updated.displayPatternPanel = false + } else { + updated.colorPanelCollapsed = false + updated.displayPatternPanel = true + if current.patternWallpaper == nil, let wallpaper = wallpaper { + updated.patternWallpaper = wallpaper + if updated.backgroundColors == nil { + updated.backgroundColors = backgroundColors + } + appeared = true + } + } + return updated + }, animated: true) + + if appeared { + self.patternPanelNode.didAppear(initialWallpaper: wallpaper, intensity: self.state.patternIntensity) + } + } + + private let motionAmount: CGFloat = 32.0 + private func setMotionEnabled(_ enabled: Bool, animated: Bool) { + guard let (layout, _, _) = self.validLayout else { + return + } + + if enabled { + let horizontal = UIInterpolatingMotionEffect(keyPath: "center.x", type: .tiltAlongHorizontalAxis) + horizontal.minimumRelativeValue = motionAmount + horizontal.maximumRelativeValue = -motionAmount + + let vertical = UIInterpolatingMotionEffect(keyPath: "center.y", type: .tiltAlongVerticalAxis) + vertical.minimumRelativeValue = motionAmount + vertical.maximumRelativeValue = -motionAmount + + let group = UIMotionEffectGroup() + group.motionEffects = [horizontal, vertical] + self.backgroundWrapperNode.view.addMotionEffect(group) + + let scale = (layout.size.width + motionAmount * 2.0) / layout.size.width + if animated { + self.backgroundWrapperNode.transform = CATransform3DMakeScale(scale, scale, 1.0) + self.backgroundWrapperNode.layer.animateScale(from: 1.0, to: scale, duration: 0.2) + } else { + self.backgroundWrapperNode.transform = CATransform3DMakeScale(scale, scale, 1.0) + } + } else { + let position = self.backgroundWrapperNode.layer.presentation()?.position + + for effect in self.backgroundWrapperNode.view.motionEffects { + self.backgroundWrapperNode.view.removeMotionEffect(effect) + } + + let scale = (layout.size.width + motionAmount * 2.0) / layout.size.width + if animated { + self.backgroundWrapperNode.transform = CATransform3DIdentity + self.backgroundWrapperNode.layer.animateScale(from: scale, to: 1.0, duration: 0.2) + if let position = position { + self.backgroundWrapperNode.layer.animatePosition(from: position, to: self.backgroundWrapperNode.layer.position, duration: 0.2) + } + } else { + self.backgroundWrapperNode.transform = CATransform3DIdentity + } + } + } } diff --git a/submodules/SettingsUI/Sources/Themes/ThemeAutoNightSettingsController.swift b/submodules/SettingsUI/Sources/Themes/ThemeAutoNightSettingsController.swift index 1e411fc73f..f9ed43dac9 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeAutoNightSettingsController.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeAutoNightSettingsController.swift @@ -523,7 +523,7 @@ public func themeAutoNightSettingsController(context: AccountContext) -> ViewCon } })) }, updateTheme: { theme in - guard let presentationTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: theme, accentColor: nil, bubbleColors: nil, serviceBackgroundColor: .black) else { + guard let presentationTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: theme) else { return } diff --git a/submodules/SettingsUI/Sources/Themes/ThemeColorsGridController.swift b/submodules/SettingsUI/Sources/Themes/ThemeColorsGridController.swift index 1d64872306..87c5221f9f 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeColorsGridController.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeColorsGridController.swift @@ -129,6 +129,7 @@ final class ThemeColorsGridController: ViewController { }, presentColorPicker: { [weak self] in if let strongSelf = self { let _ = (strongSelf.context.sharedContext.accountManager.sharedData(keys: [ApplicationSpecificSharedDataKeys.presentationThemeSettings]) + |> take(1) |> deliverOnMainQueue).start(next: { [weak self] sharedData in guard let strongSelf = self else { return @@ -144,10 +145,23 @@ final class ThemeColorsGridController: ViewController { } let controller = ThemeAccentColorController(context: strongSelf.context, mode: .background(themeReference: themeReference)) - controller.navigationPresentation = .modalInLargeLayout controller.completion = { [weak self] in if let strongSelf = self, let navigationController = strongSelf.navigationController as? NavigationController { - let _ = navigationController.popViewController(animated: true) + var controllers = navigationController.viewControllers + controllers = controllers.filter { controller in + if controller is ThemeColorsGridController { + return false + } + return true + } + navigationController.setViewControllers(controllers, animated: false) + controllers = controllers.filter { controller in + if controller is ThemeAccentColorController { + return false + } + return true + } + navigationController.setViewControllers(controllers, animated: true) } } strongSelf.push(controller) diff --git a/submodules/SettingsUI/Sources/Themes/ThemePreviewController.swift b/submodules/SettingsUI/Sources/Themes/ThemePreviewController.swift index 53ad04a89b..6c432016ee 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemePreviewController.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemePreviewController.swift @@ -17,7 +17,7 @@ import AppBundle import PresentationDataUtils public enum ThemePreviewSource { - case settings(PresentationThemeReference) + case settings(PresentationThemeReference, TelegramWallpaper?) case theme(TelegramTheme) case slug(String, TelegramMediaFile) case media(AnyMediaReference) @@ -95,7 +95,7 @@ public final class ThemePreviewController: ViewController { } )) hasInstallsCount = true - } else if case let .settings(themeReference) = source, case let .cloud(theme) = themeReference { + } else if case let .settings(themeReference, _) = source, case let .cloud(theme) = themeReference { self.theme.set(getTheme(account: context.account, slug: theme.theme.slug) |> map(Optional.init) |> `catch` { _ -> Signal in @@ -171,7 +171,13 @@ public final class ThemePreviewController: ViewController { if case .settings = self.source { isPreview = true } - self.displayNode = ThemePreviewControllerNode(context: self.context, previewTheme: self.previewTheme, dismiss: { [weak self] in + + var initialWallpaper: TelegramWallpaper? + if case let .settings(_, currentWallpaper) = self.source, let wallpaper = currentWallpaper { + initialWallpaper = wallpaper + } + + self.displayNode = ThemePreviewControllerNode(context: self.context, previewTheme: self.previewTheme, initialWallpaper: initialWallpaper, dismiss: { [weak self] in if let strongSelf = self { strongSelf.dismiss() } @@ -183,7 +189,9 @@ public final class ThemePreviewController: ViewController { self.displayNodeDidLoad() let previewTheme = self.previewTheme - if case let .file(file) = previewTheme.chat.defaultWallpaper, file.id == 0 { + if let initialWallpaper = initialWallpaper { + self.controllerNode.wallpaperPromise.set(.single(initialWallpaper)) + } else if case let .file(file) = previewTheme.chat.defaultWallpaper, file.id == 0 { self.controllerNode.wallpaperPromise.set(cachedWallpaper(account: self.context.account, slug: file.slug, settings: file.settings) |> mapToSignal { wallpaper in return .single(wallpaper?.wallpaper ?? .color(Int32(bitPattern: previewTheme.chatList.backgroundColor.rgb))) @@ -203,7 +211,7 @@ public final class ThemePreviewController: ViewController { let disposable = self.applyDisposable switch self.source { - case let .settings(reference): + case let .settings(reference, _): theme = .single(reference) case .theme, .slug: theme = combineLatest(self.theme.get() |> take(1), wallpaperPromise.get() |> take(1)) diff --git a/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift b/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift index abaff9d68b..de6da9ac49 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift @@ -65,7 +65,7 @@ final class ThemePreviewControllerNode: ASDisplayNode, UIScrollViewDelegate { private var statusDisposable: Disposable? private var fetchDisposable = MetaDisposable() - init(context: AccountContext, previewTheme: PresentationTheme, dismiss: @escaping () -> Void, apply: @escaping () -> Void, isPreview: Bool) { + init(context: AccountContext, previewTheme: PresentationTheme, initialWallpaper: TelegramWallpaper?, dismiss: @escaping () -> Void, apply: @escaping () -> Void, isPreview: Bool) { self.context = context self.previewTheme = previewTheme self.isPreview = isPreview @@ -98,8 +98,10 @@ final class ThemePreviewControllerNode: ASDisplayNode, UIScrollViewDelegate { self.instantChatBackgroundNode = WallpaperBackgroundNode() self.instantChatBackgroundNode.displaysAsynchronously = false - self.instantChatBackgroundNode.image = chatControllerBackgroundImage(theme: previewTheme, wallpaper: previewTheme.chat.defaultWallpaper, mediaBox: context.sharedContext.accountManager.mediaBox, knockoutMode: context.sharedContext.immediateExperimentalUISettings.knockoutWallpaper) - if case .gradient = previewTheme.chat.defaultWallpaper { + + let wallpaper = initialWallpaper ?? previewTheme.chat.defaultWallpaper + self.instantChatBackgroundNode.image = chatControllerBackgroundImage(theme: previewTheme, wallpaper: wallpaper, mediaBox: context.sharedContext.accountManager.mediaBox, knockoutMode: context.sharedContext.immediateExperimentalUISettings.knockoutWallpaper) + if case .gradient = wallpaper { self.instantChatBackgroundNode.imageContentMode = .scaleToFill } self.instantChatBackgroundNode.motionEnabled = previewTheme.chat.defaultWallpaper.settings?.motion ?? false @@ -167,8 +169,12 @@ final class ThemePreviewControllerNode: ASDisplayNode, UIScrollViewDelegate { self.toolbarNode.cancel = { dismiss() } + var dismissed = false self.toolbarNode.done = { - apply() + if !dismissed { + dismissed = true + apply() + } } if case let .file(file) = self.previewTheme.chat.defaultWallpaper { @@ -255,16 +261,21 @@ final class ThemePreviewControllerNode: ASDisplayNode, UIScrollViewDelegate { } }) - var patternColor: UIColor? - var patternIntensity: CGFloat = 0.5 + + var patternArguments: PatternWallpaperArguments? if let color = file.settings.color { + var patternIntensity: CGFloat = 0.5 if let intensity = file.settings.intensity { patternIntensity = CGFloat(intensity) / 100.0 } - patternColor = UIColor(rgb: UInt32(bitPattern: color), alpha: patternIntensity) + var patternColors = [UIColor(rgb: UInt32(bitPattern: color), alpha: patternIntensity)] + if let bottomColor = file.settings.bottomColor { + patternColors.append(UIColor(rgb: UInt32(bitPattern: bottomColor), alpha: patternIntensity)) + } + patternArguments = PatternWallpaperArguments(colors: patternColors, rotation: file.settings.rotation) } - strongSelf.remoteChatBackgroundNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets(), emptyColor: patternColor))() + strongSelf.remoteChatBackgroundNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets(), custom: patternArguments))() } }) } diff --git a/submodules/SettingsUI/Sources/Themes/ThemeSettingsAccentColorItem.swift b/submodules/SettingsUI/Sources/Themes/ThemeSettingsAccentColorItem.swift index 2fc1c4d720..1c9cd633b1 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeSettingsAccentColorItem.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeSettingsAccentColorItem.swift @@ -8,9 +8,10 @@ import SyncCore import TelegramPresentationData import TelegramUIPreferences import ItemListUI +import ContextUI import PresentationDataUtils -private func generateSwatchImage(theme: PresentationTheme, color: PresentationThemeAccentColor, bubbles: (UIColor, UIColor?)?, selected: Bool, more: Bool) -> UIImage? { +private func generateSwatchImage(theme: PresentationTheme, themeReference: PresentationThemeReference, color: PresentationThemeAccentColor, bubbles: (UIColor, UIColor?)?, selected: Bool, more: Bool) -> UIImage? { return generateImage(CGSize(width: 40.0, height: 40.0), rotatedContext: { size, context in let bounds = CGRect(origin: CGPoint(), size: size) context.clear(bounds) @@ -50,9 +51,17 @@ private func generateSwatchImage(theme: PresentationTheme, color: PresentationTh context.addEllipse(in: bounds.insetBy(dx: 10.0, dy: 10.0)) context.clip() - if let colors = bubbles { - var colors: (UIColor, UIColor) = (colors.0, colors.1 ?? colors.0) - + var colors: (UIColor, UIColor)? + + if let customColors = bubbles { + colors = (customColors.0, customColors.1 ?? customColors.0) + } else if case .builtin(.dayClassic) = themeReference { + let hsb = color.color.hsb + let bubbleColor = UIColor(hue: hsb.0, saturation: (hsb.1 > 0.0 && hsb.2 > 0.0) ? 0.14 : 0.0, brightness: 0.79 + hsb.2 * 0.21, alpha: 1.0) + colors = (bubbleColor, bubbleColor) + } + + if let colors = colors { let gradientColors = [colors.0.cgColor, colors.1.cgColor] as CFArray var locations: [CGFloat] = [0.0, 1.0] let colorSpace = CGColorSpaceCreateDeviceRGB() @@ -105,17 +114,21 @@ class ThemeSettingsAccentColorItem: ListViewItem, ItemListItem { var sectionId: ItemListSectionId let theme: PresentationTheme + let themeReference: PresentationThemeReference let colors: [ThemeSettingsAccentColor] let currentColor: PresentationThemeAccentColor? let updated: (PresentationThemeAccentColor?) -> Void + let contextAction: ((PresentationThemeReference, PresentationThemeAccentColor?, ASDisplayNode, ContextGesture?) -> Void)? let openColorPicker: () -> Void let tag: ItemListItemTag? - init(theme: PresentationTheme, sectionId: ItemListSectionId, colors: [ThemeSettingsAccentColor], currentColor: PresentationThemeAccentColor?, updated: @escaping (PresentationThemeAccentColor?) -> Void, openColorPicker: @escaping () -> Void, tag: ItemListItemTag? = nil) { + init(theme: PresentationTheme, sectionId: ItemListSectionId, themeReference: PresentationThemeReference, colors: [ThemeSettingsAccentColor], currentColor: PresentationThemeAccentColor?, updated: @escaping (PresentationThemeAccentColor?) -> Void, contextAction: ((PresentationThemeReference, PresentationThemeAccentColor?, ASDisplayNode, ContextGesture?) -> Void)?, openColorPicker: @escaping () -> Void, tag: ItemListItemTag? = nil) { self.theme = theme + self.themeReference = themeReference self.colors = colors self.currentColor = currentColor self.updated = updated + self.contextAction = contextAction self.openColorPicker = openColorPicker self.tag = tag self.sectionId = sectionId @@ -156,24 +169,40 @@ class ThemeSettingsAccentColorItem: ListViewItem, ItemListItem { } private final class ThemeSettingsAccentColorNode : ASDisplayNode { + private let containerNode: ContextControllerSourceNode private let iconNode: ASImageNode private var action: (() -> Void)? + private var contextAction: ((ASDisplayNode, ContextGesture?) -> Void)? override init() { + self.containerNode = ContextControllerSourceNode() + self.iconNode = ASImageNode() self.iconNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: 62.0, height: 62.0)) self.iconNode.isLayerBacked = true super.init() - self.addSubnode(self.iconNode) + self.addSubnode(self.containerNode) + self.containerNode.addSubnode(self.iconNode) + + self.containerNode.activated = { [weak self] gesture in + guard let strongSelf = self else { + gesture.cancel() + return + } + strongSelf.contextAction?(strongSelf.containerNode, gesture) + } } - func setup(theme: PresentationTheme, color: PresentationThemeAccentColor, bubbles: (UIColor, UIColor?)?, selected: Bool, more: Bool, action: @escaping () -> Void) { - self.iconNode.image = generateSwatchImage(theme: theme, color: color, bubbles: bubbles, selected: selected, more: more) + func setup(theme: PresentationTheme, themeReference: PresentationThemeReference, isDefault: Bool, color: PresentationThemeAccentColor, bubbles: (UIColor, UIColor?)?, selected: Bool, more: Bool, action: @escaping () -> Void, contextAction: ((PresentationThemeReference, PresentationThemeAccentColor?, ASDisplayNode, ContextGesture?) -> Void)?) { + self.iconNode.image = generateSwatchImage(theme: theme, themeReference: themeReference, color: color, bubbles: bubbles, selected: selected, more: more) self.action = { action() } + self.contextAction = { node, gesture in + contextAction?(themeReference, isDefault ? nil : color, node, gesture) + } } override func didLoad() { @@ -191,7 +220,8 @@ private final class ThemeSettingsAccentColorNode : ASDisplayNode { override func layout() { super.layout() - self.iconNode.frame = self.bounds + self.containerNode.frame = self.bounds + self.iconNode.frame = self.containerNode.bounds } } @@ -340,10 +370,7 @@ class ThemeSettingsAccentColorItemNode: ListViewItemNode, ItemListItemNode { var updated = false var selectedNode: ThemeSettingsAccentColorNode? - - strongSelf.customNode.frame = CGRect(origin: CGPoint(x: nodeOffset, y: 9.0), size: CGSize(width: 42.0, height: 42.0)) - nodeOffset += nodeSize.width + 18.0 - + var i = 0 for color in item.colors { let imageNode: ThemeSettingsAccentColorNode @@ -359,10 +386,12 @@ class ThemeSettingsAccentColorItemNode: ListViewItemNode, ItemListItemNode { let selected: Bool var accentColor: PresentationThemeAccentColor var itemColor: PresentationThemeAccentColor? + var isDefault = false switch color { case .default: selected = item.currentColor == nil accentColor = PresentationThemeAccentColor(baseColor: .blue, accentColor: 0x007ee5, bubbleColors: (0xe1ffc7, nil)) + isDefault = true case let .color(color): selected = item.currentColor?.baseColor == color if let currentColor = item.currentColor, selected { @@ -377,7 +406,7 @@ class ThemeSettingsAccentColorItemNode: ListViewItemNode, ItemListItemNode { selectedNode = imageNode } - imageNode.setup(theme: item.theme, color: accentColor, bubbles: accentColor.customBubbleColors, selected: selected, more: true, action: { [weak self, weak imageNode] in + imageNode.setup(theme: item.theme, themeReference: item.themeReference, isDefault: isDefault, color: accentColor, bubbles: accentColor.customBubbleColors, selected: selected, more: true, action: { [weak self, weak imageNode] in if selected { item.openColorPicker() } else { @@ -386,7 +415,7 @@ class ThemeSettingsAccentColorItemNode: ListViewItemNode, ItemListItemNode { if let imageNode = imageNode { self?.scrollToNode(imageNode, animated: true) } - }) + }, contextAction: item.contextAction) imageNode.frame = CGRect(origin: CGPoint(x: nodeOffset, y: 10.0), size: nodeSize) nodeOffset += nodeSize.width + 18.0 @@ -394,7 +423,7 @@ class ThemeSettingsAccentColorItemNode: ListViewItemNode, ItemListItemNode { i += 1 } -// strongSelf.customNode.frame = CGRect(origin: CGPoint(x: nodeOffset, y: 9.0), size: CGSize(width: 42.0, height: 42.0)) + strongSelf.customNode.frame = CGRect(origin: CGPoint(x: nodeOffset, y: 9.0), size: CGSize(width: 42.0, height: 42.0)) for k in (i ..< strongSelf.colorNodes.count).reversed() { let node = strongSelf.colorNodes[k] @@ -402,7 +431,7 @@ class ThemeSettingsAccentColorItemNode: ListViewItemNode, ItemListItemNode { node.removeFromSupernode() } - let contentSize = CGSize(width: strongSelf.colorNodes.last!.frame.maxX + nodeInset, height: strongSelf.scrollNode.frame.height) + let contentSize = CGSize(width: strongSelf.customNode.frame.maxX + nodeInset, height: strongSelf.scrollNode.frame.height) if strongSelf.scrollNode.view.contentSize != contentSize { strongSelf.scrollNode.view.contentSize = contentSize } diff --git a/submodules/SettingsUI/Sources/Themes/ThemeSettingsController.swift b/submodules/SettingsUI/Sources/Themes/ThemeSettingsController.swift index 3928b1bc34..4ef49fd500 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeSettingsController.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeSettingsController.swift @@ -79,9 +79,10 @@ private final class ThemeSettingsControllerArguments { let disableAnimations: (Bool) -> Void let selectAppIcon: (String) -> Void let editTheme: (PresentationCloudTheme) -> Void - let contextAction: (Bool, PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void + let themeContextAction: (Bool, PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void + let colorContextAction: (PresentationThemeReference, PresentationThemeAccentColor?, ASDisplayNode, ContextGesture?) -> Void - init(context: AccountContext, selectTheme: @escaping (PresentationThemeReference) -> Void, selectFontSize: @escaping (PresentationFontSize) -> Void, openWallpaperSettings: @escaping () -> Void, selectAccentColor: @escaping (PresentationThemeAccentColor?) -> Void, openAccentColorPicker: @escaping (PresentationThemeReference) -> Void, openAutoNightTheme: @escaping () -> Void, openTextSize: @escaping () -> Void, toggleLargeEmoji: @escaping (Bool) -> Void, disableAnimations: @escaping (Bool) -> Void, selectAppIcon: @escaping (String) -> Void, editTheme: @escaping (PresentationCloudTheme) -> Void, contextAction: @escaping (Bool, PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void) { + init(context: AccountContext, selectTheme: @escaping (PresentationThemeReference) -> Void, selectFontSize: @escaping (PresentationFontSize) -> Void, openWallpaperSettings: @escaping () -> Void, selectAccentColor: @escaping (PresentationThemeAccentColor?) -> Void, openAccentColorPicker: @escaping (PresentationThemeReference) -> Void, openAutoNightTheme: @escaping () -> Void, openTextSize: @escaping () -> Void, toggleLargeEmoji: @escaping (Bool) -> Void, disableAnimations: @escaping (Bool) -> Void, selectAppIcon: @escaping (String) -> Void, editTheme: @escaping (PresentationCloudTheme) -> Void, themeContextAction: @escaping (Bool, PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void, colorContextAction: @escaping (PresentationThemeReference, PresentationThemeAccentColor?, ASDisplayNode, ContextGesture?) -> Void) { self.context = context self.selectTheme = selectTheme self.selectFontSize = selectFontSize @@ -94,7 +95,8 @@ private final class ThemeSettingsControllerArguments { self.disableAnimations = disableAnimations self.selectAppIcon = selectAppIcon self.editTheme = editTheme - self.contextAction = contextAction + self.themeContextAction = themeContextAction + self.colorContextAction = colorContextAction } } @@ -331,8 +333,10 @@ private enum ThemeSettingsControllerEntry: ItemListNodeEntry { colorItems.append(contentsOf: colors.map { .color($0) }) - return ThemeSettingsAccentColorItem(theme: theme, sectionId: self.section, colors: colorItems, currentColor: currentColor, updated: { color in + return ThemeSettingsAccentColorItem(theme: theme, sectionId: self.section, themeReference: currentTheme, colors: colorItems, currentColor: currentColor, updated: { color in arguments.selectAccentColor(color) + }, contextAction: { theme, color, node, gesture in + arguments.colorContextAction(theme, color, node, gesture) }, openColorPicker: { arguments.openAccentColorPicker(currentTheme) }, tag: ThemeSettingsEntryTag.accentColor) @@ -356,7 +360,7 @@ private enum ThemeSettingsControllerEntry: ItemListNodeEntry { arguments.selectTheme(theme) } }, contextAction: { theme, node, gesture in - arguments.contextAction(theme.index == currentTheme.index, theme, node, gesture) + arguments.themeContextAction(theme.index == currentTheme.index, theme, node, gesture) }) case let .iconHeader(theme, text): return ItemListSectionHeaderItem(presentationData: presentationData, text: text, sectionId: self.section) @@ -477,7 +481,7 @@ public func themeSettingsController(context: AccountContext, focusOnItemTag: The currentTheme = current.automaticThemeSwitchSetting.theme } - guard let theme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: currentTheme, accentColor: color?.color, bubbleColors: nil) else { + guard let theme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: currentTheme, accentColor: color?.color) else { return current } @@ -486,7 +490,7 @@ public func themeSettingsController(context: AccountContext, focusOnItemTag: The themeSpecificAccentColors[currentTheme.index] = color if case let .builtin(theme) = currentTheme, theme == .dayClassic || theme == .nightAccent { - if let wallpaper = current.themeSpecificChatWallpapers[currentTheme.index], wallpaper.isColorOrGradient || wallpaper.isBuiltin { + if let wallpaper = current.themeSpecificChatWallpapers[currentTheme.index], wallpaper.isColorOrGradient || wallpaper.isPattern || wallpaper.isBuiltin { themeSpecificChatWallpapers[currentTheme.index] = nil } } @@ -524,20 +528,20 @@ public func themeSettingsController(context: AccountContext, focusOnItemTag: The } }) pushControllerImpl?(controller) - }, contextAction: { isCurrent, reference, node, gesture in - let _ = (context.sharedContext.accountManager.transaction { transaction -> PresentationThemeAccentColor? in + }, themeContextAction: { isCurrent, reference, node, gesture in + let _ = (context.sharedContext.accountManager.transaction { transaction -> (PresentationThemeAccentColor?, TelegramWallpaper?) in let settings = transaction.getSharedData(ApplicationSpecificSharedDataKeys.presentationThemeSettings) as? PresentationThemeSettings ?? PresentationThemeSettings.defaultSettings - return settings.themeSpecificAccentColors[reference.index] - } |> map { accentColor in - return makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: reference, accentColor: accentColor?.color, bubbleColors: accentColor?.customBubbleColors) + return (settings.themeSpecificAccentColors[reference.index], settings.themeSpecificChatWallpapers[reference.index]) + } |> map { accentColor, wallpaper in + return (makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: reference, accentColor: accentColor?.color, bubbleColors: accentColor?.customBubbleColors), wallpaper) } - |> deliverOnMainQueue).start(next: { theme in + |> deliverOnMainQueue).start(next: { theme, wallpaper in guard let theme = theme else { return } let presentationData = context.sharedContext.currentPresentationData.with { $0 } let strings = presentationData.strings - let themeController = ThemePreviewController(context: context, previewTheme: theme, source: .settings(reference)) + let themeController = ThemePreviewController(context: context, previewTheme: theme, source: .settings(reference, wallpaper)) var items: [ContextMenuItem] = [] if case let .cloud(theme) = reference { @@ -555,31 +559,44 @@ public func themeSettingsController(context: AccountContext, focusOnItemTag: The }))) } else { items.append(.action(ContextMenuActionItem(text: strings.Theme_Context_ChangeColors, icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/ApplyTheme"), color: theme.contextMenu.primaryColor) }, action: { c, f in - guard let theme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: reference, accentColor: nil, bubbleColors: nil, backgroundColors: nil, preview: false) else { + guard let theme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: reference, preview: false) else { return } - let controller = ThemeAccentColorController(context: context, mode: .edit(theme: theme, wallpaper: nil, defaultThemeReference: nil, create: true, completion: { result in - let controller = editThemeController(context: context, mode: .create(result), navigateToChat: { peerId in - if let navigationController = getNavigationControllerImpl?() { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId))) - } - }) - updateControllersImpl?({ controllers in - var controllers = controllers - controllers = controllers.filter { controller in - if controller is ThemeAccentColorController { - return false - } - return true - } - controllers.append(controller) - return controllers - }) - })) + let resolvedWallpaper: Signal + if case let .file(file) = theme.chat.defaultWallpaper, file.id == 0 { + resolvedWallpaper = cachedWallpaper(account: context.account, slug: file.slug, settings: file.settings) + |> map { cachedWallpaper -> TelegramWallpaper in + return cachedWallpaper?.wallpaper ?? theme.chat.defaultWallpaper + } + } else { + resolvedWallpaper = .single(theme.chat.defaultWallpaper) + } - c.dismiss(completion: { - pushControllerImpl?(controller) + let _ = (resolvedWallpaper + |> deliverOnMainQueue).start(next: { wallpaper in + let controller = ThemeAccentColorController(context: context, mode: .edit(theme: theme, wallpaper: wallpaper, defaultThemeReference: nil, create: true, completion: { result in + let controller = editThemeController(context: context, mode: .create(result), navigateToChat: { peerId in + if let navigationController = getNavigationControllerImpl?() { + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId))) + } + }) + updateControllersImpl?({ controllers in + var controllers = controllers + controllers = controllers.filter { controller in + if controller is ThemeAccentColorController { + return false + } + return true + } + controllers.append(controller) + return controllers + }) + })) + + c.dismiss(completion: { + pushControllerImpl?(controller) + }) }) }))) } @@ -633,6 +650,27 @@ public func themeSettingsController(context: AccountContext, focusOnItemTag: The let contextController = ContextController(account: context.account, presentationData: presentationData, source: .controller(ContextControllerContentSourceImpl(controller: themeController, sourceNode: node)), items: .single(items), reactionItems: [], gesture: gesture) presentInGlobalOverlayImpl?(contextController, nil) }) + }, colorContextAction: { reference, accentColor, node, gesture in + guard let theme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: reference, accentColor: accentColor?.color, bubbleColors: accentColor?.customBubbleColors) else { + return + } + let presentationData = context.sharedContext.currentPresentationData.with { $0 } + let strings = presentationData.strings + let themeController = ThemePreviewController(context: context, previewTheme: theme, source: .settings(reference, nil)) + var items: [ContextMenuItem] = [] + + let removable = accentColor?.accentColor != nil || accentColor?.bubbleColors != nil + if removable { + items.append(.action(ContextMenuActionItem(text: presentationData.strings.Appearance_RemoveThemeColor, textColor: .destructive, icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Delete"), color: theme.contextMenu.destructiveColor) + }, action: { c, f in + c.dismiss(completion: { + let controller = ThemeAccentColorController(context: context, mode: .colors(themeReference: reference)) + pushControllerImpl?(controller) + }) + }))) + } + let contextController = ContextController(account: context.account, presentationData: presentationData, source: .controller(ContextControllerContentSourceImpl(controller: themeController, sourceNode: node)), items: .single(items), reactionItems: [], gesture: gesture) + presentInGlobalOverlayImpl?(contextController, nil) }) let signal = combineLatest(queue: .mainQueue(), context.sharedContext.presentationData, context.sharedContext.accountManager.sharedData(keys: [ApplicationSpecificSharedDataKeys.presentationThemeSettings]), cloudThemes.get(), availableAppIcons, currentAppIconName.get()) @@ -700,7 +738,7 @@ public func themeSettingsController(context: AccountContext, focusOnItemTag: The return controller?.navigationController as? NavigationController } selectThemeImpl = { theme in - guard let presentationTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: theme, accentColor: nil, bubbleColors: nil, serviceBackgroundColor: .black) else { + guard let presentationTheme = makePresentationTheme(mediaBox: context.sharedContext.accountManager.mediaBox, themeReference: theme) else { return } @@ -810,9 +848,12 @@ public func themeSettingsController(context: AccountContext, focusOnItemTag: The public final class ThemeSettingsCrossfadeController: ViewController { private let snapshotView: UIView? - public init() { - self.snapshotView = UIScreen.main.snapshotView(afterScreenUpdates: false) - + public init(view: UIView? = nil) { + if let view = view { + self.snapshotView = view.snapshotContentTree() + } else { + self.snapshotView = UIScreen.main.snapshotView(afterScreenUpdates: false) + } super.init(navigationBarPresentationData: nil) self.statusBar.statusBarStyle = .Ignore diff --git a/submodules/SettingsUI/Sources/Themes/ThemeSettingsThemeItem.swift b/submodules/SettingsUI/Sources/Themes/ThemeSettingsThemeItem.swift index 91b7b469b9..3006b9664b 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeSettingsThemeItem.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeSettingsThemeItem.swift @@ -7,6 +7,7 @@ import Postbox import TelegramCore import SyncCore import TelegramPresentationData +import MergeLists import TelegramUIPreferences import ItemListUI import PresentationDataUtils @@ -15,41 +16,149 @@ import AccountContext import AppBundle import ContextUI -private var borderImages: [String: UIImage] = [:] +private struct ThemeSettingsThemeEntry: Comparable, Identifiable { + let index: Int + let themeReference: PresentationThemeReference + let title: String + let accentColor: PresentationThemeAccentColor? + var selected: Bool + let theme: PresentationTheme + + var stableId: Int64 { + return self.themeReference.index + } + + static func ==(lhs: ThemeSettingsThemeEntry, rhs: ThemeSettingsThemeEntry) -> Bool { + if lhs.index != rhs.index { + return false + } + if lhs.themeReference.index != rhs.themeReference.index { + return false + } + if lhs.accentColor != rhs.accentColor { + return false + } + if lhs.title != rhs.title { + return false + } + if lhs.selected != rhs.selected { + return false + } + if lhs.theme !== rhs.theme { + return false + } + return true + } + + static func <(lhs: ThemeSettingsThemeEntry, rhs: ThemeSettingsThemeEntry) -> Bool { + return lhs.index < rhs.index + } + + func item(context: AccountContext, action: @escaping (PresentationThemeReference) -> Void, contextAction: ((PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void)?) -> ListViewItem { + return ThemeSettingsThemeIconItem(context: context, themeReference: self.themeReference, accentColor: self.accentColor, selected: self.selected, title: self.title, theme: self.theme, action: action, contextAction: contextAction) + } +} + +private class ThemeSettingsThemeIconItem: ListViewItem { + let context: AccountContext + let themeReference: PresentationThemeReference + let accentColor: PresentationThemeAccentColor? + let selected: Bool + let title: String + let theme: PresentationTheme + let action: (PresentationThemeReference) -> Void + let contextAction: ((PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void)? + + public init(context: AccountContext, themeReference: PresentationThemeReference, accentColor: PresentationThemeAccentColor?, selected: Bool, title: String, theme: PresentationTheme, action: @escaping (PresentationThemeReference) -> Void, contextAction: ((PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void)?) { + self.context = context + self.themeReference = themeReference + self.accentColor = accentColor + self.selected = selected + self.title = title + self.theme = theme + self.action = action + self.contextAction = contextAction + } + + public func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { + async { + let node = ThemeSettingsThemeItemIconNode() + let (nodeLayout, apply) = node.asyncLayout()(self, params) + node.insets = nodeLayout.insets + node.contentSize = nodeLayout.contentSize + + Queue.mainQueue().async { + completion(node, { + return (nil, { _ in + apply(false) + }) + }) + } + } + } + + public func updateNode(async: @escaping (@escaping () -> Void) -> Void, node: @escaping () -> ListViewItemNode, params: ListViewItemLayoutParams, previousItem: ListViewItem?, nextItem: ListViewItem?, animation: ListViewItemUpdateAnimation, completion: @escaping (ListViewItemNodeLayout, @escaping (ListViewItemApply) -> Void) -> Void) { + Queue.mainQueue().async { + assert(node() is ThemeSettingsThemeItemIconNode) + if let nodeValue = node() as? ThemeSettingsThemeItemIconNode { + let layout = nodeValue.asyncLayout() + async { + let (nodeLayout, apply) = layout(self, params) + Queue.mainQueue().async { + completion(nodeLayout, { _ in + apply(animation.isAnimated) + }) + } + } + } + } + } + + public var selectable = true + public func selected(listView: ListView) { + self.action(self.themeReference) + } +} + + +private let textFont = Font.regular(12.0) +private let selectedTextFont = Font.bold(12.0) + +private var cachedBorderImages: [String: UIImage] = [:] private func generateBorderImage(theme: PresentationTheme, bordered: Bool, selected: Bool) -> UIImage? { let key = "\(theme.list.itemBlocksBackgroundColor.hexString)_\(selected ? "s" + theme.list.itemAccentColor.hexString : theme.list.disclosureArrowColor.hexString)" - if let image = borderImages[key] { + if let image = cachedBorderImages[key] { return image } else { let image = generateImage(CGSize(width: 32.0, height: 32.0), rotatedContext: { size, context in let bounds = CGRect(origin: CGPoint(), size: size) - context.setFillColor(theme.list.itemBlocksBackgroundColor.cgColor) - context.fill(bounds) - - context.setBlendMode(.clear) - context.fillEllipse(in: bounds.insetBy(dx: 1.0, dy: 1.0)) - context.setBlendMode(.normal) - + context.clear(bounds) + let lineWidth: CGFloat if selected { + lineWidth = 2.0 + context.setLineWidth(lineWidth) + context.setStrokeColor(theme.list.itemBlocksBackgroundColor.cgColor) + + context.strokeEllipse(in: bounds.insetBy(dx: 3.0 + lineWidth / 2.0, dy: 3.0 + lineWidth / 2.0)) + var accentColor = theme.list.itemAccentColor if accentColor.rgb == 0xffffff { accentColor = UIColor(rgb: 0x999999) } context.setStrokeColor(accentColor.cgColor) - lineWidth = 2.0 } else { context.setStrokeColor(theme.list.disclosureArrowColor.withAlphaComponent(0.4).cgColor) lineWidth = 1.0 } - + if bordered || selected { context.setLineWidth(lineWidth) context.strokeEllipse(in: bounds.insetBy(dx: 1.0 + lineWidth / 2.0, dy: 1.0 + lineWidth / 2.0)) } })?.stretchableImage(withLeftCapWidth: 16, topCapHeight: 16) - borderImages[key] = image + cachedBorderImages[key] = image return image } } @@ -80,9 +189,136 @@ private func createThemeImage(theme: PresentationTheme) -> Signal<(TransformImag } +private final class ThemeSettingsThemeItemIconNode : ListViewItemNode { + private let containerNode: ContextControllerSourceNode + private let imageNode: TransformImageNode + private let overlayNode: ASImageNode + private let titleNode: TextNode + + var item: ThemeSettingsThemeIconItem? + + init() { + self.containerNode = ContextControllerSourceNode() + + self.imageNode = TransformImageNode() + self.imageNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: 98.0, height: 62.0)) + self.imageNode.isLayerBacked = true + + self.overlayNode = ASImageNode() + self.overlayNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: 100.0, height: 64.0)) + self.overlayNode.isLayerBacked = true + + self.titleNode = TextNode() + self.titleNode.isUserInteractionEnabled = false + + super.init(layerBacked: false, dynamicBounce: false, rotated: false, seeThrough: false) + + self.addSubnode(self.containerNode) + self.containerNode.addSubnode(self.imageNode) + self.containerNode.addSubnode(self.overlayNode) + self.containerNode.addSubnode(self.titleNode) + + self.containerNode.activated = { [weak self] gesture in + guard let strongSelf = self, let item = strongSelf.item else { + gesture.cancel() + return + } + item.contextAction?(item.themeReference, strongSelf.containerNode, gesture) + } + } + + override func didLoad() { + super.didLoad() + + self.layer.sublayerTransform = CATransform3DMakeRotation(CGFloat.pi / 2.0, 0.0, 0.0, 1.0) + } + + func asyncLayout() -> (ThemeSettingsThemeIconItem, ListViewItemLayoutParams) -> (ListViewItemNodeLayout, (Bool) -> Void) { + let makeTitleLayout = TextNode.asyncLayout(self.titleNode) + let makeImageLayout = self.imageNode.asyncLayout() + + let currentItem = self.item + + return { [weak self] item, params in + var updatedThemeReference = false + var updatedAccentColor = false + var updatedTheme = false + var updatedSelected = false + + if currentItem?.themeReference != item.themeReference { + updatedThemeReference = true + } + if currentItem?.accentColor != item.accentColor { + updatedAccentColor = true + } + if currentItem?.theme !== item.theme { + updatedTheme = true + } + if currentItem?.selected != item.selected { + updatedSelected = true + } + + let title = NSAttributedString(string: item.title, font: item.selected ? selectedTextFont : textFont, textColor: item.selected ? item.theme.list.itemAccentColor : item.theme.list.itemPrimaryTextColor) + let (titleLayout, titleApply) = makeTitleLayout(TextNodeLayoutArguments(attributedString: title, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: params.width, height: CGFloat.greatestFiniteMagnitude), alignment: .center, cutout: nil, insets: UIEdgeInsets())) + + let itemLayout = ListViewItemNodeLayout(contentSize: CGSize(width: 116.0, height: 116.0), insets: UIEdgeInsets()) + return (itemLayout, { animated in + if let strongSelf = self { + strongSelf.item = item + + if case let .cloud(theme) = item.themeReference, theme.theme.file == nil { + if updatedTheme { + strongSelf.imageNode.setSignal(createThemeImage(theme: item.theme)) + } + strongSelf.containerNode.isGestureEnabled = false + } else { + if updatedThemeReference || updatedAccentColor { + strongSelf.imageNode.setSignal(themeIconImage(account: item.context.account, accountManager: item.context.sharedContext.accountManager, theme: item.themeReference, accentColor: item.accentColor?.color, bubbleColors: item.accentColor?.plainBubbleColors)) + } + strongSelf.containerNode.isGestureEnabled = true + } + if updatedTheme || updatedSelected { + strongSelf.overlayNode.image = generateBorderImage(theme: item.theme, bordered: true, selected: item.selected) + } + + strongSelf.containerNode.frame = CGRect(origin: CGPoint(), size: itemLayout.contentSize) + + let _ = titleApply() + + let imageSize = CGSize(width: 98.0, height: 62.0) + strongSelf.imageNode.frame = CGRect(origin: CGPoint(x: 10.0, y: 14.0), size: imageSize) + let applyLayout = makeImageLayout(TransformImageArguments(corners: ImageCorners(radius: 16.0), imageSize: imageSize, boundingSize: imageSize, intrinsicInsets: UIEdgeInsets(), emptyColor: .clear)) + applyLayout() + + strongSelf.overlayNode.frame = CGRect(origin: CGPoint(x: 9.0, y: 13.0), size: CGSize(width: 100.0, height: 64.0)) + strongSelf.titleNode.frame = CGRect(origin: CGPoint(x: 0.0, y: 88.0), size: CGSize(width: itemLayout.contentSize.width, height: 16.0)) + } + }) + } + } + + override func animateInsertion(_ currentTimestamp: Double, duration: Double, short: Bool) { + super.animateInsertion(currentTimestamp, duration: duration, short: short) + + self.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) + } + + override func animateRemoved(_ currentTimestamp: Double, duration: Double) { + super.animateRemoved(currentTimestamp, duration: duration) + + self.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.2, removeOnCompletion: false) + } + + override func animateAdded(_ currentTimestamp: Double, duration: Double) { + super.animateAdded(currentTimestamp, duration: duration) + + self.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.2) + } +} + class ThemeSettingsThemeItem: ListViewItem, ItemListItem { var sectionId: ItemListSectionId - + let context: AccountContext let theme: PresentationTheme let strings: PresentationStrings @@ -93,7 +329,7 @@ class ThemeSettingsThemeItem: ListViewItem, ItemListItem { let updatedTheme: (PresentationThemeReference) -> Void let contextAction: ((PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void)? let tag: ItemListItemTag? - + init(context: AccountContext, theme: PresentationTheme, strings: PresentationStrings, sectionId: ItemListSectionId, themes: [PresentationThemeReference], displayUnsupported: Bool, themeSpecificAccentColors: [Int64: PresentationThemeAccentColor], currentTheme: PresentationThemeReference, updatedTheme: @escaping (PresentationThemeReference) -> Void, contextAction: ((PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void)?, tag: ItemListItemTag? = nil) { self.context = context self.theme = theme @@ -107,15 +343,15 @@ class ThemeSettingsThemeItem: ListViewItem, ItemListItem { self.tag = tag self.sectionId = sectionId } - + func nodeConfiguredForParams(async: @escaping (@escaping () -> Void) -> Void, params: ListViewItemLayoutParams, synchronousLoads: Bool, previousItem: ListViewItem?, nextItem: ListViewItem?, completion: @escaping (ListViewItemNode, @escaping () -> (Signal?, (ListViewItemApply) -> Void)) -> Void) { async { let node = ThemeSettingsThemeItemNode() let (layout, apply) = node.asyncLayout()(self, params, itemListNeighbors(item: self, topItem: previousItem as? ItemListItem, bottomItem: nextItem as? ItemListItem)) - + node.contentSize = layout.contentSize node.insets = layout.insets - + Queue.mainQueue().async { completion(node, { return (nil, { _ in apply() }) @@ -123,12 +359,12 @@ class ThemeSettingsThemeItem: ListViewItem, ItemListItem { } } } - + func updateNode(async: @escaping (@escaping () -> Void) -> Void, node: @escaping () -> ListViewItemNode, params: ListViewItemLayoutParams, previousItem: ListViewItem?, nextItem: ListViewItem?, animation: ListViewItemUpdateAnimation, completion: @escaping (ListViewItemNodeLayout, @escaping (ListViewItemApply) -> Void) -> Void) { Queue.mainQueue().async { if let nodeValue = node() as? ThemeSettingsThemeItemNode { let makeLayout = nodeValue.asyncLayout() - + async { let (layout, apply) = makeLayout(self, params, itemListNeighbors(item: self, topItem: previousItem as? ItemListItem, bottomItem: nextItem as? ItemListItem)) Queue.mainQueue().async { @@ -142,211 +378,139 @@ class ThemeSettingsThemeItem: ListViewItem, ItemListItem { } } -private func areBubbleColorsEqual(_ lhs: (UIColor, UIColor)?, _ rhs: (UIColor, UIColor)?) -> Bool { - if let (lhsTopColor, lhsBottomColor) = lhs, let (rhsTopColor, rhsBottomColor) = rhs { - return lhsTopColor.rgb == rhsTopColor.rgb && lhsBottomColor.rgb == rhsBottomColor.rgb +private struct ThemeSettingsThemeItemNodeTransition { + let deletions: [ListViewDeleteItem] + let insertions: [ListViewInsertItem] + let updates: [ListViewUpdateItem] +} + +private func preparedTransition(context: AccountContext, action: @escaping (PresentationThemeReference) -> Void, contextAction: ((PresentationThemeReference, ASDisplayNode, ContextGesture?) -> Void)?, from fromEntries: [ThemeSettingsThemeEntry], to toEntries: [ThemeSettingsThemeEntry]) -> ThemeSettingsThemeItemNodeTransition { + let (deleteIndices, indicesAndItems, updateIndices) = mergeListsStableWithUpdates(leftList: fromEntries, rightList: toEntries) + + let deletions = deleteIndices.map { ListViewDeleteItem(index: $0, directionHint: nil) } + let insertions = indicesAndItems.map { ListViewInsertItem(index: $0.0, previousIndex: $0.2, item: $0.1.item(context: context, action: action, contextAction: contextAction), directionHint: .Down) } + let updates = updateIndices.map { ListViewUpdateItem(index: $0.0, previousIndex: $0.2, item: $0.1.item(context: context, action: action, contextAction: contextAction), directionHint: nil) } + + return ThemeSettingsThemeItemNodeTransition(deletions: deletions, insertions: insertions, updates: updates) +} + +private func ensureThemeVisible(listNode: ListView, themeReference: PresentationThemeReference, animated: Bool) -> Bool { + var resultNode: ThemeSettingsThemeItemIconNode? + listNode.forEachItemNode { node in + if resultNode == nil, let node = node as? ThemeSettingsThemeItemIconNode { + if node.item?.themeReference.index == themeReference.index { + resultNode = node + } + } + } + if let resultNode = resultNode { + listNode.ensureItemNodeVisible(resultNode, animated: animated, overflow: 57.0) + return true } else { - return (lhs == nil) == (rhs == nil) + return false } } -private final class ThemeSettingsThemeItemIconNode : ASDisplayNode { - private let containerNode: ContextControllerSourceNode - private let imageNode: TransformImageNode - private let overlayNode: ASImageNode - private let textNode: ASTextNode - private var action: (() -> Void)? - private var contextAction: ((ASDisplayNode, ContextGesture?) -> Void)? - - private var theme: PresentationThemeReference? - private var currentTheme: PresentationTheme? - private var accentColor: UIColor? - private var bubbleColors: (UIColor, UIColor)? - private var bordered: Bool? - private var selected: Bool? - - override init() { - self.containerNode = ContextControllerSourceNode() - - self.imageNode = TransformImageNode() - self.imageNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: 98.0, height: 62.0)) - self.imageNode.isLayerBacked = true - - self.overlayNode = ASImageNode() - self.overlayNode.frame = CGRect(origin: CGPoint(), size: CGSize(width: 100.0, height: 64.0)) - self.overlayNode.isLayerBacked = true - - self.textNode = ASTextNode() - self.textNode.isUserInteractionEnabled = false - self.textNode.displaysAsynchronously = true - - super.init() - - self.addSubnode(self.containerNode) - self.containerNode.addSubnode(self.imageNode) - self.containerNode.addSubnode(self.overlayNode) - self.containerNode.addSubnode(self.textNode) - - self.containerNode.activated = { [weak self] gesture in - guard let strongSelf = self else { - gesture.cancel() - return - } - strongSelf.contextAction?(strongSelf.containerNode, gesture) - } - } - - func setup(context: AccountContext, theme: PresentationThemeReference, accentColor: UIColor?, bubbleColors: (UIColor, UIColor)?, currentTheme: PresentationTheme, title: NSAttributedString, bordered: Bool, selected: Bool, action: @escaping () -> Void, contextAction: ((ASDisplayNode, ContextGesture?) -> Void)?) { - let updatedTheme = self.currentTheme == nil || currentTheme !== self.currentTheme! - var contextActionEnabled = true - if case let .cloud(theme) = theme, theme.theme.file == nil { - if updatedTheme || accentColor != self.accentColor { - self.imageNode.setSignal(createThemeImage(theme: currentTheme)) - self.currentTheme = currentTheme - self.accentColor = accentColor - contextActionEnabled = false - } - } else { - if theme != self.theme || accentColor != self.accentColor || !areBubbleColorsEqual(bubbleColors, self.bubbleColors) { - self.imageNode.setSignal(themeIconImage(account: context.account, accountManager: context.sharedContext.accountManager, theme: theme, accentColor: accentColor, bubbleColors: bubbleColors)) - self.theme = theme - self.accentColor = accentColor - self.bubbleColors = bubbleColors - } - } - if updatedTheme || bordered != self.bordered || selected != self.selected { - self.overlayNode.image = generateBorderImage(theme: currentTheme, bordered: bordered, selected: selected) - self.currentTheme = currentTheme - self.bordered = bordered - self.selected = selected - } - self.textNode.attributedText = title - self.action = action - self.contextAction = contextAction - self.containerNode.isGestureEnabled = contextActionEnabled - } - - override func didLoad() { - super.didLoad() - - let recognizer = TapLongTapOrDoubleTapGestureRecognizer(target: self, action: #selector(self.tapLongTapOrDoubleTapGesture(_:))) - recognizer.delaysTouchesBegan = false - recognizer.tapActionAtPoint = { point in - return .waitForSingleTap - } - self.view.addGestureRecognizer(recognizer) - } - - @objc private func tapLongTapOrDoubleTapGesture(_ recognizer: TapLongTapOrDoubleTapGestureRecognizer) { - switch recognizer.state { - case .ended: - if let (gesture, _) = recognizer.lastRecognizedGestureAndLocation { - switch gesture { - case .tap: - self.action?() - default: - break - } - } - default: - break - } - } - - override func layout() { - super.layout() - - let bounds = self.bounds - - self.containerNode.frame = CGRect(origin: CGPoint(), size: bounds.size) - - let imageSize = CGSize(width: 98.0, height: 62.0) - self.imageNode.frame = CGRect(origin: CGPoint(x: 10.0, y: 14.0), size: imageSize) - let makeLayout = self.imageNode.asyncLayout() - let applyLayout = makeLayout(TransformImageArguments(corners: ImageCorners(), imageSize: imageSize, boundingSize: imageSize, intrinsicInsets: UIEdgeInsets(), emptyColor: .clear)) - applyLayout() - - self.overlayNode.frame = CGRect(origin: CGPoint(x: 9.0, y: 13.0), size: CGSize(width: 100.0, height: 64.0)) - self.textNode.frame = CGRect(origin: CGPoint(x: 0.0, y: 14.0 + 60.0 + 4.0 + 9.0), size: CGSize(width: bounds.size.width, height: 16.0)) - } -} - - -private let textFont = Font.regular(12.0) -private let selectedTextFont = Font.bold(12.0) - class ThemeSettingsThemeItemNode: ListViewItemNode, ItemListItemNode { private let backgroundNode: ASDisplayNode private let topStripeNode: ASDisplayNode private let bottomStripeNode: ASDisplayNode private let maskNode: ASImageNode - - private let scrollNode: ASScrollNode - private var nodes: [ThemeSettingsThemeItemIconNode] = [] - + + private let listNode: ListView + private var entries: [ThemeSettingsThemeEntry]? + private var enqueuedTransitions: [ThemeSettingsThemeItemNodeTransition] = [] + private var initialized = false + private var item: ThemeSettingsThemeItem? private var layoutParams: ListViewItemLayoutParams? - + var tag: ItemListItemTag? { return self.item?.tag } - + init() { self.backgroundNode = ASDisplayNode() self.backgroundNode.isLayerBacked = true - + self.topStripeNode = ASDisplayNode() self.topStripeNode.isLayerBacked = true - + self.bottomStripeNode = ASDisplayNode() self.bottomStripeNode.isLayerBacked = true - + self.maskNode = ASImageNode() - - self.scrollNode = ASScrollNode() - + + self.listNode = ListView() + self.listNode.transform = CATransform3DMakeRotation(-CGFloat.pi / 2.0, 0.0, 0.0, 1.0) + super.init(layerBacked: false, dynamicBounce: false) - - self.addSubnode(self.scrollNode) + + self.addSubnode(self.listNode) } - + override func didLoad() { super.didLoad() - self.scrollNode.view.disablesInteractiveTransitionGestureRecognizer = true - self.scrollNode.view.showsHorizontalScrollIndicator = false + self.listNode.view.disablesInteractiveTransitionGestureRecognizer = true } - private func scrollToNode(_ node: ThemeSettingsThemeItemIconNode, animated: Bool) { - let bounds = self.scrollNode.view.bounds - let frame = node.frame.insetBy(dx: -48.0, dy: 0.0) + private func enqueueTransition(_ transition: ThemeSettingsThemeItemNodeTransition) { + self.enqueuedTransitions.append(transition) - if frame.minX < bounds.minX || frame.maxX > bounds.maxX { - self.scrollNode.view.scrollRectToVisible(frame, animated: animated) + if let _ = self.item { + while !self.enqueuedTransitions.isEmpty { + self.dequeueTransition() + } } } + private func dequeueTransition() { + guard let item = self.item, let transition = self.enqueuedTransitions.first else { + return + } + self.enqueuedTransitions.remove(at: 0) + + var options = ListViewDeleteAndInsertOptions() + if self.initialized { + options.insert(.AnimateInsertion) + } + + var scrollToItem: ListViewScrollToItem? + if !self.initialized { + if let index = item.themes.firstIndex(where: { $0.index == item.currentTheme.index }) { + scrollToItem = ListViewScrollToItem(index: index, position: .bottom(-57.0), animated: false, curve: .Default(duration: 0.0), directionHint: .Down) + self.initialized = true + } + } + + self.listNode.transaction(deleteIndices: transition.deletions, insertIndicesAndItems: transition.insertions, updateIndicesAndItems: transition.updates, options: options, scrollToItem: scrollToItem, updateSizeAndInsets: nil, updateOpaqueState: nil, completion: { _ in }) + } + func asyncLayout() -> (_ item: ThemeSettingsThemeItem, _ params: ListViewItemLayoutParams, _ neighbors: ItemListNeighbors) -> (ListViewItemNodeLayout, () -> Void) { + let currentItem = self.item + return { item, params, neighbors in let contentSize: CGSize let insets: UIEdgeInsets let separatorHeight = UIScreenPixel - + contentSize = CGSize(width: params.width, height: 116.0) insets = itemListNeighborsGroupedInsets(neighbors) - + let layout = ListViewItemNodeLayout(contentSize: contentSize, insets: insets) let layoutSize = layout.size - + return (layout, { [weak self] in if let strongSelf = self { + let isFirstLayout = currentItem == nil + strongSelf.item = item strongSelf.layoutParams = params - - strongSelf.scrollNode.view.contentInset = UIEdgeInsets(top: 0.0, left: params.leftInset, bottom: 0.0, right: params.rightInset) + strongSelf.backgroundNode.backgroundColor = item.theme.list.itemBlocksBackgroundColor strongSelf.topStripeNode.backgroundColor = item.theme.list.itemBlocksSeparatorColor strongSelf.bottomStripeNode.backgroundColor = item.theme.list.itemBlocksSeparatorColor - + if strongSelf.backgroundNode.supernode == nil { strongSelf.insertSubnode(strongSelf.backgroundNode, at: 0) } @@ -359,7 +523,7 @@ class ThemeSettingsThemeItemNode: ListViewItemNode, ItemListItemNode { if strongSelf.maskNode.supernode == nil { strongSelf.insertSubnode(strongSelf.maskNode, at: 3) } - + let hasCorners = itemListHasRoundedBlockLayout(params) var hasTopCorners = false var hasBottomCorners = false @@ -382,88 +546,53 @@ class ThemeSettingsThemeItemNode: ListViewItemNode, ItemListItemNode { hasBottomCorners = true strongSelf.bottomStripeNode.isHidden = hasCorners } - + strongSelf.maskNode.image = hasCorners ? PresentationResourcesItemList.cornersImage(item.theme, top: hasTopCorners, bottom: hasBottomCorners) : nil - + strongSelf.backgroundNode.frame = CGRect(origin: CGPoint(x: 0.0, y: -min(insets.top, separatorHeight)), size: CGSize(width: params.width, height: contentSize.height + min(insets.top, separatorHeight) + min(insets.bottom, separatorHeight))) strongSelf.maskNode.frame = strongSelf.backgroundNode.frame.insetBy(dx: params.leftInset, dy: 0.0) strongSelf.topStripeNode.frame = CGRect(origin: CGPoint(x: 0.0, y: -min(insets.top, separatorHeight)), size: CGSize(width: layoutSize.width, height: separatorHeight)) strongSelf.bottomStripeNode.frame = CGRect(origin: CGPoint(x: bottomStripeInset, y: contentSize.height + bottomStripeOffset), size: CGSize(width: layoutSize.width - bottomStripeInset, height: separatorHeight)) + + var listInsets = UIEdgeInsets() + listInsets.top += params.leftInset + 4.0 + listInsets.bottom += params.rightInset + 4.0 - strongSelf.scrollNode.frame = CGRect(origin: CGPoint(x: 0.0, y: 2.0), size: CGSize(width: layoutSize.width, height: layoutSize.height)) + strongSelf.listNode.bounds = CGRect(x: 0.0, y: 0.0, width: contentSize.height, height: contentSize.width) + strongSelf.listNode.position = CGPoint(x: contentSize.width / 2.0, y: contentSize.height / 2.0) + strongSelf.listNode.transaction(deleteIndices: [], insertIndicesAndItems: [], updateIndicesAndItems: [], options: [.Synchronous], scrollToItem: nil, updateSizeAndInsets: ListViewUpdateSizeAndInsets(size: CGSize(width: contentSize.height, height: contentSize.width), insets: listInsets, duration: 0.0, curve: .Default(duration: nil)), stationaryItemRange: nil, updateOpaqueState: nil, completion: { _ in }) - let nodeInset: CGFloat = 4.0 - let nodeSize = CGSize(width: 116.0, height: 112.0) - var nodeOffset = nodeInset - - var updated = false - var selectedNode: ThemeSettingsThemeItemIconNode? - - var i = 0 + var entries: [ThemeSettingsThemeEntry] = [] + var index: Int = 0 for theme in item.themes { if !item.displayUnsupported, case let .cloud(theme) = theme, theme.theme.file == nil { continue } - - let imageNode: ThemeSettingsThemeItemIconNode - if strongSelf.nodes.count > i { - imageNode = strongSelf.nodes[i] - } else { - imageNode = ThemeSettingsThemeItemIconNode() - strongSelf.nodes.append(imageNode) - strongSelf.scrollNode.addSubnode(imageNode) - updated = true - } - - let selected = theme.index == item.currentTheme.index - if selected { - selectedNode = imageNode - } - - let name = themeDisplayName(strings: item.strings, reference: theme) - imageNode.setup(context: item.context, theme: theme, accentColor: item.themeSpecificAccentColors[theme.index]?.color, bubbleColors: item.themeSpecificAccentColors[theme.index]?.plainBubbleColors, currentTheme: item.theme, title: NSAttributedString(string: name, font: selected ? selectedTextFont : textFont, textColor: selected ? item.theme.list.itemAccentColor : item.theme.list.itemPrimaryTextColor, paragraphAlignment: .center), bordered: true, selected: selected, action: { [weak self, weak imageNode] in - item.updatedTheme(theme) - if let imageNode = imageNode { - self?.scrollToNode(imageNode, animated: true) - } - }, contextAction: item.contextAction.flatMap { - contextAction in - return { node, gesture in - contextAction(theme, node, gesture) - } - }) - - imageNode.frame = CGRect(origin: CGPoint(x: nodeOffset, y: 0.0), size: nodeSize) - nodeOffset += nodeSize.width + 2.0 - - i += 1 + let title = themeDisplayName(strings: item.strings, reference: theme) + let accentColor = item.themeSpecificAccentColors[theme.index] + entries.append(ThemeSettingsThemeEntry(index: index, themeReference: theme, title: title, accentColor: accentColor, selected: item.currentTheme.index == theme.index, theme: item.theme)) + index += 1 } - for k in (i ..< strongSelf.nodes.count).reversed() { - let node = strongSelf.nodes[k] - strongSelf.nodes.remove(at: k) - node.removeFromSupernode() - } - - if let lastNode = strongSelf.nodes.last { - let contentSize = CGSize(width: lastNode.frame.maxX + nodeInset, height: strongSelf.scrollNode.frame.height) - if strongSelf.scrollNode.view.contentSize != contentSize { - strongSelf.scrollNode.view.contentSize = contentSize + let action: (PresentationThemeReference) -> Void = { [weak self, weak item] themeReference in + if let strongSelf = self { + strongSelf.item?.updatedTheme(themeReference) + ensureThemeVisible(listNode: strongSelf.listNode, themeReference: themeReference, animated: true) } } + let transition = preparedTransition(context: item.context, action: action, contextAction: item.contextAction, from: strongSelf.entries ?? [], to: entries) + strongSelf.enqueueTransition(transition) - if updated, let selectedNode = selectedNode { - strongSelf.scrollToNode(selectedNode, animated: false) - } + strongSelf.entries = entries } }) } } - + override func animateInsertion(_ currentTimestamp: Double, duration: Double, short: Bool) { self.layer.animateAlpha(from: 0.0, to: 1.0, duration: 0.4) } - + override func animateRemoved(_ currentTimestamp: Double, duration: Double) { self.layer.animateAlpha(from: 1.0, to: 0.0, duration: 0.15, removeOnCompletion: false) } diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperColorPanelNode.swift b/submodules/SettingsUI/Sources/Themes/WallpaperColorPanelNode.swift index 2e1e633876..6cba98b03f 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperColorPanelNode.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperColorPanelNode.swift @@ -284,7 +284,7 @@ private class ColorInputFieldNode: ASDisplayNode, UITextFieldDelegate { private func updateSelectionLayout(size: CGSize, transition: ContainedViewLayoutTransition) { self.measureNode.attributedText = NSAttributedString(string: self.textFieldNode.textField.text ?? "", font: self.textFieldNode.textField.font) let size = self.measureNode.updateLayout(size) - transition.updateFrame(node: self.selectionNode, frame: CGRect(x: self.textFieldNode.frame.minX, y: 6.0, width: max(45.0, size.width), height: 20.0)) + transition.updateFrame(node: self.selectionNode, frame: CGRect(x: self.textFieldNode.frame.minX, y: 6.0, width: max(0.0, size.width), height: 20.0)) } private func updateSelectionVisibility() { @@ -325,6 +325,7 @@ struct WallpaperColorPanelNodeState { var defaultColor: UIColor? var secondColor: UIColor? var secondColorAvailable: Bool + var preview: Bool } final class WallpaperColorPanelNode: ASDisplayNode { @@ -365,14 +366,14 @@ final class WallpaperColorPanelNode: ASDisplayNode { self.colorPickerNode = WallpaperColorPickerNode(strings: strings) self.swapButton = HighlightableButtonNode() - self.swapButton.setImage(generateTintedImage(image: UIImage(bundleImageName: "Settings/ThemeColorSwapIcon"), color: theme.chat.inputPanel.panelControlColor), for: .normal) + self.swapButton.setImage(generateTintedImage(image: UIImage(bundleImageName: "Settings/ThemeColorRotateIcon"), color: theme.chat.inputPanel.panelControlColor), for: .normal) self.addButton = HighlightableButtonNode() self.addButton.setImage(generateTintedImage(image: UIImage(bundleImageName: "Settings/ThemeColorAddIcon"), color: theme.chat.inputPanel.panelControlColor), for: .normal) self.firstColorFieldNode = ColorInputFieldNode(theme: theme) self.secondColorFieldNode = ColorInputFieldNode(theme: theme) - self.state = WallpaperColorPanelNodeState(selection: .first, firstColor: nil, secondColor: nil, secondColorAvailable: false) + self.state = WallpaperColorPanelNodeState(selection: .first, firstColor: nil, secondColor: nil, secondColorAvailable: false, preview: false) super.init() @@ -467,6 +468,7 @@ final class WallpaperColorPanelNode: ASDisplayNode { if let strongSelf = self { strongSelf.updateState({ current in var updated = current + updated.preview = true switch strongSelf.state.selection { case .first: updated.firstColor = color @@ -483,6 +485,7 @@ final class WallpaperColorPanelNode: ASDisplayNode { if let strongSelf = self { strongSelf.updateState({ current in var updated = current + updated.preview = false switch strongSelf.state.selection { case .first: updated.firstColor = color @@ -510,6 +513,7 @@ final class WallpaperColorPanelNode: ASDisplayNode { var updateLayout = updateLayout let previousFirstColor = self.state.firstColor let previousSecondColor = self.state.secondColor + let previousPreview = self.state.preview self.state = f(self.state) let firstColor: UIColor @@ -554,8 +558,8 @@ final class WallpaperColorPanelNode: ASDisplayNode { self.updateLayout(size: size, transition: animated ? .animated(duration: 0.3, curve: .easeInOut) : .immediate) } - if self.state.firstColor?.rgb != previousFirstColor?.rgb || self.state.secondColor?.rgb != previousSecondColor?.rgb { - self.colorsChanged?(firstColorIsDefault ? nil : firstColor, secondColor, updateLayout) + if self.state.firstColor?.rgb != previousFirstColor?.rgb || self.state.secondColor?.rgb != previousSecondColor?.rgb || self.state.preview != previousPreview { + self.colorsChanged?(firstColorIsDefault ? nil : firstColor, secondColor, !self.state.preview) } } @@ -679,14 +683,15 @@ final class WallpaperColorPanelNode: ASDisplayNode { } @objc private func swapPressed() { - self.updateState({ current in - var updated = current - if let secondColor = current.secondColor { - updated.firstColor = secondColor - updated.secondColor = current.firstColor - } - return updated - }) + self.rotate?() +// self.updateState({ current in +// var updated = current +// if let secondColor = current.secondColor { +// updated.firstColor = secondColor +// updated.secondColor = current.firstColor +// } +// return updated +// }) } @objc private func addPressed() { diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift index 02bad5d901..a28dfc23cd 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryController.swift @@ -157,10 +157,8 @@ public class WallpaperGalleryController: ViewController { private var overlayNode: WallpaperGalleryOverlayNode? private var messageNodes: [ListViewItemNode]? private var toolbarNode: WallpaperGalleryToolbarNode? - private var colorPanelNode: WallpaperColorPanelNode? private var patternPanelNode: WallpaperPatternPanelNode? - private var colorPanelEnabled = false private var patternPanelEnabled = false public init(context: AccountContext, source: WallpaperListSource) { @@ -204,7 +202,6 @@ public class WallpaperGalleryController: ViewController { entries = [.contextResult(result)] centralEntryIndex = 0 case let .customColor(color): - self.colorPanelEnabled = true let initialColor = color ?? 0x000000 entries = [.wallpaper(.color(initialColor), nil)] centralEntryIndex = 0 @@ -338,19 +335,7 @@ public class WallpaperGalleryController: ViewController { self.overlayNode = overlayNode self.galleryNode.overlayNode = overlayNode self.galleryNode.addSubnode(overlayNode) - - let colorPanelNode = WallpaperColorPanelNode(theme: presentationData.theme, strings: presentationData.strings) - colorPanelNode.colorsChanged = { [weak self] color, _, ended in - if let strongSelf = self , let color = color { - strongSelf.updateEntries(color: color, preview: !ended) - } - } - if case let .customColor(colorValue) = self.source, let color = colorValue { - //colorPanelNode.color = UIColor(rgb: UInt32(bitPattern: color)) - } - self.colorPanelNode = colorPanelNode - overlayNode.addSubnode(colorPanelNode) - + let toolbarNode = WallpaperGalleryToolbarNode(theme: presentationData.theme, strings: presentationData.strings, doneButtonType: .set) self.toolbarNode = toolbarNode overlayNode.addSubnode(toolbarNode) @@ -358,8 +343,10 @@ public class WallpaperGalleryController: ViewController { toolbarNode.cancel = { [weak self] in self?.dismiss(forceAway: true) } + var dismissed = false toolbarNode.done = { [weak self] in - if let strongSelf = self { + if let strongSelf = self, !dismissed { + dismissed = true if let centralItemNode = strongSelf.galleryNode.pager.centralItemNode() as? WallpaperGalleryItemNode { let options = centralItemNode.options if !strongSelf.entries.isEmpty { @@ -380,7 +367,7 @@ public class WallpaperGalleryController: ViewController { let completion: (TelegramWallpaper) -> Void = { wallpaper in let baseSettings = wallpaper.settings - let updatedSettings = WallpaperSettings(blur: options.contains(.blur), motion: options.contains(.motion), color: baseSettings?.color, intensity: baseSettings?.intensity) + let updatedSettings = WallpaperSettings(blur: options.contains(.blur), motion: options.contains(.motion), color: baseSettings?.color, bottomColor: baseSettings?.bottomColor, intensity: baseSettings?.intensity) let wallpaper = wallpaper.withUpdatedSettings(updatedSettings) let autoNightModeTriggered = strongSelf.presentationData.autoNightModeTriggered @@ -430,7 +417,7 @@ public class WallpaperGalleryController: ViewController { } } else if case let .file(file) = wallpaper, let resource = resource { if file.isPattern, let color = file.settings.color, let intensity = file.settings.intensity { - let representation = CachedPatternWallpaperRepresentation(color: color, intensity: intensity) + let representation = CachedPatternWallpaperRepresentation(color: color, bottomColor: file.settings.bottomColor, intensity: intensity, rotation: file.settings.rotation) var data: Data? if let path = strongSelf.context.account.postbox.mediaBox.completedResourcePath(resource), let maybeData = try? Data(contentsOf: URL(fileURLWithPath: path), options: .mappedRead) { @@ -630,12 +617,7 @@ public class WallpaperGalleryController: ViewController { topMessageText = presentationData.strings.WallpaperPreview_CustomColorTopText bottomMessageText = presentationData.strings.WallpaperPreview_CustomColorBottomText } - - if self.colorPanelEnabled { - topMessageText = presentationData.strings.WallpaperPreview_CustomColorTopText - bottomMessageText = presentationData.strings.WallpaperPreview_CustomColorBottomText - } - + let message1 = Message(stableId: 2, stableVersion: 0, id: MessageId(peerId: peerId, namespace: 0, id: 2), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: 66001, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peers[otherPeerId], text: bottomMessageText, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []) items.append(self.context.sharedContext.makeChatMessagePreviewItem(context: self.context, message: message1, theme: self.presentationData.theme, strings: self.presentationData.strings, wallpaper: currentWallpaper, fontSize: self.presentationData.fontSize, dateTimeFormat: self.presentationData.dateTimeFormat, nameOrder: self.presentationData.nameDisplayOrder, forcedResourceStatus: nil)) @@ -678,10 +660,6 @@ public class WallpaperGalleryController: ViewController { if let messageNodes = self.messageNodes { var bottomOffset: CGFloat = layout.size.height - bottomInset - 9.0 - if self.colorPanelEnabled { - } else { - bottomOffset -= 66.0 - } for itemNode in messageNodes { transition.updateFrame(node: itemNode, frame: CGRect(origin: CGPoint(x: 0.0, y: bottomOffset - itemNode.frame.height), size: itemNode.frame.size)) bottomOffset -= itemNode.frame.height @@ -705,16 +683,6 @@ public class WallpaperGalleryController: ViewController { var bottomInset = layout.intrinsicInsets.bottom + 49.0 let standardInputHeight = layout.deviceMetrics.keyboardHeight(inLandscape: false) let height = max(standardInputHeight, layout.inputHeight ?? 0.0) - bottomInset + 47.0 - if let colorPanelNode = self.colorPanelNode { - var colorPanelFrame = CGRect(x: 0.0, y: layout.size.height, width: layout.size.width, height: height) - if self.colorPanelEnabled { - colorPanelFrame.origin = CGPoint(x: 0.0, y: layout.size.height - bottomInset - height) - bottomInset += height - } - - transition.updateFrame(node: colorPanelNode, frame: colorPanelFrame) - colorPanelNode.updateLayout(size: colorPanelFrame.size, transition: transition) - } let currentPatternPanelNode: WallpaperPatternPanelNode if let patternPanelNode = self.patternPanelNode { @@ -731,12 +699,13 @@ public class WallpaperGalleryController: ViewController { self.overlayNode?.insertSubnode(patternPanelNode, belowSubnode: self.toolbarNode!) } - let panelHeight: CGFloat = 190.0 + let panelHeight: CGFloat = 235.0 var patternPanelFrame = CGRect(x: 0.0, y: layout.size.height, width: layout.size.width, height: panelHeight) if self.patternPanelEnabled { patternPanelFrame.origin = CGPoint(x: 0.0, y: layout.size.height - bottomInset - panelHeight) bottomInset += panelHeight } + bottomInset += 66.0 transition.updateFrame(node: currentPatternPanelNode, frame: patternPanelFrame) currentPatternPanelNode.updateLayout(size: patternPanelFrame.size, transition: transition) diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift index 7592066231..0e7e024bb3 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryItem.swift @@ -200,7 +200,7 @@ final class WallpaperGalleryItemNode: GalleryItemNode { let subtitleSignal: Signal var actionSignal: Signal = .single(nil) var colorSignal: Signal = serviceColor(from: imagePromise.get()) - var color: UIColor? + var patternArguments: PatternWallpaperArguments? let displaySize: CGSize let contentSize: CGSize @@ -255,14 +255,23 @@ final class WallpaperGalleryItemNode: GalleryItemNode { convertedRepresentations.append(ImageRepresentationWithReference(representation: .init(dimensions: dimensions, resource: file.file.resource), reference: reference(for: file.file.resource, media: file.file, message: message))) if file.isPattern { + var patternColors: [UIColor] = [] var patternColor = UIColor(rgb: 0xd6e2ee, alpha: 0.5) var patternIntensity: CGFloat = 0.5 + if let color = file.settings.color { if let intensity = file.settings.intensity { patternIntensity = CGFloat(intensity) / 100.0 } patternColor = UIColor(rgb: UInt32(bitPattern: color), alpha: patternIntensity) + patternColors.append(patternColor) + + if let bottomColor = file.settings.bottomColor { + patternColors.append(UIColor(rgb: UInt32(bitPattern: bottomColor), alpha: patternIntensity)) + } } + + patternArguments = PatternWallpaperArguments(colors: patternColors, rotation: file.settings.rotation) self.backgroundColor = patternColor.withAlphaComponent(1.0) @@ -270,7 +279,7 @@ final class WallpaperGalleryItemNode: GalleryItemNode { let makeImageLayout = self.imageNode.asyncLayout() Queue.concurrentDefaultQueue().async { - let apply = makeImageLayout(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets(), emptyColor: patternColor)) + let apply = makeImageLayout(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets(), custom: patternArguments)) Queue.mainQueue().async { if self.colorPreview { apply() @@ -280,9 +289,8 @@ final class WallpaperGalleryItemNode: GalleryItemNode { return } else if let offset = self.validOffset, self.arguments.colorPreview && abs(offset) > 0.0 { return - } - else { - color = patternColor + } else { + patternArguments = PatternWallpaperArguments(colors: patternColors, rotation: file.settings.rotation) } self.colorPreview = self.arguments.colorPreview @@ -443,7 +451,7 @@ final class WallpaperGalleryItemNode: GalleryItemNode { } self.imageNode.setSignal(signal, dispatchOnDisplayLink: false) - self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets(), emptyColor: color))() + self.imageNode.asyncLayout()(TransformImageArguments(corners: ImageCorners(), imageSize: displaySize, boundingSize: displaySize, intrinsicInsets: UIEdgeInsets(), custom: patternArguments))() self.imageNode.imageUpdated = { [weak self] image in if let strongSelf = self { var image = isBlurrable ? image : nil @@ -597,7 +605,7 @@ final class WallpaperGalleryItemNode: GalleryItemNode { } } - @objc func toggleMotion() { + @objc private func toggleMotion() { let value = !self.motionButtonNode.isSelected self.motionButtonNode.setSelected(value, animated: true) self.setMotionEnabled(value, animated: true) @@ -607,7 +615,7 @@ final class WallpaperGalleryItemNode: GalleryItemNode { return self.patternButtonNode.isSelected } - @objc func togglePattern() { + @objc private func togglePattern() { let value = !self.patternButtonNode.isSelected self.patternButtonNode.setSelected(value, animated: true) @@ -680,7 +688,7 @@ final class WallpaperGalleryItemNode: GalleryItemNode { var additionalYOffset: CGFloat = 0.0 if self.patternButtonNode.isSelected { - additionalYOffset = -190.0 + additionalYOffset = -235.0 } let leftButtonFrame = CGRect(origin: CGPoint(x: floor(layout.size.width / 2.0 - buttonSize.width - 10.0) + offset.x, y: layout.size.height - 49.0 - layout.intrinsicInsets.bottom - 54.0 + offset.y + additionalYOffset), size: buttonSize) diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryToolbarNode.swift b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryToolbarNode.swift index d455b3686a..b3f22d94dc 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryToolbarNode.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperGalleryToolbarNode.swift @@ -4,14 +4,31 @@ import AsyncDisplayKit import Display import TelegramPresentationData +enum WallpaperGalleryToolbarCancelButtonType { + case cancel + case discard +} + enum WallpaperGalleryToolbarDoneButtonType { case set case proceed + case apply } final class WallpaperGalleryToolbarNode: ASDisplayNode { private var theme: PresentationTheme - private let doneButtonType: WallpaperGalleryToolbarDoneButtonType + private let strings: PresentationStrings + + var cancelButtonType: WallpaperGalleryToolbarCancelButtonType { + didSet { + self.updateThemeAndStrings(theme: self.theme, strings: self.strings) + } + } + var doneButtonType: WallpaperGalleryToolbarDoneButtonType { + didSet { + self.updateThemeAndStrings(theme: self.theme, strings: self.strings) + } + } private let cancelButton = HighlightableButtonNode() private let doneButton = HighlightableButtonNode() @@ -21,8 +38,10 @@ final class WallpaperGalleryToolbarNode: ASDisplayNode { var cancel: (() -> Void)? var done: (() -> Void)? - init(theme: PresentationTheme, strings: PresentationStrings, doneButtonType: WallpaperGalleryToolbarDoneButtonType) { + init(theme: PresentationTheme, strings: PresentationStrings, cancelButtonType: WallpaperGalleryToolbarCancelButtonType = .cancel, doneButtonType: WallpaperGalleryToolbarDoneButtonType = .set) { self.theme = theme + self.strings = strings + self.cancelButtonType = cancelButtonType self.doneButtonType = doneButtonType super.init() @@ -73,8 +92,24 @@ final class WallpaperGalleryToolbarNode: ASDisplayNode { self.separatorNode.backgroundColor = theme.rootController.tabBar.separatorColor self.topSeparatorNode.backgroundColor = theme.rootController.tabBar.separatorColor - self.cancelButton.setTitle(strings.Common_Cancel, with: Font.regular(17.0), with: theme.list.itemPrimaryTextColor, for: []) - self.doneButton.setTitle(self.doneButtonType == .set ? strings.Wallpaper_Set : strings.Theme_Colors_Proceed, with: Font.regular(17.0), with: theme.list.itemPrimaryTextColor, for: []) + let cancelTitle: String + switch self.cancelButtonType { + case .cancel: + cancelTitle = strings.Common_Cancel + case .discard: + cancelTitle = strings.WallpaperPreview_PatternPaternDiscard + } + let doneTitle: String + switch self.doneButtonType { + case .set: + doneTitle = strings.Wallpaper_Set + case .proceed: + doneTitle = strings.Theme_Colors_Proceed + case .apply: + doneTitle = strings.WallpaperPreview_PatternPaternApply + } + self.cancelButton.setTitle(cancelTitle, with: Font.regular(17.0), with: theme.list.itemPrimaryTextColor, for: []) + self.doneButton.setTitle(doneTitle, with: Font.regular(17.0), with: theme.list.itemPrimaryTextColor, for: []) } func updateLayout(size: CGSize, layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) { @@ -89,7 +124,6 @@ final class WallpaperGalleryToolbarNode: ASDisplayNode { } @objc func donePressed() { - self.doneButton.isUserInteractionEnabled = false self.done?() } } diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryDecorationNode.swift b/submodules/SettingsUI/Sources/Themes/WallpaperOptionButtonNode.swift similarity index 80% rename from submodules/SettingsUI/Sources/Themes/WallpaperGalleryDecorationNode.swift rename to submodules/SettingsUI/Sources/Themes/WallpaperOptionButtonNode.swift index ec1a347b00..18bd92880a 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperGalleryDecorationNode.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperOptionButtonNode.swift @@ -43,7 +43,7 @@ final class WallpaperOptionButtonNode: HighlightTrackingButtonNode { self.backgroundNode = ASDisplayNode() self.backgroundNode.backgroundColor = UIColor(rgb: 0x000000, alpha: 0.3) - self.backgroundNode.cornerRadius = 6.0 + self.backgroundNode.cornerRadius = 14.0 self.checkNode = ModernCheckNode(theme: CheckNodeTheme(backgroundColor: .white, strokeColor: .clear, borderColor: .white, hasShadow: false)) self.checkNode.isUserInteractionEnabled = false @@ -147,7 +147,7 @@ final class WallpaperOptionButtonNode: HighlightTrackingButtonNode { override func measure(_ constrainedSize: CGSize) -> CGSize { let size = self.textNode.measure(constrainedSize) self.textSize = size - return CGSize(width: ceil(size.width) + 52.0, height: 30.0) + return CGSize(width: ceil(size.width) + 48.0, height: 30.0) } override func layout() { @@ -159,42 +159,15 @@ final class WallpaperOptionButtonNode: HighlightTrackingButtonNode { return } - let checkSize = CGSize(width: 18.0, height: 18.0) + let padding: CGFloat = 6.0 let spacing: CGFloat = 9.0 - let totalWidth = checkSize.width + spacing + textSize.width - let origin = floor((self.bounds.width - totalWidth) / 2.0) + let checkSize = CGSize(width: 18.0, height: 18.0) - self.checkNode.frame = CGRect(origin: CGPoint(x: origin, y: 6.0), size: checkSize) - self.colorNode.frame = CGRect(origin: CGPoint(x: origin, y: 6.0), size: checkSize) + self.checkNode.frame = CGRect(origin: CGPoint(x: padding, y: padding), size: checkSize) + self.colorNode.frame = CGRect(origin: CGPoint(x: padding, y: padding), size: checkSize) if let textSize = self.textSize { - self.textNode.frame = CGRect(x: origin + checkSize.width + spacing, y: 6.0 + UIScreenPixel, width: textSize.width, height: textSize.height) - } - } -} - -final class WallpaperGalleryDecorationNode: ASDisplayNode { - private let dismiss: () -> Void - private let apply: () -> Void - -// private var messageNodes: [ListViewItemNode]? -// private var blurredButtonNode: WallpaperOptionButtonNode? -// private var motionButtonNode: WallpaperOptionButtonNode? -// private var toolbarNode: WallpaperGalleryToolbarNode? - - init(source: WallpaperListSource, dismiss: @escaping () -> Void, apply: @escaping () -> Void) { - self.dismiss = dismiss - self.apply = apply - - super.init() - } - - override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? { - let result = super.hitTest(point, with: event) - if result != self.view { - return result - } else { - return nil + self.textNode.frame = CGRect(x: max(padding + checkSize.width + spacing, padding + checkSize.width + floor((self.bounds.width - padding - checkSize.width - textSize.width) / 2.0) - 2.0), y: 6.0 + UIScreenPixel, width: textSize.width, height: textSize.height) } } } diff --git a/submodules/SettingsUI/Sources/Themes/WallpaperPatternPanelNode.swift b/submodules/SettingsUI/Sources/Themes/WallpaperPatternPanelNode.swift index d06b8e1f35..531ed2e4be 100644 --- a/submodules/SettingsUI/Sources/Themes/WallpaperPatternPanelNode.swift +++ b/submodules/SettingsUI/Sources/Themes/WallpaperPatternPanelNode.swift @@ -13,42 +13,72 @@ private let itemSize = CGSize(width: 88.0, height: 88.0) private let inset: CGFloat = 12.0 final class WallpaperPatternPanelNode: ASDisplayNode { - private let theme: PresentationTheme + private let context: AccountContext + private var theme: PresentationTheme private let backgroundNode: ASDisplayNode private let topSeparatorNode: ASDisplayNode private let scrollNode: ASScrollNode - private let labelNode: ASTextNode + private let titleNode: ImmediateTextNode + private let labelNode: ImmediateTextNode private var sliderView: TGPhotoEditorSliderView? private var disposable: Disposable? - private var wallpapers: [TelegramWallpaper] = [] + var wallpapers: [TelegramWallpaper] = [] private var currentWallpaper: TelegramWallpaper? - var patternChanged: ((TelegramWallpaper, Int32?, Bool) -> Void)? + var serviceBackgroundColor: UIColor = UIColor(rgb: 0x748698) { + didSet { + guard let nodes = self.scrollNode.subnodes else { + return + } + for case let node as SettingsThemeWallpaperNode in nodes { + node.setOverlayBackgroundColor(self.serviceBackgroundColor.withAlphaComponent(0.4)) + } + } + } + + var backgroundColors: (UIColor, UIColor?)? = nil { + didSet { + if oldValue?.0.rgb != self.backgroundColors?.0.rgb || oldValue?.1?.rgb != self.backgroundColors?.1?.rgb { + self.updateWallpapers() + } + } + } + + private var validLayout: CGSize? + + var patternChanged: ((TelegramWallpaper?, Int32?, Bool) -> Void)? init(context: AccountContext, theme: PresentationTheme, strings: PresentationStrings) { + self.context = context self.theme = theme self.backgroundNode = ASDisplayNode() - self.backgroundNode.backgroundColor = theme.chat.inputPanel.panelBackgroundColor + self.backgroundNode.backgroundColor = self.theme.chat.inputPanel.panelBackgroundColor self.topSeparatorNode = ASDisplayNode() - self.topSeparatorNode.backgroundColor = theme.chat.inputPanel.panelSeparatorColor + self.topSeparatorNode.backgroundColor = self.theme.chat.inputPanel.panelSeparatorColor self.scrollNode = ASScrollNode() - self.labelNode = ASTextNode() + self.titleNode = ImmediateTextNode() + self.titleNode.attributedText = NSAttributedString(string: strings.WallpaperPreview_PatternTitle, font: Font.bold(17.0), textColor: theme.rootController.navigationBar.primaryTextColor) + + self.labelNode = ImmediateTextNode() self.labelNode.attributedText = NSAttributedString(string: strings.WallpaperPreview_PatternIntensity, font: Font.regular(14.0), textColor: theme.rootController.navigationBar.primaryTextColor) super.init() + self.allowsGroupOpacity = true + self.addSubnode(self.backgroundNode) self.addSubnode(self.topSeparatorNode) self.addSubnode(self.scrollNode) + self.addSubnode(self.titleNode) self.addSubnode(self.labelNode) self.disposable = ((telegramWallpapers(postbox: context.account.postbox, network: context.account.network) @@ -63,46 +93,8 @@ final class WallpaperPatternPanelNode: ASDisplayNode { } |> deliverOnMainQueue).start(next: { [weak self] wallpapers in if let strongSelf = self { - if let subnodes = strongSelf.scrollNode.subnodes { - for node in subnodes { - node.removeFromSupernode() - } - } - - var selected = true - for wallpaper in wallpapers { - let node = SettingsThemeWallpaperNode(overlayBackgroundColor: UIColor(rgb: 0x748698, alpha: 0.4)) - node.clipsToBounds = true - node.cornerRadius = 5.0 - - var updatedWallpaper = wallpaper - if case let .file(file) = updatedWallpaper { - let settings = WallpaperSettings(blur: false, motion: false, color: 0xd6e2ee, intensity: 100) - updatedWallpaper = .file(id: file.id, accessHash: file.accessHash, isCreator: file.isCreator, isDefault: file.isDefault, isPattern: file.isPattern, isDark: file.isDark, slug: file.slug, file: file.file, settings: settings) - } - - node.setWallpaper(context: context, wallpaper: updatedWallpaper, selected: selected, size: itemSize) - node.pressed = { [weak self, weak node] in - if let strongSelf = self { - strongSelf.currentWallpaper = updatedWallpaper - if let sliderView = strongSelf.sliderView { - strongSelf.patternChanged?(updatedWallpaper, Int32(sliderView.value), false) - } - if let subnodes = strongSelf.scrollNode.subnodes { - for case let subnode as SettingsThemeWallpaperNode in subnodes { - subnode.setSelected(node === subnode, animated: true) - } - } - } - } - strongSelf.scrollNode.addSubnode(node) - - selected = false - } - strongSelf.scrollNode.view.contentSize = CGSize(width: (itemSize.width + inset) * CGFloat(wallpapers.count) + inset, height: 112.0) - strongSelf.layoutItemNodes(transition: .immediate) - strongSelf.wallpapers = wallpapers + strongSelf.updateWallpapers() } })) } @@ -135,6 +127,79 @@ final class WallpaperPatternPanelNode: ASDisplayNode { self.sliderView = sliderView } + func updateWallpapers() { + guard let subnodes = self.scrollNode.subnodes else { + return + } + + for node in subnodes { + node.removeFromSupernode() + } + + let backgroundColors = self.backgroundColors ?? (UIColor(rgb: 0xd6e2ee), nil) + + var selectedFileId: Int64? + if let currentWallpaper = self.currentWallpaper, case let .file(file) = currentWallpaper { + selectedFileId = file.id + } + + for wallpaper in wallpapers { + let node = SettingsThemeWallpaperNode(overlayBackgroundColor: self.serviceBackgroundColor.withAlphaComponent(0.4)) + node.clipsToBounds = true + node.cornerRadius = 5.0 + + var updatedWallpaper = wallpaper + if case let .file(file) = updatedWallpaper { + let settings = WallpaperSettings(blur: false, motion: false, color: Int32(bitPattern: backgroundColors.0.rgb), bottomColor: backgroundColors.1.flatMap { Int32(bitPattern: $0.rgb) }, intensity: 100) + updatedWallpaper = .file(id: file.id, accessHash: file.accessHash, isCreator: file.isCreator, isDefault: file.isDefault, isPattern: file.isPattern, isDark: file.isDark, slug: file.slug, file: file.file, settings: settings) + } + + var selected = false + if case let .file(file) = wallpaper, file.id == selectedFileId { + selected = true + } + + node.setWallpaper(context: self.context, wallpaper: updatedWallpaper, selected: selected, size: itemSize) + node.pressed = { [weak self, weak node] in + if let strongSelf = self { + strongSelf.currentWallpaper = updatedWallpaper + if let sliderView = strongSelf.sliderView { + strongSelf.patternChanged?(updatedWallpaper, Int32(sliderView.value), false) + } + if let subnodes = strongSelf.scrollNode.subnodes { + for case let subnode as SettingsThemeWallpaperNode in subnodes { + let selected = node === subnode + subnode.setSelected(selected, animated: true) + if selected { + strongSelf.scrollToNode(subnode, animated: true) + } + } + } + } + } + self.scrollNode.addSubnode(node) + } + + self.scrollNode.view.contentSize = CGSize(width: (itemSize.width + inset) * CGFloat(wallpapers.count) + inset, height: 112.0) + self.layoutItemNodes(transition: .immediate) + } + + func updateTheme(_ theme: PresentationTheme) { + self.theme = theme + + self.backgroundNode.backgroundColor = self.theme.chat.inputPanel.panelBackgroundColor + self.topSeparatorNode.backgroundColor = self.theme.chat.inputPanel.panelSeparatorColor + + self.sliderView?.backColor = self.theme.list.disclosureArrowColor + self.sliderView?.trackColor = self.theme.list.itemAccentColor + self.titleNode.attributedText = NSAttributedString(string: self.labelNode.attributedText?.string ?? "", font: Font.bold(17.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + self.labelNode.attributedText = NSAttributedString(string: self.labelNode.attributedText?.string ?? "", font: Font.regular(14.0), textColor: self.theme.rootController.navigationBar.primaryTextColor) + + if let size = self.validLayout { + self.updateLayout(size: size, transition: .immediate) + } + } + @objc func sliderValueChanged() { guard let sliderView = self.sliderView else { return @@ -145,37 +210,70 @@ final class WallpaperPatternPanelNode: ASDisplayNode { } } - func didAppear() { - if let wallpaper = self.wallpapers.first { + func didAppear(initialWallpaper: TelegramWallpaper? = nil, intensity: Int32? = nil) { + var wallpaper = initialWallpaper ?? self.wallpapers.first + + if let wallpaper = wallpaper { + var selectedFileId: Int64? + if case let .file(file) = wallpaper { + selectedFileId = file.id + } + self.currentWallpaper = wallpaper - self.sliderView?.value = 40.0 + self.sliderView?.value = CGFloat(intensity ?? 40) self.scrollNode.view.contentOffset = CGPoint() - var selected = true + var selectedNode: SettingsThemeWallpaperNode? if let subnodes = self.scrollNode.subnodes { for case let subnode as SettingsThemeWallpaperNode in subnodes { + var selected = false + if case let .file(file) = subnode.wallpaper, file.id == selectedFileId { + selected = true + selectedNode = subnode + } subnode.setSelected(selected, animated: false) - selected = false } } - - if let wallpaper = self.currentWallpaper, let sliderView = self.sliderView { + + if initialWallpaper == nil, let wallpaper = self.currentWallpaper, let sliderView = self.sliderView { self.patternChanged?(wallpaper, Int32(sliderView.value), false) } + + if let selectedNode = selectedNode { + self.scrollToNode(selectedNode) + } + } + } + + private func scrollToNode(_ node: SettingsThemeWallpaperNode, animated: Bool = false) { + let bounds = self.scrollNode.view.bounds + let frame = node.frame.insetBy(dx: -48.0, dy: 0.0) + + if frame.minX < bounds.minX || frame.maxX > bounds.maxX { + self.scrollNode.view.scrollRectToVisible(frame, animated: animated) } } func updateLayout(size: CGSize, transition: ContainedViewLayoutTransition) { - let separatorHeight = UIScreenPixel + self.validLayout = size + transition.updateFrame(node: self.backgroundNode, frame: CGRect(x: 0.0, y: 0.0, width: size.width, height: size.height)) - transition.updateFrame(node: self.topSeparatorNode, frame: CGRect(x: 0.0, y: 0.0, width: size.width, height: separatorHeight)) - transition.updateFrame(node: self.scrollNode, frame: CGRect(x: 0.0, y: 0.0, width: size.width, height: 114.0)) + transition.updateFrame(node: self.topSeparatorNode, frame: CGRect(x: 0.0, y: 0.0, width: size.width, height: UIScreenPixel)) - let labelSize = self.labelNode.measure(self.bounds.size) - transition.updateFrame(node: labelNode, frame: CGRect(origin: CGPoint(x: 14.0, y: 128.0), size: labelSize)) + let titleSize = self.titleNode.updateLayout(self.bounds.size) + transition.updateFrame(node: self.titleNode, frame: CGRect(origin: CGPoint(x: floor((self.bounds.width - titleSize.width) / 2.0), y: 19.0), size: titleSize)) - self.sliderView?.frame = CGRect(origin: CGPoint(x: 15.0, y: 136.0), size: CGSize(width: size.width - 15.0 * 2.0, height: 44.0)) + let scrollViewFrame = CGRect(x: 0.0, y: 52.0, width: size.width, height: 114.0) + transition.updateFrame(node: self.scrollNode, frame: scrollViewFrame) + + let labelSize = self.labelNode.updateLayout(self.bounds.size) + var combinedHeight = labelSize.height + 34.0 + + var originY: CGFloat = scrollViewFrame.maxY + floor((size.height - scrollViewFrame.maxY - combinedHeight) / 2.0) + transition.updateFrame(node: self.labelNode, frame: CGRect(origin: CGPoint(x: 14.0, y: originY), size: labelSize)) + + self.sliderView?.frame = CGRect(origin: CGPoint(x: 15.0, y: originY + 8.0), size: CGSize(width: size.width - 15.0 * 2.0, height: 44.0)) self.layoutItemNodes(transition: transition) } diff --git a/submodules/SyncCore/Sources/TelegramWallpaper.swift b/submodules/SyncCore/Sources/TelegramWallpaper.swift index 47015e2362..8072f707d8 100644 --- a/submodules/SyncCore/Sources/TelegramWallpaper.swift +++ b/submodules/SyncCore/Sources/TelegramWallpaper.swift @@ -4,13 +4,15 @@ public struct WallpaperSettings: PostboxCoding, Equatable { public let blur: Bool public let motion: Bool public let color: Int32? + public let bottomColor: Int32? public let intensity: Int32? public let rotation: Int32? - public init(blur: Bool = false, motion: Bool = false, color: Int32? = nil, intensity: Int32? = nil, rotation: Int32? = nil) { + public init(blur: Bool = false, motion: Bool = false, color: Int32? = nil, bottomColor: Int32? = nil, intensity: Int32? = nil, rotation: Int32? = nil) { self.blur = blur self.motion = motion self.color = color + self.bottomColor = bottomColor self.intensity = intensity self.rotation = rotation } @@ -19,6 +21,7 @@ public struct WallpaperSettings: PostboxCoding, Equatable { self.blur = decoder.decodeInt32ForKey("b", orElse: 0) != 0 self.motion = decoder.decodeInt32ForKey("m", orElse: 0) != 0 self.color = decoder.decodeOptionalInt32ForKey("c") + self.bottomColor = decoder.decodeOptionalInt32ForKey("bc") self.intensity = decoder.decodeOptionalInt32ForKey("i") self.rotation = decoder.decodeOptionalInt32ForKey("r") } @@ -31,6 +34,11 @@ public struct WallpaperSettings: PostboxCoding, Equatable { } else { encoder.encodeNil(forKey: "c") } + if let bottomColor = self.bottomColor { + encoder.encodeInt32(bottomColor, forKey: "bc") + } else { + encoder.encodeNil(forKey: "bc") + } if let intensity = self.intensity { encoder.encodeInt32(intensity, forKey: "i") } else { @@ -42,6 +50,28 @@ public struct WallpaperSettings: PostboxCoding, Equatable { encoder.encodeNil(forKey: "r") } } + + public static func ==(lhs: WallpaperSettings, rhs: WallpaperSettings) -> Bool { + if lhs.blur != rhs.blur { + return false + } + if lhs.motion != rhs.motion { + return false + } + if lhs.color != rhs.color { + return false + } + if lhs.bottomColor != rhs.bottomColor { + return false + } + if lhs.intensity != rhs.intensity { + return false + } + if lhs.rotation != rhs.rotation { + return false + } + return true + } } public enum TelegramWallpaper: OrderedItemListEntryContents, Equatable { @@ -144,7 +174,7 @@ public enum TelegramWallpaper: OrderedItemListEntryContents, Equatable { return false } case let .file(lhsId, _, lhsIsCreator, lhsIsDefault, lhsIsPattern, lhsIsDark, lhsSlug, lhsFile, lhsSettings): - if case let .file(rhsId, _, rhsIsCreator, rhsIsDefault, rhsIsPattern, rhsIsDark, rhsSlug, rhsFile, rhsSettings) = rhs, lhsId == rhsId, lhsIsCreator == rhsIsCreator, lhsIsDefault == rhsIsDefault, lhsIsPattern == rhsIsPattern, lhsIsDark == rhsIsDark, lhsSlug == rhsSlug, lhsFile == rhsFile, lhsSettings == rhsSettings { + if case let .file(rhsId, _, rhsIsCreator, rhsIsDefault, rhsIsPattern, rhsIsDark, rhsSlug, rhsFile, rhsSettings) = rhs, lhsId == rhsId, lhsIsCreator == rhsIsCreator, lhsIsDefault == rhsIsDefault, lhsIsPattern == rhsIsPattern, lhsIsDark == rhsIsDark, lhsSlug == rhsSlug, lhsFile.id == rhsFile.id, lhsSettings == rhsSettings { return true } else { return false diff --git a/submodules/TelegramCore/Sources/AuthTransfer.swift b/submodules/TelegramCore/Sources/AuthTransfer.swift index 232dd17f4f..a691167d34 100644 --- a/submodules/TelegramCore/Sources/AuthTransfer.swift +++ b/submodules/TelegramCore/Sources/AuthTransfer.swift @@ -105,7 +105,7 @@ public func exportAuthTransferToken(accountManager: AccountManager, account: Una } |> mapToSignal { result -> Signal in switch result { - case let .loginTokenSuccess(authorization): + case let .loginTokenSuccess(authorization)?: switch authorization { case let .authorization(_, _, user): return updatedAccount.postbox.transaction { transaction -> Signal in diff --git a/submodules/TelegramPermissionsUI/Sources/PermissionController.swift b/submodules/TelegramPermissionsUI/Sources/PermissionController.swift index 6964197836..e43f4b9f96 100644 --- a/submodules/TelegramPermissionsUI/Sources/PermissionController.swift +++ b/submodules/TelegramPermissionsUI/Sources/PermissionController.swift @@ -15,6 +15,8 @@ public final class PermissionController: ViewController { private var state: PermissionControllerContent? private var splashScreen = false + private var locationManager: LocationManager? + private var controllerNode: PermissionControllerNode { return self.displayNode as! PermissionControllerNode } @@ -185,11 +187,15 @@ public final class PermissionController: ViewController { case let .nearbyLocation(status): self.title = self.presentationData.strings.Permissions_PeopleNearbyTitle_v0 + if self.locationManager == nil { + self.locationManager = LocationManager() + } + self.allow = { [weak self] in if let strongSelf = self { switch status { case .requestable: - DeviceAccess.authorizeAccess(to: .location(.tracking), presentationData: strongSelf.context.sharedContext.currentPresentationData.with { $0 }, { [weak self] result in + DeviceAccess.authorizeAccess(to: .location(.tracking), locationManager: strongSelf.locationManager, presentationData: strongSelf.context.sharedContext.currentPresentationData.with { $0 }, { [weak self] result in self?.proceed?(result) }) case .denied, .unreachable: diff --git a/submodules/TelegramPresentationData/Sources/ChatControllerBackgroundNode.swift b/submodules/TelegramPresentationData/Sources/ChatControllerBackgroundNode.swift index b698255fc5..6d231719cf 100644 --- a/submodules/TelegramPresentationData/Sources/ChatControllerBackgroundNode.swift +++ b/submodules/TelegramPresentationData/Sources/ChatControllerBackgroundNode.swift @@ -11,7 +11,7 @@ import AppBundle private var backgroundImageForWallpaper: (TelegramWallpaper, Bool, UIImage)? -public func chatControllerBackgroundImage(theme: PresentationTheme?, wallpaper initialWallpaper: TelegramWallpaper, mediaBox: MediaBox, composed: Bool = true, knockoutMode: Bool) -> UIImage? { +public func chatControllerBackgroundImage(theme: PresentationTheme?, wallpaper initialWallpaper: TelegramWallpaper, mediaBox: MediaBox, composed: Bool = true, knockoutMode: Bool, cached: Bool = true) -> UIImage? { var wallpaper = initialWallpaper if knockoutMode, let theme = theme { switch theme.name { @@ -28,9 +28,10 @@ public func chatControllerBackgroundImage(theme: PresentationTheme?, wallpaper i } var backgroundImage: UIImage? - if composed && wallpaper == backgroundImageForWallpaper?.0, (wallpaper.settings?.blur ?? false) == backgroundImageForWallpaper?.1 { + if cached && composed && wallpaper == backgroundImageForWallpaper?.0, (wallpaper.settings?.blur ?? false) == backgroundImageForWallpaper?.1 { backgroundImage = backgroundImageForWallpaper?.2 } else { + var succeed = true switch wallpaper { case .builtin: if let filePath = getAppBundle().path(forResource: "ChatWallpaperBuiltin0", ofType: "jpg") { @@ -41,14 +42,18 @@ public func chatControllerBackgroundImage(theme: PresentationTheme?, wallpaper i context.setFillColor(UIColor(rgb: UInt32(bitPattern: color)).withAlphaComponent(1.0).cgColor) context.fill(CGRect(origin: CGPoint(), size: size)) }) - case let .gradient(topColor, bottomColor, _): - backgroundImage = generateImage(CGSize(width: 1.0, height: 1280.0), rotatedContext: { size, context in + case let .gradient(topColor, bottomColor, settings): + backgroundImage = generateImage(CGSize(width: 640.0, height: 1280.0), rotatedContext: { size, context in let gradientColors = [UIColor(rgb: UInt32(bitPattern: topColor)).cgColor, UIColor(rgb: UInt32(bitPattern: bottomColor)).cgColor] as CFArray var locations: [CGFloat] = [0.0, 1.0] let colorSpace = CGColorSpaceCreateDeviceRGB() let gradient = CGGradient(colorsSpace: colorSpace, colors: gradientColors, locations: &locations)! + context.translateBy(x: 320.0, y: 640.0) + context.rotate(by: CGFloat(settings.rotation ?? 0) * CGFloat.pi / 180.0) + context.translateBy(x: -320.0, y: -640.0) + context.drawLinearGradient(gradient, start: CGPoint(x: 0.0, y: 0.0), end: CGPoint(x: 0.0, y: size.height), options: CGGradientDrawingOptions()) }) case let .image(representations, settings): @@ -63,13 +68,14 @@ public func chatControllerBackgroundImage(theme: PresentationTheme?, wallpaper i backgroundImage = image } if backgroundImage == nil, let path = mediaBox.completedResourcePath(largest.resource) { + succeed = false backgroundImage = UIImage(contentsOfFile: path)?.precomposed() } } case let .file(file): if file.isPattern, let color = file.settings.color, let intensity = file.settings.intensity { var image: UIImage? - let _ = mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, intensity: intensity), complete: true, fetch: true, attemptSynchronously: true).start(next: { data in + let _ = mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, bottomColor: file.settings.bottomColor, intensity: intensity, rotation: file.settings.rotation), complete: true, fetch: true, attemptSynchronously: true).start(next: { data in if data.complete { image = UIImage(contentsOfFile: data.path)?.precomposed() } @@ -86,11 +92,12 @@ public func chatControllerBackgroundImage(theme: PresentationTheme?, wallpaper i backgroundImage = image } if backgroundImage == nil, let path = mediaBox.completedResourcePath(file.file.resource) { + succeed = false backgroundImage = UIImage(contentsOfFile: path)?.precomposed() } } } - if let backgroundImage = backgroundImage, composed { + if let backgroundImage = backgroundImage, composed && succeed { backgroundImageForWallpaper = (wallpaper, (wallpaper.settings?.blur ?? false), backgroundImage) } } diff --git a/submodules/TelegramPresentationData/Sources/DefaultDarkPresentationTheme.swift b/submodules/TelegramPresentationData/Sources/DefaultDarkPresentationTheme.swift index 794aa65ef4..de169248f8 100644 --- a/submodules/TelegramPresentationData/Sources/DefaultDarkPresentationTheme.swift +++ b/submodules/TelegramPresentationData/Sources/DefaultDarkPresentationTheme.swift @@ -6,7 +6,7 @@ import TelegramUIPreferences public let defaultDarkPresentationTheme = makeDefaultDarkPresentationTheme(preview: false) -public func customizeDefaultDarkPresentationTheme(theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?) -> PresentationTheme { +public func customizeDefaultDarkPresentationTheme(theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?, wallpaper forcedWallpaper: TelegramWallpaper? = nil) -> PresentationTheme { if (theme.referenceTheme != .night) { return theme } @@ -61,7 +61,6 @@ public func customizeDefaultDarkPresentationTheme(theme: PresentationTheme, edit ) list = list.withUpdated( itemAccentColor: accentColor, - itemDisclosureActions: list.itemDisclosureActions.withUpdated(accent: list.itemDisclosureActions.accent.withUpdated(fillColor: accentColor)), itemCheckColors: list.itemCheckColors.withUpdated(fillColor: accentColor, foregroundColor: secondaryBadgeTextColor), itemBarChart: list.itemBarChart.withUpdated(color1: accentColor) ) @@ -80,7 +79,9 @@ public func customizeDefaultDarkPresentationTheme(theme: PresentationTheme, edit } var defaultWallpaper: TelegramWallpaper? - if let backgroundColors = backgroundColors { + if let forcedWallpaper = forcedWallpaper { + defaultWallpaper = forcedWallpaper + } else if let backgroundColors = backgroundColors { if let secondColor = backgroundColors.1 { defaultWallpaper = .gradient(Int32(bitPattern: backgroundColors.0.rgb), Int32(bitPattern: secondColor.rgb), WallpaperSettings()) } else { diff --git a/submodules/TelegramPresentationData/Sources/DefaultDarkTintedPresentationTheme.swift b/submodules/TelegramPresentationData/Sources/DefaultDarkTintedPresentationTheme.swift index f36b7344ab..43201ff25d 100644 --- a/submodules/TelegramPresentationData/Sources/DefaultDarkTintedPresentationTheme.swift +++ b/submodules/TelegramPresentationData/Sources/DefaultDarkTintedPresentationTheme.swift @@ -7,15 +7,7 @@ import TelegramUIPreferences private let defaultDarkTintedAccentColor = UIColor(rgb: 0x2ea6ff) public let defaultDarkTintedPresentationTheme = makeDefaultDarkTintedPresentationTheme(preview: false) -//public func makeDarkAccentPresentationTheme(accentColor: UIColor?, bubbleColors: (UIColor, UIColor?)?, preview: Bool) -> PresentationTheme { -// var accentColor = accentColor ?? defaultDarkAccentColor -// if accentColor == PresentationThemeBaseColor.blue.color { -// accentColor = defaultDarkAccentColor -// } -// return makeDarkPresentationTheme(accentColor: accentColor, bubbleColors: bubbleColors, preview: preview) -//} - -public func customizeDefaultDarkTintedPresentationTheme(theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?) -> PresentationTheme { +public func customizeDefaultDarkTintedPresentationTheme(theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?, wallpaper forcedWallpaper: TelegramWallpaper? = nil) -> PresentationTheme { if (theme.referenceTheme != .nightAccent) { return theme } @@ -44,8 +36,15 @@ public func customizeDefaultDarkTintedPresentationTheme(theme: PresentationTheme var inputBackgroundColor: UIColor? var buttonStrokeColor: UIColor? + var suggestedWallpaper: TelegramWallpaper? + var bubbleColors = bubbleColors if bubbleColors == nil, editing { + if let accentColor = accentColor { + let color = accentColor.withMultiplied(hue: 1.024, saturation: 0.573, brightness: 0.18) + suggestedWallpaper = .color(Int32(bitPattern: color.rgb)) + } + let accentColor = accentColor ?? defaultDarkTintedAccentColor let bottomColor = accentColor.withMultiplied(hue: 1.019, saturation: 0.731, brightness: 0.59) let topColor = bottomColor.withMultiplied(hue: 0.966, saturation: 0.61, brightness: 0.98) @@ -217,12 +216,16 @@ public func customizeDefaultDarkTintedPresentationTheme(theme: PresentationTheme } var defaultWallpaper: TelegramWallpaper? - if let backgroundColors = backgroundColors { + if let forcedWallpaper = forcedWallpaper { + defaultWallpaper = forcedWallpaper + } else if let backgroundColors = backgroundColors { if let secondColor = backgroundColors.1 { defaultWallpaper = .gradient(Int32(bitPattern: backgroundColors.0.rgb), Int32(bitPattern: secondColor.rgb), WallpaperSettings()) } else { defaultWallpaper = .color(Int32(bitPattern: backgroundColors.0.rgb)) } + } else if let forcedWallpaper = suggestedWallpaper { + defaultWallpaper = forcedWallpaper } var outgoingBubbleFillColor: UIColor? diff --git a/submodules/TelegramPresentationData/Sources/DefaultDayPresentationTheme.swift b/submodules/TelegramPresentationData/Sources/DefaultDayPresentationTheme.swift index 5261520510..47014f6095 100644 --- a/submodules/TelegramPresentationData/Sources/DefaultDayPresentationTheme.swift +++ b/submodules/TelegramPresentationData/Sources/DefaultDayPresentationTheme.swift @@ -8,7 +8,7 @@ public let defaultServiceBackgroundColor = UIColor(rgb: 0x000000, alpha: 0.3) public let defaultPresentationTheme = makeDefaultDayPresentationTheme(serviceBackgroundColor: defaultServiceBackgroundColor, day: false, preview: false) public let defaultDayAccentColor = UIColor(rgb: 0x007ee5) -public func customizeDefaultDayTheme(theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?, serviceBackgroundColor: UIColor?) -> PresentationTheme { +public func customizeDefaultDayTheme(theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?, wallpaper forcedWallpaper: TelegramWallpaper? = nil, serviceBackgroundColor: UIColor?) -> PresentationTheme { if (theme.referenceTheme != .day && theme.referenceTheme != .dayClassic) { return theme } @@ -21,9 +21,10 @@ public func customizeDefaultDayTheme(theme: PresentationTheme, editing: Bool, ac var chat = theme.chat var actionSheet = theme.actionSheet - var bubbleColors = bubbleColors var outgoingAccent: UIColor? var suggestedWallpaper: TelegramWallpaper? + + var bubbleColors = bubbleColors if bubbleColors == nil, editing { if day { let accentColor = accentColor ?? defaultDayAccentColor @@ -172,7 +173,9 @@ public func customizeDefaultDayTheme(theme: PresentationTheme, editing: Bool, ac } var defaultWallpaper: TelegramWallpaper? - if let backgroundColors = backgroundColors { + if let forcedWallpaper = forcedWallpaper { + defaultWallpaper = forcedWallpaper + } else if let backgroundColors = backgroundColors { if let secondColor = backgroundColors.1 { defaultWallpaper = .gradient(Int32(bitPattern: backgroundColors.0.rgb), Int32(bitPattern: secondColor.rgb), WallpaperSettings()) } else { @@ -190,6 +193,7 @@ public func customizeDefaultDayTheme(theme: PresentationTheme, editing: Bool, ac accentTextColor: accentColor, accentControlColor: accentColor, mediaActiveControlColor: accentColor, + fileTitleColor: accentColor, polls: chat.message.incoming.polls.withUpdated( radioProgress: accentColor, highlight: accentColor?.withAlphaComponent(0.12), @@ -229,7 +233,7 @@ public func customizeDefaultDayTheme(theme: PresentationTheme, editing: Bool, ac fileTitleColor: outgoingFileTitleColor, fileDescriptionColor: outgoingFileDescriptionColor, fileDurationColor: outgoingFileDurationColor, - mediaPlaceholderColor: day ? accentColor?.withMultipliedBrightnessBy(0.95) : nil, + mediaPlaceholderColor: day ? accentColor?.withMultipliedBrightnessBy(0.95) : outgoingMediaPlaceholderColor, polls: chat.message.outgoing.polls.withUpdated(radioButton: outgoingPollsButtonColor, radioProgress: outgoingPollsProgressColor, highlight: outgoingPollsProgressColor?.withAlphaComponent(0.12), separator: outgoingPollsButtonColor, bar: outgoingPollsProgressColor), actionButtonsFillColor: chat.message.outgoing.actionButtonsFillColor.withUpdated(withWallpaper: serviceBackgroundColor), actionButtonsStrokeColor: day ? chat.message.outgoing.actionButtonsStrokeColor.withUpdated(withoutWallpaper: accentColor) : nil, diff --git a/submodules/TelegramPresentationData/Sources/MakePresentationTheme.swift b/submodules/TelegramPresentationData/Sources/MakePresentationTheme.swift index 2517d0a65b..f176fc1c69 100644 --- a/submodules/TelegramPresentationData/Sources/MakePresentationTheme.swift +++ b/submodules/TelegramPresentationData/Sources/MakePresentationTheme.swift @@ -1,6 +1,7 @@ import Foundation import UIKit import Postbox +import SyncCore import TelegramUIPreferences public func makeDefaultPresentationTheme(reference: PresentationBuiltinThemeReference, serviceBackgroundColor: UIColor?, preview: Bool = false) -> PresentationTheme { @@ -18,37 +19,37 @@ public func makeDefaultPresentationTheme(reference: PresentationBuiltinThemeRefe return theme } -public func customizePresentationTheme(_ theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?) -> PresentationTheme { +public func customizePresentationTheme(_ theme: PresentationTheme, editing: Bool, accentColor: UIColor?, backgroundColors: (UIColor, UIColor?)?, bubbleColors: (UIColor, UIColor?)?, wallpaper: TelegramWallpaper? = nil) -> PresentationTheme { if accentColor == nil && bubbleColors == nil && backgroundColors == nil { return theme } switch theme.referenceTheme { case .day, .dayClassic: - return customizeDefaultDayTheme(theme: theme, editing: editing, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors, serviceBackgroundColor: nil) + return customizeDefaultDayTheme(theme: theme, editing: editing, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors, wallpaper: wallpaper, serviceBackgroundColor: nil) case .night: - return customizeDefaultDarkPresentationTheme(theme: theme, editing: editing, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors) + return customizeDefaultDarkPresentationTheme(theme: theme, editing: editing, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors, wallpaper: wallpaper) case .nightAccent: - return customizeDefaultDarkTintedPresentationTheme(theme: theme, editing: editing, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors) + return customizeDefaultDarkTintedPresentationTheme(theme: theme, editing: editing, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors, wallpaper: wallpaper) } return theme } -public func makePresentationTheme(mediaBox: MediaBox, themeReference: PresentationThemeReference, accentColor: UIColor?, bubbleColors: (UIColor, UIColor?)?, backgroundColors: (UIColor, UIColor?)? = nil, serviceBackgroundColor: UIColor? = nil, preview: Bool = false) -> PresentationTheme? { +public func makePresentationTheme(mediaBox: MediaBox, themeReference: PresentationThemeReference, accentColor: UIColor? = nil, backgroundColors: (UIColor, UIColor?)? = nil, bubbleColors: (UIColor, UIColor?)? = nil, wallpaper: TelegramWallpaper? = nil, serviceBackgroundColor: UIColor? = nil, preview: Bool = false) -> PresentationTheme? { let theme: PresentationTheme switch themeReference { case let .builtin(reference): let defaultTheme = makeDefaultPresentationTheme(reference: reference, serviceBackgroundColor: serviceBackgroundColor, preview: preview) - theme = customizePresentationTheme(defaultTheme, editing: true, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors) + theme = customizePresentationTheme(defaultTheme, editing: true, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors, wallpaper: wallpaper) case let .local(info): if let path = mediaBox.completedResourcePath(info.resource), let data = try? Data(contentsOf: URL(fileURLWithPath: path), options: .mappedRead), let loadedTheme = makePresentationTheme(data: data, resolvedWallpaper: info.resolvedWallpaper) { - theme = customizePresentationTheme(loadedTheme, editing: false, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors) + theme = customizePresentationTheme(loadedTheme, editing: false, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors, wallpaper: wallpaper) } else { return nil } case let .cloud(info): if let file = info.theme.file, let path = mediaBox.completedResourcePath(file.resource), let data = try? Data(contentsOf: URL(fileURLWithPath: path), options: .mappedRead), let loadedTheme = makePresentationTheme(data: data, resolvedWallpaper: info.resolvedWallpaper) { - theme = customizePresentationTheme(loadedTheme, editing: false, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors) + theme = customizePresentationTheme(loadedTheme, editing: false, accentColor: accentColor, backgroundColors: backgroundColors, bubbleColors: bubbleColors, wallpaper: wallpaper) } else { return nil } diff --git a/submodules/TelegramPresentationData/Sources/PresentationData.swift b/submodules/TelegramPresentationData/Sources/PresentationData.swift index c12775dcbb..eba72b32b7 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationData.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationData.swift @@ -396,8 +396,18 @@ public func serviceColor(for wallpaper: (TelegramWallpaper, UIImage?)) -> UIColo } else { return UIColor(rgb: 0x000000, alpha: 0.3) } - case .file: - if let image = wallpaper.1 { + case let .file(file): + if file.isPattern { + if let color = file.settings.color { + var mixedColor = UIColor(rgb: UInt32(bitPattern: color)) + if let bottomColor = file.settings.bottomColor { + mixedColor = mixedColor.mixedWith(UIColor(rgb: UInt32(bitPattern: bottomColor)), alpha: 0.5) + } + return serviceColor(with: mixedColor) + } else { + return UIColor(rgb: 0x000000, alpha: 0.3) + } + } else if let image = wallpaper.1 { return serviceColor(with: averageColor(from: image)) } else { return UIColor(rgb: 0x000000, alpha: 0.3) @@ -458,7 +468,11 @@ public func chatServiceBackgroundColor(wallpaper: TelegramWallpaper, mediaBox: M case let .file(file): if file.isPattern { if let color = file.settings.color { - return .single(serviceColor(with: UIColor(rgb: UInt32(bitPattern: color)))) + var mixedColor = UIColor(rgb: UInt32(bitPattern: color)) + if let bottomColor = file.settings.bottomColor { + mixedColor = mixedColor.mixedWith(UIColor(rgb: UInt32(bitPattern: bottomColor)), alpha: 0.5) + } + return .single(serviceColor(with: mixedColor)) } else { return .single(UIColor(rgb: 0x000000, alpha: 0.3)) } diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 7eca8ff272..4621071924 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -2072,3131 +2072,3135 @@ public final class PresentationStrings: Equatable { public var Passport_Identity_EditIdentityCard: String { return self._s[1735]! } public var Contacts_PermissionsTitle: String { return self._s[1736]! } public var Conversation_RestrictedInline: String { return self._s[1737]! } - public var StickerPack_ViewPack: String { return self._s[1739]! } - public var Wallet_UnknownError: String { return self._s[1740]! } + public var Appearance_RemoveThemeColor: String { return self._s[1739]! } + public var StickerPack_ViewPack: String { return self._s[1740]! } + public var Wallet_UnknownError: String { return self._s[1741]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1741]!, self._r[1741]!, [_0]) + return formatWithArgumentRanges(self._s[1742]!, self._r[1742]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1743]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1746]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1748]! } - public var Channel_Info_Stickers: String { return self._s[1749]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1750]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1751]! } - public var Passport_DeletePersonalDetails: String { return self._s[1752]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1753]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1754]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1755]! } - public var Conversation_SearchNoResults: String { return self._s[1758]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1759]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1760]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1761]! } - public var Login_Code: String { return self._s[1762]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1763]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1764]! } - public var Weekday_ShortThursday: String { return self._s[1765]! } - public var Resolve_ErrorNotFound: String { return self._s[1767]! } - public var LastSeen_Offline: String { return self._s[1768]! } - public var PeopleNearby_NoMembers: String { return self._s[1769]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1770]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1771]! } - public var GroupInfo_Title: String { return self._s[1773]! } - public var NotificationsSound_Note: String { return self._s[1774]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1775]! } - public var Watch_Message_Poll: String { return self._s[1776]! } - public var Privacy_Calls: String { return self._s[1777]! } + public var Compose_NewChannel: String { return self._s[1744]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1747]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1749]! } + public var Channel_Info_Stickers: String { return self._s[1750]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1751]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1752]! } + public var Passport_DeletePersonalDetails: String { return self._s[1753]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1754]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1755]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1756]! } + public var Conversation_SearchNoResults: String { return self._s[1759]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1760]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1761]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1762]! } + public var Login_Code: String { return self._s[1763]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1764]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1765]! } + public var Weekday_ShortThursday: String { return self._s[1766]! } + public var Resolve_ErrorNotFound: String { return self._s[1768]! } + public var LastSeen_Offline: String { return self._s[1769]! } + public var PeopleNearby_NoMembers: String { return self._s[1770]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1771]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1772]! } + public var GroupInfo_Title: String { return self._s[1774]! } + public var NotificationsSound_Note: String { return self._s[1775]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1776]! } + public var Watch_Message_Poll: String { return self._s[1777]! } + public var Privacy_Calls: String { return self._s[1778]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1778]!, self._r[1778]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1779]!, self._r[1779]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1779]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1780]! } - public var Notifications_Reset: String { return self._s[1781]! } - public var Conversation_Pin: String { return self._s[1782]! } - public var Passport_Language_lv: String { return self._s[1783]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1784]! } - public var BlockedUsers_Info: String { return self._s[1785]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1787]! } - public var Watch_Conversation_Unblock: String { return self._s[1789]! } + public var Month_ShortAugust: String { return self._s[1780]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1781]! } + public var Notifications_Reset: String { return self._s[1782]! } + public var Conversation_Pin: String { return self._s[1783]! } + public var Passport_Language_lv: String { return self._s[1784]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1785]! } + public var BlockedUsers_Info: String { return self._s[1786]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1788]! } + public var Watch_Conversation_Unblock: String { return self._s[1790]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_0]) + return formatWithArgumentRanges(self._s[1791]!, self._r[1791]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1791]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1792]! } + public var CloudStorage_Title: String { return self._s[1792]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1793]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1793]!, self._r[1793]!, [_0]) + return formatWithArgumentRanges(self._s[1794]!, self._r[1794]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1794]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1795]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1796]! } - public var Passport_Address_EditBankStatement: String { return self._s[1797]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1795]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1796]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1797]! } + public var Passport_Address_EditBankStatement: String { return self._s[1798]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1798]!, self._r[1798]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1799]!, self._r[1799]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1799]! } - public var ShareMenu_Comment: String { return self._s[1800]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1801]! } - public var Notifications_PermissionsTitle: String { return self._s[1802]! } - public var GroupPermission_NoSendLinks: String { return self._s[1803]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1804]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1805]! } - public var Settings_Support: String { return self._s[1806]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1807]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1808]! } - public var Privacy_Forwards_Preview: String { return self._s[1809]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1810]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1811]! } - public var Common_Select: String { return self._s[1813]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1814]! } - public var WallpaperSearch_ColorGray: String { return self._s[1817]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1818]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1819]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1820]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1821]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1822]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1823]! } - public var Widget_AuthRequired: String { return self._s[1824]! } - public var Camera_FlashOn: String { return self._s[1825]! } - public var Conversation_ContextMenuLookUp: String { return self._s[1826]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1827]! } - public var Watch_Suggestion_OK: String { return self._s[1828]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1800]! } + public var ShareMenu_Comment: String { return self._s[1801]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1802]! } + public var Notifications_PermissionsTitle: String { return self._s[1803]! } + public var GroupPermission_NoSendLinks: String { return self._s[1804]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1805]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1806]! } + public var Settings_Support: String { return self._s[1807]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1808]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1809]! } + public var Privacy_Forwards_Preview: String { return self._s[1810]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1811]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1812]! } + public var Common_Select: String { return self._s[1814]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1815]! } + public var WallpaperSearch_ColorGray: String { return self._s[1818]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1819]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1820]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1821]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1822]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1823]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1824]! } + public var Widget_AuthRequired: String { return self._s[1825]! } + public var Camera_FlashOn: String { return self._s[1826]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1827]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1828]! } + public var Watch_Suggestion_OK: String { return self._s[1829]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1830]!, self._r[1830]!, [_0]) + return formatWithArgumentRanges(self._s[1831]!, self._r[1831]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1832]!, self._r[1832]!, [_0]) + return formatWithArgumentRanges(self._s[1833]!, self._r[1833]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1833]! } - public var DialogList_AdLabel: String { return self._s[1834]! } - public var WatchRemote_NotificationText: String { return self._s[1835]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1836]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1837]! } - public var Conversation_ReportSpam: String { return self._s[1838]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1839]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1841]! } - public var PhoneLabel_Title: String { return self._s[1842]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1843]! } - public var Settings_ChangePhoneNumber: String { return self._s[1844]! } - public var Notifications_ExceptionsTitle: String { return self._s[1845]! } - public var Notifications_AlertTones: String { return self._s[1846]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1847]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1848]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1849]! } - public var VoiceOver_Chat_Photo: String { return self._s[1851]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1852]! } - public var ReportPeer_ReasonOther: String { return self._s[1853]! } - public var ChatList_Context_JoinChannel: String { return self._s[1854]! } - public var KeyCommand_ScrollDown: String { return self._s[1856]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[1857]! } + public var TextFormat_Strikethrough: String { return self._s[1834]! } + public var DialogList_AdLabel: String { return self._s[1835]! } + public var WatchRemote_NotificationText: String { return self._s[1836]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1837]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1838]! } + public var Conversation_ReportSpam: String { return self._s[1839]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1840]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1842]! } + public var PhoneLabel_Title: String { return self._s[1843]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1844]! } + public var Settings_ChangePhoneNumber: String { return self._s[1845]! } + public var Notifications_ExceptionsTitle: String { return self._s[1846]! } + public var Notifications_AlertTones: String { return self._s[1847]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1848]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1849]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1850]! } + public var VoiceOver_Chat_Photo: String { return self._s[1852]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1853]! } + public var ReportPeer_ReasonOther: String { return self._s[1854]! } + public var ChatList_Context_JoinChannel: String { return self._s[1855]! } + public var KeyCommand_ScrollDown: String { return self._s[1857]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1858]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1858]!, self._r[1858]!, [_0]) + return formatWithArgumentRanges(self._s[1859]!, self._r[1859]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1859]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1860]! } - public var AuthSessions_LogOut: String { return self._s[1861]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1862]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1863]! } - public var Passport_Phone_Title: String { return self._s[1864]! } - public var ContactList_Context_StartSecretChat: String { return self._s[1865]! } - public var Settings_PhoneNumber: String { return self._s[1866]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1860]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1861]! } + public var AuthSessions_LogOut: String { return self._s[1862]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1863]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1864]! } + public var Passport_Phone_Title: String { return self._s[1865]! } + public var ContactList_Context_StartSecretChat: String { return self._s[1866]! } + public var Settings_PhoneNumber: String { return self._s[1867]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1867]!, self._r[1867]!, [_0]) + return formatWithArgumentRanges(self._s[1868]!, self._r[1868]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[1869]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1870]! } - public var WebSearch_SearchNoResults: String { return self._s[1871]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1873]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[1874]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1875]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[1876]! } - public var PhotoEditor_CurvesTool: String { return self._s[1877]! } - public var Checkout_PaymentMethod: String { return self._s[1879]! } + public var NotificationsSound_Alert: String { return self._s[1870]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1871]! } + public var WebSearch_SearchNoResults: String { return self._s[1872]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1874]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[1875]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1876]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[1877]! } + public var PhotoEditor_CurvesTool: String { return self._s[1878]! } + public var Checkout_PaymentMethod: String { return self._s[1880]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1880]!, self._r[1880]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1881]!, self._r[1881]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[1881]! } - public var Camera_PhotoMode: String { return self._s[1884]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1885]! } - public var Appearance_TextSize_Apply: String { return self._s[1886]! } - public var Passport_Address_AddUtilityBill: String { return self._s[1888]! } - public var CallSettings_OnMobile: String { return self._s[1889]! } - public var Tour_Text2: String { return self._s[1890]! } + public var Contacts_AccessDeniedError: String { return self._s[1882]! } + public var Camera_PhotoMode: String { return self._s[1885]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[1886]! } + public var Appearance_TextSize_Apply: String { return self._s[1887]! } + public var Passport_Address_AddUtilityBill: String { return self._s[1889]! } + public var CallSettings_OnMobile: String { return self._s[1890]! } + public var Tour_Text2: String { return self._s[1891]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1891]!, self._r[1891]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1892]!, self._r[1892]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[1893]! } - public var Permissions_Skip: String { return self._s[1894]! } - public var Wallet_Words_NotDoneOk: String { return self._s[1895]! } - public var SecretImage_Title: String { return self._s[1896]! } - public var Watch_MessageView_Title: String { return self._s[1897]! } - public var Channel_DiscussionGroupAdd: String { return self._s[1898]! } - public var AttachmentMenu_Poll: String { return self._s[1899]! } + public var DialogList_EncryptionProcessing: String { return self._s[1894]! } + public var Permissions_Skip: String { return self._s[1895]! } + public var Wallet_Words_NotDoneOk: String { return self._s[1896]! } + public var SecretImage_Title: String { return self._s[1897]! } + public var Watch_MessageView_Title: String { return self._s[1898]! } + public var Channel_DiscussionGroupAdd: String { return self._s[1899]! } + public var AttachmentMenu_Poll: String { return self._s[1900]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1900]!, self._r[1900]!, [_0]) + return formatWithArgumentRanges(self._s[1901]!, self._r[1901]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1901]!, self._r[1901]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1902]!, self._r[1902]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[1902]! } - public var WallpaperPreview_Title: String { return self._s[1903]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1904]! } - public var Settings_ProxyConnecting: String { return self._s[1905]! } - public var Settings_CheckPhoneNumberText: String { return self._s[1907]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[1908]! } - public var Wallet_Intro_Title: String { return self._s[1909]! } - public var TwoFactorSetup_Password_Action: String { return self._s[1910]! } - public var Profile_MessageLifetime5s: String { return self._s[1911]! } - public var Username_InvalidCharacters: String { return self._s[1912]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1913]! } - public var ScheduledMessages_ClearAll: String { return self._s[1914]! } - public var WallpaperPreview_CropBottomText: String { return self._s[1915]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[1916]! } - public var Settings_AddAccount: String { return self._s[1917]! } - public var Notification_CreatedChannel: String { return self._s[1920]! } + public var Notification_CallCanceled: String { return self._s[1903]! } + public var WallpaperPreview_Title: String { return self._s[1904]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[1905]! } + public var Settings_ProxyConnecting: String { return self._s[1906]! } + public var Settings_CheckPhoneNumberText: String { return self._s[1908]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[1909]! } + public var Wallet_Intro_Title: String { return self._s[1910]! } + public var TwoFactorSetup_Password_Action: String { return self._s[1911]! } + public var Profile_MessageLifetime5s: String { return self._s[1912]! } + public var Username_InvalidCharacters: String { return self._s[1913]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[1914]! } + public var ScheduledMessages_ClearAll: String { return self._s[1915]! } + public var WallpaperPreview_CropBottomText: String { return self._s[1916]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[1917]! } + public var Settings_AddAccount: String { return self._s[1918]! } + public var Notification_CreatedChannel: String { return self._s[1921]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1921]!, self._r[1921]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1922]!, self._r[1922]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[1923]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1924]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[1925]! } - public var Contacts_TopSection: String { return self._s[1926]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1927]! } + public var Passcode_AppLockedAlert: String { return self._s[1924]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[1925]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[1926]! } + public var Contacts_TopSection: String { return self._s[1927]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[1928]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1928]!, self._r[1928]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1929]!, self._r[1929]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[1929]! } - public var Wallet_Completed_ViewWallet: String { return self._s[1930]! } + public var Wallet_Info_Receive: String { return self._s[1930]! } + public var Wallet_Completed_ViewWallet: String { return self._s[1931]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1931]!, self._r[1931]!, [_0]) + return formatWithArgumentRanges(self._s[1932]!, self._r[1932]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[1932]! } - public var UserInfo_TapToCall: String { return self._s[1933]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1935]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1936]! } - public var Common_Search: String { return self._s[1937]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[1938]! } + public var ReportPeer_ReasonSpam: String { return self._s[1933]! } + public var UserInfo_TapToCall: String { return self._s[1934]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[1936]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[1937]! } + public var Common_Search: String { return self._s[1938]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[1939]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1939]!, self._r[1939]!, [_0]) + return formatWithArgumentRanges(self._s[1940]!, self._r[1940]!, [_0]) } - public var Wallet_Month_ShortJuly: String { return self._s[1940]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1942]! } - public var Message_InvoiceLabel: String { return self._s[1943]! } - public var Conversation_InputTextPlaceholder: String { return self._s[1944]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1945]! } + public var Wallet_Month_ShortJuly: String { return self._s[1941]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[1943]! } + public var Message_InvoiceLabel: String { return self._s[1944]! } + public var Conversation_InputTextPlaceholder: String { return self._s[1945]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[1946]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1946]!, self._r[1946]!, [_0]) + return formatWithArgumentRanges(self._s[1947]!, self._r[1947]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[1947]! } - public var Conversation_Info: String { return self._s[1948]! } - public var Login_InfoDeletePhoto: String { return self._s[1949]! } - public var Passport_Language_vi: String { return self._s[1951]! } - public var UserInfo_ScamUserWarning: String { return self._s[1952]! } - public var Conversation_Search: String { return self._s[1953]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1955]! } - public var ReportPeer_ReasonPornography: String { return self._s[1956]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[1957]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1958]! } - public var Map_LiveLocationGroupDescription: String { return self._s[1959]! } - public var Channel_Setup_TypeHeader: String { return self._s[1960]! } - public var AuthSessions_LoggedIn: String { return self._s[1961]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1962]! } - public var Login_SmsRequestState3: String { return self._s[1963]! } - public var Passport_Address_EditUtilityBill: String { return self._s[1964]! } - public var Appearance_ReduceMotionInfo: String { return self._s[1965]! } - public var Join_ChannelsTooMuch: String { return self._s[1966]! } - public var Channel_Edit_LinkItem: String { return self._s[1967]! } - public var Privacy_Calls_P2PNever: String { return self._s[1968]! } - public var Conversation_AddToReadingList: String { return self._s[1970]! } - public var Share_MultipleMessagesDisabled: String { return self._s[1971]! } - public var Message_Animation: String { return self._s[1972]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[1973]! } - public var Map_Unknown: String { return self._s[1974]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[1975]! } + public var IntentsSettings_Reset: String { return self._s[1948]! } + public var Conversation_Info: String { return self._s[1949]! } + public var Login_InfoDeletePhoto: String { return self._s[1950]! } + public var Passport_Language_vi: String { return self._s[1952]! } + public var UserInfo_ScamUserWarning: String { return self._s[1953]! } + public var Conversation_Search: String { return self._s[1954]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[1956]! } + public var ReportPeer_ReasonPornography: String { return self._s[1957]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[1958]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[1959]! } + public var Map_LiveLocationGroupDescription: String { return self._s[1960]! } + public var Channel_Setup_TypeHeader: String { return self._s[1961]! } + public var AuthSessions_LoggedIn: String { return self._s[1962]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[1963]! } + public var Login_SmsRequestState3: String { return self._s[1964]! } + public var Passport_Address_EditUtilityBill: String { return self._s[1965]! } + public var Appearance_ReduceMotionInfo: String { return self._s[1966]! } + public var Join_ChannelsTooMuch: String { return self._s[1967]! } + public var Channel_Edit_LinkItem: String { return self._s[1968]! } + public var Privacy_Calls_P2PNever: String { return self._s[1969]! } + public var Conversation_AddToReadingList: String { return self._s[1971]! } + public var Share_MultipleMessagesDisabled: String { return self._s[1972]! } + public var Message_Animation: String { return self._s[1973]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[1974]! } + public var Map_Unknown: String { return self._s[1975]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[1976]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1976]!, self._r[1976]!, [_1, _2]) - } - public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1977]!, self._r[1977]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[1978]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[1979]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1980]! } + public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1978]!, self._r[1978]!, [_1, _2]) + } + public var Call_StatusRequesting: String { return self._s[1979]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[1980]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[1981]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1981]!, self._r[1981]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1982]!, self._r[1982]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1982]!, self._r[1982]!, [_0]) + return formatWithArgumentRanges(self._s[1983]!, self._r[1983]!, [_0]) } - public var Update_Skip: String { return self._s[1983]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1984]! } - public var Message_PinnedPollMessage: String { return self._s[1985]! } - public var BlockedUsers_Title: String { return self._s[1986]! } + public var Update_Skip: String { return self._s[1984]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[1985]! } + public var Message_PinnedPollMessage: String { return self._s[1986]! } + public var BlockedUsers_Title: String { return self._s[1987]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1987]!, self._r[1987]!, [_1]) + return formatWithArgumentRanges(self._s[1988]!, self._r[1988]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[1988]! } - public var NotificationsSound_Bell: String { return self._s[1989]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[1990]! } - public var Weekday_Monday: String { return self._s[1991]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1992]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1993]! } - public var ChatSettings_Groups: String { return self._s[1994]! } + public var Username_CheckingUsername: String { return self._s[1989]! } + public var NotificationsSound_Bell: String { return self._s[1990]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[1991]! } + public var Weekday_Monday: String { return self._s[1992]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[1993]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[1994]! } + public var ChatSettings_Groups: String { return self._s[1995]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[1996]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1995]!, self._r[1995]!, [_0]) + return formatWithArgumentRanges(self._s[1997]!, self._r[1997]!, [_0]) } - public var Your_card_was_declined: String { return self._s[1996]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[1998]! } - public var Wallet_Month_ShortApril: String { return self._s[1999]! } - public var ChatList_Unmute: String { return self._s[2000]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2001]! } - public var PhotoEditor_CurvesAll: String { return self._s[2002]! } - public var Weekday_ShortTuesday: String { return self._s[2003]! } - public var DialogList_Read: String { return self._s[2004]! } - public var Appearance_AppIconClassic: String { return self._s[2005]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2006]! } - public var Passport_Identity_Gender: String { return self._s[2007]! } + public var Your_card_was_declined: String { return self._s[1998]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2000]! } + public var Wallet_Month_ShortApril: String { return self._s[2001]! } + public var ChatList_Unmute: String { return self._s[2002]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2003]! } + public var PhotoEditor_CurvesAll: String { return self._s[2004]! } + public var Weekday_ShortTuesday: String { return self._s[2005]! } + public var DialogList_Read: String { return self._s[2006]! } + public var Appearance_AppIconClassic: String { return self._s[2007]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2008]! } + public var Passport_Identity_Gender: String { return self._s[2009]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2008]!, self._r[2008]!, [_0]) + return formatWithArgumentRanges(self._s[2010]!, self._r[2010]!, [_0]) } - public var Target_SelectGroup: String { return self._s[2009]! } - public var Map_HomeAndWorkInfo: String { return self._s[2011]! } + public var Target_SelectGroup: String { return self._s[2011]! } + public var Map_HomeAndWorkInfo: String { return self._s[2013]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2012]!, self._r[2012]!, [_0]) + return formatWithArgumentRanges(self._s[2014]!, self._r[2014]!, [_0]) } - public var Passport_Language_en: String { return self._s[2013]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2014]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2015]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[2016]! } - public var ScheduledMessages_SendNow: String { return self._s[2017]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[2019]! } - public var Login_InfoHelp: String { return self._s[2020]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2021]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2022]! } + public var Passport_Language_en: String { return self._s[2015]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2016]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2017]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2018]! } + public var ScheduledMessages_SendNow: String { return self._s[2019]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2021]! } + public var Login_InfoHelp: String { return self._s[2022]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2023]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2024]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2023]!, self._r[2023]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2025]!, self._r[2025]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2026]! } - public var CreatePoll_Title: String { return self._s[2027]! } - public var Conversation_ViewTheme: String { return self._s[2028]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2029]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2030]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2031]! } - public var UserInfo_GroupsInCommon: String { return self._s[2032]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2033]! } - public var Call_AudioRouteHide: String { return self._s[2034]! } + public var SocksProxySetup_AddProxy: String { return self._s[2028]! } + public var CreatePoll_Title: String { return self._s[2029]! } + public var Conversation_ViewTheme: String { return self._s[2030]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2031]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2032]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2033]! } + public var UserInfo_GroupsInCommon: String { return self._s[2034]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2035]! } + public var Call_AudioRouteHide: String { return self._s[2036]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2036]!, self._r[2036]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2038]!, self._r[2038]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2037]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2038]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2039]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2040]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2039]!, self._r[2039]!, [_0]) + return formatWithArgumentRanges(self._s[2041]!, self._r[2041]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2040]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2041]! } - public var Notifications_Title: String { return self._s[2042]! } - public var Group_Username_InvalidTooShort: String { return self._s[2043]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2044]! } + public var TextFormat_Bold: String { return self._s[2042]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2043]! } + public var Notifications_Title: String { return self._s[2044]! } + public var Group_Username_InvalidTooShort: String { return self._s[2045]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2046]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2045]!, self._r[2045]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2047]!, self._r[2047]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2047]! } - public var Stickers_SuggestAdded: String { return self._s[2048]! } - public var Login_CountryCode: String { return self._s[2049]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2050]! } - public var Map_GetDirections: String { return self._s[2051]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2052]! } - public var Login_PhoneFloodError: String { return self._s[2053]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2049]! } + public var Stickers_SuggestAdded: String { return self._s[2050]! } + public var Login_CountryCode: String { return self._s[2051]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2052]! } + public var Map_GetDirections: String { return self._s[2053]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2054]! } + public var Login_PhoneFloodError: String { return self._s[2055]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2054]!, self._r[2054]!, [_0]) + return formatWithArgumentRanges(self._s[2056]!, self._r[2056]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2055]!, self._r[2055]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2057]!, self._r[2057]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2056]! } - public var Settings_SetUsername: String { return self._s[2058]! } - public var Group_Location_ChangeLocation: String { return self._s[2059]! } - public var Notification_GroupInviterSelf: String { return self._s[2060]! } - public var InstantPage_TapToOpenLink: String { return self._s[2061]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2058]! } + public var Settings_SetUsername: String { return self._s[2060]! } + public var Group_Location_ChangeLocation: String { return self._s[2061]! } + public var Notification_GroupInviterSelf: String { return self._s[2062]! } + public var InstantPage_TapToOpenLink: String { return self._s[2063]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2062]!, self._r[2062]!, [_0]) + return formatWithArgumentRanges(self._s[2064]!, self._r[2064]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2063]! } - public var SecretChat_Title: String { return self._s[2064]! } - public var Group_UpgradeNoticeText1: String { return self._s[2065]! } - public var AuthSessions_Title: String { return self._s[2066]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2065]! } + public var SecretChat_Title: String { return self._s[2066]! } + public var Group_UpgradeNoticeText1: String { return self._s[2067]! } + public var AuthSessions_Title: String { return self._s[2068]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2067]!, self._r[2067]!, [_0]) + return formatWithArgumentRanges(self._s[2069]!, self._r[2069]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2068]! } - public var Channel_About_Title: String { return self._s[2069]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2070]! } + public var PhotoEditor_CropAuto: String { return self._s[2070]! } + public var Channel_About_Title: String { return self._s[2071]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2072]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2072]!, self._r[2072]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2074]!, self._r[2074]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2073]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2075]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2076]! } + public var VoiceOver_MessageContextReport: String { return self._s[2075]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2077]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2078]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2077]!, self._r[2077]!, [_1]) + return formatWithArgumentRanges(self._s[2079]!, self._r[2079]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2079]!, self._r[2079]!, [_0]) + return formatWithArgumentRanges(self._s[2081]!, self._r[2081]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2080]!, self._r[2080]!, [_0]) + return formatWithArgumentRanges(self._s[2082]!, self._r[2082]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2081]! } - public var Presence_online: String { return self._s[2084]! } - public var PasscodeSettings_Title: String { return self._s[2085]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2086]! } - public var Web_OpenExternal: String { return self._s[2087]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2089]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2090]! } - public var LocalGroup_Title: String { return self._s[2091]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2083]! } + public var Presence_online: String { return self._s[2086]! } + public var PasscodeSettings_Title: String { return self._s[2087]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2088]! } + public var Web_OpenExternal: String { return self._s[2089]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2091]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2092]! } + public var LocalGroup_Title: String { return self._s[2093]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2092]!, self._r[2092]!, [_0]) + return formatWithArgumentRanges(self._s[2094]!, self._r[2094]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2093]! } - public var Map_YouAreHere: String { return self._s[2094]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2095]! } + public var Map_YouAreHere: String { return self._s[2096]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2095]!, self._r[2095]!, [_0]) + return formatWithArgumentRanges(self._s[2097]!, self._r[2097]!, [_0]) } public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2096]!, self._r[2096]!, [_0]) + return formatWithArgumentRanges(self._s[2098]!, self._r[2098]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[2097]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2098]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2099]! } + public var Theme_Context_ChangeColors: String { return self._s[2099]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2100]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2101]! } public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2100]!, self._r[2100]!, [_0]) + return formatWithArgumentRanges(self._s[2102]!, self._r[2102]!, [_0]) } public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_0]) + return formatWithArgumentRanges(self._s[2103]!, self._r[2103]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[2102]! } - public var Bot_Start: String { return self._s[2103]! } + public var SocksProxySetup_Username: String { return self._s[2104]! } + public var Bot_Start: String { return self._s[2105]! } public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_0]) + return formatWithArgumentRanges(self._s[2106]!, self._r[2106]!, [_0]) } public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2105]!, self._r[2105]!, [_0]) + return formatWithArgumentRanges(self._s[2107]!, self._r[2107]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[2106]! } - public var AccentColor_Title: String { return self._s[2108]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2109]! } + public var Contacts_SortByPresence: String { return self._s[2108]! } + public var AccentColor_Title: String { return self._s[2110]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2111]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2110]!, self._r[2110]!, [_1, _2]) - } - public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2111]!, self._r[2111]!, [_0]) - } - public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[2113]! } - public var Login_InfoAvatarPhoto: String { return self._s[2114]! } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2115]! } - public var Tour_Title4: String { return self._s[2116]! } - public var Passport_Identity_Translation: String { return self._s[2117]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2118]! } - public var Login_TermsOfServiceLabel: String { return self._s[2120]! } - public var Passport_Language_it: String { return self._s[2121]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2122]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2123]! } - public var Conversation_ClearAll: String { return self._s[2125]! } - public var Wallet_Send_UninitializedText: String { return self._s[2127]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2128]! } - public var TwoStepAuth_FloodError: String { return self._s[2129]! } + public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2113]!, self._r[2113]!, [_0]) + } + public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2114]!, self._r[2114]!, [_1, _2]) + } + public var Passport_Email_EnterOtherEmail: String { return self._s[2115]! } + public var Login_InfoAvatarPhoto: String { return self._s[2116]! } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2117]! } + public var Tour_Title4: String { return self._s[2118]! } + public var Passport_Identity_Translation: String { return self._s[2119]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2120]! } + public var Login_TermsOfServiceLabel: String { return self._s[2122]! } + public var Passport_Language_it: String { return self._s[2123]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2124]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2125]! } + public var Conversation_ClearAll: String { return self._s[2127]! } + public var Wallet_Send_UninitializedText: String { return self._s[2129]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2130]! } + public var TwoStepAuth_FloodError: String { return self._s[2131]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2130]!, self._r[2130]!, [_1]) + return formatWithArgumentRanges(self._s[2132]!, self._r[2132]!, [_1]) } - public var Paint_Delete: String { return self._s[2131]! } + public var Paint_Delete: String { return self._s[2133]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2132]!, self._r[2132]!, [_0]) + return formatWithArgumentRanges(self._s[2134]!, self._r[2134]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2133]! } + public var Privacy_AddNewPeer: String { return self._s[2135]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2134]!, self._r[2134]!, [_1]) + return formatWithArgumentRanges(self._s[2136]!, self._r[2136]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2135]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2137]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2136]!, self._r[2136]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2138]!, self._r[2138]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2137]! } + public var Message_PinnedAudioMessage: String { return self._s[2139]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2138]!, self._r[2138]!, [_0]) + return formatWithArgumentRanges(self._s[2140]!, self._r[2140]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2139]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2140]! } - public var Wallet_Month_GenNovember: String { return self._s[2141]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2142]! } - public var Conversation_MessageEditedLabel: String { return self._s[2143]! } + public var Notification_Mute1hMin: String { return self._s[2141]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2142]! } + public var Wallet_Month_GenNovember: String { return self._s[2143]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2144]! } + public var Conversation_MessageEditedLabel: String { return self._s[2145]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2144]!, self._r[2144]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2146]!, self._r[2146]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2145]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2146]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2147]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2148]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2147]!, self._r[2147]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2149]!, self._r[2149]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2148]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2150]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2149]!, self._r[2149]!, [_1]) + return formatWithArgumentRanges(self._s[2151]!, self._r[2151]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2150]! } - public var Month_GenOctober: String { return self._s[2151]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2152]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2153]! } - public var MediaPicker_TimerTooltip: String { return self._s[2155]! } - public var SharedMedia_TitleAll: String { return self._s[2156]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2159]! } - public var Conversation_RestrictedMedia: String { return self._s[2160]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2161]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2163]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2164]! } + public var AccessDenied_LocationTracking: String { return self._s[2152]! } + public var Month_GenOctober: String { return self._s[2153]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2154]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2155]! } + public var MediaPicker_TimerTooltip: String { return self._s[2157]! } + public var SharedMedia_TitleAll: String { return self._s[2158]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2161]! } + public var Conversation_RestrictedMedia: String { return self._s[2162]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2163]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2165]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2166]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2165]!, self._r[2165]!, [_0]) + return formatWithArgumentRanges(self._s[2167]!, self._r[2167]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2168]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2170]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2171]! } + public var Conversation_SavedMessages: String { return self._s[2170]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2172]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2173]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2173]!, self._r[2173]!, [_0]) - } - public var VoiceOver_Chat_YourMessage: String { return self._s[2174]! } - public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2175]!, self._r[2175]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[2176]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2177]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2176]! } + public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2177]!, self._r[2177]!, [_0]) + } + public var ReportPeer_AlertSuccess: String { return self._s[2178]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2179]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2178]!, self._r[2178]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2180]!, self._r[2180]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2179]! } - public var PhotoEditor_FadeTool: String { return self._s[2180]! } - public var Privacy_ContactsReset: String { return self._s[2181]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2181]! } + public var PhotoEditor_FadeTool: String { return self._s[2182]! } + public var Privacy_ContactsReset: String { return self._s[2183]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2183]!, self._r[2183]!, [_0]) + return formatWithArgumentRanges(self._s[2185]!, self._r[2185]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2184]! } - public var ChatList_Mute: String { return self._s[2185]! } + public var Message_PinnedVideoMessage: String { return self._s[2186]! } + public var ChatList_Mute: String { return self._s[2187]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2186]!, self._r[2186]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2188]!, self._r[2188]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2187]! } - public var ShareMenu_SelectChats: String { return self._s[2190]! } - public var ChatList_Context_Unarchive: String { return self._s[2191]! } - public var MusicPlayer_VoiceNote: String { return self._s[2192]! } - public var Conversation_RestrictedText: String { return self._s[2193]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2194]! } - public var Wallet_Month_GenApril: String { return self._s[2195]! } - public var Wallet_Month_ShortMarch: String { return self._s[2196]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2197]! } - public var Cache_Videos: String { return self._s[2198]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2199]! } - public var Wallet_Month_GenFebruary: String { return self._s[2200]! } - public var FeatureDisabled_Oops: String { return self._s[2202]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2203]! } + public var Permissions_CellularDataText_v0: String { return self._s[2189]! } + public var ShareMenu_SelectChats: String { return self._s[2192]! } + public var ChatList_Context_Unarchive: String { return self._s[2193]! } + public var MusicPlayer_VoiceNote: String { return self._s[2194]! } + public var Conversation_RestrictedText: String { return self._s[2195]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2196]! } + public var Wallet_Month_GenApril: String { return self._s[2197]! } + public var Wallet_Month_ShortMarch: String { return self._s[2198]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2199]! } + public var Cache_Videos: String { return self._s[2200]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2201]! } + public var Wallet_Month_GenFebruary: String { return self._s[2202]! } + public var FeatureDisabled_Oops: String { return self._s[2204]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2205]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2204]!, self._r[2204]!, [_0]) + return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2205]! } - public var GroupPermission_NoSendPolls: String { return self._s[2206]! } - public var Wallet_Qr_ScanCode: String { return self._s[2207]! } - public var Message_VideoExpired: String { return self._s[2209]! } - public var Notifications_Badge: String { return self._s[2210]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2211]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2212]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2213]! } - public var Username_InvalidTooShort: String { return self._s[2214]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2215]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2216]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2217]! } + public var Stickers_GroupStickersHelp: String { return self._s[2207]! } + public var GroupPermission_NoSendPolls: String { return self._s[2208]! } + public var Wallet_Qr_ScanCode: String { return self._s[2209]! } + public var Message_VideoExpired: String { return self._s[2211]! } + public var Notifications_Badge: String { return self._s[2212]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2213]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2214]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2215]! } + public var Username_InvalidTooShort: String { return self._s[2216]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2217]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2218]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2219]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2218]!, self._r[2218]!, [_1]) + return formatWithArgumentRanges(self._s[2220]!, self._r[2220]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2219]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2220]! } - public var SharedMedia_CategoryDocs: String { return self._s[2223]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2221]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2222]! } + public var SharedMedia_CategoryDocs: String { return self._s[2225]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2224]!, self._r[2224]!, [_1]) + return formatWithArgumentRanges(self._s[2226]!, self._r[2226]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2225]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2227]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2227]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2229]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2228]!, self._r[2228]!, [_1]) + return formatWithArgumentRanges(self._s[2230]!, self._r[2230]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2229]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2231]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2230]!, self._r[2230]!, [_0]) + return formatWithArgumentRanges(self._s[2232]!, self._r[2232]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2231]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2232]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2233]! } - public var Channel_UpdatePhotoItem: String { return self._s[2234]! } - public var GroupInfo_LeftStatus: String { return self._s[2235]! } - public var Watch_MessageView_Forward: String { return self._s[2237]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2238]! } - public var Cache_ClearEmpty: String { return self._s[2240]! } - public var Localization_LanguageName: String { return self._s[2241]! } - public var Wallet_AccessDenied_Title: String { return self._s[2242]! } - public var WebSearch_GIFs: String { return self._s[2243]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2244]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2245]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2246]! } - public var Common_Back: String { return self._s[2247]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2248]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2249]! } - public var Wallet_Send_Send: String { return self._s[2250]! } + public var ChatSettings_PrivateChats: String { return self._s[2233]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2234]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2235]! } + public var Channel_UpdatePhotoItem: String { return self._s[2236]! } + public var GroupInfo_LeftStatus: String { return self._s[2237]! } + public var Watch_MessageView_Forward: String { return self._s[2239]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2240]! } + public var Cache_ClearEmpty: String { return self._s[2242]! } + public var Localization_LanguageName: String { return self._s[2243]! } + public var Wallet_AccessDenied_Title: String { return self._s[2244]! } + public var WebSearch_GIFs: String { return self._s[2245]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2246]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2247]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2248]! } + public var Common_Back: String { return self._s[2249]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2250]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2251]! } + public var Wallet_Send_Send: String { return self._s[2252]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2252]!, self._r[2252]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2254]!, self._r[2254]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2253]! } - public var Wallet_Month_GenJune: String { return self._s[2254]! } - public var Passport_Email_Help: String { return self._s[2255]! } - public var Watch_Conversation_Reply: String { return self._s[2257]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2260]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2261]! } - public var Channel_BanUser_Unban: String { return self._s[2263]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2264]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2265]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2267]! } - public var Wallet_Send_AddressHeader: String { return self._s[2268]! } - public var Passport_Identity_Name: String { return self._s[2269]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2255]! } + public var Wallet_Month_GenJune: String { return self._s[2256]! } + public var Passport_Email_Help: String { return self._s[2257]! } + public var Watch_Conversation_Reply: String { return self._s[2259]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2262]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2263]! } + public var Channel_BanUser_Unban: String { return self._s[2265]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2266]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2267]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2269]! } + public var Wallet_Send_AddressHeader: String { return self._s[2270]! } + public var Passport_Identity_Name: String { return self._s[2271]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2270]!, self._r[2270]!, [_0]) + return formatWithArgumentRanges(self._s[2272]!, self._r[2272]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2271]! } - public var Conversation_BlockUser: String { return self._s[2272]! } - public var Month_GenJanuary: String { return self._s[2273]! } - public var ChatSettings_TextSize: String { return self._s[2274]! } - public var Notification_PassportValuePhone: String { return self._s[2275]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2276]! } - public var Passport_Language_ne: String { return self._s[2277]! } - public var Notification_CallBack: String { return self._s[2278]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2279]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2280]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2273]! } + public var Conversation_BlockUser: String { return self._s[2274]! } + public var Month_GenJanuary: String { return self._s[2275]! } + public var ChatSettings_TextSize: String { return self._s[2276]! } + public var Notification_PassportValuePhone: String { return self._s[2277]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2278]! } + public var Passport_Language_ne: String { return self._s[2279]! } + public var Notification_CallBack: String { return self._s[2280]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2281]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2282]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2281]!, self._r[2281]!, [_0]) + return formatWithArgumentRanges(self._s[2283]!, self._r[2283]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2282]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2283]! } - public var Stickers_FrequentlyUsed: String { return self._s[2284]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2285]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2287]! } + public var Channel_Info_Management: String { return self._s[2284]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2285]! } + public var Stickers_FrequentlyUsed: String { return self._s[2286]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2287]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2289]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2288]!, self._r[2288]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2289]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2290]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2291]! } - public var CreatePoll_TextHeader: String { return self._s[2292]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2291]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2292]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2293]! } + public var CreatePoll_TextHeader: String { return self._s[2294]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2293]!, self._r[2293]!, [_0]) + return formatWithArgumentRanges(self._s[2295]!, self._r[2295]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2294]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2295]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2297]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2298]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2299]! } + public var PhotoEditor_QualityMedium: String { return self._s[2296]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2297]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2299]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2300]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2301]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2300]!, self._r[2300]!, [_0]) + return formatWithArgumentRanges(self._s[2302]!, self._r[2302]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2301]!, self._r[2301]!, [_1]) + return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2302]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2303]! } - public var Conversation_LinkDialogOpen: String { return self._s[2305]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2306]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2307]! } - public var Settings_Username: String { return self._s[2309]! } - public var Conversation_Block: String { return self._s[2311]! } - public var Wallpaper_Wallpaper: String { return self._s[2312]! } - public var SocksProxySetup_UseProxy: String { return self._s[2314]! } - public var Wallet_Send_Confirmation: String { return self._s[2315]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2316]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2317]! } - public var MessageTimer_Forever: String { return self._s[2318]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2319]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2320]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2321]! } - public var Passport_Language_da: String { return self._s[2322]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2323]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2304]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2305]! } + public var Conversation_LinkDialogOpen: String { return self._s[2307]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2308]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2309]! } + public var Settings_Username: String { return self._s[2311]! } + public var Conversation_Block: String { return self._s[2313]! } + public var Wallpaper_Wallpaper: String { return self._s[2314]! } + public var SocksProxySetup_UseProxy: String { return self._s[2316]! } + public var Wallet_Send_Confirmation: String { return self._s[2317]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2318]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2319]! } + public var MessageTimer_Forever: String { return self._s[2320]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2321]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2322]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2323]! } + public var Passport_Language_da: String { return self._s[2324]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2325]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_0]) + return formatWithArgumentRanges(self._s[2326]!, self._r[2326]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2325]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2327]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _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 Settings_AddDevice: String { return self._s[2328]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2330]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2331]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2332]! } - public var Conversation_PinnedPoll: String { return self._s[2333]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2334]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2335]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2336]! } + public var Settings_AddDevice: String { return self._s[2330]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2332]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2333]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2334]! } + public var Conversation_PinnedPoll: String { return self._s[2335]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2336]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2337]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2338]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2337]!, self._r[2337]!, [_1]) + return formatWithArgumentRanges(self._s[2339]!, self._r[2339]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2338]! } - public var Cache_ByPeerHeader: String { return self._s[2339]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2340]! } + public var Cache_ByPeerHeader: String { return self._s[2341]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2340]!, self._r[2340]!, [_0]) + return formatWithArgumentRanges(self._s[2342]!, self._r[2342]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2341]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2344]! } - public var Wallet_Completed_Title: String { return self._s[2345]! } - public var Notification_PinnedMessage: String { return self._s[2346]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2347]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2349]! } - public var Contacts_SortBy: String { return self._s[2350]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2343]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2346]! } + public var Wallet_Completed_Title: String { return self._s[2347]! } + public var Notification_PinnedMessage: String { return self._s[2348]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2349]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2351]! } + public var Contacts_SortBy: String { return self._s[2352]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2351]!, self._r[2351]!, [_1]) + return formatWithArgumentRanges(self._s[2353]!, self._r[2353]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2353]! } + public var Appearance_ColorThemeNight: String { return self._s[2355]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2354]!, self._r[2354]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2356]!, self._r[2356]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2355]! } - public var Watch_UserInfo_Service: String { return self._s[2356]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2358]! } - public var Conversation_Unpin: String { return self._s[2360]! } - public var CancelResetAccount_Title: String { return self._s[2361]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2362]! } + public var Call_EncryptionKey_Title: String { return self._s[2357]! } + public var Watch_UserInfo_Service: String { return self._s[2358]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2360]! } + public var Conversation_Unpin: String { return self._s[2362]! } + public var CancelResetAccount_Title: String { return self._s[2363]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2364]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2364]!, self._r[2364]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2366]!, self._r[2366]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2365]! } - public var CallSettings_Title: String { return self._s[2366]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2367]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2369]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2370]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2367]! } + public var CallSettings_Title: String { return self._s[2368]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2369]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2371]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2372]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2371]!, self._r[2371]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_1, _2]) } - public var Passport_Identity_DocumentDetails: String { return self._s[2372]! } - public var LoginPassword_PasswordHelp: String { return self._s[2373]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2374]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2375]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2376]! } - public var Checkout_TotalPaidAmount: String { return self._s[2377]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2374]! } + public var LoginPassword_PasswordHelp: String { return self._s[2375]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2376]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2377]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2378]! } + public var Checkout_TotalPaidAmount: String { return self._s[2379]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2378]!, self._r[2378]!, [_0]) + return formatWithArgumentRanges(self._s[2380]!, self._r[2380]!, [_0]) } - public var PasscodeSettings_ChangePasscode: String { return self._s[2379]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2381]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2382]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2381]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2383]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2384]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2383]!, self._r[2383]!, [_1]) + return formatWithArgumentRanges(self._s[2385]!, self._r[2385]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2384]! } - public var Contacts_InviteFriends: String { return self._s[2386]! } - public var Map_ChooseLocationTitle: String { return self._s[2387]! } - public var Conversation_StopPoll: String { return self._s[2389]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2386]! } + public var Contacts_InviteFriends: String { return self._s[2388]! } + public var Map_ChooseLocationTitle: String { return self._s[2389]! } + public var Conversation_StopPoll: String { return self._s[2391]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2390]!, self._r[2390]!, [_0]) + return formatWithArgumentRanges(self._s[2392]!, self._r[2392]!, [_0]) } - public var Call_Camera: String { return self._s[2391]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2392]! } - public var AppWallet_Intro_Text: String { return self._s[2393]! } - public var Calls_RatingFeedback: String { return self._s[2394]! } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2395]! } - public var Wallet_Alert_OK: String { return self._s[2396]! } - public var NotificationsSound_Pulse: String { return self._s[2397]! } - public var Watch_LastSeen_Lately: String { return self._s[2398]! } - public var ReportGroupLocation_Report: String { return self._s[2401]! } - public var Widget_NoUsers: String { return self._s[2402]! } - public var Conversation_UnvotePoll: String { return self._s[2403]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2405]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2406]! } - public var NotificationsSound_Circles: String { return self._s[2407]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2410]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2411]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2412]! } - public var Proxy_TooltipUnavailable: String { return self._s[2413]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2415]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2417]! } - public var Conversation_FileDropbox: String { return self._s[2418]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2419]! } - public var Tour_Text3: String { return self._s[2421]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2423]! } - public var GroupPermission_NoSendMessages: String { return self._s[2424]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2425]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2426]! } + public var Call_Camera: String { return self._s[2393]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2394]! } + public var AppWallet_Intro_Text: String { return self._s[2395]! } + public var Calls_RatingFeedback: String { return self._s[2396]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2397]! } + public var Wallet_Alert_OK: String { return self._s[2398]! } + public var NotificationsSound_Pulse: String { return self._s[2399]! } + public var Watch_LastSeen_Lately: String { return self._s[2400]! } + public var ReportGroupLocation_Report: String { return self._s[2403]! } + public var Widget_NoUsers: String { return self._s[2404]! } + public var Conversation_UnvotePoll: String { return self._s[2405]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2407]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2408]! } + public var NotificationsSound_Circles: String { return self._s[2409]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2412]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2413]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2414]! } + public var Proxy_TooltipUnavailable: String { return self._s[2415]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2417]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2419]! } + public var Conversation_FileDropbox: String { return self._s[2420]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2421]! } + public var Tour_Text3: String { return self._s[2423]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2425]! } + public var GroupPermission_NoSendMessages: String { return self._s[2426]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2427]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2428]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2428]!, self._r[2428]!, [_0]) + return formatWithArgumentRanges(self._s[2430]!, self._r[2430]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2429]! } - public var Checkout_ShippingOption_Title: String { return self._s[2430]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2431]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2431]! } + public var Checkout_ShippingOption_Title: String { return self._s[2432]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2433]! } public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2432]!, self._r[2432]!, [_0]) + return formatWithArgumentRanges(self._s[2434]!, self._r[2434]!, [_0]) } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2433]!, self._r[2433]!, [_0]) + return formatWithArgumentRanges(self._s[2435]!, self._r[2435]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2434]! } - public var EditTheme_FileReadError: String { return self._s[2435]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2436]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2437]! } - public var AutoDownloadSettings_Photos: String { return self._s[2439]! } - public var Appearance_PreviewIncomingText: String { return self._s[2440]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2441]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2442]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2443]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2444]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2445]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2446]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2447]! } - public var Notification_SecretChatScreenshot: String { return self._s[2448]! } - public var AccessDenied_Wallpapers: String { return self._s[2449]! } - public var ChatList_Context_Mute: String { return self._s[2451]! } - public var Passport_Address_City: String { return self._s[2452]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2453]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2454]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2455]! } - public var AccessDenied_LocationDisabled: String { return self._s[2456]! } - public var Group_Location_Title: String { return self._s[2457]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2459]! } - public var GroupInfo_Sound: String { return self._s[2460]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2461]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2462]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2463]! } - public var Contacts_Title: String { return self._s[2464]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2465]! } - public var Passport_Language_fr: String { return self._s[2466]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2467]! } - public var Notifications_ResetAllNotifications: String { return self._s[2468]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2470]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2472]! } - public var Checkout_NewCard_Title: String { return self._s[2473]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2474]! } - public var Conversation_ForwardChats: String { return self._s[2475]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2477]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2478]! } - public var Settings_FAQ: String { return self._s[2480]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2481]! } - public var Conversation_ContextMenuForward: String { return self._s[2482]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2485]! } - public var PrivacyPolicy_Title: String { return self._s[2488]! } - public var Notifications_TextTone: String { return self._s[2489]! } - public var Profile_CreateNewContact: String { return self._s[2490]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2491]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2493]! } - public var Call_Speaker: String { return self._s[2494]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2495]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2497]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2498]! } + public var Channel_Management_LabelAdministrator: String { return self._s[2436]! } + public var EditTheme_FileReadError: String { return self._s[2437]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2438]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2439]! } + public var AutoDownloadSettings_Photos: String { return self._s[2441]! } + public var Appearance_PreviewIncomingText: String { return self._s[2442]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2443]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2444]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2445]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2446]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2447]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2448]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2449]! } + public var Notification_SecretChatScreenshot: String { return self._s[2450]! } + public var AccessDenied_Wallpapers: String { return self._s[2451]! } + public var ChatList_Context_Mute: String { return self._s[2453]! } + public var Passport_Address_City: String { return self._s[2454]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2455]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2456]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2457]! } + public var AccessDenied_LocationDisabled: String { return self._s[2458]! } + public var Group_Location_Title: String { return self._s[2459]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2461]! } + public var GroupInfo_Sound: String { return self._s[2462]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2463]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2464]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2465]! } + public var Contacts_Title: String { return self._s[2466]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2467]! } + public var Passport_Language_fr: String { return self._s[2468]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2469]! } + public var Notifications_ResetAllNotifications: String { return self._s[2470]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2472]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2474]! } + public var Checkout_NewCard_Title: String { return self._s[2475]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2476]! } + public var Conversation_ForwardChats: String { return self._s[2477]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2479]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2480]! } + public var Settings_FAQ: String { return self._s[2482]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2483]! } + public var Conversation_ContextMenuForward: String { return self._s[2484]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2487]! } + public var PrivacyPolicy_Title: String { return self._s[2490]! } + public var Notifications_TextTone: String { return self._s[2491]! } + public var Profile_CreateNewContact: String { return self._s[2492]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2493]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2495]! } + public var Call_Speaker: String { return self._s[2496]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2497]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2499]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2500]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2499]!, self._r[2499]!, [_0]) + return formatWithArgumentRanges(self._s[2501]!, self._r[2501]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2500]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2501]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2502]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2503]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2504]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2505]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2506]! } - public var Bot_Unblock: String { return self._s[2507]! } - public var TextFormat_Italic: String { return self._s[2508]! } - public var WallpaperSearch_ColorPink: String { return self._s[2509]! } - public var Settings_About_Help: String { return self._s[2510]! } - public var SearchImages_Title: String { return self._s[2511]! } - public var Weekday_Wednesday: String { return self._s[2512]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2513]! } - public var ExplicitContent_AlertTitle: String { return self._s[2514]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2502]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2503]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2504]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2505]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2506]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2507]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2508]! } + public var Bot_Unblock: String { return self._s[2509]! } + public var TextFormat_Italic: String { return self._s[2510]! } + public var WallpaperSearch_ColorPink: String { return self._s[2511]! } + public var Settings_About_Help: String { return self._s[2512]! } + public var SearchImages_Title: String { return self._s[2513]! } + public var Weekday_Wednesday: String { return self._s[2514]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2515]! } + public var ExplicitContent_AlertTitle: String { return self._s[2516]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2515]!, self._r[2515]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2517]!, self._r[2517]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2516]! } - public var Weekday_Thursday: String { return self._s[2517]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2518]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2519]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2518]! } + public var Weekday_Thursday: String { return self._s[2519]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2520]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2521]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2520]!, self._r[2520]!, [_0]) + return formatWithArgumentRanges(self._s[2522]!, self._r[2522]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2521]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2522]! } - public var Passport_RequestedInformation: String { return self._s[2523]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2524]! } - public var Conversation_EncryptionProcessing: String { return self._s[2526]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2527]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2529]! } - public var Channel_Setup_Title: String { return self._s[2530]! } - public var Conversation_SearchPlaceholder: String { return self._s[2531]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2532]! } - public var Checkout_ErrorGeneric: String { return self._s[2533]! } - public var Passport_Language_hu: String { return self._s[2534]! } - public var GroupPermission_EditingDisabled: String { return self._s[2535]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2537]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2523]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2524]! } + public var Passport_RequestedInformation: String { return self._s[2525]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2526]! } + public var Conversation_EncryptionProcessing: String { return self._s[2528]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2529]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2531]! } + public var Channel_Setup_Title: String { return self._s[2532]! } + public var Conversation_SearchPlaceholder: String { return self._s[2533]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2534]! } + public var Checkout_ErrorGeneric: String { return self._s[2535]! } + public var Passport_Language_hu: String { return self._s[2536]! } + public var GroupPermission_EditingDisabled: String { return self._s[2537]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2539]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2538]!, self._r[2538]!, [_0]) + return formatWithArgumentRanges(self._s[2540]!, self._r[2540]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2541]!, self._r[2541]!, [_1]) + return formatWithArgumentRanges(self._s[2543]!, self._r[2543]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2542]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2544]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2543]!, self._r[2543]!, [_0]) + return formatWithArgumentRanges(self._s[2545]!, self._r[2545]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2544]! } - public var Group_Location_Info: String { return self._s[2545]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2546]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2547]! } + public var Conversation_CloudStorageInfo_Title: String { return self._s[2546]! } + public var Group_Location_Info: String { return self._s[2547]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2548]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2549]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2548]!, self._r[2548]!, [_0]) + return formatWithArgumentRanges(self._s[2550]!, self._r[2550]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2549]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2550]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2551]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2552]! } + public var Conversation_ClearPrivateHistory: String { return self._s[2551]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2552]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2553]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2554]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2553]!, self._r[2553]!, [_0]) + return formatWithArgumentRanges(self._s[2555]!, self._r[2555]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2554]! } - public var Message_PinnedAnimationMessage: String { return self._s[2556]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2558]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2559]! } - public var Wallet_Info_TransactionTo: String { return self._s[2561]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2562]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2563]! } - public var Embed_PlayingInPIP: String { return self._s[2564]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2565]! } + public var Passport_Language_cs: String { return self._s[2556]! } + public var Message_PinnedAnimationMessage: String { return self._s[2558]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2560]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2561]! } + public var Wallet_Info_TransactionTo: String { return self._s[2563]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2564]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2565]! } + public var Embed_PlayingInPIP: String { return self._s[2566]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2567]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2566]!, self._r[2566]!, [_0]) + return formatWithArgumentRanges(self._s[2568]!, self._r[2568]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2567]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2569]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2568]!, self._r[2568]!, [_1]) + return formatWithArgumentRanges(self._s[2570]!, self._r[2570]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2569]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2570]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2571]! } - public var AutoNightTheme_System: String { return self._s[2572]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2573]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2574]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2575]! } + public var Notification_PaymentSent: String { return self._s[2571]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2572]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2573]! } + public var AutoNightTheme_System: String { return self._s[2574]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2575]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2576]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2577]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2578]!, self._r[2578]!, [_1]) - } - public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2579]!, self._r[2579]!, [_1]) - } - public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2580]!, self._r[2580]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2582]! } - public var PasscodeSettings_HelpTop: String { return self._s[2583]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2584]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2585]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2586]! } - public var EditTheme_ShortLink: String { return self._s[2587]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2588]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2589]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2590]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2591]! } - public var Call_Accept: String { return self._s[2593]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2594]! } - public var Month_GenMarch: String { return self._s[2596]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2597]! } - public var LoginPassword_Title: String { return self._s[2598]! } - public var Call_End: String { return self._s[2599]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2600]! } - public var VoiceOver_Chat_Contact: String { return self._s[2601]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2602]! } - public var CallSettings_Always: String { return self._s[2603]! } - public var CallFeedback_Success: String { return self._s[2604]! } - public var TwoStepAuth_SetupHint: String { return self._s[2605]! } + public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2581]!, self._r[2581]!, [_1]) + } + public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2582]!, self._r[2582]!, [_1]) + } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2584]! } + public var PasscodeSettings_HelpTop: String { return self._s[2585]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2586]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2587]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2588]! } + public var EditTheme_ShortLink: String { return self._s[2589]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2590]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2591]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2592]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2593]! } + public var Call_Accept: String { return self._s[2595]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2596]! } + public var Month_GenMarch: String { return self._s[2598]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2599]! } + public var LoginPassword_Title: String { return self._s[2600]! } + public var Call_End: String { return self._s[2601]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2602]! } + public var VoiceOver_Chat_Contact: String { return self._s[2603]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2604]! } + public var CallSettings_Always: String { return self._s[2605]! } + public var CallFeedback_Success: String { return self._s[2606]! } + public var TwoStepAuth_SetupHint: String { return self._s[2607]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2606]!, self._r[2606]!, [_1]) + return formatWithArgumentRanges(self._s[2608]!, self._r[2608]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2607]! } - public var Login_PhoneTitle: String { return self._s[2608]! } - public var Passport_FieldPhoneHelp: String { return self._s[2609]! } - public var Weekday_ShortSunday: String { return self._s[2610]! } - public var Passport_InfoFAQ_URL: String { return self._s[2611]! } - public var ContactInfo_Job: String { return self._s[2613]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2614]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2615]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2616]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2617]! } - public var Invite_ChannelsTooMuch: String { return self._s[2618]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2619]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2620]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2621]! } - public var Wallet_Receive_AmountText: String { return self._s[2622]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2623]! } - public var CallFeedback_ReasonNoise: String { return self._s[2624]! } - public var Appearance_AppIconDefault: String { return self._s[2626]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2627]! } - public var MediaPicker_AddCaption: String { return self._s[2628]! } - public var CallSettings_TabIconDescription: String { return self._s[2629]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2609]! } + public var Login_PhoneTitle: String { return self._s[2610]! } + public var Passport_FieldPhoneHelp: String { return self._s[2611]! } + public var Weekday_ShortSunday: String { return self._s[2612]! } + public var Passport_InfoFAQ_URL: String { return self._s[2613]! } + public var ContactInfo_Job: String { return self._s[2615]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2616]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2617]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2618]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2619]! } + public var Invite_ChannelsTooMuch: String { return self._s[2620]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2621]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2622]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2623]! } + public var Wallet_Receive_AmountText: String { return self._s[2624]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2625]! } + public var CallFeedback_ReasonNoise: String { return self._s[2626]! } + public var Appearance_AppIconDefault: String { return self._s[2628]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2629]! } + public var MediaPicker_AddCaption: String { return self._s[2630]! } + public var CallSettings_TabIconDescription: String { return self._s[2631]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2630]!, self._r[2630]!, [_0]) - } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2631]! } - public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2632]!, self._r[2632]!, [_0]) } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2633]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2634]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2635]! } - public var DialogList_SearchSectionRecent: String { return self._s[2636]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2637]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2640]! } - public var LastSeen_WithinAWeek: String { return self._s[2641]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2642]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2644]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2645]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2633]! } + public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2634]!, self._r[2634]!, [_0]) + } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2635]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2636]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2637]! } + public var DialogList_SearchSectionRecent: String { return self._s[2638]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2639]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2642]! } + public var LastSeen_WithinAWeek: String { return self._s[2643]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2644]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2646]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2647]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2646]!, self._r[2646]!, [_0]) + return formatWithArgumentRanges(self._s[2648]!, self._r[2648]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2647]! } - public var Conversation_StatusLeftGroup: String { return self._s[2648]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2649]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2651]! } - public var GroupPermission_AddSuccess: String { return self._s[2652]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2654]! } - public var Conversation_ContextMenuCopy: String { return self._s[2655]! } - public var AccessDenied_CallMicrophone: String { return self._s[2656]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2649]! } + public var Conversation_StatusLeftGroup: String { return self._s[2650]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2651]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2653]! } + public var GroupPermission_AddSuccess: String { return self._s[2654]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2656]! } + public var Conversation_ContextMenuCopy: String { return self._s[2657]! } + public var AccessDenied_CallMicrophone: String { return self._s[2658]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2657]!, self._r[2657]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2659]!, self._r[2659]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2658]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2659]! } - public var Checkout_PaymentMethod_New: String { return self._s[2660]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2661]! } - public var PhotoEditor_QualityTool: String { return self._s[2662]! } - public var Login_SendCodeViaSms: String { return self._s[2663]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2664]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2665]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2666]! } - public var Login_EmailNotConfiguredError: String { return self._s[2667]! } - public var SocksProxySetup_Status: String { return self._s[2668]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2669]! } - public var PrivacyPolicy_Accept: String { return self._s[2670]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2671]! } - public var Appearance_AppIconClassicX: String { return self._s[2672]! } + public var Login_InvalidFirstNameError: String { return self._s[2660]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2661]! } + public var Checkout_PaymentMethod_New: String { return self._s[2662]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2663]! } + public var PhotoEditor_QualityTool: String { return self._s[2664]! } + public var Login_SendCodeViaSms: String { return self._s[2665]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2666]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2667]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2668]! } + public var Login_EmailNotConfiguredError: String { return self._s[2669]! } + public var SocksProxySetup_Status: String { return self._s[2670]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2671]! } + public var PrivacyPolicy_Accept: String { return self._s[2672]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2673]! } + public var Appearance_AppIconClassicX: String { return self._s[2674]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2673]!, self._r[2673]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2675]!, self._r[2675]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2674]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2676]! } - public var AutoNightTheme_Automatic: String { return self._s[2677]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2678]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2679]! } - public var Cache_Help: String { return self._s[2680]! } - public var Group_ErrorAccessDenied: String { return self._s[2681]! } - public var Passport_Language_fa: String { return self._s[2682]! } - public var Wallet_Intro_Text: String { return self._s[2683]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2684]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2685]! } - public var PrivacySettings_LastSeen: String { return self._s[2686]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2676]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2678]! } + public var AutoNightTheme_Automatic: String { return self._s[2679]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2680]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2681]! } + public var Cache_Help: String { return self._s[2682]! } + public var Group_ErrorAccessDenied: String { return self._s[2683]! } + public var Passport_Language_fa: String { return self._s[2684]! } + public var Wallet_Intro_Text: String { return self._s[2685]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2686]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2687]! } + public var PrivacySettings_LastSeen: String { return self._s[2688]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2687]!, self._r[2687]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2689]!, self._r[2689]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2691]! } - public var Preview_SaveGif: String { return self._s[2692]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2693]! } - public var Profile_About: String { return self._s[2694]! } - public var Channel_About_Placeholder: String { return self._s[2695]! } - public var Login_InfoTitle: String { return self._s[2696]! } + public var Wallet_Configuration_Apply: String { return self._s[2693]! } + public var Preview_SaveGif: String { return self._s[2694]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2695]! } + public var Profile_About: String { return self._s[2696]! } + public var Channel_About_Placeholder: String { return self._s[2697]! } + public var Login_InfoTitle: String { return self._s[2698]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2697]!, self._r[2697]!, [_0]) + return formatWithArgumentRanges(self._s[2699]!, self._r[2699]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2698]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2700]! } - public var ContactInfo_Title: String { return self._s[2701]! } - public var Media_ShareThisVideo: String { return self._s[2702]! } - public var Weekday_ShortFriday: String { return self._s[2703]! } - public var AccessDenied_Contacts: String { return self._s[2705]! } - public var Notification_CallIncomingShort: String { return self._s[2706]! } - public var Group_Setup_TypePublic: String { return self._s[2707]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2708]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2709]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2712]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2713]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2714]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2715]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2716]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2700]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2702]! } + public var ContactInfo_Title: String { return self._s[2703]! } + public var Media_ShareThisVideo: String { return self._s[2704]! } + public var Weekday_ShortFriday: String { return self._s[2705]! } + public var AccessDenied_Contacts: String { return self._s[2707]! } + public var Notification_CallIncomingShort: String { return self._s[2708]! } + public var Group_Setup_TypePublic: String { return self._s[2709]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2710]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2711]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2714]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2715]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2716]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2717]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2718]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2717]!, self._r[2717]!, [_0]) + return formatWithArgumentRanges(self._s[2719]!, self._r[2719]!, [_0]) } - public var DialogList_Typing: String { return self._s[2718]! } - public var CallFeedback_IncludeLogs: String { return self._s[2720]! } - public var Checkout_Phone: String { return self._s[2722]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2725]! } - public var Privacy_Calls_Integration: String { return self._s[2726]! } - public var Notifications_PermissionsAllow: String { return self._s[2727]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2731]! } - public var Settings_ChatSettings: String { return self._s[2732]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2733]! } + public var DialogList_Typing: String { return self._s[2720]! } + public var CallFeedback_IncludeLogs: String { return self._s[2722]! } + public var Checkout_Phone: String { return self._s[2724]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2727]! } + public var Privacy_Calls_Integration: String { return self._s[2728]! } + public var Notifications_PermissionsAllow: String { return self._s[2729]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2733]! } + public var Settings_ChatSettings: String { return self._s[2734]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2735]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2735]!, self._r[2735]!, [_0]) + return formatWithArgumentRanges(self._s[2737]!, self._r[2737]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2736]!, self._r[2736]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2738]!, self._r[2738]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2738]! } + public var GroupRemoved_DeleteUser: String { return self._s[2740]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2739]!, self._r[2739]!, [_0]) + return formatWithArgumentRanges(self._s[2741]!, self._r[2741]!, [_0]) } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2740]!, self._r[2740]!, [_1]) + return formatWithArgumentRanges(self._s[2742]!, self._r[2742]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2741]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2742]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2744]! } - public var Conversation_Unblock: String { return self._s[2745]! } - public var PrivacySettings_DataSettings: String { return self._s[2746]! } - public var Group_PublicLink_Info: String { return self._s[2747]! } + public var Login_ContinueWithLocalization: String { return self._s[2743]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2744]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2746]! } + public var Conversation_Unblock: String { return self._s[2747]! } + public var PrivacySettings_DataSettings: String { return self._s[2748]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[2749]! } + public var Group_PublicLink_Info: String { return self._s[2750]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2748]!, self._r[2748]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2749]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2752]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2750]!, self._r[2750]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2753]!, self._r[2753]!, [_0, _1]) } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2752]! } - public var PrivacySettings_Passcode: String { return self._s[2754]! } - public var Call_Mute: String { return self._s[2755]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2756]! } - public var Passport_Language_dz: String { return self._s[2757]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2758]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2759]! } - public var Passport_Language_tk: String { return self._s[2760]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2755]! } + public var PrivacySettings_Passcode: String { return self._s[2757]! } + public var Call_Mute: String { return self._s[2758]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2759]! } + public var Passport_Language_dz: String { return self._s[2760]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2761]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2762]! } + public var Passport_Language_tk: String { return self._s[2763]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2761]!, self._r[2761]!, [_0]) + return formatWithArgumentRanges(self._s[2764]!, self._r[2764]!, [_0]) } - public var Settings_Search: String { return self._s[2762]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2763]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2764]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2765]! } - public var Conversation_ContextMenuReply: String { return self._s[2766]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2767]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2768]! } - public var Tour_Title1: String { return self._s[2769]! } - public var Wallet_Alert_Cancel: String { return self._s[2770]! } - public var Conversation_ClearGroupHistory: String { return self._s[2772]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2773]! } - public var WallpaperPreview_Motion: String { return self._s[2774]! } + public var Settings_Search: String { return self._s[2765]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2766]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2767]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2768]! } + public var Conversation_ContextMenuReply: String { return self._s[2769]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2770]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2771]! } + public var Tour_Title1: String { return self._s[2772]! } + public var Wallet_Alert_Cancel: String { return self._s[2773]! } + public var Conversation_ClearGroupHistory: String { return self._s[2775]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2776]! } + public var WallpaperPreview_Motion: String { return self._s[2777]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2775]!, self._r[2775]!, [_0]) + return formatWithArgumentRanges(self._s[2778]!, self._r[2778]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2776]! } - public var Call_RateCall: String { return self._s[2777]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2778]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2779]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2780]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2782]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2779]! } + public var Call_RateCall: String { return self._s[2780]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2781]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2782]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2783]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2785]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2784]!, self._r[2784]!, [_0]) + return formatWithArgumentRanges(self._s[2787]!, self._r[2787]!, [_0]) } - public var Compose_Create: String { return self._s[2785]! } - public var Contacts_InviteToTelegram: String { return self._s[2786]! } - public var GroupInfo_Notifications: String { return self._s[2787]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2789]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2790]! } - public var Month_GenApril: String { return self._s[2791]! } - public var Appearance_AutoNightTheme: String { return self._s[2792]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2794]! } - public var Login_CodeSentSms: String { return self._s[2796]! } + public var Compose_Create: String { return self._s[2788]! } + public var Contacts_InviteToTelegram: String { return self._s[2789]! } + public var GroupInfo_Notifications: String { return self._s[2790]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2792]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2793]! } + public var Month_GenApril: String { return self._s[2794]! } + public var Appearance_AutoNightTheme: String { return self._s[2795]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2797]! } + public var Login_CodeSentSms: String { return self._s[2799]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2797]!, self._r[2797]!, [_0]) + return formatWithArgumentRanges(self._s[2800]!, self._r[2800]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2798]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2799]! } - public var Passport_Language_hr: String { return self._s[2800]! } - public var Common_ActionNotAllowedError: String { return self._s[2801]! } + public var EmptyGroupInfo_Line3: String { return self._s[2801]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2802]! } + public var Passport_Language_hr: String { return self._s[2803]! } + public var Common_ActionNotAllowedError: String { return self._s[2804]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2802]!, self._r[2802]!, [_0]) + return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2803]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2804]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2805]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2806]! } - public var Privacy_SecretChatsTitle: String { return self._s[2807]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2809]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2810]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2811]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2812]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2813]! } - public var Preview_DeleteGif: String { return self._s[2814]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[2815]! } - public var Group_ErrorNotMutualContact: String { return self._s[2816]! } - public var Notification_MessageLifetime5s: String { return self._s[2817]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[2818]! } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2806]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2807]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2808]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2809]! } + public var Privacy_SecretChatsTitle: String { return self._s[2810]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2812]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2813]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2814]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2815]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2816]! } + public var Preview_DeleteGif: String { return self._s[2817]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[2818]! } + public var Group_ErrorNotMutualContact: String { return self._s[2819]! } + public var Notification_MessageLifetime5s: String { return self._s[2820]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[2821]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2819]!, self._r[2819]!, [_0]) + return formatWithArgumentRanges(self._s[2822]!, self._r[2822]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[2820]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2822]! } - public var ReportSpam_DeleteThisChat: String { return self._s[2823]! } - public var Passport_Address_AddBankStatement: String { return self._s[2824]! } - public var Notification_CallIncoming: String { return self._s[2825]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[2826]! } - public var Compose_NewGroupTitle: String { return self._s[2827]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2829]! } - public var Passport_Address_Postcode: String { return self._s[2831]! } + public var VoiceOver_Chat_Video: String { return self._s[2823]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[2825]! } + public var ReportSpam_DeleteThisChat: String { return self._s[2826]! } + public var Passport_Address_AddBankStatement: String { return self._s[2827]! } + public var Notification_CallIncoming: String { return self._s[2828]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[2829]! } + public var Compose_NewGroupTitle: String { return self._s[2830]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[2832]! } + public var Passport_Address_Postcode: String { return self._s[2834]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2832]!, self._r[2832]!, [_0]) + return formatWithArgumentRanges(self._s[2835]!, self._r[2835]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2833]! } - public var Wallet_Month_ShortOctober: String { return self._s[2834]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[2835]! } - public var WallpaperColors_Title: String { return self._s[2836]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2837]! } - public var VoiceOver_MessageContextForward: String { return self._s[2838]! } - public var GroupPermission_Duration: String { return self._s[2839]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[2836]! } + public var Wallet_Month_ShortOctober: String { return self._s[2837]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[2838]! } + public var WallpaperColors_Title: String { return self._s[2839]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[2840]! } + public var VoiceOver_MessageContextForward: String { return self._s[2841]! } + public var GroupPermission_Duration: String { return self._s[2842]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2840]!, self._r[2840]!, [_0]) + return formatWithArgumentRanges(self._s[2843]!, self._r[2843]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2841]! } - public var Username_Placeholder: String { return self._s[2842]! } - public var CallFeedback_WhatWentWrong: String { return self._s[2843]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[2844]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2845]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[2844]! } + public var Username_Placeholder: String { return self._s[2845]! } + public var CallFeedback_WhatWentWrong: String { return self._s[2846]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[2847]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[2848]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2847]!, self._r[2847]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2850]!, self._r[2850]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[2848]! } - public var Channel_MessagePhotoUpdated: String { return self._s[2849]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[2850]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2851]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[2852]! } - public var Conversation_ContextMenuMore: String { return self._s[2853]! } - public var Privacy_PaymentsClearInfo: String { return self._s[2854]! } - public var CallSettings_TabIcon: String { return self._s[2855]! } - public var KeyCommand_Find: String { return self._s[2856]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[2857]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2858]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2859]! } - public var Message_PinnedGame: String { return self._s[2860]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2861]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2863]! } - public var Login_CallRequestState2: String { return self._s[2865]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2867]! } + public var Passport_PasswordDescription: String { return self._s[2851]! } + public var Channel_MessagePhotoUpdated: String { return self._s[2852]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[2853]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[2854]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[2855]! } + public var Conversation_ContextMenuMore: String { return self._s[2856]! } + public var Privacy_PaymentsClearInfo: String { return self._s[2857]! } + public var CallSettings_TabIcon: String { return self._s[2858]! } + public var KeyCommand_Find: String { return self._s[2859]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[2860]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[2861]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[2862]! } + public var Message_PinnedGame: String { return self._s[2863]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[2864]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[2866]! } + public var Login_CallRequestState2: String { return self._s[2868]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[2870]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2868]!, self._r[2868]!, [_0]) + return formatWithArgumentRanges(self._s[2871]!, self._r[2871]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2870]!, self._r[2870]!, [_0]) + return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[2871]! } - public var WallpaperPreview_Blurred: String { return self._s[2872]! } - public var Conversation_InstantPagePreview: String { return self._s[2873]! } + public var AuthSessions_AddDevice: String { return self._s[2874]! } + public var WallpaperPreview_Blurred: String { return self._s[2875]! } + public var Conversation_InstantPagePreview: String { return self._s[2876]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2874]!, self._r[2874]!, [_0]) + return formatWithArgumentRanges(self._s[2877]!, self._r[2877]!, [_0]) } - public var SecretTimer_VideoDescription: String { return self._s[2877]! } - public var WallpaperSearch_ColorRed: String { return self._s[2878]! } - public var GroupPermission_NoPinMessages: String { return self._s[2879]! } - public var Passport_Language_es: String { return self._s[2880]! } - public var Permissions_ContactsAllow_v0: String { return self._s[2882]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2883]! } + public var SecretTimer_VideoDescription: String { return self._s[2880]! } + public var WallpaperSearch_ColorRed: String { return self._s[2881]! } + public var GroupPermission_NoPinMessages: String { return self._s[2882]! } + public var Passport_Language_es: String { return self._s[2883]! } + public var Permissions_ContactsAllow_v0: String { return self._s[2885]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[2886]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2884]!, self._r[2884]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2887]!, self._r[2887]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[2885]! } - public var WebPreview_GettingLinkInfo: String { return self._s[2886]! } - public var Watch_UserInfo_Unmute: String { return self._s[2887]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2888]! } - public var AccessDenied_CameraRestricted: String { return self._s[2890]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[2888]! } + public var WebPreview_GettingLinkInfo: String { return self._s[2889]! } + public var Watch_UserInfo_Unmute: String { return self._s[2890]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[2891]! } + public var AccessDenied_CameraRestricted: String { return self._s[2893]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2891]!, self._r[2891]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2894]!, self._r[2894]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[2893]! } - public var Settings_CopyUsername: String { return self._s[2894]! } - public var Contacts_SearchLabel: String { return self._s[2895]! } - public var Map_OpenInYandexNavigator: String { return self._s[2897]! } - public var PasscodeSettings_EncryptData: String { return self._s[2898]! } - public var Settings_Wallet: String { return self._s[2899]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2900]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[2901]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[2902]! } - public var DialogList_AdNoticeAlert: String { return self._s[2903]! } - public var Wallet_Month_GenMay: String { return self._s[2905]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2906]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2907]! } - public var Localization_LanguageCustom: String { return self._s[2908]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2909]! } - public var CallFeedback_Title: String { return self._s[2910]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2913]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2914]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[2915]! } - public var Conversation_InfoGroup: String { return self._s[2916]! } - public var Compose_NewMessage: String { return self._s[2917]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2918]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2919]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[2920]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2921]! } + public var ChatList_ReadAll: String { return self._s[2896]! } + public var Settings_CopyUsername: String { return self._s[2897]! } + public var Contacts_SearchLabel: String { return self._s[2898]! } + public var Map_OpenInYandexNavigator: String { return self._s[2900]! } + public var PasscodeSettings_EncryptData: String { return self._s[2901]! } + public var Settings_Wallet: String { return self._s[2902]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[2903]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[2904]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[2905]! } + public var DialogList_AdNoticeAlert: String { return self._s[2906]! } + public var Wallet_Month_GenMay: String { return self._s[2908]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[2909]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[2910]! } + public var Localization_LanguageCustom: String { return self._s[2911]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[2912]! } + public var CallFeedback_Title: String { return self._s[2913]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[2916]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[2917]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[2918]! } + public var Conversation_InfoGroup: String { return self._s[2919]! } + public var Compose_NewMessage: String { return self._s[2920]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[2921]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[2922]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[2923]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[2924]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2922]!, self._r[2922]!, [_0]) + return formatWithArgumentRanges(self._s[2925]!, self._r[2925]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2923]! } - public var Login_CancelSignUpConfirmation: String { return self._s[2924]! } - public var ChangePhoneNumberCode_Help: String { return self._s[2925]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[2926]! } - public var Channel_BlackList_Title: String { return self._s[2927]! } - public var UserInfo_PhoneCall: String { return self._s[2928]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2930]! } - public var Wallet_Month_ShortJanuary: String { return self._s[2931]! } - public var State_connecting: String { return self._s[2932]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2933]! } - public var Wallet_Month_GenMarch: String { return self._s[2934]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[2935]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[2926]! } + public var Login_CancelSignUpConfirmation: String { return self._s[2927]! } + public var ChangePhoneNumberCode_Help: String { return self._s[2928]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[2929]! } + public var Channel_BlackList_Title: String { return self._s[2930]! } + public var UserInfo_PhoneCall: String { return self._s[2931]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[2933]! } + public var Wallet_Month_ShortJanuary: String { return self._s[2934]! } + public var State_connecting: String { return self._s[2935]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[2936]! } + public var Wallet_Month_GenMarch: String { return self._s[2937]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[2938]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2936]!, self._r[2936]!, [_0]) + return formatWithArgumentRanges(self._s[2939]!, self._r[2939]!, [_0]) } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2937]!, self._r[2937]!, [_0]) + return formatWithArgumentRanges(self._s[2940]!, self._r[2940]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[2938]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[2939]! } - public var Passport_Identity_EditPassport: String { return self._s[2940]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[2942]! } - public var Localization_EnglishLanguageName: String { return self._s[2943]! } - public var Share_AuthDescription: String { return self._s[2944]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2945]! } - public var Passport_Identity_Surname: String { return self._s[2946]! } - public var Compose_TokenListPlaceholder: String { return self._s[2947]! } - public var Wallet_AccessDenied_Camera: String { return self._s[2948]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[2949]! } - public var Settings_AboutEmpty: String { return self._s[2950]! } - public var Conversation_Unmute: String { return self._s[2951]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[2953]! } - public var Wallet_Sending_Text: String { return self._s[2954]! } + public var Notifications_GroupNotifications: String { return self._s[2941]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[2942]! } + public var Passport_Identity_EditPassport: String { return self._s[2943]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[2945]! } + public var Localization_EnglishLanguageName: String { return self._s[2946]! } + public var Share_AuthDescription: String { return self._s[2947]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[2948]! } + public var Passport_Identity_Surname: String { return self._s[2949]! } + public var Compose_TokenListPlaceholder: String { return self._s[2950]! } + public var Wallet_AccessDenied_Camera: String { return self._s[2951]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[2952]! } + public var Settings_AboutEmpty: String { return self._s[2953]! } + public var Conversation_Unmute: String { return self._s[2954]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[2956]! } + public var Wallet_Sending_Text: String { return self._s[2957]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2955]!, self._r[2955]!, [_1]) + return formatWithArgumentRanges(self._s[2958]!, self._r[2958]!, [_1]) } - public var Login_CodeSentCall: String { return self._s[2956]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2958]! } - public var ChatSettings_Appearance: String { return self._s[2959]! } - public var ClearCache_StorageUsage: String { return self._s[2960]! } - public var Appearance_PickAccentColor: String { return self._s[2961]! } + public var Login_CodeSentCall: String { return self._s[2959]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[2961]! } + public var ChatSettings_Appearance: String { return self._s[2962]! } + public var ClearCache_StorageUsage: String { return self._s[2963]! } + public var Appearance_PickAccentColor: String { return self._s[2964]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2962]!, self._r[2962]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2965]!, self._r[2965]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2963]!, self._r[2963]!, [_1]) + return formatWithArgumentRanges(self._s[2966]!, self._r[2966]!, [_1]) } - public var Notification_CallMissed: String { return self._s[2964]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2965]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2966]! } - public var Wallet_Month_GenOctober: String { return self._s[2968]! } - public var ChatAdmins_AdminLabel: String { return self._s[2969]! } - public var KeyCommand_JumpToNextChat: String { return self._s[2970]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[2972]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2973]! } - public var Month_GenJune: String { return self._s[2974]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[2975]! } - public var Watch_Location_Current: String { return self._s[2976]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[2977]! } - public var Conversation_TitleMute: String { return self._s[2978]! } + public var Notification_CallMissed: String { return self._s[2967]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[2968]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[2969]! } + public var Wallet_Month_GenOctober: String { return self._s[2971]! } + public var ChatAdmins_AdminLabel: String { return self._s[2972]! } + public var KeyCommand_JumpToNextChat: String { return self._s[2973]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[2975]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[2976]! } + public var Month_GenJune: String { return self._s[2977]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[2978]! } + public var Watch_Location_Current: String { return self._s[2979]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[2980]! } + public var Conversation_TitleMute: String { return self._s[2981]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2979]!, self._r[2979]!, [_1]) + return formatWithArgumentRanges(self._s[2982]!, self._r[2982]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[2980]! } + public var GroupInfo_DeleteAndExit: String { return self._s[2983]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2981]!, self._r[2981]!, [_0]) + return formatWithArgumentRanges(self._s[2984]!, self._r[2984]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[2982]! } - public var Chat_SlowmodeSendError: String { return self._s[2983]! } - public var MaskStickerSettings_Info: String { return self._s[2984]! } - public var EditTheme_Expand_TopInfo: String { return self._s[2985]! } + public var Call_ReportPlaceholder: String { return self._s[2985]! } + public var Chat_SlowmodeSendError: String { return self._s[2986]! } + public var MaskStickerSettings_Info: String { return self._s[2987]! } + public var EditTheme_Expand_TopInfo: String { return self._s[2988]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_0]) + return formatWithArgumentRanges(self._s[2989]!, self._r[2989]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[2987]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[2989]! } - public var Contacts_ShareTelegram: String { return self._s[2990]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2991]! } - public var Map_AddressOnMap: String { return self._s[2992]! } - public var Channel_ErrorAccessDenied: String { return self._s[2993]! } - public var UserInfo_ScamBotWarning: String { return self._s[2995]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[2996]! } - public var Call_ConnectionErrorTitle: String { return self._s[2997]! } - public var UserInfo_NotificationsEnable: String { return self._s[2998]! } - public var ArchivedChats_IntroText1: String { return self._s[2999]! } - public var Tour_Text4: String { return self._s[3002]! } - public var WallpaperSearch_Recent: String { return self._s[3003]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3004]! } - public var Profile_MessageLifetime2s: String { return self._s[3006]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3007]! } - public var Notification_MessageLifetime2s: String { return self._s[3008]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[2990]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[2992]! } + public var Contacts_ShareTelegram: String { return self._s[2993]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[2994]! } + public var Map_AddressOnMap: String { return self._s[2995]! } + public var Channel_ErrorAccessDenied: String { return self._s[2996]! } + public var UserInfo_ScamBotWarning: String { return self._s[2998]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[2999]! } + public var Call_ConnectionErrorTitle: String { return self._s[3000]! } + public var UserInfo_NotificationsEnable: String { return self._s[3001]! } + public var ArchivedChats_IntroText1: String { return self._s[3002]! } + public var Tour_Text4: String { return self._s[3005]! } + public var WallpaperSearch_Recent: String { return self._s[3006]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3007]! } + public var Profile_MessageLifetime2s: String { return self._s[3009]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3010]! } + public var Notification_MessageLifetime2s: String { return self._s[3011]! } public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3009]!, self._r[3009]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3012]!, self._r[3012]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[3010]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3011]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3012]! } + public var Cache_ClearCache: String { return self._s[3013]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3014]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3015]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3016]!, self._r[3016]!, [_0]) + return formatWithArgumentRanges(self._s[3019]!, self._r[3019]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3018]!, self._r[3018]!, [_0]) + return formatWithArgumentRanges(self._s[3021]!, self._r[3021]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3019]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3020]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3021]! } - public var ChatList_UnarchiveAction: String { return self._s[3022]! } - public var AutoNightTheme_Title: String { return self._s[3023]! } - public var InstantPage_FeedbackButton: String { return self._s[3024]! } - public var Passport_FieldAddress: String { return self._s[3025]! } + public var LocalGroup_Text: String { return self._s[3022]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3023]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3024]! } + public var ChatList_UnarchiveAction: String { return self._s[3025]! } + public var AutoNightTheme_Title: String { return self._s[3026]! } + public var InstantPage_FeedbackButton: String { return self._s[3027]! } + public var Passport_FieldAddress: String { return self._s[3028]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3029]!, self._r[3029]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3027]! } + public var Month_ShortMarch: String { return self._s[3030]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3028]!, self._r[3028]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3031]!, self._r[3031]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3029]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3030]! } - public var Passport_FloodError: String { return self._s[3031]! } - public var SecretGif_Title: String { return self._s[3032]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3033]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3034]! } - public var Passport_Language_th: String { return self._s[3036]! } - public var Passport_Address_Address: String { return self._s[3037]! } - public var Login_InvalidLastNameError: String { return self._s[3038]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3039]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3040]! } - public var ChatList_Context_Archive: String { return self._s[3041]! } - public var SettingsSearch_FAQ: String { return self._s[3042]! } - public var ShareMenu_Send: String { return self._s[3043]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3045]! } - public var Month_GenNovember: String { return self._s[3047]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3049]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3032]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3033]! } + public var Passport_FloodError: String { return self._s[3034]! } + public var SecretGif_Title: String { return self._s[3035]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3036]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3037]! } + public var Passport_Language_th: String { return self._s[3039]! } + public var Passport_Address_Address: String { return self._s[3040]! } + public var Login_InvalidLastNameError: String { return self._s[3041]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3042]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3043]! } + public var ChatList_Context_Archive: String { return self._s[3044]! } + public var SettingsSearch_FAQ: String { return self._s[3045]! } + public var ShareMenu_Send: String { return self._s[3046]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3048]! } + public var Month_GenNovember: String { return self._s[3050]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3052]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3050]!, self._r[3050]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3053]!, self._r[3053]!, [_1, _2]) } - public var Conversation_SwipeToReplyHintText: String { return self._s[3051]! } - public var Checkout_Email: String { return self._s[3052]! } - public var NotificationsSound_Tritone: String { return self._s[3053]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3055]! } - public var Wallet_ContextMenuCopy: String { return self._s[3057]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3054]! } + public var Checkout_Email: String { return self._s[3055]! } + public var NotificationsSound_Tritone: String { return self._s[3056]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3058]! } + public var Wallet_ContextMenuCopy: String { return self._s[3060]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3059]!, self._r[3059]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3060]! } + public var Appearance_TextSize_Automatic: String { return self._s[3063]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3061]!, self._r[3061]!, [_1]) + return formatWithArgumentRanges(self._s[3064]!, self._r[3064]!, [_1]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3062]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3065]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3063]!, self._r[3063]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3066]!, self._r[3066]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3064]! } - public var Notification_Exceptions_Add: String { return self._s[3065]! } - public var DialogList_You: String { return self._s[3066]! } - public var MediaPicker_Send: String { return self._s[3069]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3070]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3071]! } - public var Call_AudioRouteSpeaker: String { return self._s[3072]! } - public var Watch_UserInfo_Title: String { return self._s[3073]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3074]! } - public var Appearance_AccentColor: String { return self._s[3076]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3067]! } + public var Notification_Exceptions_Add: String { return self._s[3068]! } + public var DialogList_You: String { return self._s[3069]! } + public var MediaPicker_Send: String { return self._s[3072]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3073]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3074]! } + public var Call_AudioRouteSpeaker: String { return self._s[3075]! } + public var Watch_UserInfo_Title: String { return self._s[3076]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3077]! } + public var Appearance_AccentColor: String { return self._s[3079]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3077]!, self._r[3077]!, [_0]) + return formatWithArgumentRanges(self._s[3080]!, self._r[3080]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3078]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3081]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3079]!, self._r[3079]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3082]!, self._r[3082]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3080]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3081]! } - public var Notification_CallOutgoing: String { return self._s[3082]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3083]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3084]! } - public var Call_RecordingDisabledMessage: String { return self._s[3085]! } - public var Message_Game: String { return self._s[3086]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3087]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3088]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3089]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3090]! } - public var Date_DialogDateFormat: String { return self._s[3091]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3092]! } - public var Notifications_InAppNotifications: String { return self._s[3093]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3083]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3084]! } + public var Notification_CallOutgoing: String { return self._s[3085]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3086]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3087]! } + public var Call_RecordingDisabledMessage: String { return self._s[3088]! } + public var Message_Game: String { return self._s[3089]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3090]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3091]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3092]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3093]! } + public var Date_DialogDateFormat: String { return self._s[3094]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3095]! } + public var Notifications_InAppNotifications: String { return self._s[3096]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3094]!, self._r[3094]!, [_0]) - } - public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3095]!, self._r[3095]!, [_1, _2]) - } - public var NewContact_Title: String { return self._s[3096]! } - public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3097]!, self._r[3097]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3098]! } + public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3098]!, self._r[3098]!, [_1, _2]) + } + public var NewContact_Title: String { return self._s[3099]! } + public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3100]!, self._r[3100]!, [_0]) + } + public var Conversation_ViewContactDetails: String { return self._s[3101]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3100]!, self._r[3100]!, [_1]) + return formatWithArgumentRanges(self._s[3103]!, self._r[3103]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3101]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3102]! } - public var PrivacySettings_Title: String { return self._s[3103]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3106]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3107]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3108]! } - public var Contacts_PhoneNumber: String { return self._s[3109]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3111]! } - public var Map_ShowPlaces: String { return self._s[3112]! } - public var ChatAdmins_Title: String { return self._s[3113]! } - public var InstantPage_Reference: String { return self._s[3115]! } - public var Wallet_Info_Updating: String { return self._s[3116]! } - public var ReportGroupLocation_Text: String { return self._s[3117]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3104]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3105]! } + public var PrivacySettings_Title: String { return self._s[3106]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3109]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3110]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3111]! } + public var Contacts_PhoneNumber: String { return self._s[3112]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3114]! } + public var Map_ShowPlaces: String { return self._s[3115]! } + public var ChatAdmins_Title: String { return self._s[3116]! } + public var InstantPage_Reference: String { return self._s[3118]! } + public var Wallet_Info_Updating: String { return self._s[3119]! } + public var ReportGroupLocation_Text: String { return self._s[3120]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3118]!, self._r[3118]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3121]!, self._r[3121]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3119]! } - public var Watch_UserInfo_Block: String { return self._s[3120]! } - public var ChatSettings_Stickers: String { return self._s[3121]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3122]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3123]! } + public var Camera_FlashOff: String { return self._s[3122]! } + public var Watch_UserInfo_Block: String { return self._s[3123]! } + public var ChatSettings_Stickers: String { return self._s[3124]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3125]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3126]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3124]!, self._r[3124]!, [_0]) + return formatWithArgumentRanges(self._s[3127]!, self._r[3127]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3125]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3126]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3127]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3128]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3129]! } - public var VoiceOver_MessageContextShare: String { return self._s[3130]! } + public var Settings_ViewPhoto: String { return self._s[3128]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3129]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3130]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3131]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3132]! } + public var VoiceOver_MessageContextShare: String { return self._s[3133]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3132]!, self._r[3132]!, [_0]) - } - public var Privacy_DeleteDrafts: String { return self._s[3133]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3134]! } - public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3135]!, self._r[3135]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3136]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3137]! } - public var DialogList_SavedMessages: String { return self._s[3138]! } - public var GroupInfo_UpgradeButton: String { return self._s[3139]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3141]! } - public var DialogList_Pin: String { return self._s[3142]! } + public var Privacy_DeleteDrafts: String { return self._s[3136]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3137]! } + public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3138]!, self._r[3138]!, [_0]) + } + public var DialogList_SavedMessagesHelp: String { return self._s[3139]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3140]! } + public var DialogList_SavedMessages: String { return self._s[3141]! } + public var GroupInfo_UpgradeButton: String { return self._s[3142]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3144]! } + public var DialogList_Pin: String { return self._s[3145]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3143]!, self._r[3143]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3146]!, self._r[3146]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3144]!, self._r[3144]!, [_0]) + return formatWithArgumentRanges(self._s[3147]!, self._r[3147]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3145]! } - public var UserInfo_NotificationsDisable: String { return self._s[3146]! } - public var Paint_Outlined: String { return self._s[3147]! } - public var Activity_PlayingGame: String { return self._s[3148]! } - public var SearchImages_NoImagesFound: String { return self._s[3149]! } - public var SocksProxySetup_ProxyType: String { return self._s[3150]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3152]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3153]! } - public var Settings_AppLanguage: String { return self._s[3154]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3155]! } - public var Common_ChoosePhoto: String { return self._s[3156]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3157]! } - public var CallFeedback_ReasonEcho: String { return self._s[3158]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3148]! } + public var UserInfo_NotificationsDisable: String { return self._s[3149]! } + public var Paint_Outlined: String { return self._s[3150]! } + public var Activity_PlayingGame: String { return self._s[3151]! } + public var SearchImages_NoImagesFound: String { return self._s[3152]! } + public var SocksProxySetup_ProxyType: String { return self._s[3153]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3155]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3156]! } + public var Settings_AppLanguage: String { return self._s[3157]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3158]! } + public var Common_ChoosePhoto: String { return self._s[3159]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3160]! } + public var CallFeedback_ReasonEcho: String { return self._s[3161]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3159]!, self._r[3159]!, [_1]) + return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3160]! } - public var Activity_UploadingVideo: String { return self._s[3161]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3162]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3163]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3164]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3165]! } - public var PUSH_SENDER_YOU: String { return self._s[3166]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3167]! } - public var Checkout_PayWithTouchId: String { return self._s[3168]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3169]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3163]! } + public var Activity_UploadingVideo: String { return self._s[3164]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3165]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3166]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3167]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3168]! } + public var PUSH_SENDER_YOU: String { return self._s[3169]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3170]! } + public var Checkout_PayWithTouchId: String { return self._s[3171]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3172]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3171]!, self._r[3171]!, [_1]) - } - public var Notifications_ExceptionsNone: String { return self._s[3172]! } - public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3173]!, self._r[3173]!, [_0]) - } - public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3174]!, self._r[3174]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3176]! } - public var Passport_Address_Region: String { return self._s[3179]! } - public var ChatList_DeleteChat: String { return self._s[3180]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3181]! } - public var PhotoEditor_TiltShift: String { return self._s[3182]! } - public var Settings_FAQ_URL: String { return self._s[3183]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3184]! } - public var Passport_Language_sl: String { return self._s[3185]! } - public var Settings_PrivacySettings: String { return self._s[3187]! } - public var SharedMedia_TitleLink: String { return self._s[3188]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3189]! } - public var Settings_SetProfilePhoto: String { return self._s[3190]! } - public var Channel_About_Help: String { return self._s[3191]! } - public var Contacts_PermissionsEnable: String { return self._s[3192]! } - public var Wallet_Sending_Title: String { return self._s[3193]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3194]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3195]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3197]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3198]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3199]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3200]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3201]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3203]! } - public var Map_OpenInYandexMaps: String { return self._s[3205]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3206]! } - public var VoiceOver_MessageContextReply: String { return self._s[3207]! } - public var PhotoEditor_SaturationTool: String { return self._s[3208]! } + public var Notifications_ExceptionsNone: String { return self._s[3175]! } + public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3176]!, self._r[3176]!, [_0]) + } + public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3177]!, self._r[3177]!, [_1]) + } + public var AuthSessions_IncompleteAttempts: String { return self._s[3179]! } + public var Passport_Address_Region: String { return self._s[3182]! } + public var ChatList_DeleteChat: String { return self._s[3183]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3184]! } + public var PhotoEditor_TiltShift: String { return self._s[3185]! } + public var Settings_FAQ_URL: String { return self._s[3186]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3187]! } + public var Passport_Language_sl: String { return self._s[3188]! } + public var Settings_PrivacySettings: String { return self._s[3190]! } + public var SharedMedia_TitleLink: String { return self._s[3191]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3192]! } + public var Settings_SetProfilePhoto: String { return self._s[3193]! } + public var Channel_About_Help: String { return self._s[3194]! } + public var Contacts_PermissionsEnable: String { return self._s[3195]! } + public var Wallet_Sending_Title: String { return self._s[3196]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3197]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3198]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3200]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3201]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3202]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3203]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3204]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3206]! } + public var Map_OpenInYandexMaps: String { return self._s[3208]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3209]! } + public var VoiceOver_MessageContextReply: String { return self._s[3210]! } + public var PhotoEditor_SaturationTool: String { return self._s[3211]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3209]!, self._r[3209]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3212]!, self._r[3212]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3210]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3211]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3212]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3213]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3214]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3215]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3213]!, self._r[3213]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3216]!, self._r[3216]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3214]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3216]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3217]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3217]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3219]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3220]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3218]!, self._r[3218]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3221]!, self._r[3221]!, [_1, _2]) } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3222]!, self._r[3222]!, [_1, _2, _3]) } - public var GroupInfo_PublicLinkAdd: String { return self._s[3220]! } - public var Passport_PassportInformation: String { return self._s[3223]! } - public var Theme_Unsupported: String { return self._s[3224]! } - public var WatchRemote_AlertTitle: String { return self._s[3225]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3226]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3228]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3223]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3224]! } + public var Passport_PassportInformation: String { return self._s[3227]! } + public var Theme_Unsupported: String { return self._s[3228]! } + public var WatchRemote_AlertTitle: String { return self._s[3229]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3230]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3232]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3229]!, self._r[3229]!, [_0]) + return formatWithArgumentRanges(self._s[3233]!, self._r[3233]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3230]!, self._r[3230]!, [_1]) + return formatWithArgumentRanges(self._s[3234]!, self._r[3234]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3231]! } - public var Wallet_Navigation_Done: String { return self._s[3233]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3234]! } - public var AccessDenied_CameraDisabled: String { return self._s[3235]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3235]! } + public var Wallet_Navigation_Done: String { return self._s[3237]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3238]! } + public var AccessDenied_CameraDisabled: String { return self._s[3239]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3236]!, self._r[3236]!, [_0]) + return formatWithArgumentRanges(self._s[3240]!, self._r[3240]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3237]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3238]! } - public var PhotoEditor_ContrastTool: String { return self._s[3241]! } + public var ClearCache_Forever: String { return self._s[3241]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3242]! } + public var PhotoEditor_ContrastTool: String { return self._s[3245]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3242]!, self._r[3242]!, [_1]) + return formatWithArgumentRanges(self._s[3246]!, self._r[3246]!, [_1]) } - public var DialogList_Draft: String { return self._s[3243]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3244]! } - public var Privacy_TopPeersDelete: String { return self._s[3246]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3247]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3248]! } - public var WebSearch_RecentSectionClear: String { return self._s[3249]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3250]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3252]! } - public var Common_Done: String { return self._s[3254]! } - public var Shortcut_SwitchAccount: String { return self._s[3255]! } - public var AuthSessions_EmptyText: String { return self._s[3256]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3257]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3258]! } - public var Tour_Title5: String { return self._s[3259]! } - public var Wallet_Settings_Title: String { return self._s[3260]! } + public var DialogList_Draft: String { return self._s[3247]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3248]! } + public var Privacy_TopPeersDelete: String { return self._s[3250]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3251]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3252]! } + public var WebSearch_RecentSectionClear: String { return self._s[3253]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3254]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3256]! } + public var Common_Done: String { return self._s[3258]! } + public var Shortcut_SwitchAccount: String { return self._s[3259]! } + public var AuthSessions_EmptyText: String { return self._s[3260]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3261]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3262]! } + public var Tour_Title5: String { return self._s[3263]! } + public var Wallet_Settings_Title: String { return self._s[3264]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3261]!, self._r[3261]!, [_0]) + return formatWithArgumentRanges(self._s[3265]!, self._r[3265]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3262]! } - public var Conversation_LinkDialogSave: String { return self._s[3263]! } - public var GroupInfo_ActionRestrict: String { return self._s[3264]! } - public var Checkout_Title: String { return self._s[3265]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3267]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3269]! } - public var Notification_RenamedGroup: String { return self._s[3270]! } - public var PeopleNearby_Groups: String { return self._s[3271]! } - public var Checkout_PayWithFaceId: String { return self._s[3272]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3273]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3275]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3276]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3277]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3266]! } + public var Conversation_LinkDialogSave: String { return self._s[3267]! } + public var GroupInfo_ActionRestrict: String { return self._s[3268]! } + public var Checkout_Title: String { return self._s[3269]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3271]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3273]! } + public var Notification_RenamedGroup: String { return self._s[3274]! } + public var PeopleNearby_Groups: String { return self._s[3275]! } + public var Checkout_PayWithFaceId: String { return self._s[3276]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3277]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3279]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3280]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3281]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3278]!, self._r[3278]!, [_0]) + return formatWithArgumentRanges(self._s[3282]!, self._r[3282]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3280]! } + public var Profile_AddToExisting: String { return self._s[3284]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3281]!, self._r[3281]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3285]!, self._r[3285]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3283]! } - public var Permissions_PrivacyPolicy: String { return self._s[3284]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3285]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3286]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3288]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3290]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3291]! } + public var Cache_Files: String { return self._s[3287]! } + public var Permissions_PrivacyPolicy: String { return self._s[3288]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3289]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3290]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3292]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3294]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3295]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3292]!, self._r[3292]!, [_0]) + return formatWithArgumentRanges(self._s[3296]!, self._r[3296]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3293]! } - public var VoiceOver_AttachMedia: String { return self._s[3295]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3296]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3297]! } + public var VoiceOver_AttachMedia: String { return self._s[3299]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3300]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3297]!, self._r[3297]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3301]!, self._r[3301]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3298]! } - public var Conversation_SetReminder_Title: String { return self._s[3299]! } - public var Passport_FieldAddressHelp: String { return self._s[3300]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3301]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3302]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3302]! } + public var Conversation_SetReminder_Title: String { return self._s[3303]! } + public var Passport_FieldAddressHelp: String { return self._s[3304]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3305]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3306]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3303]!, self._r[3303]!, [_0]) + return formatWithArgumentRanges(self._s[3307]!, self._r[3307]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3304]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3305]! } - public var Login_UnknownError: String { return self._s[3306]! } - public var Group_UpgradeNoticeText2: String { return self._s[3309]! } - public var Watch_Compose_AddContact: String { return self._s[3310]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3311]! } - public var Web_Error: String { return self._s[3312]! } - public var Gif_Search: String { return self._s[3313]! } - public var Profile_MessageLifetime1h: String { return self._s[3314]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3315]! } - public var Channel_Username_CheckingUsername: String { return self._s[3316]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3317]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3318]! } - public var Channel_AboutItem: String { return self._s[3319]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3321]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3322]! } - public var GroupInfo_SharedMedia: String { return self._s[3323]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3308]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3309]! } + public var Login_UnknownError: String { return self._s[3310]! } + public var Group_UpgradeNoticeText2: String { return self._s[3313]! } + public var Watch_Compose_AddContact: String { return self._s[3314]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3315]! } + public var Web_Error: String { return self._s[3316]! } + public var Gif_Search: String { return self._s[3317]! } + public var Profile_MessageLifetime1h: String { return self._s[3318]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3319]! } + public var Channel_Username_CheckingUsername: String { return self._s[3320]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3321]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3322]! } + public var Channel_AboutItem: String { return self._s[3323]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3325]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3326]! } + public var GroupInfo_SharedMedia: String { return self._s[3327]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3324]!, self._r[3324]!, [_1]) + return formatWithArgumentRanges(self._s[3328]!, self._r[3328]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3325]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3329]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3326]!, self._r[3326]!, [_1]) + return formatWithArgumentRanges(self._s[3330]!, self._r[3330]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3327]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3328]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3329]! } - public var CreatePoll_AddOption: String { return self._s[3330]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3331]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3332]! } - public var Channel_Management_AddModerator: String { return self._s[3333]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3334]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3335]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3336]! } - public var Theme_Colors_Background: String { return self._s[3337]! } - public var NotificationsSound_Hello: String { return self._s[3339]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3340]! } - public var Channel_Stickers_Placeholder: String { return self._s[3342]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3331]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3332]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3333]! } + public var CreatePoll_AddOption: String { return self._s[3334]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3335]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3336]! } + public var Channel_Management_AddModerator: String { return self._s[3337]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3338]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3339]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3340]! } + public var Theme_Colors_Background: String { return self._s[3341]! } + public var NotificationsSound_Hello: String { return self._s[3343]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3344]! } + public var Channel_Stickers_Placeholder: String { return self._s[3346]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) + return formatWithArgumentRanges(self._s[3347]!, self._r[3347]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3344]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3345]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3346]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3347]! } - public var AutoDownloadSettings_Channels: String { return self._s[3348]! } - public var Passport_Language_mn: String { return self._s[3349]! } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3352]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3353]! } - public var Passport_Language_ja: String { return self._s[3355]! } - public var Settings_About_Title: String { return self._s[3356]! } - public var Settings_NotificationsAndSounds: String { return self._s[3357]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3358]! } - public var Settings_BlockedUsers: String { return self._s[3359]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3348]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3349]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3350]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3351]! } + public var AutoDownloadSettings_Channels: String { return self._s[3352]! } + public var Passport_Language_mn: String { return self._s[3353]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3356]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3357]! } + public var Passport_Language_ja: String { return self._s[3359]! } + public var Settings_About_Title: String { return self._s[3360]! } + public var Settings_NotificationsAndSounds: String { return self._s[3361]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3362]! } + public var Settings_BlockedUsers: String { return self._s[3363]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3360]!, self._r[3360]!, [_0]) + return formatWithArgumentRanges(self._s[3364]!, self._r[3364]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3361]! } - public var Wallet_Weekday_Today: String { return self._s[3362]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3363]! } - public var Widget_ApplicationLocked: String { return self._s[3364]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3365]! } - public var Channel_Username_Title: String { return self._s[3366]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3365]! } + public var Wallet_Weekday_Today: String { return self._s[3366]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3367]! } + public var Widget_ApplicationLocked: String { return self._s[3368]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3369]! } + public var Channel_Username_Title: String { return self._s[3370]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3367]!, self._r[3367]!, [_0]) + return formatWithArgumentRanges(self._s[3371]!, self._r[3371]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3369]! } - public var AppleWatch_Title: String { return self._s[3370]! } - public var Activity_RecordingVideoMessage: String { return self._s[3371]! } + public var AttachmentMenu_File: String { return self._s[3373]! } + public var AppleWatch_Title: String { return self._s[3374]! } + public var Activity_RecordingVideoMessage: String { return self._s[3375]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3372]!, self._r[3372]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3376]!, self._r[3376]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3373]! } - public var Weekday_Saturday: String { return self._s[3374]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3375]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3376]! } - public var Common_Next: String { return self._s[3378]! } - public var Channel_Stickers_YourStickers: String { return self._s[3380]! } - public var Message_Theme: String { return self._s[3381]! } - public var Call_AudioRouteHeadphones: String { return self._s[3382]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3384]! } - public var Watch_Contacts_NoResults: String { return self._s[3386]! } - public var PhotoEditor_TintTool: String { return self._s[3389]! } - public var LoginPassword_ResetAccount: String { return self._s[3391]! } - public var Settings_SavedMessages: String { return self._s[3392]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3393]! } - public var Bot_GenericSupportStatus: String { return self._s[3394]! } - public var StickerPack_Add: String { return self._s[3395]! } - public var Checkout_TotalAmount: String { return self._s[3396]! } - public var Your_cards_number_is_invalid: String { return self._s[3397]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3398]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3399]! } + public var Theme_Colors_Messages: String { return self._s[3377]! } + public var Weekday_Saturday: String { return self._s[3378]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3379]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3380]! } + public var Common_Next: String { return self._s[3382]! } + public var Channel_Stickers_YourStickers: String { return self._s[3384]! } + public var Message_Theme: String { return self._s[3385]! } + public var Call_AudioRouteHeadphones: String { return self._s[3386]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3388]! } + public var Watch_Contacts_NoResults: String { return self._s[3390]! } + public var PhotoEditor_TintTool: String { return self._s[3393]! } + public var LoginPassword_ResetAccount: String { return self._s[3395]! } + public var Settings_SavedMessages: String { return self._s[3396]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3397]! } + public var Bot_GenericSupportStatus: String { return self._s[3398]! } + public var StickerPack_Add: String { return self._s[3399]! } + public var Checkout_TotalAmount: String { return self._s[3400]! } + public var Your_cards_number_is_invalid: String { return self._s[3401]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3402]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3403]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3400]!, self._r[3400]!, [_0]) + return formatWithArgumentRanges(self._s[3404]!, self._r[3404]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3401]!, self._r[3401]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3405]!, self._r[3405]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3402]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3406]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3404]!, self._r[3404]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3408]!, self._r[3408]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3405]!, self._r[3405]!, [_0]) + return formatWithArgumentRanges(self._s[3409]!, self._r[3409]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3406]! } - public var StickerPack_Share: String { return self._s[3407]! } - public var Passport_DeleteAddress: String { return self._s[3408]! } - public var Settings_Passport: String { return self._s[3409]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3410]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3411]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3412]! } - public var Contacts_PermissionsText: String { return self._s[3413]! } - public var Group_Setup_HistoryVisible: String { return self._s[3414]! } - public var Wallet_Month_ShortDecember: String { return self._s[3416]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3417]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3418]! } - public var SocksProxySetup_Title: String { return self._s[3419]! } - public var Notification_Mute1h: String { return self._s[3420]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3410]! } + public var StickerPack_Share: String { return self._s[3411]! } + public var Passport_DeleteAddress: String { return self._s[3412]! } + public var Settings_Passport: String { return self._s[3413]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3414]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3415]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3416]! } + public var Contacts_PermissionsText: String { return self._s[3417]! } + public var Group_Setup_HistoryVisible: String { return self._s[3418]! } + public var Wallet_Month_ShortDecember: String { return self._s[3420]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3421]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3422]! } + public var SocksProxySetup_Title: String { return self._s[3423]! } + public var Notification_Mute1h: String { return self._s[3424]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3421]!, self._r[3421]!, [_0]) + return formatWithArgumentRanges(self._s[3425]!, self._r[3425]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3422]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3426]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3423]!, self._r[3423]!, [_1]) + return formatWithArgumentRanges(self._s[3427]!, self._r[3427]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3424]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3427]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3429]! } - public var DialogList_NoMessagesText: String { return self._s[3430]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3431]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3432]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3434]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3435]! } - public var Common_TakePhotoOrVideo: String { return self._s[3436]! } - public var Wallet_Words_Text: String { return self._s[3437]! } - public var Call_StatusBusy: String { return self._s[3438]! } - public var Conversation_PinnedMessage: String { return self._s[3439]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3440]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3441]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3442]! } - public var Undo_ChatCleared: String { return self._s[3443]! } - public var AppleWatch_ReplyPresets: String { return self._s[3444]! } - public var Passport_DiscardMessageDescription: String { return self._s[3446]! } - public var Login_NetworkError: String { return self._s[3447]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3428]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3431]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3433]! } + public var DialogList_NoMessagesText: String { return self._s[3434]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3435]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3436]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3438]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3439]! } + public var Common_TakePhotoOrVideo: String { return self._s[3440]! } + public var Wallet_Words_Text: String { return self._s[3441]! } + public var Call_StatusBusy: String { return self._s[3442]! } + public var Conversation_PinnedMessage: String { return self._s[3443]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3444]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3445]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3446]! } + public var Undo_ChatCleared: String { return self._s[3447]! } + public var AppleWatch_ReplyPresets: String { return self._s[3448]! } + public var Passport_DiscardMessageDescription: String { return self._s[3450]! } + public var Login_NetworkError: String { return self._s[3451]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3448]!, self._r[3448]!, [_0]) + return formatWithArgumentRanges(self._s[3452]!, self._r[3452]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3449]!, self._r[3449]!, [_0]) + return formatWithArgumentRanges(self._s[3453]!, self._r[3453]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3450]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3452]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3453]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3454]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3456]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3457]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3455]!, self._r[3455]!, [_0]) + return formatWithArgumentRanges(self._s[3459]!, self._r[3459]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3456]! } - public var VoiceOver_Chat_Music: String { return self._s[3457]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3458]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3460]! } - public var ConversationMedia_Title: String { return self._s[3461]! } - public var EncryptionKey_Title: String { return self._s[3463]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3464]! } - public var Notification_Exceptions_AddException: String { return self._s[3465]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3466]! } - public var Profile_MessageLifetime1m: String { return self._s[3467]! } + public var Call_ConnectionErrorMessage: String { return self._s[3460]! } + public var VoiceOver_Chat_Music: String { return self._s[3461]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3462]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3464]! } + public var ConversationMedia_Title: String { return self._s[3465]! } + public var EncryptionKey_Title: String { return self._s[3467]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3468]! } + public var Notification_Exceptions_AddException: String { return self._s[3469]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3470]! } + public var Profile_MessageLifetime1m: String { return self._s[3471]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3468]!, self._r[3468]!, [_1]) + return formatWithArgumentRanges(self._s[3472]!, self._r[3472]!, [_1]) } - public var Month_GenMay: String { return self._s[3469]! } + public var Month_GenMay: String { return self._s[3473]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3470]!, self._r[3470]!, [_0]) + return formatWithArgumentRanges(self._s[3474]!, self._r[3474]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3471]! } - public var Wallet_Send_AddressInfo: String { return self._s[3472]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3473]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3474]! } + public var PeopleNearby_Users: String { return self._s[3475]! } + public var Wallet_Send_AddressInfo: String { return self._s[3476]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3477]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3478]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3476]!, self._r[3476]!, [_0]) + return formatWithArgumentRanges(self._s[3480]!, self._r[3480]!, [_0]) } - public var Conversation_EmptyPlaceholder: String { return self._s[3477]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3478]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3479]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3480]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3481]! } - public var Channel_JoinChannel: String { return self._s[3483]! } - public var Appearance_Animations: String { return self._s[3486]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3481]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3482]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3483]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3484]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3485]! } + public var Channel_JoinChannel: String { return self._s[3487]! } + public var Appearance_Animations: String { return self._s[3490]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3487]!, self._r[3487]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3491]!, self._r[3491]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3489]! } - public var Appearance_ShareTheme: String { return self._s[3490]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3491]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3493]! } - public var Passport_Address_Street: String { return self._s[3494]! } - public var Conversation_AddContact: String { return self._s[3495]! } - public var Login_PhonePlaceholder: String { return self._s[3496]! } - public var Channel_Members_InviteLink: String { return self._s[3498]! } - public var Bot_Stop: String { return self._s[3499]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3501]! } - public var Notification_PassportValueAddress: String { return self._s[3502]! } - public var Month_ShortJuly: String { return self._s[3503]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3504]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3505]! } - public var Passport_Identity_ReverseSide: String { return self._s[3506]! } - public var Watch_Stickers_Recents: String { return self._s[3509]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3511]! } - public var Map_SendThisLocation: String { return self._s[3512]! } + public var Stickers_GroupStickers: String { return self._s[3493]! } + public var Appearance_ShareTheme: String { return self._s[3494]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3495]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3497]! } + public var Passport_Address_Street: String { return self._s[3498]! } + public var Conversation_AddContact: String { return self._s[3499]! } + public var Login_PhonePlaceholder: String { return self._s[3500]! } + public var Channel_Members_InviteLink: String { return self._s[3502]! } + public var Bot_Stop: String { return self._s[3503]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3505]! } + public var Notification_PassportValueAddress: String { return self._s[3506]! } + public var Month_ShortJuly: String { return self._s[3507]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3508]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3509]! } + public var Passport_Identity_ReverseSide: String { return self._s[3510]! } + public var Watch_Stickers_Recents: String { return self._s[3513]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3515]! } + public var Map_SendThisLocation: String { return self._s[3516]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3513]!, self._r[3513]!, [_0]) - } - public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3514]!, self._r[3514]!, [_0]) - } - public var ConvertToSupergroup_Note: String { return self._s[3515]! } - public var Wallet_Intro_NotNow: String { return self._s[3516]! } - public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3517]!, self._r[3517]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3518]! } + public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3518]!, self._r[3518]!, [_0]) + } + public var ConvertToSupergroup_Note: String { return self._s[3519]! } + public var Wallet_Intro_NotNow: String { return self._s[3520]! } + public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3521]!, self._r[3521]!, [_0]) + } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3522]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3519]!, self._r[3519]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3523]!, self._r[3523]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3521]! } - public var Wallpaper_SearchShort: String { return self._s[3522]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3524]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3525]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3526]! } + public var Login_CallRequestState3: String { return self._s[3525]! } + public var Wallpaper_SearchShort: String { return self._s[3526]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3528]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3529]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3530]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3527]!, self._r[3527]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3531]!, self._r[3531]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3528]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3532]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3532]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3536]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3533]!, self._r[3533]!, [_0]) + return formatWithArgumentRanges(self._s[3537]!, self._r[3537]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3534]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3535]! } + public var Passport_CorrectErrors: String { return self._s[3538]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3539]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3536]!, self._r[3536]!, [_0]) + return formatWithArgumentRanges(self._s[3540]!, self._r[3540]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3537]! } - public var Channel_DiscussionGroup: String { return self._s[3538]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3539]! } + public var Map_SendMyCurrentLocation: String { return self._s[3541]! } + public var Channel_DiscussionGroup: String { return self._s[3542]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3543]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3540]!, self._r[3540]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3544]!, self._r[3544]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3541]! } - public var Permissions_NotificationsText_v0: String { return self._s[3542]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3543]! } - public var Appearance_AppIcon: String { return self._s[3544]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3545]! } - public var LoginPassword_FloodError: String { return self._s[3546]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3548]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3549]! } + public var SharedMedia_SearchNoResults: String { return self._s[3545]! } + public var Permissions_NotificationsText_v0: String { return self._s[3546]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3547]! } + public var Appearance_AppIcon: String { return self._s[3548]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3549]! } + public var LoginPassword_FloodError: String { return self._s[3550]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3552]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3553]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3550]!, self._r[3550]!, [_0]) - } - public var Passport_Language_bn: String { return self._s[3551]! } - public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3552]!, self._r[3552]!, [_0]) - } - public var ChatList_Context_Pin: String { return self._s[3553]! } - public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3554]!, self._r[3554]!, [_0]) } + public var Passport_Language_bn: String { return self._s[3555]! } + public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3556]!, self._r[3556]!, [_0]) + } + public var ChatList_Context_Pin: String { return self._s[3557]! } + public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3558]!, self._r[3558]!, [_0]) + } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3555]!, self._r[3555]!, [_0]) + return formatWithArgumentRanges(self._s[3559]!, self._r[3559]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3556]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3560]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3562]! } - public var Wallet_Month_GenDecember: String { return self._s[3563]! } - public var Contacts_PermissionsAllow: String { return self._s[3564]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3565]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3566]! } - public var WallpaperPreview_Pattern: String { return self._s[3567]! } - public var Paint_Duplicate: String { return self._s[3568]! } - public var Passport_Address_Country: String { return self._s[3569]! } - public var Notification_RenamedChannel: String { return self._s[3571]! } - public var ChatList_Context_Unmute: String { return self._s[3572]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3573]! } - public var Group_MessagePhotoUpdated: String { return self._s[3574]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3575]! } - public var Conversation_ContextMenuBan: String { return self._s[3576]! } - public var TwoStepAuth_EmailSent: String { return self._s[3577]! } - public var MessagePoll_NoVotes: String { return self._s[3578]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3579]! } - public var Passport_Language_is: String { return self._s[3580]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3582]! } - public var Tour_Text5: String { return self._s[3583]! } + public var Wallet_Navigation_Close: String { return self._s[3560]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3564]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3566]! } + public var Wallet_Month_GenDecember: String { return self._s[3567]! } + public var Contacts_PermissionsAllow: String { return self._s[3568]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3569]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3570]! } + public var WallpaperPreview_Pattern: String { return self._s[3571]! } + public var Paint_Duplicate: String { return self._s[3572]! } + public var Passport_Address_Country: String { return self._s[3573]! } + public var Notification_RenamedChannel: String { return self._s[3575]! } + public var ChatList_Context_Unmute: String { return self._s[3576]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3577]! } + public var Group_MessagePhotoUpdated: String { return self._s[3578]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3579]! } + public var Conversation_ContextMenuBan: String { return self._s[3580]! } + public var TwoStepAuth_EmailSent: String { return self._s[3581]! } + public var MessagePoll_NoVotes: String { return self._s[3582]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3583]! } + public var Passport_Language_is: String { return self._s[3584]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3586]! } + public var Tour_Text5: String { return self._s[3587]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3585]!, self._r[3585]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3589]!, self._r[3589]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3586]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3587]! } + public var Undo_SecretChatDeleted: String { return self._s[3590]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3591]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3588]!, self._r[3588]!, [_0]) + return formatWithArgumentRanges(self._s[3592]!, self._r[3592]!, [_0]) } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3589]! } - public var Paint_Edit: String { return self._s[3591]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3593]! } - public var Undo_DeletedGroup: String { return self._s[3595]! } - public var LoginPassword_ForgotPassword: String { return self._s[3596]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3597]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3598]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3593]! } + public var Paint_Edit: String { return self._s[3595]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3597]! } + public var Undo_DeletedGroup: String { return self._s[3599]! } + public var LoginPassword_ForgotPassword: String { return self._s[3600]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3601]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3602]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3599]!, self._r[3599]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3603]!, self._r[3603]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3600]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3601]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3602]! } - public var Passport_Language_uz: String { return self._s[3603]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3604]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3605]! } - public var Map_StopLiveLocation: String { return self._s[3607]! } - public var VoiceOver_MessageContextSend: String { return self._s[3609]! } - public var PasscodeSettings_Help: String { return self._s[3610]! } - public var NotificationsSound_Input: String { return self._s[3611]! } - public var Share_Title: String { return self._s[3614]! } - public var LogoutOptions_Title: String { return self._s[3615]! } - public var Wallet_Send_AddressText: String { return self._s[3616]! } - public var Login_TermsOfServiceAgree: String { return self._s[3617]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3618]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3619]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3620]! } - public var EnterPasscode_EnterTitle: String { return self._s[3621]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3604]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3605]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3606]! } + public var Passport_Language_uz: String { return self._s[3607]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3608]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3609]! } + public var Map_StopLiveLocation: String { return self._s[3611]! } + public var VoiceOver_MessageContextSend: String { return self._s[3613]! } + public var PasscodeSettings_Help: String { return self._s[3614]! } + public var NotificationsSound_Input: String { return self._s[3615]! } + public var Share_Title: String { return self._s[3618]! } + public var LogoutOptions_Title: String { return self._s[3619]! } + public var Wallet_Send_AddressText: String { return self._s[3620]! } + public var Login_TermsOfServiceAgree: String { return self._s[3621]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3622]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3623]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3624]! } + public var EnterPasscode_EnterTitle: String { return self._s[3625]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3622]!, self._r[3622]!, [_0]) + return formatWithArgumentRanges(self._s[3626]!, self._r[3626]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3623]! } - public var Conversation_AddToContacts: String { return self._s[3624]! } + public var Settings_CopyPhoneNumber: String { return self._s[3627]! } + public var Conversation_AddToContacts: String { return self._s[3628]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3625]!, self._r[3625]!, [_0]) + return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3626]! } + public var NotificationsSound_Keys: String { return self._s[3630]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3627]!, self._r[3627]!, [_0]) + return formatWithArgumentRanges(self._s[3631]!, self._r[3631]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3628]! } - public var Message_Video: String { return self._s[3629]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3630]! } + public var Notification_MessageLifetime1w: String { return self._s[3632]! } + public var Message_Video: String { return self._s[3633]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3634]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3631]!, self._r[3631]!, [_1]) + return formatWithArgumentRanges(self._s[3635]!, self._r[3635]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3634]! } + public var Wallet_Receive_AmountInfo: String { return self._s[3638]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3635]!, self._r[3635]!, [_0]) + return formatWithArgumentRanges(self._s[3639]!, self._r[3639]!, [_0]) } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3636]!, self._r[3636]!, [_0]) + return formatWithArgumentRanges(self._s[3640]!, self._r[3640]!, [_0]) } - public var Passport_Language_mk: String { return self._s[3637]! } + public var Passport_Language_mk: String { return self._s[3641]! } public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3638]!, self._r[3638]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3642]!, self._r[3642]!, [_1, _2, _3]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3639]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3641]! } - public var PrivacyPolicy_Decline: String { return self._s[3642]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3643]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3644]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3645]! } - public var Permissions_SiriAllow_v0: String { return self._s[3647]! } - public var Wallet_Month_ShortAugust: String { return self._s[3648]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3649]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3643]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3645]! } + public var PrivacyPolicy_Decline: String { return self._s[3646]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3647]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3648]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3649]! } + public var Permissions_SiriAllow_v0: String { return self._s[3651]! } + public var Wallet_Month_ShortAugust: String { return self._s[3652]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3653]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3650]!, self._r[3650]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3654]!, self._r[3654]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3651]!, self._r[3651]!, [_0]) + return formatWithArgumentRanges(self._s[3655]!, self._r[3655]!, [_0]) } - public var Paint_Regular: String { return self._s[3652]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3653]! } - public var SocksProxySetup_ShareLink: String { return self._s[3654]! } - public var Wallet_Qr_Title: String { return self._s[3655]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3656]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3658]! } - public var Wallet_Settings_Configuration: String { return self._s[3659]! } - public var GroupInfo_InviteByLink: String { return self._s[3660]! } - public var MessageTimer_Custom: String { return self._s[3661]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3662]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3664]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3665]! } - public var VoiceOver_Chat_Selected: String { return self._s[3666]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3667]! } - public var Channel_Username_InvalidTaken: String { return self._s[3668]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3669]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3670]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3671]! } - public var Settings_ChatBackground: String { return self._s[3672]! } - public var Channel_Subscribers_Title: String { return self._s[3673]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3674]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3675]! } - public var Watch_ConnectionDescription: String { return self._s[3676]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3679]! } - public var IntentsSettings_SuggestBy: String { return self._s[3681]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3682]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3683]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3684]! } - public var EditProfile_Title: String { return self._s[3685]! } - public var NotificationsSound_Bamboo: String { return self._s[3687]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3689]! } - public var Login_SmsRequestState2: String { return self._s[3690]! } - public var Passport_Language_ar: String { return self._s[3691]! } + public var Paint_Regular: String { return self._s[3656]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3657]! } + public var SocksProxySetup_ShareLink: String { return self._s[3658]! } + public var Wallet_Qr_Title: String { return self._s[3659]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3660]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3662]! } + public var Wallet_Settings_Configuration: String { return self._s[3663]! } + public var GroupInfo_InviteByLink: String { return self._s[3664]! } + public var MessageTimer_Custom: String { return self._s[3665]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3666]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3668]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3669]! } + public var VoiceOver_Chat_Selected: String { return self._s[3670]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3671]! } + public var Channel_Username_InvalidTaken: String { return self._s[3672]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3673]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3674]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3675]! } + public var Settings_ChatBackground: String { return self._s[3676]! } + public var Channel_Subscribers_Title: String { return self._s[3677]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3678]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3679]! } + public var Watch_ConnectionDescription: String { return self._s[3680]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3683]! } + public var IntentsSettings_SuggestBy: String { return self._s[3685]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3686]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3687]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3688]! } + public var EditProfile_Title: String { return self._s[3689]! } + public var NotificationsSound_Bamboo: String { return self._s[3691]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3693]! } + public var Login_SmsRequestState2: String { return self._s[3694]! } + public var Passport_Language_ar: String { return self._s[3695]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3692]!, self._r[3692]!, [_0]) + return formatWithArgumentRanges(self._s[3696]!, self._r[3696]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3693]! } - public var Wallet_Created_Text: String { return self._s[3694]! } - public var Conversation_MessageDialogEdit: String { return self._s[3696]! } - public var Wallet_Created_Proceed: String { return self._s[3697]! } - public var Wallet_Words_Done: String { return self._s[3698]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3699]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3697]! } + public var Wallet_Created_Text: String { return self._s[3698]! } + public var Conversation_MessageDialogEdit: String { return self._s[3700]! } + public var Wallet_Created_Proceed: String { return self._s[3701]! } + public var Wallet_Words_Done: String { return self._s[3702]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3703]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3700]!, self._r[3700]!, [_1]) + return formatWithArgumentRanges(self._s[3704]!, self._r[3704]!, [_1]) } - public var Common_Close: String { return self._s[3701]! } - public var GroupInfo_PublicLink: String { return self._s[3702]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3703]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3704]! } + public var Common_Close: String { return self._s[3705]! } + public var GroupInfo_PublicLink: String { return self._s[3706]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3707]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3708]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3708]!, self._r[3708]!, [_0]) + return formatWithArgumentRanges(self._s[3712]!, self._r[3712]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3709]! } + public var UserInfo_About_Placeholder: String { return self._s[3713]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3710]!, self._r[3710]!, [_0]) - } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3711]! } - public var Channel_Info_Banned: String { return self._s[3713]! } - public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3714]!, self._r[3714]!, [_0]) } - public var Appearance_Other: String { return self._s[3715]! } - public var Passport_Language_my: String { return self._s[3716]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3717]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3715]! } + public var Channel_Info_Banned: String { return self._s[3717]! } + public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3718]!, self._r[3718]!, [_0]) + } + public var Appearance_Other: String { return self._s[3719]! } + public var Passport_Language_my: String { return self._s[3720]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3721]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3718]!, self._r[3718]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3722]!, self._r[3722]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3719]! } - public var Preview_CopyAddress: String { return self._s[3720]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3723]! } + public var Preview_CopyAddress: String { return self._s[3724]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3721]!, self._r[3721]!, [_0]) + return formatWithArgumentRanges(self._s[3725]!, self._r[3725]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3722]! } - public var UserInfo_BotSettings: String { return self._s[3723]! } - public var LiveLocation_MenuStopAll: String { return self._s[3725]! } - public var Passport_PasswordCreate: String { return self._s[3726]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3727]! } - public var Message_PinnedLocationMessage: String { return self._s[3728]! } - public var Map_Satellite: String { return self._s[3729]! } - public var Watch_Message_Unsupported: String { return self._s[3730]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3731]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3732]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3726]! } + public var UserInfo_BotSettings: String { return self._s[3727]! } + public var LiveLocation_MenuStopAll: String { return self._s[3729]! } + public var Passport_PasswordCreate: String { return self._s[3730]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3731]! } + public var Message_PinnedLocationMessage: String { return self._s[3732]! } + public var Map_Satellite: String { return self._s[3733]! } + public var Watch_Message_Unsupported: String { return self._s[3734]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3735]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3736]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3733]!, self._r[3733]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3737]!, self._r[3737]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3734]!, self._r[3734]!, [_0]) + return formatWithArgumentRanges(self._s[3738]!, self._r[3738]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3735]! } + public var Wallet_WordImport_Continue: String { return self._s[3739]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3736]!, self._r[3736]!, [_0]) + return formatWithArgumentRanges(self._s[3740]!, self._r[3740]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3737]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3738]! } - public var NotificationsSound_None: String { return self._s[3739]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3740]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3742]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3743]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3741]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3742]! } + public var NotificationsSound_None: String { return self._s[3743]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3744]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3746]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3747]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_1]) + return formatWithArgumentRanges(self._s[3748]!, self._r[3748]!, [_1]) } - public var Cache_Indexing: String { return self._s[3745]! } - public var DialogList_RecentTitlePeople: String { return self._s[3747]! } - public var DialogList_EncryptionRejected: String { return self._s[3748]! } - public var GroupInfo_Administrators: String { return self._s[3749]! } - public var Passport_ScanPassportHelp: String { return self._s[3750]! } - public var Application_Name: String { return self._s[3751]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3752]! } - public var Appearance_ThemeCarouselDay: String { return self._s[3754]! } - public var Passport_Identity_TranslationHelp: String { return self._s[3755]! } + public var Cache_Indexing: String { return self._s[3749]! } + public var DialogList_RecentTitlePeople: String { return self._s[3751]! } + public var DialogList_EncryptionRejected: String { return self._s[3752]! } + public var GroupInfo_Administrators: String { return self._s[3753]! } + public var Passport_ScanPassportHelp: String { return self._s[3754]! } + public var Application_Name: String { return self._s[3755]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3756]! } + public var Appearance_ThemeCarouselDay: String { return self._s[3758]! } + public var Passport_Identity_TranslationHelp: String { return self._s[3759]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3756]!, self._r[3756]!, [_0]) + return formatWithArgumentRanges(self._s[3760]!, self._r[3760]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3757]!, self._r[3757]!, [_0]) + return formatWithArgumentRanges(self._s[3761]!, self._r[3761]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3758]!, self._r[3758]!, [_0]) + return formatWithArgumentRanges(self._s[3762]!, self._r[3762]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3759]! } - public var Privacy_ChatsTitle: String { return self._s[3760]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[3761]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3762]! } - public var Watch_Suggestion_HoldOn: String { return self._s[3763]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[3764]! } - public var WebBrowser_Title: String { return self._s[3765]! } - public var Group_LinkedChannel: String { return self._s[3766]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3767]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[3768]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3769]! } - public var Appearance_TextSize_UseSystem: String { return self._s[3770]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[3771]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[3773]! } - public var Channel_Setup_TypePublic: String { return self._s[3775]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[3763]! } + public var Privacy_ChatsTitle: String { return self._s[3764]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[3765]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[3766]! } + public var Watch_Suggestion_HoldOn: String { return self._s[3767]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[3768]! } + public var WebBrowser_Title: String { return self._s[3769]! } + public var Group_LinkedChannel: String { return self._s[3770]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[3771]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[3772]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[3773]! } + public var Appearance_TextSize_UseSystem: String { return self._s[3774]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[3775]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[3777]! } + public var Channel_Setup_TypePublic: String { return self._s[3779]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3776]!, self._r[3776]!, [_0]) + return formatWithArgumentRanges(self._s[3780]!, self._r[3780]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[3778]! } - public var Map_OpenInMaps: String { return self._s[3780]! } + public var Channel_TypeSetup_Title: String { return self._s[3782]! } + public var Map_OpenInMaps: String { return self._s[3784]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3781]!, self._r[3781]!, [_1]) + return formatWithArgumentRanges(self._s[3785]!, self._r[3785]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[3783]! } + public var NotificationsSound_Tremolo: String { return self._s[3787]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3784]!, self._r[3784]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3788]!, self._r[3788]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[3785]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3786]! } - public var Passport_PasswordHelp: String { return self._s[3787]! } - public var Login_CodeExpiredError: String { return self._s[3788]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3789]! } - public var Conversation_TitleUnmute: String { return self._s[3790]! } - public var Passport_Identity_ScansHelp: String { return self._s[3791]! } - public var Passport_Language_lo: String { return self._s[3792]! } - public var Camera_FlashAuto: String { return self._s[3793]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[3794]! } - public var Common_Cancel: String { return self._s[3795]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[3796]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3797]! } - public var Appearance_TintAllColors: String { return self._s[3798]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[3789]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[3790]! } + public var Passport_PasswordHelp: String { return self._s[3791]! } + public var Login_CodeExpiredError: String { return self._s[3792]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[3793]! } + public var Conversation_TitleUnmute: String { return self._s[3794]! } + public var Passport_Identity_ScansHelp: String { return self._s[3795]! } + public var Passport_Language_lo: String { return self._s[3796]! } + public var Camera_FlashAuto: String { return self._s[3797]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[3798]! } + public var Common_Cancel: String { return self._s[3799]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[3800]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[3801]! } + public var Appearance_TintAllColors: String { return self._s[3802]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3799]!, self._r[3799]!, [_1]) + return formatWithArgumentRanges(self._s[3803]!, self._r[3803]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[3800]! } - public var ChatSettings_Title: String { return self._s[3802]! } - public var Passport_PasswordReset: String { return self._s[3803]! } - public var SocksProxySetup_TypeNone: String { return self._s[3804]! } - public var EditTheme_Title: String { return self._s[3806]! } - public var PhoneNumberHelp_Help: String { return self._s[3807]! } - public var Checkout_EnterPassword: String { return self._s[3808]! } - public var Share_AuthTitle: String { return self._s[3810]! } - public var Activity_UploadingDocument: String { return self._s[3811]! } - public var State_Connecting: String { return self._s[3812]! } - public var Profile_MessageLifetime1w: String { return self._s[3813]! } - public var Conversation_ContextMenuReport: String { return self._s[3814]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3815]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[3816]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[3804]! } + public var ChatSettings_Title: String { return self._s[3806]! } + public var Passport_PasswordReset: String { return self._s[3807]! } + public var SocksProxySetup_TypeNone: String { return self._s[3808]! } + public var EditTheme_Title: String { return self._s[3810]! } + public var PhoneNumberHelp_Help: String { return self._s[3811]! } + public var Checkout_EnterPassword: String { return self._s[3812]! } + public var Share_AuthTitle: String { return self._s[3814]! } + public var Activity_UploadingDocument: String { return self._s[3815]! } + public var State_Connecting: String { return self._s[3816]! } + public var Profile_MessageLifetime1w: String { return self._s[3817]! } + public var Conversation_ContextMenuReport: String { return self._s[3818]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[3819]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[3820]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3817]!, self._r[3817]!, [_0]) + return formatWithArgumentRanges(self._s[3821]!, self._r[3821]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[3818]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[3819]! } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3821]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3822]! } - public var PhotoEditor_Set: String { return self._s[3823]! } - public var EmptyGroupInfo_Title: String { return self._s[3824]! } - public var Login_PadPhoneHelp: String { return self._s[3825]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3827]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3829]! } - public var NotificationsSound_Complete: String { return self._s[3830]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3831]! } - public var Group_Info_AdminLog: String { return self._s[3832]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3833]! } + public var AuthSessions_Terminate: String { return self._s[3822]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[3823]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[3825]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[3826]! } + public var PhotoEditor_Set: String { return self._s[3827]! } + public var EmptyGroupInfo_Title: String { return self._s[3828]! } + public var Login_PadPhoneHelp: String { return self._s[3829]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[3831]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[3833]! } + public var NotificationsSound_Complete: String { return self._s[3834]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[3835]! } + public var Group_Info_AdminLog: String { return self._s[3836]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[3837]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3838]!, self._r[3838]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3835]! } - public var Group_Location_CreateInThisPlace: String { return self._s[3837]! } - public var Conversation_Admin: String { return self._s[3838]! } - public var Conversation_GifTooltip: String { return self._s[3839]! } - public var Passport_NotLoggedInMessage: String { return self._s[3840]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[3839]! } + public var Group_Location_CreateInThisPlace: String { return self._s[3841]! } + public var Conversation_Admin: String { return self._s[3842]! } + public var Conversation_GifTooltip: String { return self._s[3843]! } + public var Passport_NotLoggedInMessage: String { return self._s[3844]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3842]!, self._r[3842]!, [_0]) + return formatWithArgumentRanges(self._s[3846]!, self._r[3846]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[3843]! } - public var SharedMedia_EmptyTitle: String { return self._s[3845]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3847]! } - public var Username_Help: String { return self._s[3848]! } - public var DialogList_LanguageTooltip: String { return self._s[3850]! } - public var Map_LoadError: String { return self._s[3851]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3852]! } - public var Channel_AdminLog_AddMembers: String { return self._s[3853]! } - public var ArchivedChats_IntroTitle2: String { return self._s[3854]! } - public var Notification_Exceptions_NewException: String { return self._s[3855]! } - public var TwoStepAuth_EmailTitle: String { return self._s[3856]! } - public var WatchRemote_AlertText: String { return self._s[3857]! } + public var Profile_MessageLifetimeForever: String { return self._s[3847]! } + public var SharedMedia_EmptyTitle: String { return self._s[3849]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[3851]! } + public var Username_Help: String { return self._s[3852]! } + public var DialogList_LanguageTooltip: String { return self._s[3854]! } + public var Map_LoadError: String { return self._s[3855]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[3856]! } + public var Channel_AdminLog_AddMembers: String { return self._s[3857]! } + public var ArchivedChats_IntroTitle2: String { return self._s[3858]! } + public var Notification_Exceptions_NewException: String { return self._s[3859]! } + public var TwoStepAuth_EmailTitle: String { return self._s[3860]! } + public var WatchRemote_AlertText: String { return self._s[3861]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3858]!, self._r[3858]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3862]!, self._r[3862]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[3862]! } - public var WebBrowser_DefaultBrowser: String { return self._s[3863]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[3866]! } + public var WebBrowser_DefaultBrowser: String { return self._s[3867]! } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3864]!, self._r[3864]!, [_0]) + return formatWithArgumentRanges(self._s[3868]!, self._r[3868]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3865]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[3866]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[3869]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[3870]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3867]!, self._r[3867]!, [_0]) + return formatWithArgumentRanges(self._s[3871]!, self._r[3871]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3868]!, self._r[3868]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3872]!, self._r[3872]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[3869]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3870]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[3872]! } - public var Wallet_Created_ExportErrorText: String { return self._s[3873]! } - public var ChatList_UndoArchiveText1: String { return self._s[3874]! } - public var AccessDenied_VideoMicrophone: String { return self._s[3875]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3876]! } - public var Cache_ClearNone: String { return self._s[3877]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[3878]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[3879]! } + public var Group_AdminLog_EmptyText: String { return self._s[3873]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[3874]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[3876]! } + public var Wallet_Created_ExportErrorText: String { return self._s[3877]! } + public var ChatList_UndoArchiveText1: String { return self._s[3878]! } + public var AccessDenied_VideoMicrophone: String { return self._s[3879]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[3880]! } + public var Cache_ClearNone: String { return self._s[3881]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[3882]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[3883]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3880]!, self._r[3880]!, [_0]) + return formatWithArgumentRanges(self._s[3884]!, self._r[3884]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[3881]! } + public var Passport_Identity_Country: String { return self._s[3885]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3882]!, self._r[3882]!, [_0]) + return formatWithArgumentRanges(self._s[3886]!, self._r[3886]!, [_0]) } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3883]!, self._r[3883]!, [_0]) + return formatWithArgumentRanges(self._s[3887]!, self._r[3887]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[3884]! } - public var AccessDenied_Settings: String { return self._s[3885]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3886]! } - public var Month_ShortMay: String { return self._s[3887]! } - public var Compose_NewGroup: String { return self._s[3889]! } - public var Group_Setup_TypePrivate: String { return self._s[3891]! } - public var Login_PadPhoneHelpTitle: String { return self._s[3893]! } - public var Appearance_ThemeDayClassic: String { return self._s[3894]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3895]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[3896]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3897]! } - public var Conversation_typing: String { return self._s[3899]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[3900]! } - public var Paint_Masks: String { return self._s[3901]! } - public var Contacts_DeselectAll: String { return self._s[3902]! } + public var Exceptions_AddToExceptions: String { return self._s[3888]! } + public var AccessDenied_Settings: String { return self._s[3889]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[3890]! } + public var Month_ShortMay: String { return self._s[3891]! } + public var Compose_NewGroup: String { return self._s[3893]! } + public var Group_Setup_TypePrivate: String { return self._s[3895]! } + public var Login_PadPhoneHelpTitle: String { return self._s[3897]! } + public var Appearance_ThemeDayClassic: String { return self._s[3898]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[3899]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[3900]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[3901]! } + public var Conversation_typing: String { return self._s[3903]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[3904]! } + public var Paint_Masks: String { return self._s[3905]! } + public var Contacts_DeselectAll: String { return self._s[3906]! } public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3903]!, self._r[3903]!, [_0]) + return formatWithArgumentRanges(self._s[3907]!, self._r[3907]!, [_0]) } - public var Username_InvalidTaken: String { return self._s[3904]! } - public var Call_StatusNoAnswer: String { return self._s[3905]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[3906]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3907]! } - public var Passport_Identity_Selfie: String { return self._s[3908]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[3909]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3910]! } - public var Conversation_ClearSecretHistory: String { return self._s[3911]! } - public var PeopleNearby_Description: String { return self._s[3913]! } - public var NetworkUsageSettings_Title: String { return self._s[3914]! } - public var Your_cards_security_code_is_invalid: String { return self._s[3916]! } + public var Username_InvalidTaken: String { return self._s[3908]! } + public var Call_StatusNoAnswer: String { return self._s[3909]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[3910]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[3911]! } + public var Passport_Identity_Selfie: String { return self._s[3912]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[3913]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[3914]! } + public var Conversation_ClearSecretHistory: String { return self._s[3915]! } + public var PeopleNearby_Description: String { return self._s[3917]! } + public var NetworkUsageSettings_Title: String { return self._s[3918]! } + public var Your_cards_security_code_is_invalid: String { return self._s[3920]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3918]!, self._r[3918]!, [_0]) + return formatWithArgumentRanges(self._s[3922]!, self._r[3922]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3919]!, self._r[3919]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3923]!, self._r[3923]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[3921]! } - public var VoiceOver_Navigation_Search: String { return self._s[3922]! } - public var Map_LiveLocationTitle: String { return self._s[3923]! } - public var Login_InfoAvatarAdd: String { return self._s[3924]! } - public var Passport_Identity_FilesView: String { return self._s[3925]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[3926]! } - public var Privacy_Calls_NeverAllow: String { return self._s[3927]! } - public var VoiceOver_Chat_File: String { return self._s[3928]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3929]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[3925]! } + public var VoiceOver_Navigation_Search: String { return self._s[3926]! } + public var Map_LiveLocationTitle: String { return self._s[3927]! } + public var Login_InfoAvatarAdd: String { return self._s[3928]! } + public var Passport_Identity_FilesView: String { return self._s[3929]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[3930]! } + public var Privacy_Calls_NeverAllow: String { return self._s[3931]! } + public var VoiceOver_Chat_File: String { return self._s[3932]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[3933]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3930]!, self._r[3930]!, [_0]) + return formatWithArgumentRanges(self._s[3934]!, self._r[3934]!, [_0]) } - public var ContactInfo_PhoneNumberHidden: String { return self._s[3931]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[3932]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3933]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[3935]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[3936]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[3937]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3934]!, self._r[3934]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3938]!, self._r[3938]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3935]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[3936]! } - public var Tour_Title2: String { return self._s[3937]! } - public var Wallet_Sent_ViewWallet: String { return self._s[3938]! } - public var Conversation_FileOpenIn: String { return self._s[3939]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3940]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[3941]! } - public var Wallpaper_Set: String { return self._s[3942]! } - public var Passport_Identity_Translations: String { return self._s[3944]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[3939]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[3940]! } + public var Tour_Title2: String { return self._s[3941]! } + public var Wallet_Sent_ViewWallet: String { return self._s[3942]! } + public var Conversation_FileOpenIn: String { return self._s[3943]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[3944]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[3945]! } + public var Wallpaper_Set: String { return self._s[3946]! } + public var Passport_Identity_Translations: String { return self._s[3948]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3945]!, self._r[3945]!, [_0]) + return formatWithArgumentRanges(self._s[3949]!, self._r[3949]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[3946]! } + public var Channel_LeaveChannel: String { return self._s[3950]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3947]!, self._r[3947]!, [_1]) + return formatWithArgumentRanges(self._s[3951]!, self._r[3951]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3949]! } - public var PhotoEditor_HighlightsTint: String { return self._s[3950]! } - public var Passport_Email_Delete: String { return self._s[3951]! } - public var Conversation_Mute: String { return self._s[3953]! } - public var Channel_AddBotAsAdmin: String { return self._s[3954]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[3956]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[3957]! } - public var ChatSettings_IntentsSettings: String { return self._s[3959]! } - public var Channel_Management_LabelOwner: String { return self._s[3960]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[3953]! } + public var PhotoEditor_HighlightsTint: String { return self._s[3954]! } + public var Passport_Email_Delete: String { return self._s[3955]! } + public var Conversation_Mute: String { return self._s[3957]! } + public var Channel_AddBotAsAdmin: String { return self._s[3958]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[3960]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[3961]! } + public var ChatSettings_IntentsSettings: String { return self._s[3963]! } + public var Channel_Management_LabelOwner: String { return self._s[3964]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3961]!, self._r[3961]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3965]!, self._r[3965]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[3962]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[3963]! } - public var Common_No: String { return self._s[3964]! } - public var Weekday_Sunday: String { return self._s[3965]! } - public var Notification_Reply: String { return self._s[3966]! } - public var Conversation_ViewMessage: String { return self._s[3967]! } + public var Calls_CallTabDescription: String { return self._s[3966]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[3967]! } + public var Common_No: String { return self._s[3968]! } + public var Weekday_Sunday: String { return self._s[3969]! } + public var Notification_Reply: String { return self._s[3970]! } + public var Conversation_ViewMessage: String { return self._s[3971]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3968]!, self._r[3968]!, [_0]) + return formatWithArgumentRanges(self._s[3972]!, self._r[3972]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3969]!, self._r[3969]!, [_0]) + return formatWithArgumentRanges(self._s[3973]!, self._r[3973]!, [_0]) } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3970]!, self._r[3970]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3974]!, self._r[3974]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3971]! } - public var Wallet_Send_Title: String { return self._s[3972]! } - public var Message_PinnedDocumentMessage: String { return self._s[3973]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[3974]! } - public var DialogList_TabTitle: String { return self._s[3976]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[3977]! } - public var Passport_FieldEmail: String { return self._s[3978]! } - public var Conversation_UnpinMessageAlert: String { return self._s[3979]! } - public var Passport_Address_TypeBankStatement: String { return self._s[3980]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[3981]! } - public var Passport_Identity_ExpiryDate: String { return self._s[3982]! } - public var Privacy_Calls_P2P: String { return self._s[3983]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[3975]! } + public var Wallet_Send_Title: String { return self._s[3976]! } + public var Message_PinnedDocumentMessage: String { return self._s[3977]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[3978]! } + public var DialogList_TabTitle: String { return self._s[3980]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[3981]! } + public var Passport_FieldEmail: String { return self._s[3982]! } + public var Conversation_UnpinMessageAlert: String { return self._s[3983]! } + public var Passport_Address_TypeBankStatement: String { return self._s[3984]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[3985]! } + public var Passport_Identity_ExpiryDate: String { return self._s[3986]! } + public var Privacy_Calls_P2P: String { return self._s[3987]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3985]!, self._r[3985]!, [_0]) + return formatWithArgumentRanges(self._s[3989]!, self._r[3989]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[3986]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[3990]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3987]!, self._r[3987]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3991]!, self._r[3991]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[3988]! } - public var EnterPasscode_ChangeTitle: String { return self._s[3989]! } - public var TwoFactorSetup_Email_Title: String { return self._s[3990]! } - public var Passport_InfoText: String { return self._s[3991]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3992]! } + public var Stickers_ClearRecent: String { return self._s[3992]! } + public var EnterPasscode_ChangeTitle: String { return self._s[3993]! } + public var TwoFactorSetup_Email_Title: String { return self._s[3994]! } + public var Passport_InfoText: String { return self._s[3995]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[3996]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3993]!, self._r[3993]!, [_0]) + return formatWithArgumentRanges(self._s[3997]!, self._r[3997]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3994]!, self._r[3994]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3998]!, self._r[3998]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3995]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[3996]! } - public var VoiceOver_Navigation_Compose: String { return self._s[3997]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[3998]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4000]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4001]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[3999]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4000]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4001]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4002]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4004]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4005]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4002]!, self._r[4002]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4006]!, self._r[4006]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4004]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4005]! } - public var Map_HomeAndWorkTitle: String { return self._s[4006]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4008]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4009]! } + public var Map_HomeAndWorkTitle: String { return self._s[4010]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4008]!, self._r[4008]!, [_0]) + return formatWithArgumentRanges(self._s[4012]!, self._r[4012]!, [_0]) } - public var DialogList_Unread: String { return self._s[4009]! } + public var DialogList_Unread: String { return self._s[4013]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4010]!, self._r[4010]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4014]!, self._r[4014]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4011]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4012]! } + public var User_DeletedAccount: String { return self._s[4015]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4016]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4013]!, self._r[4013]!, [_0]) + return formatWithArgumentRanges(self._s[4017]!, self._r[4017]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4014]! } - public var SharedMedia_CategoryMedia: String { return self._s[4015]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4016]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4017]! } - public var Watch_ChatList_Compose: String { return self._s[4018]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4019]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4020]! } - public var Watch_Microphone_Access: String { return self._s[4021]! } - public var Group_Setup_HistoryHeader: String { return self._s[4022]! } - public var Map_SetThisLocation: String { return self._s[4023]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4024]! } - public var Activity_UploadingPhoto: String { return self._s[4025]! } - public var Conversation_Edit: String { return self._s[4027]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4028]! } - public var Login_TermsOfServiceDecline: String { return self._s[4029]! } - public var Message_PinnedContactMessage: String { return self._s[4030]! } + public var UserInfo_NotificationsDefault: String { return self._s[4018]! } + public var SharedMedia_CategoryMedia: String { return self._s[4019]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4020]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4021]! } + public var Watch_ChatList_Compose: String { return self._s[4022]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4023]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4024]! } + public var Watch_Microphone_Access: String { return self._s[4025]! } + public var Group_Setup_HistoryHeader: String { return self._s[4026]! } + public var Map_SetThisLocation: String { return self._s[4027]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4028]! } + public var Activity_UploadingPhoto: String { return self._s[4029]! } + public var Conversation_Edit: String { return self._s[4031]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4032]! } + public var Login_TermsOfServiceDecline: String { return self._s[4033]! } + public var Message_PinnedContactMessage: String { return self._s[4034]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4031]!, self._r[4031]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4035]!, self._r[4035]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4032]!, self._r[4032]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4036]!, self._r[4036]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4033]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4035]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4036]! } + public var Appearance_LargeEmoji: String { return self._s[4037]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4039]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4040]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4037]!, self._r[4037]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4041]!, self._r[4041]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4038]! } - public var Message_PinnedPhotoMessage: String { return self._s[4039]! } - public var Passport_FieldPhone: String { return self._s[4040]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4041]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4042]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4044]! } - public var Conversation_Call: String { return self._s[4045]! } - public var Common_TakePhoto: String { return self._s[4047]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4048]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4049]! } - public var Channel_NotificationLoading: String { return self._s[4050]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4042]! } + public var Message_PinnedPhotoMessage: String { return self._s[4043]! } + public var Passport_FieldPhone: String { return self._s[4044]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4045]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4046]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4048]! } + public var Conversation_Call: String { return self._s[4049]! } + public var Common_TakePhoto: String { return self._s[4051]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4052]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4053]! } + public var Channel_NotificationLoading: String { return self._s[4054]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4051]!, self._r[4051]!, [_0]) - } - public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4052]!, self._r[4052]!, [_0]) - } - public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4053]!, self._r[4053]!, [_1]) - } - public var Permissions_SiriTitle_v0: String { return self._s[4054]! } - public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4055]!, self._r[4055]!, [_0]) } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4056]!, self._r[4056]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4057]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4058]! } - public var ClearCache_FreeSpace: String { return self._s[4059]! } - public var Common_edit: String { return self._s[4060]! } - public var PrivacySettings_AuthSessions: String { return self._s[4061]! } - public var Month_ShortJune: String { return self._s[4062]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4063]! } - public var Call_ReportSend: String { return self._s[4064]! } - public var Watch_LastSeen_JustNow: String { return self._s[4065]! } - public var Notifications_MessageNotifications: String { return self._s[4066]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4067]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4069]! } - public var Group_Status: String { return self._s[4070]! } + public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4057]!, self._r[4057]!, [_1]) + } + public var Permissions_SiriTitle_v0: String { return self._s[4058]! } + public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4059]!, self._r[4059]!, [_0]) + } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4060]!, self._r[4060]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[4061]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4062]! } + public var ClearCache_FreeSpace: String { return self._s[4063]! } + public var Common_edit: String { return self._s[4064]! } + public var PrivacySettings_AuthSessions: String { return self._s[4065]! } + public var Month_ShortJune: String { return self._s[4066]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4067]! } + public var Call_ReportSend: String { return self._s[4068]! } + public var Watch_LastSeen_JustNow: String { return self._s[4069]! } + public var Notifications_MessageNotifications: String { return self._s[4070]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4071]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4073]! } + public var Group_Status: String { return self._s[4074]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4071]!, self._r[4071]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4075]!, self._r[4075]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4072]! } - public var ShareMenu_ShareTo: String { return self._s[4073]! } - public var Conversation_Moderate_Ban: String { return self._s[4074]! } + public var TextFormat_AddLinkTitle: String { return self._s[4076]! } + public var ShareMenu_ShareTo: String { return self._s[4077]! } + public var Conversation_Moderate_Ban: String { return self._s[4078]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4075]!, self._r[4075]!, [_0]) + return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4076]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4077]! } + public var SharedMedia_ViewInChat: String { return self._s[4080]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4081]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4078]!, self._r[4078]!, [_1]) + return formatWithArgumentRanges(self._s[4082]!, self._r[4082]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4083]!, self._r[4083]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4081]!, self._r[4081]!, [_0]) + return formatWithArgumentRanges(self._s[4085]!, self._r[4085]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4082]! } - public var Appearance_ReduceMotion: String { return self._s[4083]! } + public var Map_OpenInHereMaps: String { return self._s[4086]! } + public var Appearance_ReduceMotion: String { return self._s[4087]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4084]!, self._r[4084]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4088]!, self._r[4088]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4085]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4086]! } - public var PhotoEditor_Skip: String { return self._s[4087]! } - public func Chat_DeleteMessagesConfirmation(_ 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 var Channel_Setup_TypePublicHelp: String { return self._s[4089]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4090]! } + public var PhotoEditor_Skip: String { return self._s[4091]! } + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, _1, _2) } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, _1, _2) } - public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func UserCount(_ 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 PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func GroupInfo_ShowMoreMembers(_ 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 ChatList_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Conversation_StatusOnline(_ 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 Notifications_ExceptionMuteExpires_Days(_ 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 PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_Years(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[10 * 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[11 * 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[12 * 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[13 * 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[14 * 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[15 * 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[16 * 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[17 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_ShareItem(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[19 * 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[20 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[21 * 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[22 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedAudios(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[23 * 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[24 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Conversation_StatusMembers(_ 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 ForwardedPhotos(_ 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 MessageTimer_Weeks(_ 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 SharedMedia_File(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[28 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_AddMaskCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Video(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[30 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreExtended(_ 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 Wallpaper_DeleteConfirmation(_ 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 VoiceOver_Chat_ContactPhoneNumberCount(_ 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 Call_Minutes(_ 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 AttachmentMenu_SendGif(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Minutes(_ 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 ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[39 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func ForwardedLocations(_ 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 MessageTimer_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfSimple(_ 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 MuteExpires_Days(_ 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 ForwardedGifs(_ 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 ForwardedStickers(_ 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_Months(_ 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 VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) - } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[48 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LiveLocation_MenuChatsCount(_ 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 Map_ETAMinutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Notification_GameScoreSelfExtended(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Generic(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func StickerPack_RemoveMaskCount(_ 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 LastSeen_HoursAgo(_ 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 SharedMedia_Link(_ 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) + return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) } public func Passport_Scans(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[3 * 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[59 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func ForwardedFiles(_ value: Int32) -> String { + public func Call_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[4 * 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[61 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PrivacyLastSeenSettings_AddUsers(_ 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[62 * 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[63 * 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[64 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Forward_ConfirmMultipleFiles(_ 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 MessageTimer_ShortHours(_ 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 PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[67 * 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[68 * 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[69 * 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[70 * 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[71 * 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[72 * 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[73 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Call_Seconds(_ 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 Call_ShortMinutes(_ 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 GroupInfo_ParticipantCount(_ 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 MessageTimer_Seconds(_ 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 ServiceMessage_GameScoreSimple(_ 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 AttachmentMenu_SendPhoto(_ 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 AttachmentMenu_SendVideo(_ 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 Media_ShareVideo(_ 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 AttachmentMenu_SendItem(_ 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 ChatList_DeletedChats(_ 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 Media_SharePhoto(_ 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 Notification_GameScoreSimple(_ 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 ForwardedPolls(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[86 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_LastSeen_HoursAgo(_ 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 PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessagePoll_VotedCount(_ 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 PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessageTimer_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[91 * 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[92 * 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[93 * 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[94 * 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[95 * 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[96 * 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[97 * 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[98 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[5 * 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[99 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[7 * 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[8 * 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[9 * 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[10 * 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[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[100 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func SharedMedia_Photo(_ 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 Theme_UsersCount(_ 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 SharedMedia_DeleteItemsConfirmation(_ 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 ForwardedVideoMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedContacts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ForwardedVideos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) - } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, _2, _1, _3) } public func ForwardedMessages(_ 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) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_InviteContacts(_ value: Int32) -> String { + public func MuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) } - public func LastSeen_MinutesAgo(_ 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[110 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[15 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortSeconds(_ 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[111 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[16 * 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[112 * 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[113 * 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[114 * 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[115 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 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[19 * 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[20 * 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[21 * 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[22 * 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[23 * 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[24 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Media_ShareItem(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[25 * 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[26 * 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[27 * 6 + Int(form.rawValue)]!, stringValue) } public func Call_ShortSeconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[28 * 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[29 * 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[30 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedContacts(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[31 * 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[32 * 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[33 * 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[34 * 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[35 * 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[36 * 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[37 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_RemoveMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[38 * 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[39 * 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[40 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Call_ShortMinutes(_ 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 Conversation_StatusSubscribers(_ 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 AttachmentMenu_SendItem(_ 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 MuteExpires_Minutes(_ 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 PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[46 * 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[47 * 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[48 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ServiceMessage_GameScoreExtended(_ 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 SharedMedia_File(_ 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 AttachmentMenu_SendGif(_ 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 StickerPack_AddMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Minutes(_ 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 ForwardedGifs(_ 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 Call_Seconds(_ 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 Notifications_Exceptions(_ 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 CreatePoll_AddMoreOptions(_ 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 ServiceMessage_GameScoreSimple(_ 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 QuickSend_Photos(_ 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 DialogList_LiveLocationChatsCount(_ 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 Contacts_ImportersCount(_ 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 ServiceMessage_GameScoreSelfSimple(_ 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 Notification_GameScoreSelfSimple(_ 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 ChatList_DeletedChats(_ 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 Watch_LastSeen_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendVideo(_ 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 GroupInfo_ParticipantCount(_ 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 MessageTimer_Years(_ 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_GameScoreExtended(_ 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 Wallet_Updated_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Link(_ 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 MessageTimer_Weeks(_ 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 ForwardedLocations(_ 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 PUSH_CHAT_MESSAGE_PHOTOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + 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[75 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func LiveLocationUpdated_MinutesAgo(_ 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 Watch_LastSeen_MinutesAgo(_ 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 Forward_ConfirmMultipleFiles(_ 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 SharedMedia_Photo(_ 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 ForwardedPolls(_ 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 MessageTimer_ShortHours(_ 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 PUSH_CHANNEL_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[82 * 6 + Int(form.rawValue)]!, _1, _2) + } + 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[83 * 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[84 * 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[85 * 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[86 * 6 + Int(form.rawValue)]!, _1, _2) + } + 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[87 * 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[88 * 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[89 * 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[90 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func GroupInfo_ShowMoreMembers(_ 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 MuteFor_Days(_ 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 Wallet_Updated_MinutesAgo(_ 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 LastSeen_MinutesAgo(_ 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 Invitation_Members(_ 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 SharedMedia_DeleteItemsConfirmation(_ 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 Watch_UserInfo_Mute(_ 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 Media_SharePhoto(_ 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 Contacts_InviteContacts(_ 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 MuteFor_Hours(_ 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 Conversation_StatusMembers(_ 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 LastSeen_HoursAgo(_ 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 ForwardedVideoMessages(_ 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 ForwardedPhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedVideos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[105 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_StickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[108 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_ShortWeeks(_ 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 Theme_UsersCount(_ 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 Wallpaper_DeleteConfirmation(_ 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 PUSH_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 Conversation_SelectedMessages(_ 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 LiveLocation_MenuChatsCount(_ 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 Chat_DeleteMessagesConfirmation(_ 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 MuteExpires_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func MessageTimer_ShortDays(_ 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) diff --git a/submodules/TelegramPresentationData/Sources/PresentationThemeCodable.swift b/submodules/TelegramPresentationData/Sources/PresentationThemeCodable.swift index 54f92d68ad..0e18340c01 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationThemeCodable.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationThemeCodable.swift @@ -39,7 +39,9 @@ extension TelegramWallpaper: Codable { case "builtin": self = .builtin(WallpaperSettings()) default: - if [6,7].contains(value.count), let color = UIColor(hexString: value) { + let optionKeys = ["motion", "blur"] + + if value.count == 6, let color = UIColor(hexString: value) { self = .color(Int32(bitPattern: color.rgb)) } else { let components = value.components(separatedBy: " ") @@ -52,28 +54,48 @@ extension TelegramWallpaper: Codable { blur = true } - if components.count >= 2 && components.count <= 4 && [6,7].contains(components[0].count) && !["motion", "blur"].contains(components[0]) && [6,7].contains(components[1].count) && !["motion", "blur"].contains(components[1]), let topColor = UIColor(hexString: components[0]), let bottomColor = UIColor(hexString: components[1]) { + if components.count >= 2 && components.count <= 5 && components[0].count == 6 && !optionKeys.contains(components[0]) && components[1].count == 6 && !optionKeys.contains(components[1]), let topColor = UIColor(hexString: components[0]), let bottomColor = UIColor(hexString: components[1]) { + + var rotation: Int32? + if components.count > 2, components[2].count <= 3, let value = Int32(components[2]) { + if value >= 0 && value < 360 { + rotation = value + } + } + self = .gradient(Int32(bitPattern: topColor.rgb), Int32(bitPattern: bottomColor.rgb), WallpaperSettings(blur: blur, motion: motion)) } else { var slug: String? var color: Int32? + var bottomColor: Int32? var intensity: Int32? if !components.isEmpty { slug = components[0] } - if components.count > 1, !["motion", "blur"].contains(components[1]), components[1].count == 6, let value = UIColor(hexString: components[1]) { - color = Int32(bitPattern: value.rgb) - } - if components.count > 2, !["motion", "blur"].contains(components[2]), let value = Int32(components[2]) { - if value >= 0 && value <= 100 { - intensity = value - } else { - intensity = 50 + if components.count > 1 { + for i in 1 ..< components.count { + let component = components[i] + if optionKeys.contains(component) { + continue + } + if component.count == 6, let value = UIColor(hexString: component) { + if color == nil { + color = Int32(bitPattern: value.rgb) + } else if bottomColor == nil { + bottomColor = Int32(bitPattern: value.rgb) + } + } else if component.count <= 3, let value = Int32(component) { + if value >= 0 && value <= 100 { + intensity = value + } else { + intensity = 50 + } + } } } if let slug = slug { - self = .file(id: 0, accessHash: 0, isCreator: false, isDefault: false, isPattern: color != nil, isDark: false, slug: slug, file: TelegramMediaFile(fileId: MediaId(namespace: 0, id: 0), partialReference: nil, resource: LocalFileMediaResource(fileId: 0), previewRepresentations: [], immediateThumbnailData: nil, mimeType: "", size: nil, attributes: []), settings: WallpaperSettings(blur: blur, motion: motion, color: color, intensity: intensity)) + self = .file(id: 0, accessHash: 0, isCreator: false, isDefault: false, isPattern: color != nil, isDark: false, slug: slug, file: TelegramMediaFile(fileId: MediaId(namespace: 0, id: 0), partialReference: nil, resource: LocalFileMediaResource(fileId: 0), previewRepresentations: [], immediateThumbnailData: nil, mimeType: "", size: nil, attributes: []), settings: WallpaperSettings(blur: blur, motion: motion, color: color, bottomColor: bottomColor, intensity: intensity)) } else { throw PresentationThemeDecodingError.generic } @@ -96,6 +118,9 @@ extension TelegramWallpaper: Codable { var components: [String] = [] components.append(String(format: "%06x", topColor)) components.append(String(format: "%06x", bottomColor)) + if let rotation = settings.rotation { + components.append("\(rotation)") + } if settings.motion { components.append("motion") } @@ -113,6 +138,12 @@ extension TelegramWallpaper: Codable { if let intensity = file.settings.intensity { components.append("\(intensity)") } + if let bottomColor = file.settings.bottomColor { + components.append(String(format: "%06x", bottomColor)) + } + if let rotation = file.settings.rotation { + components.append("\(rotation)") + } } if file.settings.motion { components.append("motion") diff --git a/submodules/TelegramPresentationData/Sources/WallpaperUtils.swift b/submodules/TelegramPresentationData/Sources/WallpaperUtils.swift index a74f121ba2..ae81d73b1a 100644 --- a/submodules/TelegramPresentationData/Sources/WallpaperUtils.swift +++ b/submodules/TelegramPresentationData/Sources/WallpaperUtils.swift @@ -22,13 +22,22 @@ public extension TelegramWallpaper { var isColorOrGradient: Bool { switch self { - case .color, .gradient: + case .color, .gradient: return true default: return false } } + var isPattern: Bool { + switch self { + case let .file(file): + return file.isPattern + default: + return false + } + } + var isBuiltin: Bool { switch self { case .builtin: diff --git a/submodules/TelegramUI/Images.xcassets/Settings/ThemeColorSwapIcon.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Settings/ThemeColorSwapIcon.imageset/Contents.json new file mode 100644 index 0000000000..8dec65adad --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Settings/ThemeColorSwapIcon.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "ic_input_change.pdf" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} \ No newline at end of file diff --git a/submodules/TelegramUI/Images.xcassets/Settings/ThemeColorSwapIcon.imageset/ic_input_change.pdf b/submodules/TelegramUI/Images.xcassets/Settings/ThemeColorSwapIcon.imageset/ic_input_change.pdf new file mode 100644 index 0000000000..6151d0db8b Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Settings/ThemeColorSwapIcon.imageset/ic_input_change.pdf differ diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift index 6056cd9f7c..fb82c397ad 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageAttachedContentNode.swift @@ -487,7 +487,7 @@ final class ChatMessageAttachedContentNode: ASDisplayNode { let (_, initialImageWidth, refineLayout) = contentImageLayout(context, presentationData.theme.theme, presentationData.strings, presentationData.dateTimeFormat, message, wallpaper, .full, associatedData.automaticDownloadPeerType, .constrained(CGSize(width: constrainedSize.width - horizontalInsets.left - horizontalInsets.right, height: constrainedSize.height)), layoutConstants, contentMode) initialWidth = initialImageWidth + horizontalInsets.left + horizontalInsets.right refineContentImageLayout = refineLayout - if case let .file(_, _, isTheme, _) = wallpaper.content, isTheme { + if case let .file(_, _, _, _, isTheme, _) = wallpaper.content, isTheme { skipStandardStatus = true } } diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift index 8afa4ac59b..54a8e8c452 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageInteractiveMediaNode.swift @@ -303,7 +303,7 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode, GalleryItemTransitio unboundSize = CGSize(width: floor(dimensions.cgSize.width * 0.5), height: floor(dimensions.cgSize.height * 0.5)) } else if let wallpaper = media as? WallpaperPreviewMedia { switch wallpaper.content { - case let .file(file, _, isTheme, isSupported): + case let .file(file, _, _, _, isTheme, isSupported): if let thumbnail = file.previewRepresentations.first, var dimensions = file.dimensions { let dimensionsVertical = dimensions.width < dimensions.height let thumbnailVertical = thumbnail.dimensions.width < thumbnail.dimensions.height @@ -433,13 +433,19 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode, GalleryItemTransitio var onlyFullSizeVideoThumbnail: Bool? var emptyColor: UIColor + var patternArguments: PatternWallpaperArguments? if isSticker { emptyColor = .clear } else { emptyColor = message.effectivelyIncoming(context.account.peerId) ? theme.chat.message.incoming.mediaPlaceholderColor : theme.chat.message.outgoing.mediaPlaceholderColor } - if let wallpaper = media as? WallpaperPreviewMedia, case let .file(_, patternColor, _, _) = wallpaper.content { - emptyColor = patternColor ?? UIColor(rgb: 0xd6e2ee, alpha: 0.5) + if let wallpaper = media as? WallpaperPreviewMedia, case let .file(_, patternColor, patternBottomColor, rotation, _, _) = wallpaper.content { + var colors: [UIColor] = [] + colors.append(patternColor ?? UIColor(rgb: 0xd6e2ee, alpha: 0.5)) + if let patternBottomColor = patternBottomColor { + colors.append(patternBottomColor) + } + patternArguments = PatternWallpaperArguments(colors: colors, rotation: rotation) } if mediaUpdated || isSendingUpdated || automaticPlaybackUpdated { @@ -572,7 +578,7 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode, GalleryItemTransitio } else if let wallpaper = media as? WallpaperPreviewMedia { updateImageSignal = { synchronousLoad in switch wallpaper.content { - case let .file(file, _, isTheme, _): + case let .file(file, _, _, _, isTheme, _): if isTheme { return themeImage(account: context.account, accountManager: context.sharedContext.accountManager, fileReference: FileMediaReference.message(message: MessageReference(message), media: file)) } else { @@ -585,12 +591,12 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode, GalleryItemTransitio } case let .color(color): return solidColorImage(color) - case let .gradient(topColor, bottomColor): - return gradientImage([topColor, bottomColor]) + case let .gradient(topColor, bottomColor, rotation): + return gradientImage([topColor, bottomColor], rotation: rotation ?? 0) } } - if case let .file(file, _, _, _) = wallpaper.content { + if case let .file(file, _, _, _, _, _) = wallpaper.content { updatedFetchControls = FetchControls(fetch: { manual in if let strongSelf = self { strongSelf.fetchDisposable.set(messageMediaFileInteractiveFetched(context: context, message: message, file: file, userInitiated: manual).start()) @@ -634,7 +640,7 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode, GalleryItemTransitio } } else if let wallpaper = media as? WallpaperPreviewMedia { switch wallpaper.content { - case let .file(file, _, _, _): + case let .file(file, _, _, _, _, _): updatedStatusSignal = messageMediaFileStatus(context: context, messageId: message.id, file: file) |> map { resourceStatus -> (MediaResourceStatus, MediaResourceStatus?) in return (resourceStatus, nil) @@ -645,7 +651,7 @@ final class ChatMessageInteractiveMediaNode: ASDisplayNode, GalleryItemTransitio } } - let arguments = TransformImageArguments(corners: corners, imageSize: drawingSize, boundingSize: boundingSize, intrinsicInsets: UIEdgeInsets(), resizeMode: isInlinePlayableVideo ? .fill(.black) : .blurBackground, emptyColor: emptyColor) + let arguments = TransformImageArguments(corners: corners, imageSize: drawingSize, boundingSize: boundingSize, intrinsicInsets: UIEdgeInsets(), resizeMode: isInlinePlayableVideo ? .fill(.black) : .blurBackground, emptyColor: emptyColor, custom: patternArguments) let imageFrame = CGRect(origin: CGPoint(x: -arguments.insets.left, y: -arguments.insets.top), size: arguments.drawingSize) diff --git a/submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift b/submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift index d351bade5d..5edef04901 100644 --- a/submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift +++ b/submodules/TelegramUI/TelegramUI/ChatMessageWebpageBubbleContentNode.swift @@ -251,7 +251,7 @@ final class ChatMessageWebpageBubbleContentNode: ChatMessageBubbleContentNode { if let wallpaper = parseWallpaperUrl(webpage.url), case let .slug(_, _, color, intensity) = wallpaper { patternColor = color?.withAlphaComponent(CGFloat(intensity ?? 50) / 100.0) } - let media = WallpaperPreviewMedia(content: .file(file, patternColor, false, false)) + let media = WallpaperPreviewMedia(content: .file(file, patternColor, nil, 0, false, false)) mediaAndFlags = (media, [.preferMediaAspectFilled]) if let fileSize = file.size { badge = dataSizeString(fileSize, decimalSeparator: item.presentationData.dateTimeFormat.decimalSeparator) @@ -285,7 +285,7 @@ final class ChatMessageWebpageBubbleContentNode: ChatMessageBubbleContentNode { let components = text.replacingOccurrences(of: "#", with: "").components(separatedBy: "-") if components.count == 2, let topColorCode = components.first, let bottomColorCode = components.last { if let topColor = UIColor(hexString: topColorCode), let bottomColor = UIColor(hexString: bottomColorCode) { - let media = WallpaperPreviewMedia(content: .gradient(topColor, bottomColor)) + let media = WallpaperPreviewMedia(content: .gradient(topColor, bottomColor, 0)) mediaAndFlags = (media, ChatMessageAttachedContentNodeMediaFlags()) } } else if components.count == 1, let colorCode = components.first { @@ -311,7 +311,7 @@ final class ChatMessageWebpageBubbleContentNode: ChatMessageBubbleContentNode { file = contentFile } if let file = file { - let media = WallpaperPreviewMedia(content: .file(file, nil, true, isSupported)) + let media = WallpaperPreviewMedia(content: .file(file, nil, nil, nil, true, isSupported)) mediaAndFlags = (media, ChatMessageAttachedContentNodeMediaFlags()) } } diff --git a/submodules/TelegramUI/TelegramUI/CreateChannelController.swift b/submodules/TelegramUI/TelegramUI/CreateChannelController.swift index 30493d6001..9cb387fbfb 100644 --- a/submodules/TelegramUI/TelegramUI/CreateChannelController.swift +++ b/submodules/TelegramUI/TelegramUI/CreateChannelController.swift @@ -139,9 +139,10 @@ private enum CreateChannelEntry: ItemListNodeEntry { let arguments = arguments as! CreateChannelArguments switch self { case let .channelInfo(theme, strings, dateTimeFormat, peer, state, avatar): - return ItemListAvatarAndNameInfoItem(accountContext: arguments.context, presentationData: presentationData, dateTimeFormat: dateTimeFormat, mode: .generic, peer: peer, presence: nil, cachedData: nil, state: state, sectionId: ItemListSectionId(self.section), style: .blocks(withTopInset: false, withExtendedBottomInset: false), editingNameUpdated: { editingName in + return ItemListAvatarAndNameInfoItem(accountContext: arguments.context, presentationData: presentationData, dateTimeFormat: dateTimeFormat, mode: .editSettings, peer: peer, presence: nil, cachedData: nil, state: state, sectionId: ItemListSectionId(self.section), style: .blocks(withTopInset: false, withExtendedBottomInset: false), editingNameUpdated: { editingName in arguments.updateEditingName(editingName) }, avatarTapped: { + arguments.changeProfilePhoto() }, updatingImage: avatar, tag: CreateChannelEntryTag.info) case let .setProfilePhoto(theme, text): return ItemListActionItem(presentationData: presentationData, title: text, kind: .generic, alignment: .natural, sectionId: ItemListSectionId(self.section), style: .blocks, action: { @@ -188,7 +189,6 @@ private func CreateChannelEntries(presentationData: PresentationData, state: Cre let peer = TelegramGroup(id: PeerId(namespace: -1, id: 0), title: state.editingName.composedTitle, photo: [], participantCount: 0, role: .creator(rank: nil), membership: .Member, flags: [], defaultBannedRights: nil, migrationReference: nil, creationDate: 0, version: 0) entries.append(.channelInfo(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, peer, groupInfoState, state.avatar)) - entries.append(.setProfilePhoto(presentationData.theme, presentationData.strings.Channel_UpdatePhotoItem)) entries.append(.descriptionSetup(presentationData.theme, presentationData.strings.Channel_Edit_AboutItem, state.editingDescriptionText)) entries.append(.descriptionInfo(presentationData.theme, presentationData.strings.Channel_About_Help)) diff --git a/submodules/TelegramUI/TelegramUI/CreateGroupController.swift b/submodules/TelegramUI/TelegramUI/CreateGroupController.swift index d18162efae..e78968ab6a 100644 --- a/submodules/TelegramUI/TelegramUI/CreateGroupController.swift +++ b/submodules/TelegramUI/TelegramUI/CreateGroupController.swift @@ -300,7 +300,6 @@ private func createGroupEntries(presentationData: PresentationData, state: Creat let peer = TelegramGroup(id: PeerId(namespace: -1, id: 0), title: state.editingName.composedTitle, photo: [], participantCount: 0, role: .creator(rank: nil), membership: .Member, flags: [], defaultBannedRights: nil, migrationReference: nil, creationDate: 0, version: 0) entries.append(.groupInfo(presentationData.theme, presentationData.strings, presentationData.dateTimeFormat, peer, groupInfoState, state.avatar)) - //entries.append(.setProfilePhoto(presentationData.theme, presentationData.strings.GroupInfo_SetGroupPhoto)) var peers: [Peer] = [] for peerId in peerIds { diff --git a/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift b/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift index 05ef528873..3baf603f0b 100644 --- a/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift +++ b/submodules/TelegramUI/TelegramUI/FetchCachedRepresentations.swift @@ -82,7 +82,7 @@ public func fetchCachedResourceRepresentation(account: Account, resource: MediaR if !data.complete { return .complete() } - return fetchCachedPatternWallpaperRepresentation(account: account, resource: resource, resourceData: data, representation: representation) + return fetchCachedPatternWallpaperRepresentation(resource: resource, resourceData: data, representation: representation) } } else if let representation = representation as? CachedAlbumArtworkRepresentation { return account.postbox.mediaBox.resourceData(resource, option: .complete(waitUntilFetchStatus: false)) @@ -452,21 +452,66 @@ private func fetchCachedPatternWallpaperRepresentation(resource: MediaResource, let size = CGSize(width: image.size.width * image.scale, height: image.size.height * image.scale) - let backgroundColor = UIColor(rgb: UInt32(bitPattern: representation.color)) - let foregroundColor = patternColor(for: backgroundColor, intensity: CGFloat(representation.intensity) / 100.0) + var colors: [UIColor] = [] + if let bottomColor = representation.bottomColor { + colors.append(UIColor(rgb: UInt32(bitPattern: bottomColor))) + } + colors.append(UIColor(rgb: UInt32(bitPattern: representation.color))) + + let intensity = CGFloat(representation.intensity) / 100.0 let colorImage = generateImage(size, contextGenerator: { size, c in let rect = CGRect(origin: CGPoint(), size: size) c.setBlendMode(.copy) - c.setFillColor(backgroundColor.cgColor) - c.fill(rect) + + if colors.count == 1, let color = colors.first { + c.setFillColor(color.cgColor) + c.fill(rect) + } else { + let gradientColors = colors.map { $0.cgColor } as CFArray + let delta: CGFloat = 1.0 / (CGFloat(colors.count) - 1.0) + + var locations: [CGFloat] = [] + for i in 0 ..< colors.count { + locations.append(delta * CGFloat(i)) + } + let colorSpace = CGColorSpaceCreateDeviceRGB() + let gradient = CGGradient(colorsSpace: colorSpace, colors: gradientColors, locations: &locations)! + + c.saveGState() + c.translateBy(x: rect.width / 2.0, y: rect.height / 2.0) + c.rotate(by: CGFloat(representation.rotation ?? 0) * CGFloat.pi / -180.0) + c.translateBy(x: -rect.width / 2.0, y: -rect.height / 2.0) + + c.drawLinearGradient(gradient, start: CGPoint(x: 0.0, y: 0.0), end: CGPoint(x: 0.0, y: rect.height), options: CGGradientDrawingOptions()) + c.restoreGState() + } c.setBlendMode(.normal) if let cgImage = image.cgImage { c.clip(to: rect, mask: cgImage) } - c.setFillColor(foregroundColor.cgColor) - c.fill(rect) + + if colors.count == 1, let color = colors.first { + c.setFillColor(patternColor(for: color, intensity: intensity).cgColor) + c.fill(rect) + } else { + let gradientColors = colors.map { patternColor(for: $0, intensity: intensity).cgColor } as CFArray + let delta: CGFloat = 1.0 / (CGFloat(colors.count) - 1.0) + + var locations: [CGFloat] = [] + for i in 0 ..< colors.count { + locations.append(delta * CGFloat(i)) + } + let colorSpace = CGColorSpaceCreateDeviceRGB() + let gradient = CGGradient(colorsSpace: colorSpace, colors: gradientColors, locations: &locations)! + + c.translateBy(x: rect.width / 2.0, y: rect.height / 2.0) + c.rotate(by: CGFloat(representation.rotation ?? 0) * CGFloat.pi / -180.0) + c.translateBy(x: -rect.width / 2.0, y: -rect.height / 2.0) + + c.drawLinearGradient(gradient, start: CGPoint(x: 0.0, y: 0.0), end: CGPoint(x: 0.0, y: rect.height), options: CGGradientDrawingOptions()) + } }, scale: 1.0) if let colorImage = colorImage, let colorDestination = CGImageDestinationCreateWithURL(url as CFURL, kUTTypeJPEG, 1, nil) { @@ -554,89 +599,6 @@ private func fetchCachedBlurredWallpaperRepresentation(account: Account, resourc }) |> runOn(Queue.concurrentDefaultQueue()) } -private func fetchCachedPatternWallpaperMaskRepresentation(account: Account, resource: MediaResource, resourceData: MediaResourceData, representation: CachedPatternWallpaperMaskRepresentation) -> Signal { - return Signal({ subscriber in - if let data = try? Data(contentsOf: URL(fileURLWithPath: resourceData.path), options: [.mappedIfSafe]) { - if let image = UIImage(data: data) { - let path = NSTemporaryDirectory() + "\(arc4random64())" - let url = URL(fileURLWithPath: path) - - let size = representation.size != nil ? image.size.aspectFitted(representation.size!) : CGSize(width: image.size.width * image.scale, height: image.size.height * image.scale) - - let alphaImage = generateImage(size, contextGenerator: { size, context in - context.setFillColor(UIColor.black.cgColor) - context.fill(CGRect(origin: CGPoint(), size: size)) - context.clip(to: CGRect(origin: CGPoint(), size: size), mask: image.cgImage!) - context.setFillColor(UIColor.white.cgColor) - context.fill(CGRect(origin: CGPoint(), size: size)) - }, scale: 1.0) - - if let alphaImage = alphaImage, let alphaDestination = CGImageDestinationCreateWithURL(url as CFURL, kUTTypeJPEG, 1, nil) { - CGImageDestinationSetProperties(alphaDestination, [:] as CFDictionary) - - let colorQuality: Float = 0.87 - - let options = NSMutableDictionary() - options.setObject(colorQuality as NSNumber, forKey: kCGImageDestinationLossyCompressionQuality as NSString) - - CGImageDestinationAddImage(alphaDestination, alphaImage.cgImage!, options as CFDictionary) - if CGImageDestinationFinalize(alphaDestination) { - subscriber.putNext(.temporaryPath(path)) - subscriber.putCompletion() - } - } - } - } - return EmptyDisposable - }) |> runOn(Queue.concurrentDefaultQueue()) -} - -private func fetchCachedPatternWallpaperRepresentation(account: Account, resource: MediaResource, resourceData: MediaResourceData, representation: CachedPatternWallpaperRepresentation) -> Signal { - return Signal({ subscriber in - if let data = try? Data(contentsOf: URL(fileURLWithPath: resourceData.path), options: [.mappedIfSafe]) { - if let image = UIImage(data: data) { - let path = NSTemporaryDirectory() + "\(arc4random64())" - let url = URL(fileURLWithPath: path) - - let size = CGSize(width: image.size.width * image.scale, height: image.size.height * image.scale) - - let backgroundColor = UIColor(rgb: UInt32(bitPattern: representation.color)) - let foregroundColor = patternColor(for: backgroundColor, intensity: CGFloat(representation.intensity) / 100.0) - - let colorImage = generateImage(size, contextGenerator: { size, c in - let rect = CGRect(origin: CGPoint(), size: size) - c.setBlendMode(.copy) - c.setFillColor(backgroundColor.cgColor) - c.fill(rect) - - c.setBlendMode(.normal) - if let cgImage = image.cgImage { - c.clip(to: rect, mask: cgImage) - } - c.setFillColor(foregroundColor.cgColor) - c.fill(rect) - }, scale: 1.0) - - if let colorImage = colorImage, let colorDestination = CGImageDestinationCreateWithURL(url as CFURL, kUTTypeJPEG, 1, nil) { - CGImageDestinationSetProperties(colorDestination, [:] as CFDictionary) - - let colorQuality: Float = 0.9 - - let options = NSMutableDictionary() - options.setObject(colorQuality as NSNumber, forKey: kCGImageDestinationLossyCompressionQuality as NSString) - - CGImageDestinationAddImage(colorDestination, colorImage.cgImage!, options as CFDictionary) - if CGImageDestinationFinalize(colorDestination) { - subscriber.putNext(.temporaryPath(path)) - subscriber.putCompletion() - } - } - } - } - return EmptyDisposable - }) |> runOn(Queue.concurrentDefaultQueue()) -} - public enum FetchAlbumArtworkError { case moreDataNeeded(Int) } diff --git a/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift b/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift index a051e0ee50..9c5191fe37 100644 --- a/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift +++ b/submodules/TelegramUI/TelegramUI/OpenChatMessage.swift @@ -283,15 +283,24 @@ func openChatMessageImpl(_ params: OpenChatMessageParams) -> Bool { case let .map(mapMedia): params.dismissInput() - let controllerParams = LocationViewParams(sendLiveLocation: { location in - let outMessage: EnqueueMessage = .message(text: "", attributes: [], mediaReference: .standalone(media: location), replyToMessageId: nil, localGroupingKey: nil) +// let controllerParams = LocationViewParams(sendLiveLocation: { location in +// let outMessage: EnqueueMessage = .message(text: "", attributes: [], mediaReference: .standalone(media: location), replyToMessageId: nil, localGroupingKey: nil) +// params.enqueueMessage(outMessage) +// }, stopLiveLocation: { +// params.context.liveLocationManager?.cancelLiveLocation(peerId: params.message.id.peerId) +// }, openUrl: params.openUrl, openPeer: { peer in +// params.openPeer(peer, .info) +// }) +// let controller = LocationViewController(context: params.context, mapMedia: mapMedia, params: controllerParams) + let controller = legacyLocationController(message: params.message, mapMedia: mapMedia, context: params.context, openPeer: { peer in + params.openPeer(peer, .info) + }, sendLiveLocation: { coordinate, period in + let outMessage: EnqueueMessage = .message(text: "", attributes: [], mediaReference: .standalone(media: TelegramMediaMap(latitude: coordinate.latitude, longitude: coordinate.longitude, geoPlace: nil, venue: nil, liveBroadcastingTimeout: period)), replyToMessageId: nil, localGroupingKey: nil) params.enqueueMessage(outMessage) }, stopLiveLocation: { params.context.liveLocationManager?.cancelLiveLocation(peerId: params.message.id.peerId) - }, openUrl: params.openUrl, openPeer: { peer in - params.openPeer(peer, .info) - }) - let controller = LocationViewController(context: params.context, mapMedia: mapMedia, params: controllerParams) + }, openUrl: params.openUrl) + controller.navigationPresentation = .modal params.navigationController?.pushViewController(controller) return true case let .stickerPack(reference): diff --git a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping index 3ef4900888..82836d7d01 100644 Binary files a/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift b/submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift index 5eedd94ae5..ee80059e53 100644 --- a/submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift +++ b/submodules/TelegramUI/TelegramUI/UpgradedAccounts.swift @@ -167,7 +167,7 @@ public func upgradedAccounts(accountManager: AccountManager, rootPath: String, e let _ = accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedScaledImageRepresentation(size: CGSize(width: 720.0, height: 720.0), mode: .aspectFit), complete: true, fetch: true).start() if file.isPattern { if let color = file.settings.color, let intensity = file.settings.intensity { - let _ = accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, intensity: intensity), complete: true, fetch: true).start() + let _ = accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, bottomColor: file.settings.bottomColor, intensity: intensity, rotation: file.settings.rotation), complete: true, fetch: true).start() } } else { if file.settings.blur { diff --git a/submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift b/submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift index 1224b0784a..8773fec6c8 100644 --- a/submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift +++ b/submodules/TelegramUI/TelegramUI/WallpaperPreviewMedia.swift @@ -5,9 +5,9 @@ import TelegramCore import SyncCore enum WallpaperPreviewMediaContent: Equatable { - case file(TelegramMediaFile, UIColor?, Bool, Bool) + case file(TelegramMediaFile, UIColor?, UIColor?, Int32?, Bool, Bool) case color(UIColor) - case gradient(UIColor, UIColor) + case gradient(UIColor, UIColor, Int32?) } final class WallpaperPreviewMedia: Media { diff --git a/submodules/TelegramUIPreferences/Sources/PresentationThemeSettings.swift b/submodules/TelegramUIPreferences/Sources/PresentationThemeSettings.swift index d5b004a529..0a788c83bf 100644 --- a/submodules/TelegramUIPreferences/Sources/PresentationThemeSettings.swift +++ b/submodules/TelegramUIPreferences/Sources/PresentationThemeSettings.swift @@ -96,7 +96,7 @@ public struct PresentationCloudTheme: PostboxCoding, Equatable { return false } if lhs.resolvedWallpaper != rhs.resolvedWallpaper { - return false + return false } return true } diff --git a/submodules/WallpaperResources/Sources/WallpaperResources.swift b/submodules/WallpaperResources/Sources/WallpaperResources.swift index 8361697a5f..d84c5da42b 100644 --- a/submodules/WallpaperResources/Sources/WallpaperResources.swift +++ b/submodules/WallpaperResources/Sources/WallpaperResources.swift @@ -295,6 +295,26 @@ public enum PatternWallpaperDrawMode { case screen } +public struct PatternWallpaperArguments: TransformImageCustomArguments { + let colors: [UIColor] + let rotation: Int32? + let preview: Bool + + public init(colors: [UIColor], rotation: Int32?, preview: Bool = false) { + self.colors = colors + self.rotation = rotation + self.preview = preview + } + + public func serialized() -> NSArray { + let array = NSMutableArray() + array.addObjects(from: self.colors) + array.add(NSNumber(value: self.rotation ?? 0)) + array.add(NSNumber(value: self.preview)) + return array + } +} + private func patternWallpaperDatas(account: Account, accountManager: AccountManager, representations: [ImageRepresentationWithReference], mode: PatternWallpaperDrawMode, autoFetchFullSize: Bool = false) -> Signal<(Data?, Data?, Bool), NoError> { if let smallestRepresentation = smallestImageRepresentation(representations.map({ $0.representation })), let largestRepresentation = largestImageRepresentation(representations.map({ $0.representation })), let smallestIndex = representations.firstIndex(where: { $0.representation == smallestRepresentation }), let largestIndex = representations.firstIndex(where: { $0.representation == largestRepresentation }) { @@ -394,6 +414,8 @@ public func patternWallpaperImageInternal(thumbnailData: Data?, fullSizeData: Da return .single((thumbnailData, fullSizeData, fullSizeComplete)) |> map { (thumbnailData, fullSizeData, fullSizeComplete) in return { arguments in + var scale = scale + let drawingRect = arguments.drawingRect var fittedSize = arguments.imageSize if abs(fittedSize.width - arguments.boundingSize.width).isLessThanOrEqualTo(CGFloat(1.0)) { @@ -414,35 +436,68 @@ public func patternWallpaperImageInternal(thumbnailData: Data?, fullSizeData: Da } } - if let combinedColor = arguments.emptyColor { + if let customArguments = arguments.custom as? PatternWallpaperArguments, let combinedColor = customArguments.colors.first { + if customArguments.preview { + scale = max(1.0, UIScreenScale - 1.0) + } + + let combinedColors = customArguments.colors + let colors = combinedColors.reversed().map { $0.withAlphaComponent(1.0) } let color = combinedColor.withAlphaComponent(1.0) let intensity = combinedColor.alpha - if fullSizeImage == nil { - let context = DrawingContext(size: arguments.drawingSize, scale: 1.0, clear: true) - context.withFlippedContext { c in - c.setBlendMode(.copy) - c.setFillColor(color.cgColor) - c.fill(arguments.drawingRect) - } - - addCorners(context, arguments: arguments) - - return context - } - - let context = DrawingContext(size: arguments.drawingSize, scale: scale, clear: true) + let context = DrawingContext(size: arguments.drawingSize, scale: fullSizeImage == nil ? 1.0 : scale, clear: true) context.withFlippedContext { c in c.setBlendMode(.copy) - c.setFillColor(color.cgColor) - c.fill(arguments.drawingRect) + + if colors.count == 1 { + c.setFillColor(color.cgColor) + c.fill(arguments.drawingRect) + } else { + let gradientColors = colors.map { $0.cgColor } as CFArray + let delta: CGFloat = 1.0 / (CGFloat(colors.count) - 1.0) + + var locations: [CGFloat] = [] + for i in 0 ..< colors.count { + locations.append(delta * CGFloat(i)) + } + let colorSpace = CGColorSpaceCreateDeviceRGB() + let gradient = CGGradient(colorsSpace: colorSpace, colors: gradientColors, locations: &locations)! + + c.saveGState() + c.translateBy(x: arguments.drawingSize.width / 2.0, y: arguments.drawingSize.height / 2.0) + c.rotate(by: CGFloat(customArguments.rotation ?? 0) * CGFloat.pi / -180.0) + c.translateBy(x: -arguments.drawingSize.width / 2.0, y: -arguments.drawingSize.height / 2.0) + + c.drawLinearGradient(gradient, start: CGPoint(x: 0.0, y: 0.0), end: CGPoint(x: 0.0, y: arguments.drawingSize.height), options: CGGradientDrawingOptions()) + c.restoreGState() + } if let fullSizeImage = fullSizeImage { c.setBlendMode(.normal) c.interpolationQuality = .medium c.clip(to: fittedRect, mask: fullSizeImage) - c.setFillColor(patternColor(for: color, intensity: intensity, prominent: prominent).cgColor) - c.fill(arguments.drawingRect) + + if colors.count == 1 { + c.setFillColor(patternColor(for: color, intensity: intensity, prominent: prominent).cgColor) + c.fill(arguments.drawingRect) + } else { + let gradientColors = colors.map { patternColor(for: $0, intensity: intensity, prominent: prominent).cgColor } as CFArray + let delta: CGFloat = 1.0 / (CGFloat(colors.count) - 1.0) + + var locations: [CGFloat] = [] + for i in 0 ..< colors.count { + locations.append(delta * CGFloat(i)) + } + let colorSpace = CGColorSpaceCreateDeviceRGB() + let gradient = CGGradient(colorsSpace: colorSpace, colors: gradientColors, locations: &locations)! + + c.translateBy(x: arguments.drawingSize.width / 2.0, y: arguments.drawingSize.height / 2.0) + c.rotate(by: CGFloat(customArguments.rotation ?? 0) * CGFloat.pi / -180.0) + c.translateBy(x: -arguments.drawingSize.width / 2.0, y: -arguments.drawingSize.height / 2.0) + + c.drawLinearGradient(gradient, start: CGPoint(x: 0.0, y: 0.0), end: CGPoint(x: 0.0, y: arguments.drawingSize.height), options: CGGradientDrawingOptions()) + } } } @@ -490,7 +545,7 @@ public func solidColorImage(_ color: UIColor) -> Signal<(TransformImageArguments }) } -public func gradientImage(_ colors: [UIColor]) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { +public func gradientImage(_ colors: [UIColor], rotation: Int32 = 0) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { guard !colors.isEmpty else { return .complete() } @@ -515,6 +570,10 @@ public func gradientImage(_ colors: [UIColor]) -> Signal<(TransformImageArgument let colorSpace = CGColorSpaceCreateDeviceRGB() let gradient = CGGradient(colorsSpace: colorSpace, colors: gradientColors, locations: &locations)! + c.translateBy(x: arguments.drawingSize.width / 2.0, y: arguments.drawingSize.height / 2.0) + c.rotate(by: CGFloat(rotation) * CGFloat.pi / 180.0) + c.translateBy(x: -arguments.drawingSize.width / 2.0, y: -arguments.drawingSize.height / 2.0) + c.drawLinearGradient(gradient, start: CGPoint(x: 0.0, y: 0.0), end: CGPoint(x: 0.0, y: arguments.drawingSize.height), options: CGGradientDrawingOptions()) } @@ -893,7 +952,7 @@ public func themeImage(account: Account, accountManager: AccountManager, fileRef let _ = accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedScaledImageRepresentation(size: CGSize(width: 720.0, height: 720.0), mode: .aspectFit), complete: true, fetch: true).start() if file.isPattern, let color = file.settings.color, let intensity = file.settings.intensity { - return accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, intensity: intensity), complete: true, fetch: true) + return accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, bottomColor: file.settings.bottomColor, intensity: intensity, rotation: file.settings.rotation), complete: true, fetch: true) |> mapToSignal { data in if data.complete, let data = try? Data(contentsOf: URL(fileURLWithPath: data.path)), let image = UIImage(data: data) { return .single((theme, image, thumbnailData)) @@ -1007,7 +1066,7 @@ public func themeIconImage(account: Account, accountManager: AccountManager, the incomingColor = UIColor(rgb: 0xffffff) if let accentColor = accentColor { if let bubbleColors = bubbleColors { - backgroundColor = UIColor(rgb: 0xffffff) + backgroundColor = UIColor(rgb: 0xd6e2ee) outgoingColor = bubbleColors } else { backgroundColor = accentColor.withMultiplied(hue: 1.019, saturation: 0.867, brightness: 0.965) @@ -1067,7 +1126,7 @@ public func themeIconImage(account: Account, accountManager: AccountManager, the backgroundColor = (.black, nil) case let .file(file): if file.isPattern, let color = file.settings.color { - backgroundColor = (UIColor(rgb: UInt32(bitPattern: color)), nil) + backgroundColor = (UIColor(rgb: UInt32(bitPattern: color)), file.settings.bottomColor.flatMap { UIColor(rgb: UInt32(bitPattern: $0)) }) } else { backgroundColor = (theme.chatList.backgroundColor, nil) } @@ -1085,7 +1144,7 @@ public func themeIconImage(account: Account, accountManager: AccountManager, the let _ = accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedScaledImageRepresentation(size: CGSize(width: 720.0, height: 720.0), mode: .aspectFit), complete: true, fetch: true).start() if file.isPattern, let color = file.settings.color, let intensity = file.settings.intensity { - return accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, intensity: intensity), complete: true, fetch: true) + return accountManager.mediaBox.cachedResourceRepresentation(file.file.resource, representation: CachedPatternWallpaperRepresentation(color: color, bottomColor: file.settings.bottomColor, intensity: intensity, rotation: file.settings.rotation), complete: true, fetch: true) |> mapToSignal { _ in return .complete() } @@ -1174,7 +1233,7 @@ public func themeIconImage(account: Account, accountManager: AccountManager, the c.translateBy(x: -drawingRect.width / 2.0, y: -drawingRect.height / 2.0) c.draw(outgoing!.cgImage!, in: CGRect(x: 9.0, y: 12.0, width: 57.0, height: 16.0)) } - + addCorners(context, arguments: arguments) return context } }