diff --git a/.gitmodules b/.gitmodules index 3ea55256ad..965d7fd310 100644 --- a/.gitmodules +++ b/.gitmodules @@ -22,4 +22,4 @@ url=https://github.com/bazelbuild/rules_apple.git url = https://chromium.googlesource.com/chromium/tools/depot_tools.git [submodule "third-party/webrtc/webrtc-ios"] path = third-party/webrtc/webrtc-ios -url=../webrtc-ios.git +url=https://github.com/ali-fareed/webrtc-ios.git diff --git a/Makefile b/Makefile index 1658b08759..6dee5a27ea 100644 --- a/Makefile +++ b/Makefile @@ -3,7 +3,7 @@ include Utils.makefile -APP_VERSION="6.2" +APP_VERSION="6.2.1" CORE_COUNT=$(shell sysctl -n hw.logicalcpu) CORE_COUNT_MINUS_ONE=$(shell expr ${CORE_COUNT} \- 1) diff --git a/Telegram/NotificationService/Serialization.m b/Telegram/NotificationService/Serialization.m index f886eaeea4..80295733b7 100644 --- a/Telegram/NotificationService/Serialization.m +++ b/Telegram/NotificationService/Serialization.m @@ -3,7 +3,7 @@ @implementation Serialization - (NSUInteger)currentLayer { - return 114; + return 115; } - (id _Nullable)parseMessage:(NSData * _Nullable)data { diff --git a/Telegram/Telegram-iOS/en.lproj/Localizable.strings b/Telegram/Telegram-iOS/en.lproj/Localizable.strings index 1086610d45..63a6c83733 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -5522,5 +5522,19 @@ Any member of this group will be able to see messages in the channel."; "Conversation.Timer.Title" = "Send With Timer"; "Conversation.Timer.Send" = "Send With Timer"; +"Paint.Pen" = "Pen"; +"Paint.Marker" = "Marker"; +"Paint.Neon" = "Neon"; +"Paint.Arrow" = "Arrow"; + "Conversation.NoticeInvitedByInChannel" = "%@ invited you to this channel"; "Conversation.NoticeInvitedByInGroup" = "%@ invited you to this group"; + +"ChatList.MessagePhotos_1" = "1 Photo"; +"ChatList.MessagePhotos_any" = "%@ Photos"; +"ChatList.MessageVideos_1" = "1 Videos"; +"ChatList.MessageVideos_any" = "%@ Videos"; + +"Conversation.PrivateChannelTimeLimitedAlertTitle" = "Join Channel"; +"Conversation.PrivateChannelTimeLimitedAlertText" = "This channel is private. Please join it to continue viewing its content."; +"Conversation.PrivateChannelTimeLimitedAlertJoin" = "Join"; diff --git a/submodules/AccountContext/Sources/AccountContext.swift b/submodules/AccountContext/Sources/AccountContext.swift index 8fc8f16b71..22747dc95c 100644 --- a/submodules/AccountContext/Sources/AccountContext.swift +++ b/submodules/AccountContext/Sources/AccountContext.swift @@ -192,6 +192,16 @@ public enum NavigateToChatKeepStack { case never } +public final class ChatPeekTimeout { + public let deadline: Int32 + public let linkData: String + + public init(deadline: Int32, linkData: String) { + self.deadline = deadline + self.linkData = linkData + } +} + public final class NavigateToChatControllerParams { public let navigationController: NavigationController public let chatController: ChatController? @@ -206,12 +216,13 @@ public final class NavigateToChatControllerParams { public let purposefulAction: (() -> Void)? public let scrollToEndIfExists: Bool public let activateMessageSearch: Bool + public let peekData: ChatPeekTimeout? public let animated: Bool public let options: NavigationAnimationOptions public let parentGroupId: PeerGroupId? public let completion: (ChatController) -> Void - public init(navigationController: NavigationController, chatController: ChatController? = nil, context: AccountContext, chatLocation: ChatLocation, subject: ChatControllerSubject? = nil, botStart: ChatControllerInitialBotStart? = nil, updateTextInputState: ChatTextInputState? = nil, activateInput: Bool = false, keepStack: NavigateToChatKeepStack = .default, useExisting: Bool = true, purposefulAction: (() -> Void)? = nil, scrollToEndIfExists: Bool = false, activateMessageSearch: Bool = false, animated: Bool = true, options: NavigationAnimationOptions = [], parentGroupId: PeerGroupId? = nil, completion: @escaping (ChatController) -> Void = { _ in }) { + public init(navigationController: NavigationController, chatController: ChatController? = nil, context: AccountContext, chatLocation: ChatLocation, subject: ChatControllerSubject? = nil, botStart: ChatControllerInitialBotStart? = nil, updateTextInputState: ChatTextInputState? = nil, activateInput: Bool = false, keepStack: NavigateToChatKeepStack = .default, useExisting: Bool = true, purposefulAction: (() -> Void)? = nil, scrollToEndIfExists: Bool = false, activateMessageSearch: Bool = false, peekData: ChatPeekTimeout? = nil, animated: Bool = true, options: NavigationAnimationOptions = [], parentGroupId: PeerGroupId? = nil, completion: @escaping (ChatController) -> Void = { _ in }) { self.navigationController = navigationController self.chatController = chatController self.context = context @@ -225,6 +236,7 @@ public final class NavigateToChatControllerParams { self.purposefulAction = purposefulAction self.scrollToEndIfExists = scrollToEndIfExists self.activateMessageSearch = activateMessageSearch + self.peekData = peekData self.animated = animated self.options = options self.parentGroupId = parentGroupId diff --git a/submodules/AccountContext/Sources/ChatController.swift b/submodules/AccountContext/Sources/ChatController.swift index 0fc0720950..e0fe69e795 100644 --- a/submodules/AccountContext/Sources/ChatController.swift +++ b/submodules/AccountContext/Sources/ChatController.swift @@ -27,7 +27,7 @@ public struct ChatControllerInitialBotStart { public enum ChatControllerInteractionNavigateToPeer { case `default` - case chat(textInputState: ChatTextInputState?, subject: ChatControllerSubject?) + case chat(textInputState: ChatTextInputState?, subject: ChatControllerSubject?, peekData: ChatPeekTimeout?) case info case withBotStartPayload(ChatControllerInitialBotStart) } diff --git a/submodules/AlertUI/Sources/ThemedTextAlertController.swift b/submodules/AlertUI/Sources/ThemedTextAlertController.swift index e59dafd6d4..8cd9de35ac 100644 --- a/submodules/AlertUI/Sources/ThemedTextAlertController.swift +++ b/submodules/AlertUI/Sources/ThemedTextAlertController.swift @@ -13,8 +13,8 @@ public final class AlertControllerContext { } } -public func textAlertController(alertContext: AlertControllerContext, title: String?, text: String, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, allowInputInset: Bool = true) -> AlertController { - let controller = standardTextAlertController(theme: alertContext.theme, title: title, text: text, actions: actions, actionLayout: actionLayout, allowInputInset: allowInputInset) +public func textAlertController(alertContext: AlertControllerContext, title: String?, text: String, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, allowInputInset: Bool = true, dismissOnOutsideTap: Bool = true) -> AlertController { + let controller = standardTextAlertController(theme: alertContext.theme, title: title, text: text, actions: actions, actionLayout: actionLayout, allowInputInset: allowInputInset, dismissOnOutsideTap: dismissOnOutsideTap) let presentationDataDisposable = alertContext.themeSignal.start(next: { [weak controller] theme in controller?.theme = theme }) @@ -36,7 +36,7 @@ public func richTextAlertController(alertContext: AlertControllerContext, title: } action.action() }) - }, actionLayout: actionLayout), allowInputInset: allowInputInset) + }, actionLayout: actionLayout, dismissOnOutsideTap: true), allowInputInset: allowInputInset) dismissImpl = { [weak controller] in controller?.dismissAnimated() } diff --git a/submodules/AvatarNode/Sources/AvatarNode.swift b/submodules/AvatarNode/Sources/AvatarNode.swift index 063a7ad1af..6299364116 100644 --- a/submodules/AvatarNode/Sources/AvatarNode.swift +++ b/submodules/AvatarNode/Sources/AvatarNode.swift @@ -330,7 +330,7 @@ public final class AvatarNode: ASDisplayNode { if let peer = peer, let signal = peerAvatarImage(account: context.account, peerReference: PeerReference(peer), authorOfMessage: authorOfMessage, representation: representation, displayDimensions: displayDimensions, emptyColor: emptyColor, synchronousLoad: synchronousLoad, provideUnrounded: storeUnrounded) { self.contents = nil self.displaySuspended = true - self.imageReady.set(self.imageNode.ready) + self.imageReady.set(self.imageNode.contentReady) self.imageNode.setSignal(signal |> beforeNext { [weak self] next in Queue.mainQueue().async { self?.unroundedImage = next?.1 diff --git a/submodules/ChatListUI/Sources/ChatListControllerNode.swift b/submodules/ChatListUI/Sources/ChatListControllerNode.swift index d847718d60..6f4eb396bf 100644 --- a/submodules/ChatListUI/Sources/ChatListControllerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListControllerNode.swift @@ -200,7 +200,7 @@ private final class ChatListShimmerNode: ASDisplayNode { }, present: { _ in }) let items = (0 ..< 2).map { _ -> ChatListItem in - return ChatListItem(presentationData: chatListPresentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer1, text: "Text", attributes: [], media: [], peers: peers, associatedMessages: SimpleDictionary(), associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) + return ChatListItem(presentationData: chatListPresentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer1, text: "Text", attributes: [], media: [], peers: peers, associatedMessages: SimpleDictionary(), associatedMessageIds: [])], peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) } var itemNodes: [ChatListItemNode] = [] diff --git a/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift b/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift index 2ccb196620..33af650006 100644 --- a/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift +++ b/submodules/ChatListUI/Sources/ChatListSearchContainerNode.swift @@ -485,7 +485,7 @@ public enum ChatListSearchEntry: Comparable, Identifiable { } }) case let .message(message, peer, readState, presentationData): - return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(message: message, peer: peer, combinedReadState: readState, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: true, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) + return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(messages: [message], peer: peer, combinedReadState: readState, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: true, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: enableHeaders ? ChatListSearchItemHeader(type: .messages, theme: presentationData.theme, strings: presentationData.strings, actionTitle: nil, action: nil) : nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) case let .addContact(phoneNumber, theme, strings): return ContactsAddItem(theme: theme, strings: strings, phoneNumber: phoneNumber, header: ChatListSearchItemHeader(type: .phoneNumber, theme: theme, strings: strings, actionTitle: nil, action: nil), action: { interaction.addContact(phoneNumber) @@ -1385,8 +1385,8 @@ public final class ChatListSearchContainerNode: SearchDisplayControllerContentNo bounds = selectedItemNode.bounds } switch item.content { - case let .peer(message, peer, _, _, _, _, _, _, _, _, _, _): - return (selectedItemNode.view, bounds, message?.id ?? peer.peerId) + case let .peer(messages, peer, _, _, _, _, _, _, _, _, _, _): + return (selectedItemNode.view, bounds, messages.last?.id ?? peer.peerId) case let .groupReference(groupId, _, _, _, _): return (selectedItemNode.view, bounds, groupId) } diff --git a/submodules/ChatListUI/Sources/Node/ChatListItem.swift b/submodules/ChatListUI/Sources/Node/ChatListItem.swift index c9a4c168ed..089974b675 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListItem.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListItem.swift @@ -20,7 +20,7 @@ import ChatListSearchItemNode import ContextUI public enum ChatListItemContent { - case peer(message: Message?, peer: RenderedPeer, combinedReadState: CombinedPeerReadState?, isRemovedFromTotalUnreadCount: Bool, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, embeddedState: PeerChatListEmbeddedInterfaceState?, inputActivities: [(Peer, PeerInputActivity)]?, promoInfo: ChatListNodeEntryPromoInfo?, ignoreUnreadBadge: Bool, displayAsMessage: Bool, hasFailedMessages: Bool) + case peer(messages: [Message], peer: RenderedPeer, combinedReadState: CombinedPeerReadState?, isRemovedFromTotalUnreadCount: Bool, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, embeddedState: PeerChatListEmbeddedInterfaceState?, inputActivities: [(Peer, PeerInputActivity)]?, promoInfo: ChatListNodeEntryPromoInfo?, ignoreUnreadBadge: Bool, displayAsMessage: Bool, hasFailedMessages: Bool) case groupReference(groupId: PeerGroupId, peers: [ChatListGroupReferencePeer], message: Message?, unreadState: PeerGroupUnreadCountersCombinedSummary, hiddenByDefault: Bool) public var chatLocation: ChatLocation? { @@ -124,8 +124,8 @@ public class ChatListItem: ListViewItem, ChatListSearchItemNeighbour { public func selected(listView: ListView) { switch self.content { - case let .peer(message, peer, _, _, _, _, _, _, promoInfo, _, _, _): - if let message = message, let peer = peer.peer { + case let .peer(messages, peer, _, _, _, _, _, _, promoInfo, _, _, _): + if let message = messages.last, let peer = peer.peer { self.interaction.messageSelected(peer, message, promoInfo) } else if let peer = peer.peer { self.interaction.peerSelected(peer, promoInfo) @@ -328,6 +328,61 @@ private final class CachedChatListSearchResult { } } +private final class ChatListMediaPreviewNode: ASDisplayNode { + private let context: AccountContext + private let message: Message + private let media: Media + + private let imageNode: TransformImageNode + + private var requestedImage: Bool = false + private var disposable: Disposable? + + init(context: AccountContext, message: Message, media: Media) { + self.context = context + self.message = message + self.media = media + + self.imageNode = TransformImageNode() + + super.init() + + self.addSubnode(self.imageNode) + } + + deinit { + self.disposable?.dispose() + } + + func updateLayout(size: CGSize, synchronousLoads: Bool) { + var dimensions = CGSize(width: 100.0, height: 100.0) + if let image = self.media as? TelegramMediaImage { + if let largest = largestImageRepresentation(image.representations) { + dimensions = largest.dimensions.cgSize + if !self.requestedImage { + self.requestedImage = true + let signal = mediaGridMessagePhoto(account: self.context.account, photoReference: .message(message: MessageReference(self.message), media: image), fullRepresentationSize: CGSize(width: 36.0, height: 36.0), synchronousLoad: synchronousLoads) + self.imageNode.setSignal(signal, attemptSynchronously: synchronousLoads) + } + } + } else if let file = self.media as? TelegramMediaFile { + if let mediaDimensions = file.dimensions { + dimensions = mediaDimensions.cgSize + if !self.requestedImage { + self.requestedImage = true + let signal = mediaGridMessageVideo(postbox: self.context.account.postbox, videoReference: .message(message: MessageReference(self.message), media: file), synchronousLoad: synchronousLoads, autoFetchFullSizeThumbnail: true, useMiniThumbnailIfAvailable: true) + self.imageNode.setSignal(signal, attemptSynchronously: synchronousLoads) + } + } + } + + let makeLayout = self.imageNode.asyncLayout() + self.imageNode.frame = CGRect(origin: CGPoint(), size: size) + let apply = makeLayout(TransformImageArguments(corners: ImageCorners(radius: 2.0), imageSize: dimensions.aspectFilled(size), boundingSize: size, intrinsicInsets: UIEdgeInsets())) + apply() + } +} + class ChatListItemNode: ItemListRevealOptionsItemNode { var item: ChatListItem? @@ -342,7 +397,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let measureNode: TextNode private var currentItemHeight: CGFloat? let textNode: TextNode - let contentImageNode: TransformImageNode let inputActivitiesNode: ChatListInputActivitiesNode let dateNode: TextNode let separatorNode: ASDisplayNode @@ -355,6 +409,10 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var credibilityIconNode: ASImageNode? let mutedIconNode: ASImageNode + private var currentTextLeftCutout: CGFloat = 0.0 + private var currentMediaPreviewSpecs: [(message: Message, media: Media, size: CGSize)] = [] + private var mediaPreviewNodes: [MediaId: ChatListMediaPreviewNode] = [:] + var selectableControlNode: ItemListSelectableControlNode? var reorderControlNode: ItemListEditableReorderControlNode? @@ -364,7 +422,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { private var cachedChatListSearchResult: CachedChatListSearchResult? var layoutParams: (ChatListItem, first: Bool, last: Bool, firstWithHeader: Bool, nextIsPinned: Bool, ListViewItemLayoutParams, countersSize: CGFloat)? - private var contentImageMedia: Media? private var isHighlighted: Bool = false private var skipFadeout: Bool = false @@ -423,14 +480,14 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { case .groupReference: return nil case let .peer(peer): - if let message = peer.message { + if let message = peer.messages.last { var result = "" if message.flags.contains(.Incoming) { result += "Message" } else { result += "Outgoing message" } - let (_, initialHideAuthor, messageText) = chatListItemStrings(strings: item.presentationData.strings, nameDisplayOrder: item.presentationData.nameDisplayOrder, message: peer.message, chatPeer: peer.peer, accountPeerId: item.context.account.peerId, isPeerGroup: false) + let (_, initialHideAuthor, messageText) = chatListItemStrings(strings: item.presentationData.strings, nameDisplayOrder: item.presentationData.nameDisplayOrder, messages: peer.messages, chatPeer: peer.peer, accountPeerId: item.context.account.peerId, isPeerGroup: false) if message.flags.contains(.Incoming), !initialHideAuthor, let author = message.author, author is TelegramUser { result += "\nFrom: \(author.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder))" } @@ -473,9 +530,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { self.textNode.isUserInteractionEnabled = false self.textNode.displaysAsynchronously = true - self.contentImageNode = TransformImageNode() - self.contentImageNode.isHidden = true - self.inputActivitiesNode = ChatListInputActivitiesNode() self.inputActivitiesNode.isUserInteractionEnabled = false self.inputActivitiesNode.alpha = 0.0 @@ -517,7 +571,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { self.contextContainer.addSubnode(self.titleNode) self.contextContainer.addSubnode(self.authorNode) self.contextContainer.addSubnode(self.textNode) - self.contextContainer.addSubnode(self.contentImageNode) self.contextContainer.addSubnode(self.dateNode) self.contextContainer.addSubnode(self.statusNode) self.contextContainer.addSubnode(self.pinnedIconNode) @@ -548,9 +601,9 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var displayAsMessage = false var enablePreview = true switch item.content { - case let .peer(message, peerValue, _, _, _, _, _, _, _, _, displayAsMessageValue, _): + case let .peer(messages, peerValue, _, _, _, _, _, _, _, _, displayAsMessageValue, _): displayAsMessage = displayAsMessageValue - if displayAsMessage, let author = message?.author as? TelegramUser { + if displayAsMessage, let author = messages.last?.author as? TelegramUser { peer = author } else { peer = peerValue.chatMainPeer @@ -674,7 +727,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let reorderControlLayout = ItemListEditableReorderControlNode.asyncLayout(self.reorderControlNode) let currentItem = self.layoutParams?.0 - let currentContentImageMedia = self.contentImageMedia let currentChatListText = self.cachedChatListText let currentChatListSearchResult = self.cachedChatListSearchResult @@ -685,7 +737,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { let badgeFont = Font.regular(floor(item.presentationData.fontSize.itemListBaseFontSize * 14.0 / 17.0)) let account = item.context.account - var message: Message? + var messages: [Message] enum ContentPeer { case chat(RenderedPeer) case group([ChatListGroupReferencePeer]) @@ -706,8 +758,8 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var groupHiddenByDefault = false switch item.content { - case let .peer(messageValue, peerValue, combinedReadStateValue, isRemovedFromTotalUnreadCountValue, peerPresenceValue, summaryInfoValue, embeddedStateValue, inputActivitiesValue, promoInfoValue, ignoreUnreadBadge, displayAsMessageValue, hasFailedMessagesValue): - message = messageValue + case let .peer(messagesValue, peerValue, combinedReadStateValue, isRemovedFromTotalUnreadCountValue, peerPresenceValue, summaryInfoValue, embeddedStateValue, inputActivitiesValue, promoInfoValue, ignoreUnreadBadge, displayAsMessageValue, hasFailedMessagesValue): + messages = messagesValue contentPeer = .chat(peerValue) combinedReadState = combinedReadStateValue if let combinedReadState = combinedReadState, promoInfoValue == nil && !ignoreUnreadBadge { @@ -729,14 +781,18 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { isPeerGroup = false promoInfo = promoInfoValue displayAsMessage = displayAsMessageValue - hasFailedMessages = messageValue?.flags.contains(.Failed) ?? false // hasFailedMessagesValue + hasFailedMessages = messagesValue.last?.flags.contains(.Failed) ?? false // hasFailedMessagesValue case let .groupReference(_, peers, messageValue, unreadState, hiddenByDefault): if let _ = messageValue, !peers.isEmpty { contentPeer = .chat(peers[0].peer) } else { contentPeer = .group(peers) } - message = messageValue + if let message = messageValue { + messages = [message] + } else { + messages = [] + } combinedReadState = nil isRemovedFromTotalUnreadCount = false embeddedState = nil @@ -752,10 +808,10 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { hasFailedMessages = false } - if let messageValue = message { + if let messageValue = messages.last { for media in messageValue.media { if let media = media as? TelegramMediaAction, case .historyCleared = media.action { - message = nil + messages = [] } } } @@ -824,7 +880,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var hideAuthor = false switch contentPeer { case let .chat(itemPeer): - var (peer, initialHideAuthor, messageText) = chatListItemStrings(strings: item.presentationData.strings, nameDisplayOrder: item.presentationData.nameDisplayOrder, message: message, chatPeer: itemPeer, accountPeerId: item.context.account.peerId, enableMediaEmoji: !enableChatListPhotos, isPeerGroup: isPeerGroup) + var (peer, initialHideAuthor, messageText) = chatListItemStrings(strings: item.presentationData.strings, nameDisplayOrder: item.presentationData.nameDisplayOrder, messages: messages, chatPeer: itemPeer, accountPeerId: item.context.account.peerId, enableMediaEmoji: !enableChatListPhotos, isPeerGroup: isPeerGroup) if case let .psa(_, maybePsaText) = promoInfo, let psaText = maybePsaText { initialHideAuthor = true @@ -843,19 +899,23 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var inlineAuthorPrefix: String? if case .groupReference = item.content { - if let author = message?.author as? TelegramUser { + if let author = messages.last?.author as? TelegramUser { if author.id == item.context.account.peerId { inlineAuthorPrefix = item.presentationData.strings.DialogList_You - } else if message?.id.peerId.namespace != Namespaces.Peer.CloudUser && message?.id.peerId.namespace != Namespaces.Peer.SecretChat { + } else if messages.last?.id.peerId.namespace != Namespaces.Peer.CloudUser && messages.last?.id.peerId.namespace != Namespaces.Peer.SecretChat { inlineAuthorPrefix = author.compactDisplayTitle } } } - var contentImageMedia: Media? var chatListText: (String, String)? var chatListSearchResult: CachedChatListSearchResult? + let contentImageSize = CGSize(width: 18.0, height: 18.0) + let contentImageSpacing: CGFloat = 2.0 + let contentImageTrailingSpace: CGFloat = 5.0 + var contentImageSpecs: [(message: Message, media: Media, size: CGSize)] = [] + switch contentData { case let .chat(itemPeer, _, _, text): var peerText: String? @@ -863,7 +923,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { if let messagePeer = itemPeer.chatMainPeer { peerText = messagePeer.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder) } - } else if let message = message, let author = message.author as? TelegramUser, let peer = itemPeer.chatMainPeer, !(peer is TelegramUser) { + } else if let message = messages.last, let author = message.author as? TelegramUser, let peer = itemPeer.chatMainPeer, !(peer is TelegramUser) { if let peer = peer as? TelegramChannel, case .broadcast = peer.info { } else if !displayAsMessage { peerText = author.id == account.peerId ? item.presentationData.strings.DialogList_You : author.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder) @@ -884,7 +944,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { authorAttributedString = NSAttributedString(string: item.presentationData.strings.DialogList_Draft, font: textFont, textColor: theme.messageDraftTextColor) attributedText = NSAttributedString(string: foldLineBreaks(embeddedState.text.string.replacingOccurrences(of: "\n\n", with: " ")), font: textFont, textColor: theme.messageTextColor) - } else if let message = message { + } else if let message = messages.last { let composedString: NSMutableAttributedString if let inlineAuthorPrefix = inlineAuthorPrefix { composedString = NSMutableAttributedString() @@ -920,28 +980,52 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { authorAttributedString = NSAttributedString(string: peerText, font: textFont, textColor: theme.authorNameColor) } - if enableChatListPhotos && !message.containsSecretMedia { - for media in message.media { - if let image = media as? TelegramMediaImage { - textLeftCutout += 26.0 - contentImageMedia = image - break - } else if let file = media as? TelegramMediaFile { - if file.isVideo && !file.isInstantVideo { - textLeftCutout += 26.0 - contentImageMedia = file - break - } - } else if let webpage = media as? TelegramMediaWebpage, case let .Loaded(content) = webpage.content { - if let image = content.image { - textLeftCutout += 26.0 - contentImageMedia = image - break - } else if let file = content.file { - if file.isVideo && !file.isInstantVideo { - textLeftCutout += 26.0 - contentImageMedia = file - break + var displayMediaPreviews = true + if message.containsSecretMedia { + displayMediaPreviews = false + } else if let _ = message.peers[message.id.peerId] as? TelegramSecretChat { + displayMediaPreviews = false + } + if !item.context.sharedContext.immediateExperimentalUISettings.chatListPhotos { + displayMediaPreviews = false + } + if displayMediaPreviews { + let contentImageFillSize = CGSize(width: 8.0, height: contentImageSize.height) + _ = contentImageFillSize + for message in messages { + inner: for media in message.media { + if let image = media as? TelegramMediaImage { + if let _ = largestImageRepresentation(image.representations) { + //let imageSize = largest.dimensions.cgSize + //let fitSize = imageSize.aspectFilled(contentImageFillSize) + let fitSize = contentImageSize + contentImageSpecs.append((message, image, fitSize)) + } + break inner + } else if let file = media as? TelegramMediaFile { + if file.isVideo, !file.isInstantVideo, let _ = file.dimensions { + //let imageSize = dimensions.cgSize + //let fitSize = imageSize.aspectFilled(contentImageFillSize) + let fitSize = contentImageSize + contentImageSpecs.append((message, file, fitSize)) + } + break inner + } else if let webpage = media as? TelegramMediaWebpage, case let .Loaded(content) = webpage.content { + let imageTypes = ["photo", "video", "embed", "gif", "document", "telegram_album"] + if let image = content.image, let type = content.type, imageTypes.contains(type) { + if let _ = largestImageRepresentation(image.representations) { + //let imageSize = largest.dimensions.cgSize + let fitSize = contentImageSize + contentImageSpecs.append((message, image, fitSize)) + } + break inner + } else if let file = content.file { + if file.isVideo, !file.isInstantVideo, let _ = file.dimensions { + //let imageSize = dimensions.cgSize + let fitSize = contentImageSize + contentImageSpecs.append((message, file, fitSize)) + } + break inner } } } @@ -980,9 +1064,19 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { attributedText = textString } + for i in 0 ..< contentImageSpecs.count { + if i != 0 { + textLeftCutout += contentImageSpacing + } + textLeftCutout += contentImageSpecs[i].size.width + if i == contentImageSpecs.count - 1 { + textLeftCutout += contentImageTrailingSpace + } + } + switch contentData { case let .chat(itemPeer, _, _, _): - if let message = message, let author = message.author as? TelegramUser, displayAsMessage { + if let message = messages.last, let author = message.author as? TelegramUser, displayAsMessage { titleAttributedString = NSAttributedString(string: author.id == account.peerId ? item.presentationData.strings.DialogList_You : author.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder), font: titleFont, textColor: theme.titleColor) } else if isPeerGroup { titleAttributedString = NSAttributedString(string: item.presentationData.strings.ChatList_ArchivedChatsTitle, font: titleFont, textColor: theme.titleColor) @@ -1024,7 +1118,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { dateAttributedString = NSAttributedString(string: dateText, font: dateFont, textColor: theme.dateTextColor) } - if !isPeerGroup, let message = message, message.author?.id == account.peerId && !hasDraft { + if !isPeerGroup, let message = messages.last, message.author?.id == account.peerId && !hasDraft { if message.flags.isSending && !message.isSentOrAcknowledged { statusState = .clock(PresentationResourcesChatList.clockFrameImage(item.presentationData.theme), PresentationResourcesChatList.clockMinImage(item.presentationData.theme)) } else if message.id.peerId != account.peerId { @@ -1041,7 +1135,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } if unreadCount.unread { - if !isPeerGroup, let message = message, message.tags.contains(.unseenPersonalMessage), unreadCount.count == 1 { + if !isPeerGroup, let message = messages.last, message.tags.contains(.unseenPersonalMessage), unreadCount.count == 1 { } else { let badgeTextColor: UIColor if unreadCount.muted { @@ -1111,8 +1205,8 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { var credibilityIconOffset: CGFloat = 0.0 if displayAsMessage { switch item.content { - case let .peer(message, _, _, _, _, _, _, _, _, _, _, _): - if let peer = message?.author { + case let .peer(messages, _, _, _, _, _, _, _, _, _, _, _): + if let peer = messages.last?.author { if peer.isScam { currentCredibilityIconImage = PresentationResourcesChatList.scamIcon(item.presentationData.theme, type: .regular) credibilityIconOffset = 2.0 @@ -1184,7 +1278,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { if !textLeftCutout.isZero { textCutout = TextNodeCutout(topLeft: CGSize(width: textLeftCutout, height: 10.0), topRight: nil, bottomRight: nil) } - let (textLayout, textApply) = textLayout(TextNodeLayoutArguments(attributedString: textAttributedString, backgroundColor: nil, maximumNumberOfLines: authorAttributedString == nil ? 2 : 1, truncationType: .end, constrainedSize: CGSize(width: rawContentWidth - badgeSize - textLeftCutout, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: textCutout, insets: UIEdgeInsets(top: 2.0, left: 1.0, bottom: 2.0, right: 1.0))) + let (textLayout, textApply) = textLayout(TextNodeLayoutArguments(attributedString: textAttributedString, backgroundColor: nil, maximumNumberOfLines: authorAttributedString == nil ? 2 : 1, truncationType: .end, constrainedSize: CGSize(width: rawContentWidth - badgeSize, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: textCutout, insets: UIEdgeInsets(top: 2.0, left: 1.0, bottom: 2.0, right: 1.0))) let titleRectWidth = rawContentWidth - dateLayout.size.width - 10.0 - statusWidth - titleIconsWidth let (titleLayout, titleApply) = titleLayout(TextNodeLayoutArguments(attributedString: titleAttributedString, backgroundColor: nil, maximumNumberOfLines: 1, truncationType: .end, constrainedSize: CGSize(width: titleRectWidth, height: CGFloat.greatestFiniteMagnitude), alignment: .natural, cutout: nil, insets: UIEdgeInsets())) @@ -1241,20 +1335,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { peerLeftRevealOptions = [] } - var updateImageSignal: Signal<(TransformImageArguments) -> DrawingContext?, NoError>? - if let contentImageMedia = contentImageMedia { - if let currentContentImageMedia = currentContentImageMedia, contentImageMedia.isSemanticallyEqual(to: currentContentImageMedia) { - } else { - if let message = message { - if let image = contentImageMedia as? TelegramMediaImage { - updateImageSignal = mediaGridMessagePhoto(account: item.context.account, photoReference: .message(message: MessageReference(message), media: image)) - } else if let file = contentImageMedia as? TelegramMediaFile { - updateImageSignal = mediaGridMessageVideo(postbox: item.context.account.postbox, videoReference: .message(message: MessageReference(message), media: file), autoFetchFullSizeThumbnail: true) - } - } - } - } - let (onlineLayout, onlineApply) = onlineLayout(online) var animateContent = false if let currentItem = currentItem, currentItem.content.chatLocation == item.content.chatLocation { @@ -1287,8 +1367,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } let layout = ListViewItemNodeLayout(contentSize: CGSize(width: params.width, height: max(0.0, itemHeight + heightOffset)), insets: insets) - let contentImageSize = CGSize(width: 18.0, height: 18.0) - var customActions: [ChatListItemAccessibilityCustomAction] = [] for option in peerLeftRevealOptions { customActions.append(ChatListItemAccessibilityCustomAction(name: option.title, target: nil, selector: #selector(ChatListItemNode.performLocalAccessibilityCustomAction(_:)), key: option.key)) @@ -1301,42 +1379,11 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { if let strongSelf = self { strongSelf.layoutParams = (item, first, last, firstWithHeader, nextIsPinned, params, countersSize) strongSelf.currentItemHeight = itemHeight - strongSelf.contentImageMedia = contentImageMedia strongSelf.cachedChatListText = chatListText strongSelf.cachedChatListSearchResult = chatListSearchResult strongSelf.contextContainer.frame = CGRect(origin: CGPoint(), size: layout.contentSize) - var dimensions: CGSize? - if let contentImageMedia = contentImageMedia as? TelegramMediaImage { - dimensions = largestRepresentationForPhoto(contentImageMedia)?.dimensions.cgSize - } else if let contentImageMedia = contentImageMedia as? TelegramMediaFile { - dimensions = contentImageMedia.dimensions?.cgSize - } - - var contentImageNodeAppeared = false - if let dimensions = dimensions { - let makeImageLayout = strongSelf.contentImageNode.asyncLayout() - let imageSize = contentImageSize - - let applyImageLayout = makeImageLayout(TransformImageArguments(corners: ImageCorners(radius: 2.0), imageSize: dimensions.aspectFilled(imageSize), boundingSize: imageSize, intrinsicInsets: UIEdgeInsets())) - applyImageLayout() - - if let updateImageSignal = updateImageSignal { - strongSelf.contentImageNode.setSignal(updateImageSignal) - if currentContentImageMedia == nil { - strongSelf.contentImageNode.isHidden = false - contentImageNodeAppeared = true - } - } - } else { - if currentContentImageMedia != nil { - strongSelf.contentImageNode.removeFromSupernode() - strongSelf.contentImageNode.setSignal(.single({ _ in nil })) - strongSelf.contentImageNode.isHidden = true - } - } - if case .groupReference = item.content { strongSelf.layer.sublayerTransform = CATransform3DMakeTranslation(0.0, layout.contentSize.height - itemHeight, 0.0) } @@ -1541,12 +1588,6 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { strongSelf.authorNode.frame = authorNodeFrame let textNodeFrame = CGRect(origin: CGPoint(x: contentRect.origin.x, y: contentRect.minY + titleLayout.size.height - 1.0 + UIScreenPixel + (authorLayout.size.height.isZero ? 0.0 : (authorLayout.size.height - 3.0))), size: textLayout.size) strongSelf.textNode.frame = textNodeFrame - let contentImageFrame = CGRect(origin: textNodeFrame.origin.offsetBy(dx: 1.0, dy: 2.0), size: contentImageSize) - if contentImageNodeAppeared { - strongSelf.contentImageNode.frame = contentImageFrame - } else { - transition.updateFrame(node: strongSelf.contentImageNode, frame: contentImageFrame) - } var animateInputActivitiesFrame = false if let inputActivities = inputActivities, !inputActivities.isEmpty { @@ -1586,7 +1627,7 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } } if let inputActivitiesSize = inputActivitiesSize { - let inputActivitiesFrame = CGRect(origin: CGPoint(x: authorNodeFrame.minX + 1.0, y: authorNodeFrame.minY + UIScreenPixel), size: inputActivitiesSize) + let inputActivitiesFrame = CGRect(origin: CGPoint(x: contentRect.minX, y: authorNodeFrame.minY + UIScreenPixel), size: inputActivitiesSize) if animateInputActivitiesFrame { transition.updateFrame(node: strongSelf.inputActivitiesNode, frame: inputActivitiesFrame) } else { @@ -1595,6 +1636,43 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } inputActivitiesApply?() + var mediaPreviewOffset = textNodeFrame.origin.offsetBy(dx: 1.0, dy: 2.0) + var validMediaIds: [MediaId] = [] + for (message, media, mediaSize) in contentImageSpecs { + guard let mediaId = media.id else { + continue + } + validMediaIds.append(mediaId) + let previewNode: ChatListMediaPreviewNode + var previewNodeTransition = transition + var previewNodeAlphaTransition: ContainedViewLayoutTransition = .animated(duration: 0.15, curve: .easeInOut) + if let current = strongSelf.mediaPreviewNodes[mediaId] { + previewNode = current + } else { + previewNodeTransition = .immediate + previewNodeAlphaTransition = .immediate + previewNode = ChatListMediaPreviewNode(context: item.context, message: message, media: media) + strongSelf.mediaPreviewNodes[mediaId] = previewNode + strongSelf.contextContainer.addSubnode(previewNode) + } + previewNode.updateLayout(size: mediaSize, synchronousLoads: synchronousLoads) + previewNodeAlphaTransition.updateAlpha(node: previewNode, alpha: strongSelf.inputActivitiesNode.alpha.isZero ? 1.0 : 0.0) + previewNodeTransition.updateFrame(node: previewNode, frame: CGRect(origin: mediaPreviewOffset, size: mediaSize)) + mediaPreviewOffset.x += mediaSize.width + contentImageSpacing + } + var removeMediaIds: [MediaId] = [] + for (mediaId, itemNode) in strongSelf.mediaPreviewNodes { + if !validMediaIds.contains(mediaId) { + removeMediaIds.append(mediaId) + itemNode.removeFromSupernode() + } + } + for mediaId in removeMediaIds { + strongSelf.mediaPreviewNodes.removeValue(forKey: mediaId) + } + strongSelf.currentMediaPreviewSpecs = contentImageSpecs + strongSelf.currentTextLeftCutout = textLeftCutout + if !contentDelta.x.isZero || !contentDelta.y.isZero { let titlePosition = strongSelf.titleNode.position transition.animatePosition(node: strongSelf.titleNode, from: CGPoint(x: titlePosition.x - contentDelta.x, y: titlePosition.y - contentDelta.y)) @@ -1749,9 +1827,17 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { textFrame.origin.x = contentRect.origin.x transition.updateFrameAdditive(node: self.textNode, frame: textFrame) - var contentImageFrame = self.contentImageNode.frame - contentImageFrame.origin = textFrame.origin.offsetBy(dx: 1.0, dy: 2.0) - transition.updateFrame(node: self.contentImageNode, frame: contentImageFrame) + var mediaPreviewOffset = textFrame.origin.offsetBy(dx: 1.0, dy: 2.0) + let contentImageSpacing: CGFloat = 2.0 + for (_, media, mediaSize) in self.currentMediaPreviewSpecs { + guard let mediaId = media.id else { + continue + } + if let previewNode = self.mediaPreviewNodes[mediaId] { + transition.updateFrame(node: previewNode, frame: CGRect(origin: mediaPreviewOffset, size: mediaSize)) + } + mediaPreviewOffset.x += mediaSize.width + contentImageSpacing + } let dateFrame = self.dateNode.frame transition.updateFrame(node: self.dateNode, frame: CGRect(origin: CGPoint(x: contentRect.origin.x + contentRect.size.width - dateFrame.size.width, y: dateFrame.minY), size: dateFrame.size)) diff --git a/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift b/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift index 176347742a..24fcb85727 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListItemStrings.swift @@ -7,9 +7,44 @@ import TelegramUIPreferences import TelegramStringFormatting import LocalizedPeerData -public func chatListItemStrings(strings: PresentationStrings, nameDisplayOrder: PresentationPersonNameOrder, message: Message?, chatPeer: RenderedPeer, accountPeerId: PeerId, enableMediaEmoji: Bool = true, isPeerGroup: Bool = false) -> (peer: Peer?, hideAuthor: Bool, messageText: String) { +private enum MessageGroupType { + case photos + case videos + case generic +} + +private func singleMessageType(message: Message) -> MessageGroupType { + for media in message.media { + if let _ = media as? TelegramMediaImage { + return .photos + } else if let file = media as? TelegramMediaFile { + if file.isVideo && !file.isInstantVideo { + return .videos + } + } + } + return .generic +} + +private func messageGroupType(messages: [Message]) -> MessageGroupType { + if messages.isEmpty { + return .generic + } + let currentType = singleMessageType(message: messages[0]) + for i in 1 ..< messages.count { + let nextType = singleMessageType(message: messages[i]) + if nextType != currentType { + return .generic + } + } + return currentType +} + +public func chatListItemStrings(strings: PresentationStrings, nameDisplayOrder: PresentationPersonNameOrder, messages: [Message], chatPeer: RenderedPeer, accountPeerId: PeerId, enableMediaEmoji: Bool = true, isPeerGroup: Bool = false) -> (peer: Peer?, hideAuthor: Bool, messageText: String) { let peer: Peer? + let message = messages.last + var hideAuthor = false var messageText: String if let message = message { @@ -19,151 +54,178 @@ public func chatListItemStrings(strings: PresentationStrings, nameDisplayOrder: peer = chatPeer.chatMainPeer } - messageText = message.text + messageText = messages[0].text - for media in message.media { - switch media { - case _ as TelegramMediaImage: - if message.text.isEmpty { - messageText = strings.Message_Photo - } else if #available(iOSApplicationExtension 9.0, iOS 9.0, *) { - if enableMediaEmoji { - messageText = "🖼 \(messageText)" + var textIsReady = false + if messages.count > 1 { + let groupType = messageGroupType(messages: messages) + switch groupType { + case .photos: + if !messageText.isEmpty { + textIsReady = true + } else { + messageText = strings.ChatList_MessagePhotos(Int32(messages.count)) + textIsReady = true + } + case .videos: + if !messageText.isEmpty { + textIsReady = true + } else { + messageText = strings.ChatList_MessageVideos(Int32(messages.count)) + textIsReady = true + } + case .generic: + break + } + } + + if !textIsReady { + for media in message.media { + switch media { + case _ as TelegramMediaImage: + if message.text.isEmpty { + messageText = strings.Message_Photo + } else if #available(iOSApplicationExtension 9.0, iOS 9.0, *) { + if enableMediaEmoji { + messageText = "🖼 \(messageText)" + } } - } - case let fileMedia as TelegramMediaFile: - var processed = false - inner: for attribute in fileMedia.attributes { - switch attribute { - case .Animated: - messageText = strings.Message_Animation - processed = true - break inner - case let .Audio(isVoice, _, title, performer, _): - if !message.text.isEmpty { - messageText = "🎤 \(messageText)" - } else if isVoice { - if message.text.isEmpty { - messageText = strings.Message_Audio - } else { + case let fileMedia as TelegramMediaFile: + var processed = false + inner: for attribute in fileMedia.attributes { + switch attribute { + case .Animated: + messageText = strings.Message_Animation + processed = true + break inner + case let .Audio(isVoice, _, title, performer, _): + if !message.text.isEmpty { messageText = "🎤 \(messageText)" - } - processed = true - break inner - } else { - let descriptionString: String - if let title = title, let performer = performer, !title.isEmpty, !performer.isEmpty { - descriptionString = title + " — " + performer - } else if let title = title, !title.isEmpty { - descriptionString = title - } else if let performer = performer, !performer.isEmpty { - descriptionString = performer - } else if let fileName = fileMedia.fileName { - descriptionString = fileName - } else { - descriptionString = strings.Message_Audio - } - messageText = descriptionString - processed = true - break inner - } - case let .Sticker(displayText, _, _): - if displayText.isEmpty { - messageText = strings.Message_Sticker - processed = true - break inner - } else { - messageText = strings.Message_StickerText(displayText).0 - processed = true - break inner - } - case let .Video(_, _, flags): - if flags.contains(.instantRoundVideo) { - messageText = strings.Message_VideoMessage - processed = true - break inner - } else { - if message.text.isEmpty { - messageText = strings.Message_Video - processed = true - } else if #available(iOSApplicationExtension 9.0, iOS 9.0, *) { - if !fileMedia.isAnimated && enableMediaEmoji { - messageText = "📹 \(messageText)" - processed = true + } else if isVoice { + if message.text.isEmpty { + messageText = strings.Message_Audio + } else { + messageText = "🎤 \(messageText)" } + processed = true break inner + } else { + let descriptionString: String + if let title = title, let performer = performer, !title.isEmpty, !performer.isEmpty { + descriptionString = title + " — " + performer + } else if let title = title, !title.isEmpty { + descriptionString = title + } else if let performer = performer, !performer.isEmpty { + descriptionString = performer + } else if let fileName = fileMedia.fileName { + descriptionString = fileName + } else { + descriptionString = strings.Message_Audio + } + messageText = descriptionString + processed = true + break inner + } + case let .Sticker(displayText, _, _): + if displayText.isEmpty { + messageText = strings.Message_Sticker + processed = true + break inner + } else { + messageText = strings.Message_StickerText(displayText).0 + processed = true + break inner + } + case let .Video(_, _, flags): + if flags.contains(.instantRoundVideo) { + messageText = strings.Message_VideoMessage + processed = true + break inner + } else { + if message.text.isEmpty { + messageText = strings.Message_Video + processed = true + } else if #available(iOSApplicationExtension 9.0, iOS 9.0, *) { + if enableMediaEmoji { + if !fileMedia.isAnimated { + messageText = "📹 \(messageText)" + } + } + processed = true + break inner + } + } + default: + break + } + } + if !processed { + if !message.text.isEmpty { + messageText = "📎 \(messageText)" + } else { + if fileMedia.isAnimatedSticker { + messageText = strings.Message_Sticker + } else { + if let fileName = fileMedia.fileName { + messageText = fileName + } else { + messageText = strings.Message_File + } + } + } + } + case let location as TelegramMediaMap: + if location.liveBroadcastingTimeout != nil { + messageText = strings.Message_LiveLocation + } else { + messageText = strings.Message_Location + } + case _ as TelegramMediaContact: + messageText = strings.Message_Contact + case let game as TelegramMediaGame: + messageText = "🎮 \(game.title)" + case let invoice as TelegramMediaInvoice: + messageText = invoice.title + case let action as TelegramMediaAction: + switch action.action { + case let .phoneCall(_, discardReason, _): + hideAuthor = !isPeerGroup + let incoming = message.flags.contains(.Incoming) + if let discardReason = discardReason { + switch discardReason { + case .busy, .disconnect: + messageText = strings.Notification_CallCanceled + case .missed: + messageText = incoming ? strings.Notification_CallMissed : strings.Notification_CallCanceled + case .hangup: + break + } + } + + if messageText.isEmpty { + if incoming { + messageText = strings.Notification_CallIncoming + } else { + messageText = strings.Notification_CallOutgoing } } default: - break + hideAuthor = true + if let text = plainServiceMessageString(strings: strings, nameDisplayOrder: nameDisplayOrder, message: message, accountPeerId: accountPeerId) { + messageText = text + } } - } - if !processed { - if !message.text.isEmpty { - messageText = "📎 \(messageText)" - } else { - if fileMedia.isAnimatedSticker { - messageText = strings.Message_Sticker - } else { - if let fileName = fileMedia.fileName { - messageText = fileName - } else { - messageText = strings.Message_File - } - } + case _ as TelegramMediaExpiredContent: + if let text = plainServiceMessageString(strings: strings, nameDisplayOrder: nameDisplayOrder, message: message, accountPeerId: accountPeerId) { + messageText = text } - } - case let location as TelegramMediaMap: - if location.liveBroadcastingTimeout != nil { - messageText = strings.Message_LiveLocation - } else { - messageText = strings.Message_Location - } - case _ as TelegramMediaContact: - messageText = strings.Message_Contact - case let game as TelegramMediaGame: - messageText = "🎮 \(game.title)" - case let invoice as TelegramMediaInvoice: - messageText = invoice.title - case let action as TelegramMediaAction: - switch action.action { - case let .phoneCall(_, discardReason, _): - hideAuthor = !isPeerGroup - let incoming = message.flags.contains(.Incoming) - if let discardReason = discardReason { - switch discardReason { - case .busy, .disconnect: - messageText = strings.Notification_CallCanceled - case .missed: - messageText = incoming ? strings.Notification_CallMissed : strings.Notification_CallCanceled - case .hangup: - break - } - } - - if messageText.isEmpty { - if incoming { - messageText = strings.Notification_CallIncoming - } else { - messageText = strings.Notification_CallOutgoing - } - } - default: - hideAuthor = true - if let text = plainServiceMessageString(strings: strings, nameDisplayOrder: nameDisplayOrder, message: message, accountPeerId: accountPeerId) { - messageText = text - } - } - case _ as TelegramMediaExpiredContent: - if let text = plainServiceMessageString(strings: strings, nameDisplayOrder: nameDisplayOrder, message: message, accountPeerId: accountPeerId) { - messageText = text - } - case let poll as TelegramMediaPoll: - messageText = "📊 \(poll.text)" - case let dice as TelegramMediaDice: - messageText = dice.emoji - default: - break + case let poll as TelegramMediaPoll: + messageText = "📊 \(poll.text)" + case let dice as TelegramMediaDice: + messageText = dice.emoji + default: + break + } } } } else { diff --git a/submodules/ChatListUI/Sources/Node/ChatListNode.swift b/submodules/ChatListUI/Sources/Node/ChatListNode.swift index 2272018731..326c5bcb5a 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNode.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNode.swift @@ -176,10 +176,10 @@ private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatL nodeInteraction.additionalCategorySelected(id) } ), directionHint: entry.directionHint) - case let .PeerEntry(index, presentationData, message, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, promoInfo, hasFailedMessages, isContact): + case let .PeerEntry(index, presentationData, messages, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, promoInfo, hasFailedMessages, isContact): switch mode { case .chatList: - return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, filterData: filterData, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, promoInfo: promoInfo, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewInsertItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, filterData: filterData, index: index, content: .peer(messages: messages, peer: peer, combinedReadState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, promoInfo: promoInfo, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) case let .peers(filter, isSelecting, _, filters): let itemPeer = peer.chatMainPeer var chatPeer: Peer? @@ -290,10 +290,10 @@ private func mappedInsertEntries(context: AccountContext, nodeInteraction: ChatL private func mappedUpdateEntries(context: AccountContext, nodeInteraction: ChatListNodeInteraction, peerGroupId: PeerGroupId, filterData: ChatListItemFilterData?, mode: ChatListNodeMode, entries: [ChatListNodeViewTransitionUpdateEntry]) -> [ListViewUpdateItem] { return entries.map { entry -> ListViewUpdateItem in switch entry.entry { - case let .PeerEntry(index, presentationData, message, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, promoInfo, hasFailedMessages, isContact): + case let .PeerEntry(index, presentationData, messages, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, presence, summaryInfo, editing, hasActiveRevealControls, selected, inputActivities, promoInfo, hasFailedMessages, isContact): switch mode { case .chatList: - return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, filterData: filterData, index: index, content: .peer(message: message, peer: peer, combinedReadState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, promoInfo: promoInfo, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) + return ListViewUpdateItem(index: entry.index, previousIndex: entry.previousIndex, item: ChatListItem(presentationData: presentationData, context: context, peerGroupId: peerGroupId, filterData: filterData, index: index, content: .peer(messages: messages, peer: peer, combinedReadState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, presence: presence, summaryInfo: summaryInfo, embeddedState: embeddedState, inputActivities: inputActivities, promoInfo: promoInfo, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: hasFailedMessages), editing: editing, hasActiveRevealControls: hasActiveRevealControls, selected: selected, header: nil, enableContextActions: true, hiddenOffset: false, interaction: nodeInteraction), directionHint: entry.directionHint) case let .peers(filter, isSelecting, _, filters): let itemPeer = peer.chatMainPeer var chatPeer: Peer? diff --git a/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift b/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift index 32a7a79d5e..415d0d42f8 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListNodeEntries.swift @@ -46,7 +46,7 @@ public enum ChatListNodeEntryPromoInfo: Equatable { enum ChatListNodeEntry: Comparable, Identifiable { case HeaderEntry - case PeerEntry(index: ChatListIndex, presentationData: ChatListPresentationData, message: Message?, readState: CombinedPeerReadState?, isRemovedFromTotalUnreadCount: Bool, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, peer: RenderedPeer, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, editing: Bool, hasActiveRevealControls: Bool, selected: Bool, inputActivities: [(Peer, PeerInputActivity)]?, promoInfo: ChatListNodeEntryPromoInfo?, hasFailedMessages: Bool, isContact: Bool) + case PeerEntry(index: ChatListIndex, presentationData: ChatListPresentationData, messages: [Message], readState: CombinedPeerReadState?, isRemovedFromTotalUnreadCount: Bool, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, peer: RenderedPeer, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, editing: Bool, hasActiveRevealControls: Bool, selected: Bool, inputActivities: [(Peer, PeerInputActivity)]?, promoInfo: ChatListNodeEntryPromoInfo?, hasFailedMessages: Bool, isContact: Bool) case HoleEntry(ChatListHole, theme: PresentationTheme) case GroupReferenceEntry(index: ChatListIndex, presentationData: ChatListPresentationData, groupId: PeerGroupId, peers: [ChatListGroupReferencePeer], message: Message?, editing: Bool, unreadState: PeerGroupUnreadCountersCombinedSummary, revealed: Bool, hiddenByDefault: Bool) case ArchiveIntro(presentationData: ChatListPresentationData) @@ -98,27 +98,33 @@ enum ChatListNodeEntry: Comparable, Identifiable { } else { return false } - case let .PeerEntry(lhsIndex, lhsPresentationData, lhsMessage, lhsUnreadCount, lhsIsRemovedFromTotalUnreadCount, lhsEmbeddedState, lhsPeer, lhsPresence, lhsSummaryInfo, lhsEditing, lhsHasRevealControls, lhsSelected, lhsInputActivities, lhsAd, lhsHasFailedMessages, lhsIsContact): + case let .PeerEntry(lhsIndex, lhsPresentationData, lhsMessages, lhsUnreadCount, lhsIsRemovedFromTotalUnreadCount, lhsEmbeddedState, lhsPeer, lhsPresence, lhsSummaryInfo, lhsEditing, lhsHasRevealControls, lhsSelected, lhsInputActivities, lhsAd, lhsHasFailedMessages, lhsIsContact): switch rhs { - case let .PeerEntry(rhsIndex, rhsPresentationData, rhsMessage, rhsUnreadCount, rhsIsRemovedFromTotalUnreadCount, rhsEmbeddedState, rhsPeer, rhsPresence, rhsSummaryInfo, rhsEditing, rhsHasRevealControls, rhsSelected, rhsInputActivities, rhsAd, rhsHasFailedMessages, rhsIsContact): + case let .PeerEntry(rhsIndex, rhsPresentationData, rhsMessages, rhsUnreadCount, rhsIsRemovedFromTotalUnreadCount, rhsEmbeddedState, rhsPeer, rhsPresence, rhsSummaryInfo, rhsEditing, rhsHasRevealControls, rhsSelected, rhsInputActivities, rhsAd, rhsHasFailedMessages, rhsIsContact): if lhsIndex != rhsIndex { return false } if lhsPresentationData !== rhsPresentationData { return false } - if lhsMessage?.stableVersion != rhsMessage?.stableVersion { + if lhsUnreadCount != rhsUnreadCount { return false } - if lhsMessage?.id != rhsMessage?.id || lhsMessage?.flags != rhsMessage?.flags || lhsUnreadCount != rhsUnreadCount { + if lhsMessages.count != rhsMessages.count { return false } - if let lhsMessage = lhsMessage, let rhsMessage = rhsMessage { - if lhsMessage.associatedMessages.count != rhsMessage.associatedMessages.count { + for i in 0 ..< lhsMessages.count { + if lhsMessages[i].stableVersion != rhsMessages[i].stableVersion { return false } - for (id, message) in lhsMessage.associatedMessages { - if let otherMessage = rhsMessage.associatedMessages[id] { + if lhsMessages[i].id != rhsMessages[i].id { + return false + } + if lhsMessages[i].associatedMessages.count != rhsMessages[i].associatedMessages.count { + return false + } + for (id, message) in lhsMessages[i].associatedMessages { + if let otherMessage = rhsMessages[i].associatedMessages[id] { if message.stableVersion != otherMessage.stableVersion { return false } @@ -295,20 +301,20 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, var filterAfterHole = false loop: for entry in view.entries { switch entry { - case let .MessageEntry(index, message, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): + case let .MessageEntry(index, messages, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): if let savedMessagesPeer = savedMessagesPeer, savedMessagesPeer.id == index.messageIndex.id.peerId { continue loop } if state.pendingRemovalPeerIds.contains(index.messageIndex.id.peerId) { continue loop } - var updatedMessage = message + var updatedMessages = messages var updatedCombinedReadState = combinedReadState if state.pendingClearHistoryPeerIds.contains(index.messageIndex.id.peerId) { - updatedMessage = nil + updatedMessages = [] updatedCombinedReadState = nil } - result.append(.PeerEntry(index: offsetPinnedIndex(index, offset: pinnedIndexOffset), presentationData: state.presentationData, message: updatedMessage, readState: updatedCombinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], promoInfo: nil, hasFailedMessages: hasFailed, isContact: isContact)) + result.append(.PeerEntry(index: offsetPinnedIndex(index, offset: pinnedIndexOffset), presentationData: state.presentationData, messages: updatedMessages, readState: updatedCombinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], promoInfo: nil, hasFailedMessages: hasFailed, isContact: isContact)) case let .HoleEntry(hole): if hole.index.timestamp == Int32.max - 1 { //return ([.HeaderEntry], true) @@ -321,7 +327,7 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, var pinningIndex: UInt16 = UInt16(pinnedIndexOffset == 0 ? 0 : (pinnedIndexOffset - 1)) if let savedMessagesPeer = savedMessagesPeer { - result.append(.PeerEntry(index: ChatListIndex.absoluteUpperBound.predecessor, presentationData: state.presentationData, message: nil, readState: nil, isRemovedFromTotalUnreadCount: false, embeddedInterfaceState: nil, peer: RenderedPeer(peerId: savedMessagesPeer.id, peers: SimpleDictionary([savedMessagesPeer.id: savedMessagesPeer])), presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), editing: state.editing, hasActiveRevealControls: false, selected: false, inputActivities: nil, promoInfo: nil, hasFailedMessages: false, isContact: false)) + result.append(.PeerEntry(index: ChatListIndex.absoluteUpperBound.predecessor, presentationData: state.presentationData, messages: [], readState: nil, isRemovedFromTotalUnreadCount: false, embeddedInterfaceState: nil, peer: RenderedPeer(peerId: savedMessagesPeer.id, peers: SimpleDictionary([savedMessagesPeer.id: savedMessagesPeer])), presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), editing: state.editing, hasActiveRevealControls: false, selected: false, inputActivities: nil, promoInfo: nil, hasFailedMessages: false, isContact: false)) } else { if !filteredAdditionalItemEntries.isEmpty { for item in filteredAdditionalItemEntries.reversed() { @@ -336,8 +342,8 @@ func chatListNodeEntriesForView(_ view: ChatListView, state: ChatListNodeState, promoInfo = .psa(type: type, message: message) } switch item.entry { - case let .MessageEntry(index, message, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): - result.append(.PeerEntry(index: ChatListIndex(pinningIndex: pinningIndex, messageIndex: index.messageIndex), presentationData: state.presentationData, message: message, readState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], promoInfo: promoInfo, hasFailedMessages: hasFailed, isContact: isContact)) + case let .MessageEntry(index, messages, combinedReadState, isRemovedFromTotalUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): + result.append(.PeerEntry(index: ChatListIndex(pinningIndex: pinningIndex, messageIndex: index.messageIndex), presentationData: state.presentationData, messages: messages, readState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: embeddedState, peer: peer, presence: peerPresence, summaryInfo: summaryInfo, editing: state.editing, hasActiveRevealControls: index.messageIndex.id.peerId == state.peerIdWithRevealedOptions, selected: state.selectedPeerIds.contains(index.messageIndex.id.peerId), inputActivities: state.peerInputActivities?.activities[index.messageIndex.id.peerId], promoInfo: promoInfo, hasFailedMessages: hasFailed, isContact: isContact)) if pinningIndex != 0 { pinningIndex -= 1 } diff --git a/submodules/ContactListUI/Sources/ContactContextMenus.swift b/submodules/ContactListUI/Sources/ContactContextMenus.swift index c5c09c42a4..57a057e4a8 100644 --- a/submodules/ContactListUI/Sources/ContactContextMenus.swift +++ b/submodules/ContactListUI/Sources/ContactContextMenus.swift @@ -21,7 +21,7 @@ func contactContextMenuItems(context: AccountContext, peerId: PeerId, contactsCo items.append(.action(ContextMenuActionItem(text: strings.ContactList_Context_SendMessage, icon: { theme in generateTintedImage(image: UIImage(bundleImageName: "Chat/Context Menu/Message"), color: theme.contextMenu.primaryColor) }, action: { _, f in if let contactsController = contactsController, let navigationController = contactsController.navigationController as? NavigationController { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId))) + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId), peekData: nil)) } f(.default) }))) @@ -58,7 +58,7 @@ func contactContextMenuItems(context: AccountContext, peerId: PeerId, contactsCo |> deliverOnMainQueue).start(next: { currentPeerId in if let currentPeerId = currentPeerId { if let contactsController = contactsController, let navigationController = (contactsController.navigationController as? NavigationController) { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(currentPeerId))) + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(currentPeerId), peekData: nil)) } } else { var createSignal = createSecretChat(account: context.account, peerId: peerId) @@ -93,7 +93,7 @@ func contactContextMenuItems(context: AccountContext, peerId: PeerId, contactsCo createSecretChatDisposable.set((createSignal |> deliverOnMainQueue).start(next: { peerId in if let navigationController = (contactsController?.navigationController as? NavigationController) { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId))) + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId), peekData: nil)) } }, error: { _ in if let contactsController = contactsController { diff --git a/submodules/Display/Source/ImageNode.swift b/submodules/Display/Source/ImageNode.swift index 87422abbc6..3522fad829 100644 --- a/submodules/Display/Source/ImageNode.swift +++ b/submodules/Display/Source/ImageNode.swift @@ -127,6 +127,12 @@ public class ImageNode: ASDisplayNode { private var first = true private let enableEmpty: Bool + private let _contentReady = Promise() + private var didSetReady: Bool = false + public var contentReady: Signal { + return self._contentReady.get() + } + public var ready: Signal { if let hasImage = self.hasImage { return hasImage.get() @@ -171,6 +177,10 @@ public class ImageNode: ASDisplayNode { hasImage.set(true) } } + if !strongSelf.didSetReady { + strongSelf.didSetReady = true + strongSelf._contentReady.set(.single(true)) + } } } })) diff --git a/submodules/Display/Source/TextAlertController.swift b/submodules/Display/Source/TextAlertController.swift index cd06ed2fab..c9c2120160 100644 --- a/submodules/Display/Source/TextAlertController.swift +++ b/submodules/Display/Source/TextAlertController.swift @@ -137,6 +137,11 @@ public final class TextAlertContentNode: AlertContentNode { private var validLayout: CGSize? + private let _dismissOnOutsideTap: Bool + override public var dismissOnOutsideTap: Bool { + return self._dismissOnOutsideTap + } + public var textAttributeAction: (NSAttributedString.Key, (Any) -> Void)? { didSet { if let (attribute, textAttributeAction) = self.textAttributeAction { @@ -160,9 +165,10 @@ public final class TextAlertContentNode: AlertContentNode { } } - public init(theme: AlertControllerTheme, title: NSAttributedString?, text: NSAttributedString, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout) { + public init(theme: AlertControllerTheme, title: NSAttributedString?, text: NSAttributedString, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout, dismissOnOutsideTap: Bool) { self.theme = theme self.actionLayout = actionLayout + self._dismissOnOutsideTap = dismissOnOutsideTap if let title = title { let titleNode = ImmediateTextNode() titleNode.attributedText = title @@ -364,11 +370,11 @@ public final class TextAlertContentNode: AlertContentNode { } } -public func textAlertController(theme: AlertControllerTheme, title: NSAttributedString?, text: NSAttributedString, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal) -> AlertController { - return AlertController(theme: theme, contentNode: TextAlertContentNode(theme: theme, title: title, text: text, actions: actions, actionLayout: actionLayout)) +public func textAlertController(theme: AlertControllerTheme, title: NSAttributedString?, text: NSAttributedString, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, dismissOnOutsideTap: Bool = true) -> AlertController { + return AlertController(theme: theme, contentNode: TextAlertContentNode(theme: theme, title: title, text: text, actions: actions, actionLayout: actionLayout, dismissOnOutsideTap: dismissOnOutsideTap)) } -public func standardTextAlertController(theme: AlertControllerTheme, title: String?, text: String, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, allowInputInset: Bool = true, parseMarkdown: Bool = false) -> AlertController { +public func standardTextAlertController(theme: AlertControllerTheme, title: String?, text: String, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, allowInputInset: Bool = true, parseMarkdown: Bool = false, dismissOnOutsideTap: Bool = true) -> AlertController { var dismissImpl: (() -> Void)? let attributedText: NSAttributedString if parseMarkdown { @@ -385,7 +391,7 @@ public func standardTextAlertController(theme: AlertControllerTheme, title: Stri dismissImpl?() action.action() }) - }, actionLayout: actionLayout), allowInputInset: allowInputInset) + }, actionLayout: actionLayout, dismissOnOutsideTap: dismissOnOutsideTap), allowInputInset: allowInputInset) dismissImpl = { [weak controller] in controller?.dismissAnimated() } diff --git a/submodules/Display/Source/TextNode.swift b/submodules/Display/Source/TextNode.swift index cbde782489..508a177271 100644 --- a/submodules/Display/Source/TextNode.swift +++ b/submodules/Display/Source/TextNode.swift @@ -905,6 +905,7 @@ public class TextNode: ASDisplayNode { var strikethroughs: [TextNodeStrikethrough] = [] var lineConstrainedWidth = constrainedSize.width + var lineConstrainedWidthDelta: CGFloat = 0.0 var lineOriginY = floorToScreenPixels(layoutSize.height + fontAscent) if !first { lineOriginY += fontLineSpacing @@ -915,6 +916,7 @@ public class TextNode: ASDisplayNode { if cutoutEnabled { if lineOriginY - fontLineHeight < cutoutMaxY && lineOriginY + fontLineHeight > cutoutMinY { lineConstrainedWidth = max(1.0, lineConstrainedWidth - cutoutWidth) + lineConstrainedWidthDelta = -cutoutWidth lineCutoutOffset = cutoutOffset lineAdditionalWidth = cutoutWidth } @@ -945,6 +947,7 @@ public class TextNode: ASDisplayNode { let originalLine = CTTypesetterCreateLineWithOffset(typesetter, lineRange, 0.0) var lineConstrainedSize = constrainedSize + lineConstrainedSize.width += lineConstrainedWidthDelta if bottomCutoutEnabled { lineConstrainedSize.width -= bottomCutoutSize.width } diff --git a/submodules/InstantPageUI/Sources/InstantPageControllerNode.swift b/submodules/InstantPageUI/Sources/InstantPageControllerNode.swift index 1360bc8ac7..26019a1434 100644 --- a/submodules/InstantPageUI/Sources/InstantPageControllerNode.swift +++ b/submodules/InstantPageUI/Sources/InstantPageControllerNode.swift @@ -1168,9 +1168,9 @@ final class InstantPageControllerNode: ASDisplayNode, UIScrollViewDelegate { strongSelf.loadProgress.set(1.0) strongSelf.context.sharedContext.openResolvedUrl(result, context: strongSelf.context, urlContext: .generic, navigationController: strongSelf.getNavigationController(), openPeer: { peerId, navigation in switch navigation { - case let .chat(_, subject): + case let .chat(_, subject, peekData): if let navigationController = strongSelf.getNavigationController() { - strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject)) + strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject, peekData: peekData)) } case let .withBotStartPayload(botStart): if let navigationController = strongSelf.getNavigationController() { diff --git a/submodules/JoinLinkPreviewUI/Sources/JoinLinkPreviewController.swift b/submodules/JoinLinkPreviewUI/Sources/JoinLinkPreviewController.swift index 23c81a3bb1..addcdda352 100644 --- a/submodules/JoinLinkPreviewUI/Sources/JoinLinkPreviewController.swift +++ b/submodules/JoinLinkPreviewUI/Sources/JoinLinkPreviewController.swift @@ -21,14 +21,14 @@ public final class JoinLinkPreviewController: ViewController { private let context: AccountContext private let link: String - private let navigateToPeer: (PeerId) -> Void + private let navigateToPeer: (PeerId, ChatPeekTimeout?) -> Void private let parentNavigationController: NavigationController? private var resolvedState: ExternalJoiningChatState? private var presentationData: PresentationData private let disposable = MetaDisposable() - public init(context: AccountContext, link: String, navigateToPeer: @escaping (PeerId) -> Void, parentNavigationController: NavigationController?, resolvedState: ExternalJoiningChatState? = nil) { + public init(context: AccountContext, link: String, navigateToPeer: @escaping (PeerId, ChatPeekTimeout?) -> Void, parentNavigationController: NavigationController?, resolvedState: ExternalJoiningChatState? = nil) { self.context = context self.link = link self.navigateToPeer = navigateToPeer @@ -81,7 +81,10 @@ public final class JoinLinkPreviewController: ViewController { let data = JoinLinkPreviewData(isGroup: participants != nil, isJoined: false) strongSelf.controllerNode.setPeer(image: photoRepresentation, title: title, memberCount: participantsCount, members: participants ?? [], data: data) case let .alreadyJoined(peerId): - strongSelf.navigateToPeer(peerId) + strongSelf.navigateToPeer(peerId, nil) + strongSelf.dismiss() + case let .peek(peerId, deadline): + strongSelf.navigateToPeer(peerId, ChatPeekTimeout(deadline: deadline, linkData: strongSelf.link)) strongSelf.dismiss() case .invalidHash: strongSelf.present(textAlertController(context: strongSelf.context, title: nil, text: strongSelf.presentationData.strings.GroupInfo_InvitationLinkDoesNotExist, actions: [TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Common_OK, action: {})]), in: .window(.root)) @@ -119,7 +122,7 @@ public final class JoinLinkPreviewController: ViewController { self.disposable.set((joinChatInteractively(with: self.link, account: self.context.account) |> deliverOnMainQueue).start(next: { [weak self] peerId in if let strongSelf = self { if let peerId = peerId { - strongSelf.navigateToPeer(peerId) + strongSelf.navigateToPeer(peerId, nil) strongSelf.dismiss() } } diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/Font.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushArrow.imageset/Contents.json similarity index 75% rename from submodules/LegacyComponents/LegacyImages.xcassets/Editor/Font.imageset/Contents.json rename to submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushArrow.imageset/Contents.json index 88687252ce..84eb1bf387 100644 --- a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/Font.imageset/Contents.json +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushArrow.imageset/Contents.json @@ -1,7 +1,7 @@ { "images" : [ { - "filename" : "ic_editor_font.pdf", + "filename" : "ic_menu_brush4.pdf", "idiom" : "universal" } ], diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushArrow.imageset/ic_menu_brush4.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushArrow.imageset/ic_menu_brush4.pdf new file mode 100644 index 0000000000..d09005a3e7 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushArrow.imageset/ic_menu_brush4.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/Contents.json new file mode 100644 index 0000000000..e4d1a3e45b --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_menu_brush2.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/ic_menu_brush2.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/ic_menu_brush2.pdf new file mode 100644 index 0000000000..326fa48931 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/ic_menu_brush2.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/Contents.json new file mode 100644 index 0000000000..7c10dc82bd --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_menu_brush3.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/ic_menu_brush3.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/ic_menu_brush3.pdf new file mode 100644 index 0000000000..ab17d8361f Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/ic_menu_brush3.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/Contents.json new file mode 100644 index 0000000000..e6a3712dd8 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_menu_brush1.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/ic_menu_brush1.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/ic_menu_brush1.pdf new file mode 100644 index 0000000000..7e189831a4 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/ic_menu_brush1.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/Contents.json new file mode 100644 index 0000000000..2c4b2648b1 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_editor_brush4.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/ic_editor_brush4.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/ic_editor_brush4.pdf new file mode 100644 index 0000000000..abf261fda2 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/ic_editor_brush4.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedMarker.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedMarker.imageset/Contents.json new file mode 100644 index 0000000000..8ab8127274 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedMarker.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_editor_brush2.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/Font.imageset/ic_editor_font.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedMarker.imageset/ic_editor_brush2.pdf similarity index 75% rename from submodules/LegacyComponents/LegacyImages.xcassets/Editor/Font.imageset/ic_editor_font.pdf rename to submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedMarker.imageset/ic_editor_brush2.pdf index 6aed45f0fd..88964822ea 100644 Binary files a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/Font.imageset/ic_editor_font.pdf and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedMarker.imageset/ic_editor_brush2.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/Contents.json new file mode 100644 index 0000000000..c94485170a --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_editor_brush3.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/ic_editor_brush3.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/ic_editor_brush3.pdf new file mode 100644 index 0000000000..0eaaefca86 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/ic_editor_brush3.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/Contents.json new file mode 100644 index 0000000000..0402056ad7 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_editor_brush1.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/ic_editor_brush1.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/ic_editor_brush1.pdf new file mode 100644 index 0000000000..cafe10024a Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/ic_editor_brush1.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/Contents.json new file mode 100644 index 0000000000..f0dc497980 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_menu_font3.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/ic_menu_font3.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/ic_menu_font3.pdf new file mode 100644 index 0000000000..2eaf63ce00 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/ic_menu_font3.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/Contents.json new file mode 100644 index 0000000000..3fb42a5beb --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_menu_font2.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/ic_menu_font2.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/ic_menu_font2.pdf new file mode 100644 index 0000000000..d09aa5b91f Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/ic_menu_font2.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/Contents.json new file mode 100644 index 0000000000..ebb7714e79 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_menu_font1.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/ic_menu_font1.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/ic_menu_font1.pdf new file mode 100644 index 0000000000..3df88ff7e2 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/ic_menu_font1.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/Contents.json new file mode 100644 index 0000000000..65bf1ccf54 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_editor_font3.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/ic_editor_font3.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/ic_editor_font3.pdf new file mode 100644 index 0000000000..36c0581182 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/ic_editor_font3.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/Contents.json new file mode 100644 index 0000000000..4707972b2b --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_editor_font2.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/ic_editor_font2.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/ic_editor_font2.pdf new file mode 100644 index 0000000000..c233e90211 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/ic_editor_font2.pdf differ diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/Contents.json b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/Contents.json new file mode 100644 index 0000000000..2b6288fbc5 --- /dev/null +++ b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/Contents.json @@ -0,0 +1,12 @@ +{ + "images" : [ + { + "filename" : "ic_editor_font1.pdf", + "idiom" : "universal" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/ic_editor_font1.pdf b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/ic_editor_font1.pdf new file mode 100644 index 0000000000..12ea2bf065 Binary files /dev/null and b/submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/ic_editor_font1.pdf differ diff --git a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGCameraCapturedVideo.h b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGCameraCapturedVideo.h index 23b96a7c0d..4e7d79f2a8 100644 --- a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGCameraCapturedVideo.h +++ b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGCameraCapturedVideo.h @@ -3,13 +3,18 @@ #import @class AVURLAsset; +@class TGMediaAsset; @interface TGCameraCapturedVideo : NSObject -@property (nonatomic, readonly) AVURLAsset *avAsset; +@property (nonatomic, readonly) SSignal *avAsset; @property (nonatomic, readonly) NSTimeInterval videoDuration; +@property (nonatomic, readonly) bool isAnimation; +@property (nonatomic, readonly) TGMediaAsset *originalAsset; + - (instancetype)initWithURL:(NSURL *)url; +- (instancetype)initWithAsset:(TGMediaAsset *)asset; - (void)_cleanUp; diff --git a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaPickerGalleryVideoItem.h b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaPickerGalleryVideoItem.h index 50a159832c..9c7af118da 100644 --- a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaPickerGalleryVideoItem.h +++ b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaPickerGalleryVideoItem.h @@ -7,7 +7,7 @@ @interface TGMediaPickerGalleryVideoItem : TGMediaPickerGalleryItem -@property (nonatomic, readonly) AVAsset *avAsset; +@property (nonatomic, readonly) SSignal *avAsset; @property (nonatomic, readonly) CGSize dimensions; - (SSignal *)durationSignal; diff --git a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaSelectionContext.h b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaSelectionContext.h index d0bda84a40..a982afb9bb 100644 --- a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaSelectionContext.h +++ b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGMediaSelectionContext.h @@ -52,7 +52,7 @@ @interface TGMediaSelectionChange : NSObject -@property (nonatomic, readonly) id item; +@property (nonatomic, readonly) NSObject *item; @property (nonatomic, readonly) bool selected; @property (nonatomic, readonly) bool animated; @property (nonatomic, readonly, strong) id sender; diff --git a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintEntityView.h b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintEntityView.h index 50266d90d1..49601b8e27 100644 --- a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintEntityView.h +++ b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintEntityView.h @@ -4,6 +4,12 @@ @class TGPhotoPaintEntitySelectionView; @class TGPaintUndoManager; +@interface UIView (PixelColor) + +- (UIColor *)colorAtPoint:(CGPoint)point; + +@end + @interface TGPhotoPaintEntityView : UIView { NSInteger _entityUUID; @@ -55,4 +61,4 @@ - (void)fadeIn; - (void)fadeOut; -@end \ No newline at end of file +@end diff --git a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintTextEntity.h b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintTextEntity.h index 3e363b0ece..2cde313c36 100644 --- a/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintTextEntity.h +++ b/submodules/LegacyComponents/PublicHeaders/LegacyComponents/TGPhotoPaintTextEntity.h @@ -4,9 +4,9 @@ @class TGPhotoPaintFont; typedef enum { - TGPhotoPaintTextEntityStyleBorder, - TGPhotoPaintTextEntityStyleClassic, - TGPhotoPaintTextEntityStyleFrame + TGPhotoPaintTextEntityStyleOutlined, + TGPhotoPaintTextEntityStyleRegular, + TGPhotoPaintTextEntityStyleFramed } TGPhotoPaintTextEntityStyle; @interface TGPhotoPaintTextEntity : TGPhotoPaintEntity diff --git a/submodules/LegacyComponents/Sources/PGPhotoEditor.m b/submodules/LegacyComponents/Sources/PGPhotoEditor.m index 04345363c3..20b94852f4 100644 --- a/submodules/LegacyComponents/Sources/PGPhotoEditor.m +++ b/submodules/LegacyComponents/Sources/PGPhotoEditor.m @@ -270,13 +270,21 @@ GPUImageOutput *currentInput = _currentInput; if ([currentInput isKindOfClass:[PGVideoMovie class]]) { - if (!_playing) { - _playing = true; - [_videoQueue dispatch:^{ - if ([currentInput isKindOfClass:[PGVideoMovie class]]) { - [(PGVideoMovie *)currentInput startProcessing]; - } - }]; + if (capture) { + if ([currentInput isKindOfClass:[PGVideoMovie class]]) + [(PGVideoMovie *)currentInput process]; + [_finalFilter useNextFrameForImageCapture]; + if (completion != nil) + completion(); + } else { + if (!_playing) { + _playing = true; + [_videoQueue dispatch:^{ + if ([currentInput isKindOfClass:[PGVideoMovie class]]) { + [(PGVideoMovie *)currentInput startProcessing]; + } + }]; + } } } else if ([currentInput isKindOfClass:[GPUImageTextureInput class]]) { if (capture) diff --git a/submodules/LegacyComponents/Sources/PGVideoMovie.h b/submodules/LegacyComponents/Sources/PGVideoMovie.h index ec7daec9dc..c018f6795b 100755 --- a/submodules/LegacyComponents/Sources/PGVideoMovie.h +++ b/submodules/LegacyComponents/Sources/PGVideoMovie.h @@ -14,6 +14,7 @@ - (void)cancelProcessing; - (void)processMovieFrame:(CMSampleBufferRef)movieSampleBuffer; +- (void)process; - (void)reprocessCurrent; @end diff --git a/submodules/LegacyComponents/Sources/PGVideoMovie.m b/submodules/LegacyComponents/Sources/PGVideoMovie.m index 2f04ffe670..5dc886cef8 100755 --- a/submodules/LegacyComponents/Sources/PGVideoMovie.m +++ b/submodules/LegacyComponents/Sources/PGVideoMovie.m @@ -250,6 +250,11 @@ NSString *const kYUVVideoRangeConversionForLAFragmentShaderString = SHADER_STRIN [self processPixelBufferAtTime:outputItemTime]; } +- (void)process { + _shouldReprocessCurrentFrame = true; + [self displayLinkCallback:displayLink]; +} + - (void)processPixelBufferAtTime:(CMTime)outputItemTime { if ([playerItemOutput hasNewPixelBufferForItemTime:outputItemTime] || _shouldReprocessCurrentFrame) diff --git a/submodules/LegacyComponents/Sources/TGAttachmentCarouselItemView.m b/submodules/LegacyComponents/Sources/TGAttachmentCarouselItemView.m index f58bda1b49..d022e75c5c 100644 --- a/submodules/LegacyComponents/Sources/TGAttachmentCarouselItemView.m +++ b/submodules/LegacyComponents/Sources/TGAttachmentCarouselItemView.m @@ -178,7 +178,13 @@ const NSUInteger TGAttachmentDisplayedAssetLimit = 500; if (strongSelf == nil) return; - NSInteger index = [strongSelf->_fetchResult indexOfAsset:(TGMediaAsset *)change.item]; + NSInteger index = 0; + if ([change.item isKindOfClass:[TGCameraCapturedVideo class]]) { + index = [strongSelf->_fetchResult indexOfAsset:((TGCameraCapturedVideo *)change.item).originalAsset]; + } else { + index = [strongSelf->_fetchResult indexOfAsset:(TGMediaAsset *)change.item]; + } + [strongSelf updateSendButtonsFromIndex:index]; [strongSelf updateSelectionIndexes]; @@ -917,7 +923,7 @@ const NSUInteger TGAttachmentDisplayedAssetLimit = 500; if ([editableItem isKindOfClass:[TGMediaAsset class]]) { return [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)editableItem]; } else if ([editableItem isKindOfClass:[TGCameraCapturedVideo class]]) { - return [SSignal single:((TGCameraCapturedVideo *)editableItem).avAsset]; + return ((TGCameraCapturedVideo *)editableItem).avAsset; } else { return [editableItem originalImageSignal:position]; } diff --git a/submodules/LegacyComponents/Sources/TGCameraCapturedVideo.m b/submodules/LegacyComponents/Sources/TGCameraCapturedVideo.m index 05fafa2751..b76faaa41a 100644 --- a/submodules/LegacyComponents/Sources/TGCameraCapturedVideo.m +++ b/submodules/LegacyComponents/Sources/TGCameraCapturedVideo.m @@ -3,21 +3,49 @@ #import #import +#import "LegacyComponentsGlobals.h" +#import "TGStringUtils.h" +#import "TGMediaAsset.h" +#import "TGMediaAsset+TGMediaEditableItem.h" + +#import "TGGifConverter.h" + @interface TGCameraCapturedVideo () { CGSize _cachedSize; NSTimeInterval _cachedDuration; + + AVURLAsset *_cachedAVAsset; } @end @implementation TGCameraCapturedVideo ++ (NSURL *)videoURLForAsset:(TGMediaAsset *)asset { + NSURL *convertedGifsUrl = [NSURL fileURLWithPath:[[[LegacyComponentsGlobals provider] dataStoragePath] stringByAppendingPathComponent:@"convertedGifs"]]; + [[NSFileManager defaultManager] createDirectoryAtPath:convertedGifsUrl.path withIntermediateDirectories:true attributes:nil error:nil]; + return [convertedGifsUrl URLByAppendingPathComponent:[NSString stringWithFormat:@"%@.mp4", [TGStringUtils md5:asset.identifier]]]; +} + - (instancetype)initWithURL:(NSURL *)url { self = [super init]; if (self != nil) { - _avAsset = [[AVURLAsset alloc] initWithURL:url options:nil]; + _cachedAVAsset = [[AVURLAsset alloc] initWithURL:url options:nil]; + _cachedSize = CGSizeZero; + _cachedDuration = 0.0; + } + return self; +} + +- (instancetype)initWithAsset:(TGMediaAsset *)asset +{ + self = [super init]; + if (self != nil) + { + _originalAsset = asset; + _cachedSize = CGSizeZero; _cachedDuration = 0.0; } @@ -26,7 +54,9 @@ - (void)_cleanUp { - [[NSFileManager defaultManager] removeItemAtPath:_avAsset.URL.path error:nil]; + if (_originalAsset == nil) { + [[NSFileManager defaultManager] removeItemAtPath:_cachedAVAsset.URL.path error:nil]; + } } - (bool)isVideo @@ -34,9 +64,47 @@ return true; } +- (bool)isAnimation { + return _originalAsset != nil; +} + +- (SSignal *)avAsset { + if (_originalAsset != nil) { + if (_cachedAVAsset != nil) { + return [SSignal single:_cachedAVAsset]; + } else { + NSURL *videoUrl = [TGCameraCapturedVideo videoURLForAsset:_originalAsset]; + return [[TGMediaAssetImageSignals imageDataForAsset:_originalAsset allowNetworkAccess:false] mapToSignal:^SSignal *(TGMediaAssetImageData *assetData) { + NSData *data = assetData.imageData; + + const char *gif87Header = "GIF87"; + const char *gif89Header = "GIF89"; + if (data.length >= 5 && (!memcmp(data.bytes, gif87Header, 5) || !memcmp(data.bytes, gif89Header, 5))) + { + return [[TGGifConverter convertGifToMp4:data] map:^id(NSDictionary *result) + { + NSString *filePath = result[@"path"]; + [[NSFileManager defaultManager] moveItemAtPath:filePath toPath:videoUrl.path error:nil]; + + return [AVURLAsset assetWithURL:videoUrl]; + }]; + } else { + return [SSignal complete]; + } + }]; + } + } else { + return [SSignal single:_cachedAVAsset]; + } +} + - (NSString *)uniqueIdentifier { - return _avAsset.URL.absoluteString; + if (_originalAsset) { + return _originalAsset.uniqueIdentifier; + } else { + return _cachedAVAsset.URL.absoluteString; + } } - (CGSize)originalSize @@ -44,7 +112,11 @@ if (!CGSizeEqualToSize(_cachedSize, CGSizeZero)) return _cachedSize; - AVAssetTrack *track = _avAsset.tracks.firstObject; + if (_originalAsset != nil) { + return [_originalAsset originalSize]; + } + + AVAssetTrack *track = _cachedAVAsset.tracks.firstObject; _cachedSize = CGRectApplyAffineTransform((CGRect){ CGPointZero, track.naturalSize }, track.preferredTransform).size; return _cachedSize; } @@ -59,29 +131,41 @@ if (_cachedDuration > DBL_EPSILON) return _cachedDuration; - _cachedDuration = CMTimeGetSeconds(_avAsset.duration); + if (_cachedAVAsset != nil) { + _cachedDuration = CMTimeGetSeconds(_cachedAVAsset.duration); + } return _cachedDuration; } - (SSignal *)thumbnailImageSignal { - CGFloat thumbnailImageSide = TGPhotoEditorScreenImageMaxSize().width; - CGSize size = TGScaleToSize(self.originalSize, CGSizeMake(thumbnailImageSide, thumbnailImageSide)); + if (_originalAsset != nil) { + return [_originalAsset thumbnailImageSignal]; + } else { + CGFloat thumbnailImageSide = TGPhotoEditorScreenImageMaxSize().width; + CGSize size = TGScaleToSize(self.originalSize, CGSizeMake(thumbnailImageSide, thumbnailImageSide)); - return [TGMediaAssetImageSignals videoThumbnailForAVAsset:_avAsset size:size timestamp:kCMTimeZero]; + return [TGMediaAssetImageSignals videoThumbnailForAVAsset:_cachedAVAsset size:size timestamp:kCMTimeZero]; + } } -- (SSignal *)screenImageSignal:(NSTimeInterval)__unused position +- (SSignal *)screenImageSignal:(NSTimeInterval)position { - CGFloat imageSide = 1280.0f; - CGSize size = TGScaleToSize(self.originalSize, CGSizeMake(imageSide, imageSide)); - - return [TGMediaAssetImageSignals videoThumbnailForAVAsset:_avAsset size:size timestamp:kCMTimeZero]; + if (_originalAsset != nil) { + return [_originalAsset screenImageSignal:position]; + } else { + CGFloat imageSide = 1280.0f; + CGSize size = TGScaleToSize(self.originalSize, CGSizeMake(imageSide, imageSide)); + + return [TGMediaAssetImageSignals videoThumbnailForAVAsset:_cachedAVAsset size:size timestamp:kCMTimeZero]; + } } - (SSignal *)originalImageSignal:(NSTimeInterval)position { - return [TGMediaAssetImageSignals videoThumbnailForAVAsset:_avAsset size:self.originalSize timestamp:CMTimeMakeWithSeconds(position, NSEC_PER_SEC)]; + return [[self avAsset] mapToSignal:^SSignal *(AVURLAsset *avAsset) { + return [TGMediaAssetImageSignals videoThumbnailForAVAsset:avAsset size:self.originalSize timestamp:CMTimeMakeWithSeconds(position, NSEC_PER_SEC)]; + }]; } @end diff --git a/submodules/LegacyComponents/Sources/TGCameraController.m b/submodules/LegacyComponents/Sources/TGCameraController.m index ecd41d03a5..1213e7f783 100644 --- a/submodules/LegacyComponents/Sources/TGCameraController.m +++ b/submodules/LegacyComponents/Sources/TGCameraController.m @@ -1772,7 +1772,7 @@ static CGPoint TGCameraControllerClampPointToScreenSize(__unused id self, __unus if ([editableItem isKindOfClass:[TGMediaAsset class]]) { return [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)editableItem]; } else if ([editableItem isKindOfClass:[TGCameraCapturedVideo class]]) { - return [SSignal single:((TGCameraCapturedVideo *)editableItem).avAsset]; + return ((TGCameraCapturedVideo *)editableItem).avAsset; } else { return [editableItem originalImageSignal:position]; } @@ -2467,7 +2467,9 @@ static CGPoint TGCameraControllerClampPointToScreenSize(__unused id self, __unus else if ([item isKindOfClass:[TGCameraCapturedVideo class]]) { TGCameraCapturedVideo *video = (TGCameraCapturedVideo *)item; - return [SSignal single:@{@"type": @"video", @"url": video.avAsset.URL}]; + return [[video avAsset] mapToSignal:^SSignal *(AVURLAsset *avAsset) { + return [SSignal single:@{@"type": @"video", @"url": avAsset.URL}]; + }]; } return [SSignal complete]; @@ -2689,9 +2691,11 @@ static CGPoint TGCameraControllerClampPointToScreenSize(__unused id self, __unus }; CGSize imageSize = TGFillSize(asset.originalSize, CGSizeMake(512, 512)); - SSignal *trimmedVideoThumbnailSignal = [[TGMediaAssetImageSignals videoThumbnailForAVAsset:video.avAsset size:imageSize timestamp:CMTimeMakeWithSeconds(adjustments.trimStartValue, NSEC_PER_SEC)] map:^UIImage *(UIImage *image) - { + SSignal *trimmedVideoThumbnailSignal = [[video avAsset] mapToSignal:^SSignal *(AVURLAsset *avAsset) { + return [[TGMediaAssetImageSignals videoThumbnailForAVAsset:avAsset size:imageSize timestamp:CMTimeMakeWithSeconds(adjustments.trimStartValue, NSEC_PER_SEC)] map:^UIImage *(UIImage *image) + { return cropVideoThumbnail(image, TGScaleToFill(asset.originalSize, CGSizeMake(512, 512)), asset.originalSize, true); + }]; }]; SSignal *videoThumbnailSignal = [inlineThumbnailSignal(asset) map:^UIImage *(UIImage *image) @@ -2709,7 +2713,7 @@ static CGPoint TGCameraControllerClampPointToScreenSize(__unused id self, __unus { NSMutableDictionary *dict = [[NSMutableDictionary alloc] init]; dict[@"type"] = @"cameraVideo"; - dict[@"url"] = video.avAsset.URL; +// dict[@"url"] = video.avAsset.URL; dict[@"previewImage"] = image; dict[@"adjustments"] = adjustments; dict[@"dimensions"] = [NSValue valueWithCGSize:dimensions]; diff --git a/submodules/LegacyComponents/Sources/TGCameraPhotoPreviewController.m b/submodules/LegacyComponents/Sources/TGCameraPhotoPreviewController.m index 3ad5230219..087b786a57 100644 --- a/submodules/LegacyComponents/Sources/TGCameraPhotoPreviewController.m +++ b/submodules/LegacyComponents/Sources/TGCameraPhotoPreviewController.m @@ -1026,7 +1026,7 @@ if ([editableItem isKindOfClass:[TGMediaAsset class]]) { return [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)editableItem]; } else if ([editableItem isKindOfClass:[TGCameraCapturedVideo class]]) { - return [SSignal single:((TGCameraCapturedVideo *)editableItem).avAsset]; + return ((TGCameraCapturedVideo *)editableItem).avAsset; } else { return [editableItem originalImageSignal:position]; } diff --git a/submodules/LegacyComponents/Sources/TGClipboardGalleryPhotoItem.m b/submodules/LegacyComponents/Sources/TGClipboardGalleryPhotoItem.m index a895683486..4a711e3464 100644 --- a/submodules/LegacyComponents/Sources/TGClipboardGalleryPhotoItem.m +++ b/submodules/LegacyComponents/Sources/TGClipboardGalleryPhotoItem.m @@ -38,7 +38,7 @@ - (TGPhotoEditorTab)toolbarTabs { - return TGPhotoEditorCropTab | TGPhotoEditorToolsTab | TGPhotoEditorPaintTab | TGPhotoEditorTimerTab; + return TGPhotoEditorCropTab | TGPhotoEditorToolsTab | TGPhotoEditorPaintTab; } diff --git a/submodules/LegacyComponents/Sources/TGGifConverter.m b/submodules/LegacyComponents/Sources/TGGifConverter.m index 7acce7f64a..01df95a41f 100644 --- a/submodules/LegacyComponents/Sources/TGGifConverter.m +++ b/submodules/LegacyComponents/Sources/TGGifConverter.m @@ -77,7 +77,11 @@ const CGFloat TGGifConverterMaximumSide = 720.0f; return; } - CGSize targetSize = TGFitSizeF(CGSizeMake(sourceWidth, sourceHeight), CGSizeMake(TGGifConverterMaximumSide, TGGifConverterMaximumSide)); + const CGFloat blockSize = 16.0f; + CGFloat renderWidth = CGFloor(sourceWidth / blockSize) * blockSize; + CGFloat renderHeight = CGFloor(sourceHeight * renderWidth / sourceWidth); + + CGSize targetSize = TGFitSizeF(CGSizeMake(renderWidth, renderHeight), CGSizeMake(TGGifConverterMaximumSide, TGGifConverterMaximumSide)); NSDictionary *videoCleanApertureSettings = @ { @@ -122,8 +126,8 @@ const CGFloat TGGifConverterMaximumSide = 720.0f; NSDictionary *attributes = @ { (NSString *)kCVPixelBufferPixelFormatTypeKey : @(kCVPixelFormatType_32ARGB), - (NSString *)kCVPixelBufferWidthKey : @(sourceWidth), - (NSString *)kCVPixelBufferHeightKey : @(sourceHeight), + (NSString *)kCVPixelBufferWidthKey : @(renderWidth), + (NSString *)kCVPixelBufferHeightKey : @(renderHeight), (NSString *)kCVPixelBufferCGImageCompatibilityKey : @YES, (NSString *)kCVPixelBufferCGBitmapContextCompatibilityKey : @YES }; @@ -148,7 +152,7 @@ const CGFloat TGGifConverterMaximumSide = 720.0f; if (gifProperties != NULL) { - CVPixelBufferRef pxBuffer = [self newBufferFrom:imgRef withPixelBufferPool:adaptor.pixelBufferPool andAttributes:adaptor.sourcePixelBufferAttributes]; + CVPixelBufferRef pxBuffer = [self newBufferFrom:imgRef size:targetSize withPixelBufferPool:adaptor.pixelBufferPool andAttributes:adaptor.sourcePixelBufferAttributes]; if (pxBuffer != NULL) { if (previewImage == nil) { @@ -231,13 +235,10 @@ const CGFloat TGGifConverterMaximumSide = 720.0f; }]; }; -+ (CVPixelBufferRef)newBufferFrom:(CGImageRef)frame withPixelBufferPool:(CVPixelBufferPoolRef)pixelBufferPool andAttributes:(NSDictionary *)attributes ++ (CVPixelBufferRef)newBufferFrom:(CGImageRef)frame size:(CGSize)size withPixelBufferPool:(CVPixelBufferPoolRef)pixelBufferPool andAttributes:(NSDictionary *)attributes { NSParameterAssert(frame); - size_t width = CGImageGetWidth(frame); - size_t height = CGImageGetHeight(frame); - size_t bpc = 8; CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); CVPixelBufferRef pxBuffer = NULL; @@ -246,7 +247,7 @@ const CGFloat TGGifConverterMaximumSide = 720.0f; if (pixelBufferPool) status = CVPixelBufferPoolCreatePixelBuffer(kCFAllocatorDefault, pixelBufferPool, &pxBuffer); else - status = CVPixelBufferCreate(kCFAllocatorDefault, width, height, kCVPixelFormatType_32ARGB, (__bridge CFDictionaryRef)attributes, &pxBuffer); + status = CVPixelBufferCreate(kCFAllocatorDefault, size.width, size.height, kCVPixelFormatType_32ARGB, (__bridge CFDictionaryRef)attributes, &pxBuffer); NSAssert(status == kCVReturnSuccess, @"Could not create a pixel buffer"); @@ -255,10 +256,10 @@ const CGFloat TGGifConverterMaximumSide = 720.0f; size_t bytesPerRow = CVPixelBufferGetBytesPerRow(pxBuffer); - CGContextRef context = CGBitmapContextCreate(pxData, width, height, bpc, bytesPerRow, colorSpace, kCGImageAlphaNoneSkipFirst); + CGContextRef context = CGBitmapContextCreate(pxData, size.width, size.height, 8, bytesPerRow, colorSpace, kCGImageAlphaNoneSkipFirst); NSAssert(context, @"Could not create a context"); - CGContextDrawImage(context, CGRectMake(0, 0, width, height), frame); + CGContextDrawImage(context, CGRectMake(0, 0, size.width, size.height), frame); CVPixelBufferUnlockBaseAddress(pxBuffer, 0); diff --git a/submodules/LegacyComponents/Sources/TGMediaAssetsPickerController.m b/submodules/LegacyComponents/Sources/TGMediaAssetsPickerController.m index 016db19c0c..129069faf0 100644 --- a/submodules/LegacyComponents/Sources/TGMediaAssetsPickerController.m +++ b/submodules/LegacyComponents/Sources/TGMediaAssetsPickerController.m @@ -434,7 +434,7 @@ if ([editableItem isKindOfClass:[TGMediaAsset class]]) { return [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)editableItem]; } else if ([editableItem isKindOfClass:[TGCameraCapturedVideo class]]) { - return [SSignal single:((TGCameraCapturedVideo *)editableItem).avAsset]; + return ((TGCameraCapturedVideo *)editableItem).avAsset; } else { return [editableItem originalImageSignal:position]; } diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m index 7bd0493772..638486cb1a 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m @@ -21,6 +21,7 @@ #import "TGModernGallerySelectableItem.h" #import "TGModernGalleryEditableItem.h" #import "TGMediaPickerGalleryPhotoItem.h" +#import "TGMediaPickerGalleryVideoItem.h" #import "TGMediaPickerGalleryPhotoItemView.h" #import "TGMediaPickerGalleryVideoItemView.h" @@ -150,6 +151,8 @@ [strongSelf.window endEditing:true]; if (strongSelf->_doneLongPressed != nil) strongSelf->_doneLongPressed(strongSelf->_currentItem); + + [[NSUserDefaults standardUserDefaults] setObject:@(3) forKey:@"TG_displayedMediaTimerTooltip_v3"]; }; _muteButton = [[TGModernButton alloc] initWithFrame:CGRectMake(0, 0, 39.0f, 39.0f)]; @@ -571,7 +574,15 @@ [strongSelf->_portraitToolbarView setEditButtonsEnabled:available animated:true]; [strongSelf->_landscapeToolbarView setEditButtonsEnabled:available animated:true]; + + bool sendableAsGif = !strongSelf->_inhibitMute && [strongItemView isKindOfClass:[TGMediaPickerGalleryVideoItemView class]]; + if ([strongSelf->_currentItem isKindOfClass:[TGMediaPickerGalleryVideoItem class]]) { + TGMediaPickerGalleryVideoItem *item = (TGMediaPickerGalleryVideoItem *)strongSelf->_currentItem; + if ([item.asset isKindOfClass:[TGCameraCapturedVideo class]] && ((TGCameraCapturedVideo *)item.asset).isAnimation) { + sendableAsGif = false; + } + } strongSelf->_muteButton.hidden = !sendableAsGif; } }]]; @@ -911,7 +922,7 @@ - (bool)shouldDisplayTooltip { - return ![[[NSUserDefaults standardUserDefaults] objectForKey:@"TG_displayedMediaTimerTooltip_v2"] boolValue]; + return [[[NSUserDefaults standardUserDefaults] objectForKey:@"TG_displayedMediaTimerTooltip_v3"] intValue] < 3; } - (void)setupTooltip:(CGRect)rect @@ -919,7 +930,7 @@ if (_tooltipContainerView != nil || !_hasTimer) return; - _tooltipTimer = [TGTimerTarget scheduledMainThreadTimerWithTarget:self action:@selector(tooltipTimerTick) interval:2.5 repeat:false]; + _tooltipTimer = [TGTimerTarget scheduledMainThreadTimerWithTarget:self action:@selector(tooltipTimerTick) interval:3.5 repeat:false]; _tooltipContainerView = [[TGMenuContainerView alloc] initWithFrame:CGRectMake(0.0f, 0.0f, self.frame.size.width, self.frame.size.height)]; [self addSubview:_tooltipContainerView]; @@ -934,7 +945,8 @@ [_tooltipContainerView showMenuFromRect:rect animated:false]; - [[NSUserDefaults standardUserDefaults] setObject:@true forKey:@"TG_displayedMediaTimerTooltip_v2"]; + int counter = [[[NSUserDefaults standardUserDefaults] objectForKey:@"TG_displayedMediaTimerTooltip_v3"] intValue]; + [[NSUserDefaults standardUserDefaults] setObject:@(counter + 1) forKey:@"TG_displayedMediaTimerTooltip_v3"]; } - (void)tooltipTimerTick diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryModel.m b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryModel.m index 366f031f2b..20692716e2 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryModel.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryModel.m @@ -575,7 +575,7 @@ if ([editableItem isKindOfClass:[TGMediaAsset class]]) { return [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)editableItem]; } else if ([editableItem isKindOfClass:[TGCameraCapturedVideo class]]) { - return [SSignal single:((TGCameraCapturedVideo *)editableItem).avAsset]; + return ((TGCameraCapturedVideo *)editableItem).avAsset; } else { return [editableItem originalImageSignal:position]; } diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryPhotoItemView.m b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryPhotoItemView.m index f16a6ecd76..e86d449368 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryPhotoItemView.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryPhotoItemView.m @@ -1,7 +1,5 @@ #import "TGMediaPickerGalleryPhotoItemView.h" -#import - #import "LegacyComponentsInternal.h" #import "TGFont.h" #import "TGStringUtils.h" @@ -34,7 +32,6 @@ void (^_currentAvailabilityObserver)(bool); UIView *_temporaryRepView; - PHLivePhotoView *_livePhotoView; UIView *_contentView; UIView *_contentWrapperView; @@ -116,11 +113,6 @@ { _imageView.hidden = false; [_imageView reset]; - if (_livePhotoView != nil) - { - [_livePhotoView removeFromSuperview]; - _livePhotoView = nil; - } [self setProgressVisible:false value:0.0f animated:false]; } @@ -231,8 +223,7 @@ } [strongSelf reset]; - - strongSelf->_livePhotoView.frame = strongSelf->_imageView.frame; + }]]; if (!item.asFile) diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGallerySelectedItemsModel.m b/submodules/LegacyComponents/Sources/TGMediaPickerGallerySelectedItemsModel.m index 4e6dcdf8a4..da3b641321 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGallerySelectedItemsModel.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGallerySelectedItemsModel.m @@ -50,9 +50,7 @@ return; if (next.selected) - { [strongSelf addSelectedItem:next.item]; - } else if (!strongSelf->_keepItems) [strongSelf removeSelectedItem:next.item]; }]]; diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItem.m b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItem.m index 227dcaae33..ac47761f5e 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItem.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItem.m @@ -25,7 +25,7 @@ return CGSizeZero; } -- (AVAsset *)avAsset +- (SSignal *)avAsset { if ([self.asset isKindOfClass:[TGCameraCapturedVideo class]]) return ((TGCameraCapturedVideo *)self.asset).avAsset; @@ -70,10 +70,13 @@ - (TGPhotoEditorTab)toolbarTabs { - if ([self.asset isKindOfClass:[TGMediaAsset class]] && ((TGMediaAsset *)self.asset).subtypes & TGMediaAssetSubtypePhotoLive) - return TGPhotoEditorCropTab | TGPhotoEditorPaintTab | TGPhotoEditorToolsTab | TGPhotoEditorTimerTab; - else + if ([self.asset isKindOfClass:[TGMediaAsset class]] && ((TGMediaAsset *)self.asset).subtypes & TGMediaAssetSubtypePhotoLive) { + return TGPhotoEditorCropTab | TGPhotoEditorPaintTab | TGPhotoEditorToolsTab; + } else if ([self.asset isKindOfClass:[TGCameraCapturedVideo class]] && ((TGCameraCapturedVideo *)self.asset).isAnimation) { + return TGPhotoEditorCropTab | TGPhotoEditorPaintTab | TGPhotoEditorToolsTab; + } else { return TGPhotoEditorCropTab | TGPhotoEditorToolsTab | TGPhotoEditorPaintTab | TGPhotoEditorQualityTab; + } } - (Class)viewClass diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m index 105344a3a1..90fc17467f 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryVideoItemView.m @@ -1045,16 +1045,16 @@ if (_videoView != nil) { SMetaDisposable *currentAudioSession = _currentAudioSession; -// if (currentAudioSession) -// { + if (currentAudioSession) + { // _videoView.deallocBlock = ^ // { -// [[SQueue concurrentDefaultQueue] dispatch:^ -// { -// [currentAudioSession setDisposable:nil]; -// }]; + [[SQueue concurrentDefaultQueue] dispatch:^ + { + [currentAudioSession setDisposable:nil]; + }]; // }; -// } + } // [_videoView cleanupPlayer]; _photoEditor.previewOutput = nil; @@ -1092,10 +1092,14 @@ [self inhibitVolumeOverlay]; SSignal *itemSignal = nil; - if ([self.item.asset isKindOfClass:[TGMediaAsset class]]) + if ([self.item.asset isKindOfClass:[TGMediaAsset class]]) { itemSignal = [TGMediaAssetImageSignals playerItemForVideoAsset:(TGMediaAsset *)self.item.asset]; - else if (self.item.avAsset != nil) - itemSignal = [SSignal single:[AVPlayerItem playerItemWithAsset:self.item.avAsset]]; + } + else if (self.item.avAsset != nil) { + itemSignal = [self.item.avAsset mapToSignal:^SSignal *(AVAsset *avAsset) { + return [SSignal single:[AVPlayerItem playerItemWithAsset:avAsset]]; + }]; + } [_playerItemDisposable setDisposable:[[itemSignal deliverOn:[SQueue mainQueue]] startWithNext:^(AVPlayerItem *playerItem) { @@ -1546,7 +1550,7 @@ if (timestamps.count == 0) return; - AVAsset *avAsset = self.item.avAsset ?: _player.currentItem.asset; + SSignal *avAsset = self.item.avAsset ?: [SSignal single:_player.currentItem.asset]; TGMediaEditingContext *editingContext = self.item.editingContext; id editableItem = self.item.editableMediaItem; @@ -1554,7 +1558,9 @@ if ([self.item.asset isKindOfClass:[TGMediaAsset class]] && ![self itemIsLivePhoto]) thumbnailsSignal = [TGMediaAssetImageSignals videoThumbnailsForAsset:self.item.asset size:size timestamps:timestamps]; else if (avAsset != nil) - thumbnailsSignal = [TGMediaAssetImageSignals videoThumbnailsForAVAsset:avAsset size:size timestamps:timestamps]; + thumbnailsSignal = [avAsset mapToSignal:^SSignal *(AVAsset *avAsset) { + return [TGMediaAssetImageSignals videoThumbnailsForAVAsset:avAsset size:size timestamps:timestamps]; + }]; _requestingThumbnails = true; diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerModernGalleryMixin.m b/submodules/LegacyComponents/Sources/TGMediaPickerModernGalleryMixin.m index 87ae43882f..a5f4585265 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerModernGalleryMixin.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerModernGalleryMixin.m @@ -370,13 +370,18 @@ case TGMediaAssetGifType: { +// TGCameraCapturedVideo *convertedAsset = [[TGCameraCapturedVideo alloc] initWithAsset:asset]; +// galleryItem = [[TGMediaPickerGalleryVideoItem alloc] initWithAsset:convertedAsset]; galleryItem = [[TGMediaPickerGalleryGifItem alloc] initWithAsset:asset]; } break; default: { - galleryItem = [[TGMediaPickerGalleryPhotoItem alloc] initWithAsset:asset]; + if (asset.subtypes & TGMediaAssetSubtypePhotoLive) + galleryItem = [[TGMediaPickerGalleryVideoItem alloc] initWithAsset:asset]; + else + galleryItem = [[TGMediaPickerGalleryPhotoItem alloc] initWithAsset:asset]; } break; } diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerPhotoCounterButton.m b/submodules/LegacyComponents/Sources/TGMediaPickerPhotoCounterButton.m index e4d4ba8c16..ebc05148dc 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerPhotoCounterButton.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerPhotoCounterButton.m @@ -68,7 +68,7 @@ const CGFloat TGPhotoCounterButtonMaskFade = 18; _countLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, -0.5f, frame.size.width + 1.0, frame.size.height)]; _countLabel.backgroundColor = [UIColor clearColor]; - _countLabel.font = [TGFont roundedFontOfSize:17]; + _countLabel.font = [TGFont roundedFontOfSize:18]; _countLabel.text = [TGStringUtils stringWithLocalizedNumber:0]; _countLabel.textColor = [UIColor whiteColor]; [_wrapperView addSubview:_countLabel]; @@ -299,15 +299,15 @@ const CGFloat TGPhotoCounterButtonMaskFade = 18; { labelOrigin = 12 + TGScreenPixel + (38 - labelWidth) / 2; - if ([_countLabel.text isEqualToString:@"1"] || [_countLabel.text isEqualToString:@"4"]) - labelOrigin -= 2 * TGScreenPixel; +// if ([_countLabel.text isEqualToString:@"1"] || [_countLabel.text isEqualToString:@"4"]) +// labelOrigin -= 2 * TGScreenPixel; } else { labelOrigin = (processingLabelWidth > 0) ? -processingLabelWidth + 19 + 13 - 4.5f: 64 - 38 + (38 - labelWidth) / 2.0f - 13; } - _countLabel.frame = CGRectMake(labelOrigin, 6.0f, labelWidth, _countLabel.frame.size.height); + _countLabel.frame = CGRectMake(labelOrigin, 5.0 + TGScreenPixel, labelWidth, _countLabel.frame.size.height); _countLabel.transform = transform; } diff --git a/submodules/LegacyComponents/Sources/TGPaintArrowBrush.h b/submodules/LegacyComponents/Sources/TGPaintArrowBrush.h new file mode 100644 index 0000000000..36b1c0e563 --- /dev/null +++ b/submodules/LegacyComponents/Sources/TGPaintArrowBrush.h @@ -0,0 +1,5 @@ +#import "TGPaintBrush.h" + +@interface TGPaintArrowBrush : TGPaintBrush + +@end diff --git a/submodules/LegacyComponents/Sources/TGPaintArrowBrush.m b/submodules/LegacyComponents/Sources/TGPaintArrowBrush.m new file mode 100644 index 0000000000..cc36638983 --- /dev/null +++ b/submodules/LegacyComponents/Sources/TGPaintArrowBrush.m @@ -0,0 +1,90 @@ +#import "TGPaintArrowBrush.h" + +const CGFloat TGPaintArrowBrushHardness = 0.92f; + +@implementation TGPaintArrowBrush + +- (CGFloat)spacing +{ + return 0.15f; +} + +- (CGFloat)alpha +{ + return 0.85f; +} + +- (CGFloat)angle +{ + return 0.0f; +} + +//- (CGFloat)dynamic +//{ +// return 0.75f; +//} + +- (bool)arrow +{ + return true; +} + +- (CGImageRef)generateRadialStampForSize:(CGSize)size hardness:(CGFloat)hardness +{ + CGColorSpaceRef colorspace = CGColorSpaceCreateDeviceGray(); + CGContextRef ctx = CGBitmapContextCreate(NULL, (NSInteger)size.width, (NSInteger)size.height, 8, (NSInteger)size.width, colorspace, kCGImageAlphaNone); + + CGContextSetGrayFillColor(ctx, 0.0f, 1.0f); + CGContextFillRect(ctx, CGRectMake(0, 0, size.width, size.height)); + + NSArray *colors = @[(__bridge id) [UIColor whiteColor].CGColor, (__bridge id) [UIColor blackColor].CGColor]; + const CGFloat locations[] = {0.0, 1.0}; + + CGGradientRef gradientRef = CGGradientCreateWithColors(colorspace, (__bridge CFArrayRef) colors, locations); + CGPoint center = CGPointMake(size.width / 2, size.height / 2); + + CGFloat maxRadius = size.width / 2; + CGFloat hFactor = hardness * 0.99; + CGGradientDrawingOptions options = kCGGradientDrawsBeforeStartLocation |kCGGradientDrawsAfterEndLocation; + CGContextDrawRadialGradient(ctx, gradientRef, center, hFactor * maxRadius, center, maxRadius, options); + + CGImageRef image = CGBitmapContextCreateImage(ctx); + + CGContextRelease(ctx); + CGColorSpaceRelease(colorspace); + CGGradientRelease(gradientRef); + + return image; +} + +- (CGImageRef)stampRef +{ + static CGImageRef image = NULL; + + if (image == NULL) + image = [self generateRadialStampForSize:TGPaintBrushTextureSize hardness:TGPaintArrowBrushHardness]; + + return image; +} + +- (CGImageRef)previewStampRef +{ + if (_previewStampRef == NULL) + _previewStampRef = [self generateRadialStampForSize:TGPaintBrushPreviewTextureSize hardness:TGPaintArrowBrushHardness]; + + return _previewStampRef; +} + +static UIImage *radialBrushPreviewImage = nil; + +- (UIImage *)previewImage +{ + return radialBrushPreviewImage; +} + +- (void)setPreviewImage:(UIImage *)previewImage +{ + radialBrushPreviewImage = previewImage; +} + +@end diff --git a/submodules/LegacyComponents/Sources/TGPaintBrush.h b/submodules/LegacyComponents/Sources/TGPaintBrush.h index f38be2ae0e..84c6987a72 100644 --- a/submodules/LegacyComponents/Sources/TGPaintBrush.h +++ b/submodules/LegacyComponents/Sources/TGPaintBrush.h @@ -10,7 +10,9 @@ @property (nonatomic, readonly) CGFloat alpha; @property (nonatomic, readonly) CGFloat angle; @property (nonatomic, readonly) CGFloat scale; +@property (nonatomic, readonly) CGFloat dynamic; @property (nonatomic, readonly) bool lightSaber; +@property (nonatomic, readonly) bool arrow; @property (nonatomic, readonly) CGImageRef stampRef; @property (nonatomic, readonly) CGImageRef previewStampRef; @@ -20,4 +22,4 @@ @end extern const CGSize TGPaintBrushTextureSize; -extern const CGSize TGPaintBrushPreviewTextureSize; \ No newline at end of file +extern const CGSize TGPaintBrushPreviewTextureSize; diff --git a/submodules/LegacyComponents/Sources/TGPaintBrush.m b/submodules/LegacyComponents/Sources/TGPaintBrush.m index 67ca1ad9ce..6ae5cad0ba 100644 --- a/submodules/LegacyComponents/Sources/TGPaintBrush.m +++ b/submodules/LegacyComponents/Sources/TGPaintBrush.m @@ -61,6 +61,11 @@ const CGSize TGPaintBrushPreviewTextureSize = { 64.0f, 64.0f }; return 1.0f; } +- (CGFloat)dynamic +{ + return 0.0f; +} + - (bool)lightSaber { return false; diff --git a/submodules/LegacyComponents/Sources/TGPaintBrushPreview.m b/submodules/LegacyComponents/Sources/TGPaintBrushPreview.m index ef997b683a..ed39c11790 100644 --- a/submodules/LegacyComponents/Sources/TGPaintBrushPreview.m +++ b/submodules/LegacyComponents/Sources/TGPaintBrushPreview.m @@ -283,10 +283,11 @@ const NSUInteger TGPaintBrushPreviewSegmentsCount = 100; [self _setupBrush]; [_renderState reset]; _path.remainder = 0.0f; + _path.pressureRemainder = 0.0f; _path.brush = brush; [TGPaintRender renderPath:_path renderState:_renderState]; - + if (_brush.lightSaber) { glBindFramebuffer(GL_FRAMEBUFFER, _lightFramebuffer); diff --git a/submodules/LegacyComponents/Sources/TGPaintInput.m b/submodules/LegacyComponents/Sources/TGPaintInput.m index ed38085d09..53ba273bf0 100644 --- a/submodules/LegacyComponents/Sources/TGPaintInput.m +++ b/submodules/LegacyComponents/Sources/TGPaintInput.m @@ -9,6 +9,7 @@ #import "TGPaintPath.h" #import "TGPaintState.h" #import "TGPaintCanvas.h" +#import "TGPaintBrush.h" #import @interface TGPaintInput () @@ -19,6 +20,8 @@ CGPoint _lastLocation; CGFloat _lastRemainder; + CGFloat _lastPressureRemainder; + CGFloat _lastAngle; TGPaintPoint *_points[3]; NSInteger _pointsCount; @@ -48,7 +51,7 @@ CGPoint midPoint1 = TGPaintMultiplyPoint(TGPaintAddPoints(prev1.CGPoint, prev2.CGPoint), 0.5f); CGFloat midPressure1 = (prev1.z + prev2.z) * 0.5f; CGPoint midPoint2 = TGPaintMultiplyPoint(TGPaintAddPoints(cur.CGPoint, prev1.CGPoint), 0.5f); - CGFloat midPressure2 = (cur.z + prev2.z) * 0.5f; + CGFloat midPressure2 = (cur.z + prev1.z) * 0.5f; NSInteger segmentDistance = 2; CGFloat distance = TGPaintDistance(midPoint1, midPoint2); @@ -126,12 +129,15 @@ if (_pointsCount != 0) pressure = (pressure + _points[_pointsCount - 1].z) / 2.0f; - pressure = 1.0f; TGPaintPoint *point = [TGPaintPoint pointWithX:location.x y:location.y z:pressure]; _points[_pointsCount++] = point; if (_pointsCount == 3) { + CGPoint prev = _points[1].CGPoint; + CGPoint cur = _points[2].CGPoint; + _lastAngle = atan2(cur.y - prev.y, cur.x - prev.x); + [self smoothenAndPaintPoints:canvas ended:false]; _moved = true; } @@ -156,6 +162,22 @@ else { [self smoothenAndPaintPoints:canvas ended:true]; + + if (canvas.state.brush.arrow) { + CGFloat arrowLength = canvas.state.weight * 4.5; + CGFloat angle = _lastAngle; + + TGPaintPoint *tip = [TGPaintPoint pointWithX:location.x y:location.y z:0.8]; + TGPaintPoint *leftTip = [TGPaintPoint pointWithX:location.x + cos(angle - M_PI_4 * 3) * arrowLength y:location.y + sin(angle - M_PI_4 * 3.2) * arrowLength z:1.0]; + leftTip.edge = true; + TGPaintPath *left = [[TGPaintPath alloc] initWithPoints:@[tip, leftTip]]; + [self paintPath:left inCanvas:canvas]; + + TGPaintPoint *rightTip = [TGPaintPoint pointWithX:location.x + cos(angle + M_PI_4 * 3) * arrowLength y:location.y + sin(angle + M_PI_4 * 3.2) * arrowLength z:1.0]; + rightTip.edge = true; + TGPaintPath *right = [[TGPaintPath alloc] initWithPoints:@[tip, rightTip]]; + [self paintPath:right inCanvas:canvas]; + } } _pointsCount = 0; @@ -181,16 +203,20 @@ path.brush = canvas.state.brush; path.baseWeight = canvas.state.weight; - if (_clearBuffer) + if (_clearBuffer) { _lastRemainder = 0.0f; + _lastPressureRemainder = 0.0f; + } path.remainder = _lastRemainder; + path.pressureRemainder = _lastPressureRemainder; [canvas.painting paintStroke:path clearBuffer:_clearBuffer completion:^ { TGDispatchOnMainThread(^ { _lastRemainder = path.remainder; + _lastPressureRemainder = path.pressureRemainder; _clearBuffer = false; }); }]; diff --git a/submodules/LegacyComponents/Sources/TGPaintPath.h b/submodules/LegacyComponents/Sources/TGPaintPath.h index a4a1d01529..953112369a 100644 --- a/submodules/LegacyComponents/Sources/TGPaintPath.h +++ b/submodules/LegacyComponents/Sources/TGPaintPath.h @@ -43,6 +43,7 @@ typedef enum @property (nonatomic, strong) TGPaintBrush *brush; @property (nonatomic, assign) CGFloat remainder; +@property (nonatomic, assign) CGFloat pressureRemainder; - (instancetype)initWithPoint:(TGPaintPoint *)point; - (instancetype)initWithPoints:(NSArray *)points; diff --git a/submodules/LegacyComponents/Sources/TGPaintRadialBrush.m b/submodules/LegacyComponents/Sources/TGPaintRadialBrush.m index 7d5124ab4f..2bf80678af 100644 --- a/submodules/LegacyComponents/Sources/TGPaintRadialBrush.m +++ b/submodules/LegacyComponents/Sources/TGPaintRadialBrush.m @@ -19,6 +19,11 @@ const CGFloat TGPaintRadialBrushHardness = 0.92f; return 0.0f; } +//- (CGFloat)dynamic +//{ +// return 0.75f; +//} + - (CGImageRef)generateRadialStampForSize:(CGSize)size hardness:(CGFloat)hardness { CGColorSpaceRef colorspace = CGColorSpaceCreateDeviceGray(); diff --git a/submodules/LegacyComponents/Sources/TGPaintRender.m b/submodules/LegacyComponents/Sources/TGPaintRender.m index d23fc0adc2..4f95a87887 100644 --- a/submodules/LegacyComponents/Sources/TGPaintRender.m +++ b/submodules/LegacyComponents/Sources/TGPaintRender.m @@ -14,6 +14,7 @@ const NSInteger TGPaintRenderStateDefaultSize = 256; } @property (nonatomic, assign) CGFloat brushWeight; +@property (nonatomic, assign) CGFloat brushDynamic; @property (nonatomic, assign) CGFloat spacing; @property (nonatomic, assign) CGFloat alpha; @property (nonatomic, assign) CGFloat angle; @@ -23,6 +24,7 @@ const NSInteger TGPaintRenderStateDefaultSize = 256; @property (nonatomic, readonly) NSUInteger count; @property (nonatomic, assign) CGFloat remainder; +@property (nonatomic, assign) CGFloat pressureRemainder; - (void)reset; @@ -103,6 +105,7 @@ const NSInteger TGPaintRenderStateDefaultSize = 256; } _remainder = 0; + _pressureRemainder = 0; } @end @@ -120,18 +123,15 @@ typedef struct + (void)_paintStamp:(TGPaintPoint *)point state:(TGPaintRenderState *)state { - CGFloat weight = state.brushWeight; - - CGPoint start = point.CGPoint; - - CGFloat brushSize = weight; - CGFloat rotationalScatter = 0.0f; + CGFloat brushSize = state.brushWeight * state.scale; CGFloat angleOffset = fabs(state.angle) > FLT_EPSILON ? state.angle : 0.0f; CGFloat alpha = MIN(1.0f, state.alpha * 1.55f); [state prepare]; - [state appendValuesCount:1]; - [state addPoint:start size:brushSize angle:rotationalScatter + angleOffset alpha:alpha index:0]; + [state appendValuesCount:4]; + for (NSInteger i = 0; i < 4; i++) { + [state addPoint:point.CGPoint size:brushSize angle:angleOffset alpha:alpha index:i]; + } } + (void)_paintFromPoint:(TGPaintPoint *)lastLocation toPoint:(TGPaintPoint *)location state:(TGPaintRenderState *)state @@ -139,6 +139,7 @@ typedef struct CGFloat lastP = lastLocation.z; CGFloat p = location.z; CGFloat pDelta = p - lastP; + CGFloat pChange = 0.0f; CGFloat f, distance = TGPaintDistance(lastLocation.CGPoint, location.CGPoint); CGPoint vector = TGPaintSubtractPoints(location.CGPoint, lastLocation.CGPoint); @@ -148,8 +149,8 @@ typedef struct CGFloat brushWeight = state.brushWeight * state.scale; CGFloat step = MAX(1.0f, state.spacing * brushWeight); - CGFloat pressure = lastP; - CGFloat pressureStep = 0.0f; + CGFloat pressure = lastP + state.pressureRemainder; + CGFloat pressureStep = pressureStep = pDelta / ((distance - state.remainder) / step); if (distance > 0.0f) unitVector = TGPaintMultiplyPoint(vector, 1.0f / distance); @@ -168,27 +169,29 @@ typedef struct for (f = state.remainder; f <= distance; f += step, pressure += pressureStep) { CGFloat alpha = boldenFirst ? boldenedAlpha : state.alpha; - CGFloat brushSize = brushWeight; -// CGFloat brushSize = MIN(brushWeight, brushWeight - pressure * brushWeight * 0.55f); + CGFloat brushSize = MAX(1.0, brushWeight - state.brushDynamic * pressure * brushWeight); +// CGFloat brushSize = brushWeight; [state addPoint:start size:brushSize angle:vectorAngle alpha:alpha index:i]; start = TGPaintAddPoints(start, TGPaintMultiplyPoint(unitVector, step)); - - i++; - + boldenFirst = false; - pressureStep = pDelta / (distance / step); + pChange += pressureStep; + + i++; } +// NSLog(@"final pressure %f", pressure); if (boldenLast) { [state appendValuesCount:1]; - CGFloat brushSize = MIN(brushWeight, brushWeight - pressure * brushWeight * 0.65f); + CGFloat brushSize = MAX(1.0, brushWeight - state.brushDynamic * pressure * brushWeight); [state addPoint:location.CGPoint size:brushSize angle:vectorAngle alpha:boldenedAlpha index:i]; } state.remainder = f - distance; + state.pressureRemainder = pChange - pDelta; } + (CGRect)_drawWithState:(TGPaintRenderState *)state @@ -292,6 +295,7 @@ typedef struct + (CGRect)renderPath:(TGPaintPath *)path renderState:(TGPaintRenderState *)renderState { renderState.brushWeight = path.baseWeight; + renderState.brushDynamic = path.brush.dynamic; renderState.spacing = path.brush.spacing; renderState.alpha = path.brush.alpha; renderState.angle = path.brush.angle; @@ -313,6 +317,7 @@ typedef struct } path.remainder = renderState.remainder; + path.pressureRemainder = renderState.pressureRemainder; return [self _drawWithState:renderState]; } diff --git a/submodules/LegacyComponents/Sources/TGPaintSwatch.h b/submodules/LegacyComponents/Sources/TGPaintSwatch.h index 9451dae9d1..c98faa1d98 100644 --- a/submodules/LegacyComponents/Sources/TGPaintSwatch.h +++ b/submodules/LegacyComponents/Sources/TGPaintSwatch.h @@ -4,7 +4,7 @@ @interface TGPaintSwatch : NSObject @property (nonatomic, readonly) UIColor *color; -@property (nonatomic, readonly) CGFloat colorLocaton; +@property (nonatomic, readonly) CGFloat colorLocation; @property (nonatomic, readonly) CGFloat brushWeight; + (instancetype)swatchWithColor:(UIColor *)color colorLocation:(CGFloat)colorLocation brushWeight:(CGFloat)brushWeight; diff --git a/submodules/LegacyComponents/Sources/TGPaintSwatch.m b/submodules/LegacyComponents/Sources/TGPaintSwatch.m index 781fd18bb5..3cb8fb3e4b 100644 --- a/submodules/LegacyComponents/Sources/TGPaintSwatch.m +++ b/submodules/LegacyComponents/Sources/TGPaintSwatch.m @@ -11,14 +11,14 @@ return false; TGPaintSwatch *swatch = (TGPaintSwatch *)object; - return [swatch.color isEqual:self.color] && fabs(swatch.colorLocaton - self.colorLocaton) < FLT_EPSILON && fabs(swatch.brushWeight - self.brushWeight) < FLT_EPSILON; + return [swatch.color isEqual:self.color] && fabs(swatch.colorLocation - self.colorLocation) < FLT_EPSILON && fabs(swatch.brushWeight - self.brushWeight) < FLT_EPSILON; } + (instancetype)swatchWithColor:(UIColor *)color colorLocation:(CGFloat)colorLocation brushWeight:(CGFloat)brushWeight { TGPaintSwatch *swatch = [[TGPaintSwatch alloc] init]; swatch->_color = color; - swatch->_colorLocaton = colorLocation; + swatch->_colorLocation = colorLocation; swatch->_brushWeight = brushWeight; return swatch; diff --git a/submodules/LegacyComponents/Sources/TGPhotoBrushSettingsView.m b/submodules/LegacyComponents/Sources/TGPhotoBrushSettingsView.m index f97ca65ace..6547a3c5ca 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoBrushSettingsView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoBrushSettingsView.m @@ -10,19 +10,20 @@ #import "TGPaintBrush.h" #import "TGPaintBrushPreview.h" -const CGFloat TGPhotoBrushSettingsViewMargin = 19.0f; +const CGFloat TGPhotoBrushSettingsViewMargin = 10.0f; const CGFloat TGPhotoBrushSettingsItemHeight = 44.0f; @interface TGPhotoBrushSettingsView () { NSArray *_brushes; - TGPaintBrushPreview *_preview; - UIImageView *_backgroundView; + UIView *_wrapperView; + UIView *_contentView; + UIVisualEffectView *_effectView; NSArray *_brushViews; + NSArray *_brushIconViews; NSArray *_brushSeparatorViews; - UIImageView *_selectedCheckView; UIImage *_landscapeLeftBackgroundImage; UIImage *_landscapeRightBackgroundImage; @@ -40,80 +41,110 @@ const CGFloat TGPhotoBrushSettingsItemHeight = 44.0f; if (self != nil) { _brushes = brushes; - _preview = preview; _interfaceOrientation = UIInterfaceOrientationPortrait; - _backgroundView = [[UIImageView alloc] init]; - //_backgroundView.alpha = 0.98f; - [self addSubview:_backgroundView]; + _wrapperView = [[UIView alloc] init]; + _wrapperView.clipsToBounds = true; + _wrapperView.layer.cornerRadius = 12.0; + [self addSubview:_wrapperView]; + + _effectView = [[UIVisualEffectView alloc] initWithEffect:[UIBlurEffect effectWithStyle:UIBlurEffectStyleDark]]; + _effectView.alpha = 0.0f; + _effectView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; + [_wrapperView addSubview:_effectView]; + + _contentView = [[UIView alloc] init]; + _contentView.alpha = 0.0f; + _contentView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; + [_wrapperView addSubview:_contentView]; + + UIFont *font = [UIFont systemFontOfSize:17]; NSMutableArray *brushViews = [[NSMutableArray alloc] init]; + NSMutableArray *brushIconViews = [[NSMutableArray alloc] init]; NSMutableArray *separatorViews = [[NSMutableArray alloc] init]; [brushes enumerateObjectsUsingBlock:^(__unused TGPaintBrush *brush, NSUInteger index, __unused BOOL *stop) { - TGModernButton *button = [[TGModernButton alloc] initWithFrame:CGRectMake(0, TGPhotoBrushSettingsViewMargin + index * TGPhotoBrushSettingsItemHeight, 0, 0)]; - button.tag = index; - button.imageView.contentMode = UIViewContentModeCenter; - button.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 30.0f, 0.0f, 0.0f); - [button addTarget:self action:@selector(brushButtonPressed:) forControlEvents:UIControlEventTouchUpInside]; - [self addSubview:button]; + NSString *title; + UIImage *icon; + switch (index) { + case 0: + title = TGLocalized(@"Paint.Pen"); + icon = [UIImage imageNamed:@"Editor/BrushPen"]; + break; + case 1: + title = TGLocalized(@"Paint.Marker"); + icon = [UIImage imageNamed:@"Editor/BrushMarker"]; + break; + case 2: + title = TGLocalized(@"Paint.Neon"); + icon = [UIImage imageNamed:@"Editor/BrushNeon"]; + break; + case 3: + title = TGLocalized(@"Paint.Arrow"); + icon = [UIImage imageNamed:@"Editor/BrushArrow"]; + break; + default: + break; + } + TGModernButton *button = [[TGModernButton alloc] initWithFrame:CGRectMake(0, index * TGPhotoBrushSettingsItemHeight, 0, 0)]; + button.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft; + button.titleLabel.font = font; + button.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 16.0f, 0.0f, 0.0f); + button.tag = index; + [button setTitle:title forState:UIControlStateNormal]; + [button setTitleColor:[UIColor whiteColor]]; + [button addTarget:self action:@selector(brushButtonPressed:) forControlEvents:UIControlEventTouchUpInside]; + [_contentView addSubview:button]; [brushViews addObject:button]; + UIImageView *iconView = [[UIImageView alloc] initWithImage:TGTintedImage(icon, [UIColor whiteColor])]; + [button addSubview:iconView]; + [brushIconViews addObject:iconView]; + if (index != brushes.count - 1) { UIView *separatorView = [[UIView alloc] init]; - separatorView.backgroundColor = UIColorRGB(0xd6d6da); - [self addSubview:separatorView]; + separatorView.backgroundColor = UIColorRGBA(0xffffff, 0.2); + [_contentView addSubview:separatorView]; [separatorViews addObject:separatorView]; } }]; _brushViews = brushViews; + _brushIconViews = brushIconViews; _brushSeparatorViews = separatorViews; - - _selectedCheckView = [[UIImageView alloc] initWithImage:TGComponentsImageNamed(@"PaintCheck")]; - _selectedCheckView.frame = CGRectMake(15.0f, 16.0f, _selectedCheckView.frame.size.width, _selectedCheckView.frame.size.height); } return self; } - (void)brushButtonPressed:(TGModernButton *)sender { - [sender addSubview:_selectedCheckView]; - if (self.brushChanged != nil) self.brushChanged(_brushes[sender.tag]); } - (void)present { - self.alpha = 0.0f; - - self.layer.rasterizationScale = TGScreenScaling(); - self.layer.shouldRasterize = true; - - [self _setupBrushPreviews]; - - [UIView animateWithDuration:0.2 animations:^ + [UIView animateWithDuration:0.25 animations:^ { - self.alpha = 1.0f; + _effectView.alpha = 1.0f; + _contentView.alpha = 1.0f; } completion:^(__unused BOOL finished) { - //self.layer.shouldRasterize = false; + }]; } - (void)dismissWithCompletion:(void (^)(void))completion { - self.layer.rasterizationScale = TGScreenScaling(); - self.layer.shouldRasterize = true; - - [UIView animateWithDuration:0.15 animations:^ + [UIView animateWithDuration:0.2 animations:^ { - self.alpha = 0.0f; + _effectView.alpha = 0.0f; + _contentView.alpha = 0.0f; } completion:^(__unused BOOL finished) { if (completion != nil) @@ -121,90 +152,38 @@ const CGFloat TGPhotoBrushSettingsItemHeight = 44.0f; }]; } -- (void)_setupBrushPreviews -{ - [_brushes enumerateObjectsUsingBlock:^(TGPaintBrush *aBrush, NSUInteger index, __unused BOOL *stop) - { - UIImage *image = aBrush.previewImage; - if (image == nil) - { - image = [_preview imageForBrush:aBrush size:CGSizeMake([self sizeThatFits:CGSizeZero].width - 85.0f, TGPhotoBrushSettingsItemHeight)]; - aBrush.previewImage = image; - } - - [_brushViews[index] setImage:image forState:UIControlStateNormal]; - }]; -} - -- (TGPaintBrush *)brush -{ - return _brushes[_selectedCheckView.superview.tag]; -} - -- (void)setBrush:(TGPaintBrush *)brush -{ - [_brushes enumerateObjectsUsingBlock:^(TGPaintBrush *aBrush, NSUInteger index, BOOL *stop) - { - if ([brush isEqual:aBrush]) - { - [_brushViews[index] addSubview:_selectedCheckView]; - *stop = true; - } - }]; -} - - (CGSize)sizeThatFits:(CGSize)__unused size { - return CGSizeMake(256, _brushViews.count * TGPhotoBrushSettingsItemHeight + TGPhotoBrushSettingsViewMargin * 2); + return CGSizeMake(220, _brushViews.count * TGPhotoBrushSettingsItemHeight + TGPhotoBrushSettingsViewMargin * 2); } - (void)setInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation { _interfaceOrientation = interfaceOrientation; - switch (self.interfaceOrientation) - { - case UIInterfaceOrientationLandscapeLeft: - { - _backgroundView.image = [TGPhotoPaintSettingsView landscapeLeftBackgroundImage]; - } - break; - - case UIInterfaceOrientationLandscapeRight: - { - _backgroundView.image = [TGPhotoPaintSettingsView landscapeRightBackgroundImage]; - } - break; - - default: - { - _backgroundView.image = [TGPhotoPaintSettingsView portraitBackgroundImage]; - } - break; - } - [self setNeedsLayout]; } - (void)layoutSubviews { + CGFloat arrowSize = 0.0f; switch (self.interfaceOrientation) { case UIInterfaceOrientationLandscapeLeft: { - _backgroundView.frame = CGRectMake(TGPhotoBrushSettingsViewMargin - 13.0f, TGPhotoBrushSettingsViewMargin, self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2 + 13.0f, self.frame.size.height - TGPhotoBrushSettingsViewMargin * 2); + _wrapperView.frame = CGRectMake(TGPhotoBrushSettingsViewMargin - arrowSize, TGPhotoBrushSettingsViewMargin, self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2 + arrowSize, self.frame.size.height - TGPhotoBrushSettingsViewMargin * 2); } break; case UIInterfaceOrientationLandscapeRight: { - _backgroundView.frame = CGRectMake(TGPhotoBrushSettingsViewMargin, TGPhotoBrushSettingsViewMargin, self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2 + 13.0f, self.frame.size.height - TGPhotoBrushSettingsViewMargin * 2); + _wrapperView.frame = CGRectMake(TGPhotoBrushSettingsViewMargin, TGPhotoBrushSettingsViewMargin, self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2 + arrowSize, self.frame.size.height - TGPhotoBrushSettingsViewMargin * 2); } break; default: { - _backgroundView.frame = CGRectMake(TGPhotoBrushSettingsViewMargin, TGPhotoBrushSettingsViewMargin, self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2, self.frame.size.height - TGPhotoBrushSettingsViewMargin * 2 + 13.0f); + _wrapperView.frame = CGRectMake(TGPhotoBrushSettingsViewMargin, TGPhotoBrushSettingsViewMargin, self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2, self.frame.size.height - TGPhotoBrushSettingsViewMargin * 2 + arrowSize); } break; } @@ -213,13 +192,17 @@ const CGFloat TGPhotoBrushSettingsItemHeight = 44.0f; [_brushViews enumerateObjectsUsingBlock:^(TGModernButton *view, NSUInteger index, __unused BOOL *stop) { - view.frame = CGRectMake(TGPhotoBrushSettingsViewMargin, TGPhotoBrushSettingsViewMargin + TGPhotoBrushSettingsItemHeight * index, self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2, TGPhotoBrushSettingsItemHeight); - + view.frame = CGRectMake(0.0f, TGPhotoBrushSettingsItemHeight * index, _contentView.frame.size.width, TGPhotoBrushSettingsItemHeight); + }]; + + [_brushIconViews enumerateObjectsUsingBlock:^(UIImageView *view, NSUInteger index, __unused BOOL *stop) + { + view.frame = CGRectMake(_contentView.frame.size.width - 42.0f, (TGPhotoBrushSettingsItemHeight - view.frame.size.height) / 2.0, view.frame.size.width, view.frame.size.height); }]; [_brushSeparatorViews enumerateObjectsUsingBlock:^(UIView *view, NSUInteger index, __unused BOOL *stop) { - view.frame = CGRectMake(TGPhotoBrushSettingsViewMargin + 44.0f, TGPhotoBrushSettingsViewMargin + TGPhotoBrushSettingsItemHeight * (index + 1), self.frame.size.width - TGPhotoBrushSettingsViewMargin * 2 - 44.0f, thickness); + view.frame = CGRectMake(0.0f, TGPhotoBrushSettingsItemHeight * (index + 1), _contentView.frame.size.width, thickness); }]; } diff --git a/submodules/LegacyComponents/Sources/TGPhotoEditorController.m b/submodules/LegacyComponents/Sources/TGPhotoEditorController.m index b20090ad9a..42ceded223 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoEditorController.m +++ b/submodules/LegacyComponents/Sources/TGPhotoEditorController.m @@ -1552,7 +1552,7 @@ if ([item isKindOfClass:[TGMediaAsset class]]) assetSignal = [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)item]; else if ([item isKindOfClass:[TGCameraCapturedVideo class]]) - assetSignal = [SSignal single:((TGCameraCapturedVideo *)item).avAsset]; + assetSignal = ((TGCameraCapturedVideo *)item).avAsset; [assetSignal startWithNext:^(AVAsset *asset) { diff --git a/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.h b/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.h index 09bcdf009b..e7753eccf4 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.h +++ b/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.h @@ -15,6 +15,8 @@ - (void)updateVisibility:(bool)visible; +- (UIColor *)colorAtPoint:(CGPoint)point; + - (void)setupWithPaintingData:(TGPaintingData *)paintingData; - (TGPhotoPaintEntityView *)createEntityViewWithEntity:(TGPhotoPaintEntity *)entity; diff --git a/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.m b/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.m index 4ded3095dd..f4e9b85126 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoEntitiesContainerView.m @@ -47,7 +47,7 @@ - (void)handleTap:(UITapGestureRecognizer *)gestureRecognizer { - CGPoint location = [gestureRecognizer locationInView:self]; + CGPoint point = [gestureRecognizer locationInView:self]; NSMutableArray *intersectedViews = [[NSMutableArray alloc] init]; for (TGPhotoPaintEntityView *view in self.subviews) @@ -55,7 +55,7 @@ if (![view isKindOfClass:[TGPhotoPaintEntityView class]]) continue; - if ([view pointInside:[view convertPoint:location fromView:self] withEvent:nil]) + if ([view pointInside:[view convertPoint:point fromView:self] withEvent:nil]) [intersectedViews addObject:view]; } @@ -65,7 +65,7 @@ __block TGPhotoPaintEntityView *subresult = nil; [intersectedViews enumerateObjectsWithOptions:NSEnumerationReverse usingBlock:^(TGPhotoPaintEntityView *view, __unused NSUInteger index, BOOL *stop) { - if ([view precisePointInside:[view convertPoint:location fromView:self]]) + if ([view precisePointInside:[view convertPoint:point fromView:self]]) { subresult = view; *stop = true; @@ -83,6 +83,40 @@ self.entitySelected(result); } +- (UIColor *)colorAtPoint:(CGPoint)point { + NSMutableArray *intersectedViews = [[NSMutableArray alloc] init]; + for (TGPhotoPaintEntityView *view in self.subviews) + { + if (![view isKindOfClass:[TGPhotoPaintEntityView class]]) + continue; + + if ([view pointInside:[view convertPoint:point fromView:self] withEvent:nil]) + [intersectedViews addObject:view]; + } + + TGPhotoPaintEntityView *result = nil; + if (intersectedViews.count > 1) + { + __block TGPhotoPaintEntityView *subresult = nil; + [intersectedViews enumerateObjectsWithOptions:NSEnumerationReverse usingBlock:^(TGPhotoPaintEntityView *view, __unused NSUInteger index, BOOL *stop) + { + if ([view precisePointInside:[view convertPoint:point fromView:self]]) + { + subresult = view; + *stop = true; + } + }]; + + result = subresult ?: intersectedViews.lastObject; + } + else if (intersectedViews.count == 1) + { + result = intersectedViews.firstObject; + } + + return [result colorAtPoint:[result convertPoint:point fromView:self]]; +} + - (NSUInteger)entitiesCount { return MAX(0, (NSInteger)self.subviews.count - 1); diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintColorPicker.m b/submodules/LegacyComponents/Sources/TGPhotoPaintColorPicker.m index 2b9221453e..23cc4584ba 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoPaintColorPicker.m +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintColorPicker.m @@ -137,7 +137,7 @@ const CGFloat TGPhotoPaintDefaultColorLocation = 1.0f; - (void)setSwatch:(TGPaintSwatch *)swatch { - [self setLocation:swatch.colorLocaton]; + [self setLocation:swatch.colorLocation]; [self setWeight:swatch.brushWeight]; } diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintController.m b/submodules/LegacyComponents/Sources/TGPhotoPaintController.m index 704274fea7..fd797df610 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoPaintController.m +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintController.m @@ -23,6 +23,7 @@ #import "TGPaintRadialBrush.h" #import "TGPaintEllipticalBrush.h" #import "TGPaintNeonBrush.h" +#import "TGPaintArrowBrush.h" #import "TGPaintCanvas.h" #import "TGPaintingWrapperView.h" #import "TGPaintState.h" @@ -45,6 +46,7 @@ #import "TGPhotoEntitiesContainerView.h" #import "TGPhotoStickerEntityView.h" #import "TGPhotoTextEntityView.h" +#import "TGPhotoPaintEyedropperView.h" #import "TGPaintFaceDetector.h" #import "TGPhotoMaskPosition.h" @@ -83,6 +85,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; UIView *_contentWrapperView; UIView *_dimView; + TGModernButton *_doneButton; TGPhotoPaintActionsView *_landscapeActionsView; TGPhotoPaintActionsView *_portraitActionsView; @@ -104,6 +107,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; TGPhotoPaintSelectionContainerView *_selectionContainerView; TGPhotoPaintEntitySelectionView *_entitySelectionView; + TGPhotoPaintEyedropperView *_eyedropperView; TGPhotoTextEntityView *_editedTextView; CGPoint _editedTextCenter; @@ -122,6 +126,11 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; bool _enableStickers; + NSData *_eyedropperBackgroundData; + CGSize _eyedropperBackgroundSize; + NSInteger _eyedropperBackgroundBytesPerRow; + CGBitmapInfo _eyedropperBackgroundInfo; + id _context; } @@ -151,10 +160,11 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; [ [[TGPaintRadialBrush alloc] init], [[TGPaintEllipticalBrush alloc] init], - [[TGPaintNeonBrush alloc] init] + [[TGPaintNeonBrush alloc] init], + [[TGPaintArrowBrush alloc] init], ]; _selectedTextFont = [[TGPhotoPaintFont availableFonts] firstObject]; - _selectedTextStyle = TGPhotoPaintTextEntityStyleBorder; + _selectedTextStyle = TGPhotoPaintTextEntityStyleFramed; if (_photoEditor.paintingData.undoManager != nil) _undoManager = [_photoEditor.paintingData.undoManager copy]; @@ -265,11 +275,30 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; _dimView.backgroundColor = UIColorRGBA(0x000000, 0.4f); _dimView.userInteractionEnabled = false; [_entitiesContainerView addSubview:_dimView]; - + _selectionContainerView = [[TGPhotoPaintSelectionContainerView alloc] init]; _selectionContainerView.clipsToBounds = false; [_containerView addSubview:_selectionContainerView]; + _eyedropperView = [[TGPhotoPaintEyedropperView alloc] init]; + _eyedropperView.locationChanged = ^(CGPoint location, bool finished) { + __strong TGPhotoPaintController *strongSelf = weakSelf; + if (strongSelf != nil) + { + UIColor *color = [strongSelf colorAtPoint:location]; + strongSelf->_eyedropperView.color = color; + + if (finished) { + TGPaintSwatch *swatch = [TGPaintSwatch swatchWithColor:color colorLocation:0.5 brushWeight:strongSelf->_portraitSettingsView.swatch.brushWeight]; + [strongSelf setCurrentSwatch:swatch sender:nil]; + + [strongSelf commitEyedropper:false]; + } + } + }; + _eyedropperView.hidden = true; + [_selectionContainerView addSubview:_eyedropperView]; + _wrapperView = [[TGPhotoPaintSparseView alloc] initWithFrame:CGRectZero]; [self.view addSubview:_wrapperView]; @@ -307,12 +336,22 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; _landscapeActionsView.clearPressed = clearPressed; [_wrapperView addSubview:_landscapeActionsView]; + _doneButton = [[TGModernButton alloc] init]; + _doneButton.alpha = 0.0f; + _doneButton.userInteractionEnabled = false; + [_doneButton setTitle:TGLocalized(@"Common.Done") forState:UIControlStateNormal]; + _doneButton.titleLabel.font = TGSystemFontOfSize(17.0); + [_doneButton sizeToFit]; + [_wrapperView addSubview:_doneButton]; + void (^settingsPressed)(void) = ^ { __strong TGPhotoPaintController *strongSelf = weakSelf; if (strongSelf == nil) return; + [strongSelf commitEyedropper:true]; + if ([strongSelf->_currentEntityView isKindOfClass:[TGPhotoTextEntityView class]]) [strongSelf presentTextSettingsView]; else if ([strongSelf->_currentEntityView isKindOfClass:[TGPhotoStickerEntityView class]]) @@ -321,11 +360,22 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; [strongSelf presentBrushSettingsView]; }; + void (^eyedropperPressed)(void) = ^ + { + __strong TGPhotoPaintController *strongSelf = weakSelf; + if (strongSelf == nil) + return; + + [self enableEyedropper]; + }; + void (^beganColorPicking)(void) = ^ { __strong TGPhotoPaintController *strongSelf = weakSelf; if (strongSelf == nil) return; + + [strongSelf commitEyedropper:true]; if (![strongSelf->_currentEntityView isKindOfClass:[TGPhotoTextEntityView class]]) [strongSelf setDimHidden:false animated:true]; @@ -346,6 +396,8 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; if (strongSelf == nil) return; + [strongSelf commitEyedropper:true]; + [strongSelf setCurrentSwatch:swatch sender:sender]; if (![strongSelf->_currentEntityView isKindOfClass:[TGPhotoTextEntityView class]]) @@ -353,6 +405,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; }; _portraitSettingsView = [[TGPhotoPaintSettingsView alloc] initWithContext:_context]; + _portraitSettingsView.eyedropperPressed = eyedropperPressed; _portraitSettingsView.beganColorPicking = beganColorPicking; _portraitSettingsView.changedColor = changedColor; _portraitSettingsView.finishedColorPicking = finishedColorPicking; @@ -362,6 +415,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; [_portraitToolsWrapperView addSubview:_portraitSettingsView]; _landscapeSettingsView = [[TGPhotoPaintSettingsView alloc] initWithContext:_context]; + _landscapeSettingsView.eyedropperPressed = eyedropperPressed; _landscapeSettingsView.beganColorPicking = beganColorPicking; _landscapeSettingsView.changedColor = changedColor; _landscapeSettingsView.finishedColorPicking = finishedColorPicking; @@ -489,7 +543,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; - (TGPhotoEditorTab)availableTabs { TGPhotoEditorTab result = TGPhotoEditorPaintTab | TGPhotoEditorEraserTab | TGPhotoEditorTextTab; - if (_enableStickers) { + if (_enableStickers && _stickersContext != nil) { result |= TGPhotoEditorStickerTab; } return result; @@ -497,6 +551,8 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; - (void)handleTabAction:(TGPhotoEditorTab)tab { + [self commitEyedropper:true]; + switch (tab) { case TGPhotoEditorStickerTab: @@ -625,6 +681,49 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; #pragma mark - Data Handling +- (UIImage *)eyedropperImage +{ + UIImage *backgroundImage = [self.photoEditor currentResultImage]; + + CGSize fittedSize = TGFitSize(_painting.size, TGPhotoEditorResultImageMaxSize); + UIImage *paintingImage = _painting.isEmpty ? nil : [_painting imageWithSize:fittedSize andData:NULL]; + NSMutableArray *entities = [[NSMutableArray alloc] init]; + + UIImage *entitiesImage = nil; + if (paintingImage == nil && _entitiesContainerView.entitiesCount < 1) + { + return backgroundImage; + } + else if (_entitiesContainerView.entitiesCount > 0) + { + for (TGPhotoPaintEntityView *view in _entitiesContainerView.subviews) + { + if (![view isKindOfClass:[TGPhotoPaintEntityView class]]) + continue; + + TGPhotoPaintEntity *entity = [view entity]; + if (entity != nil) { + [entities addObject:entity]; + } + } + entitiesImage = [_entitiesContainerView imageInRect:_entitiesContainerView.bounds background:nil still:true]; + } + + if (entitiesImage == nil && paintingImage == nil) { + return backgroundImage; + } else { + UIGraphicsBeginImageContextWithOptions(fittedSize, false, 1.0); + + [backgroundImage drawInRect:CGRectMake(0.0, 0.0, fittedSize.width, fittedSize.height)]; + [paintingImage drawInRect:CGRectMake(0.0, 0.0, fittedSize.width, fittedSize.height)]; + [entitiesImage drawInRect:CGRectMake(0.0, 0.0, fittedSize.width, fittedSize.height)]; + + UIImage *result = UIGraphicsGetImageFromCurrentImageContext(); + UIGraphicsEndImageContext(); + return result; + } +} + - (TGPaintingData *)_prepareResultData { if (_resultData != nil) @@ -698,6 +797,60 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; return [self _prepareResultData]; } +- (void)enableEyedropper { + if (!_eyedropperView.isHidden) + return; + + [self selectEntityView:nil]; + + self.controlVideoPlayback(false); + [_entitiesContainerView updateVisibility:false]; + + UIImage *image = [self eyedropperImage]; + CGImageRef cgImage = image.CGImage; + CFDataRef pixelData = CGDataProviderCopyData(CGImageGetDataProvider(cgImage)); + + _eyedropperBackgroundData = (__bridge NSData *)pixelData; + _eyedropperBackgroundSize = image.size; + _eyedropperBackgroundBytesPerRow = CGImageGetBytesPerRow(cgImage); + _eyedropperBackgroundInfo = CGImageGetBitmapInfo(cgImage); + + [_eyedropperView update]; + [_eyedropperView present]; +} + +- (void)commitEyedropper:(bool)immediate { + self.controlVideoPlayback(true); + [_entitiesContainerView updateVisibility:true]; + + _eyedropperBackgroundData = nil; + _eyedropperBackgroundSize = CGSizeZero; + _eyedropperBackgroundBytesPerRow = 0; + _eyedropperBackgroundInfo = 0; + + double timeout = immediate ? 0.0 : 0.2; + TGDispatchAfter(timeout, dispatch_get_main_queue(), ^{ + [_eyedropperView dismiss]; + }); +} + +- (UIColor *)colorFromData:(NSData *)data width:(NSInteger)width height:(NSInteger)height x:(NSInteger)x y:(NSInteger)y bpr:(NSInteger)bpr { + uint8_t *pixel = (uint8_t *)data.bytes + bpr * y + x * 4; + if (_eyedropperBackgroundInfo & kCGBitmapByteOrder32Little) { + return [UIColor colorWithRed:pixel[2] / 255.0 green:pixel[1] / 255.0 blue:pixel[0] / 255.0 alpha:1.0]; + } else { + return [UIColor colorWithRed:pixel[0] / 255.0 green:pixel[1] / 255.0 blue:pixel[2] / 255.0 alpha:1.0]; + } +} + +- (UIColor *)colorAtPoint:(CGPoint)point +{ + CGPoint convertedPoint = CGPointMake(point.x / _eyedropperView.bounds.size.width * _eyedropperBackgroundSize.width, point.y / _eyedropperView.bounds.size.height * _eyedropperBackgroundSize.height); + UIColor *backgroundColor = [self colorFromData:_eyedropperBackgroundData width:_eyedropperBackgroundSize.width height:_eyedropperBackgroundSize.height x:convertedPoint.x y:convertedPoint.y bpr:_eyedropperBackgroundBytesPerRow]; + return backgroundColor; +} + + #pragma mark - Entities - (void)selectEntityView:(TGPhotoPaintEntityView *)view @@ -734,7 +887,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; if ([view isKindOfClass:[TGPhotoTextEntityView class]]) { TGPaintSwatch *textSwatch = ((TGPhotoPaintTextEntity *)view.entity).swatch; - [self setCurrentSwatch:[TGPaintSwatch swatchWithColor:textSwatch.color colorLocation:textSwatch.colorLocaton brushWeight:_portraitSettingsView.swatch.brushWeight] sender:nil]; + [self setCurrentSwatch:[TGPaintSwatch swatchWithColor:textSwatch.color colorLocation:textSwatch.colorLocation brushWeight:_portraitSettingsView.swatch.brushWeight] sender:nil]; } _entitySelectionView = [view createSelectionView]; @@ -1061,7 +1214,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; TGPaintSwatch *currentSwatch = _portraitSettingsView.swatch; TGPaintSwatch *whiteSwatch = [TGPaintSwatch swatchWithColor:[UIColor whiteColor] colorLocation:1.0f brushWeight:currentSwatch.brushWeight]; TGPaintSwatch *blackSwatch = [TGPaintSwatch swatchWithColor:[UIColor blackColor] colorLocation:0.85f brushWeight:currentSwatch.brushWeight]; - [self setCurrentSwatch:_selectedTextStyle == TGPhotoPaintTextEntityStyleBorder ? blackSwatch : whiteSwatch sender:nil]; + [self setCurrentSwatch:_selectedTextStyle == TGPhotoPaintTextEntityStyleOutlined ? blackSwatch : whiteSwatch sender:nil]; CGFloat maxWidth = [self fittedContentSize].width - 26.0f; TGPhotoPaintTextEntity *entity = [[TGPhotoPaintTextEntity alloc] initWithText:@"" font:_selectedTextFont swatch:_portraitSettingsView.swatch baseFontSize:[self _textBaseFontSizeForCurrentPainting] maxWidth:maxWidth style:_selectedTextStyle]; @@ -1258,13 +1411,35 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; - (void)updateSettingsButton { - if ([_currentEntityView isKindOfClass:[TGPhotoTextEntityView class]]) - [self setSettingsButtonIcon:TGPhotoPaintSettingsViewIconText]; - else if ([_currentEntityView isKindOfClass:[TGPhotoStickerEntityView class]]) + if ([_currentEntityView isKindOfClass:[TGPhotoTextEntityView class]]) { + TGPhotoPaintSettingsViewIcon icon; + switch (((TGPhotoTextEntityView *)_currentEntityView).entity.style) { + case TGPhotoPaintTextEntityStyleRegular: + icon = TGPhotoPaintSettingsViewIconTextRegular; + break; + case TGPhotoPaintTextEntityStyleOutlined: + icon = TGPhotoPaintSettingsViewIconTextOutlined; + break; + case TGPhotoPaintTextEntityStyleFramed: + icon = TGPhotoPaintSettingsViewIconTextFramed; + break; + } + [self setSettingsButtonIcon:icon]; + } + else if ([_currentEntityView isKindOfClass:[TGPhotoStickerEntityView class]]) { [self setSettingsButtonIcon:TGPhotoPaintSettingsViewIconMirror]; - else - [self setSettingsButtonIcon:TGPhotoPaintSettingsViewIconBrush]; - + } + else { + TGPhotoPaintSettingsViewIcon icon = TGPhotoPaintSettingsViewIconBrushPen; + if ([_canvasView.state.brush isKindOfClass:[TGPaintEllipticalBrush class]]) { + icon = TGPhotoPaintSettingsViewIconBrushMarker; + } else if ([_canvasView.state.brush isKindOfClass:[TGPaintNeonBrush class]]) { + icon = TGPhotoPaintSettingsViewIconBrushNeon; + } else if ([_canvasView.state.brush isKindOfClass:[TGPaintArrowBrush class]]) { + icon = TGPhotoPaintSettingsViewIconBrushArrow; + } + [self setSettingsButtonIcon:icon]; + } [self _updateTabs]; } @@ -1347,12 +1522,13 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; if (strongSelf == nil) return; - if (strongSelf->_canvasView.state.eraser && brush.lightSaber) + if (strongSelf->_canvasView.state.eraser && (brush.lightSaber || brush.arrow)) brush = strongSelf->_brushes.firstObject; [strongSelf->_canvasView setBrush:brush]; [strongSelf settingsWrapperPressed]; + [strongSelf updateSettingsButton]; }; _settingsView = view; [view sizeToFit]; @@ -1383,6 +1559,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; [textView setFont:font]; [strongSelf settingsWrapperPressed]; + [strongSelf updateSettingsButton]; }; view.styleChanged = ^(TGPhotoPaintTextEntityStyle style) { @@ -1392,13 +1569,13 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; strongSelf->_selectedTextStyle = style; - if (style == TGPhotoPaintTextEntityStyleBorder && [strongSelf->_portraitSettingsView.swatch.color isEqual:[UIColor whiteColor]]) + if (style == TGPhotoPaintTextEntityStyleOutlined && [strongSelf->_portraitSettingsView.swatch.color isEqual:[UIColor whiteColor]]) { TGPaintSwatch *currentSwatch = strongSelf->_portraitSettingsView.swatch; TGPaintSwatch *blackSwatch = [TGPaintSwatch swatchWithColor:[UIColor blackColor] colorLocation:0.85f brushWeight:currentSwatch.brushWeight]; [strongSelf setCurrentSwatch:blackSwatch sender:nil]; } - else if (style != TGPhotoPaintTextEntityStyleBorder && [strongSelf->_portraitSettingsView.swatch.color isEqual:UIColorRGB(0x000000)]) + else if (style != TGPhotoPaintTextEntityStyleOutlined && [strongSelf->_portraitSettingsView.swatch.color isEqual:UIColorRGB(0x000000)]) { TGPaintSwatch *currentSwatch = strongSelf->_portraitSettingsView.swatch; TGPaintSwatch *whiteSwatch = [TGPaintSwatch swatchWithColor:[UIColor whiteColor] colorLocation:1.0f brushWeight:currentSwatch.brushWeight]; @@ -1409,6 +1586,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; [textView setStyle:style]; [strongSelf settingsWrapperPressed]; + [strongSelf updateSettingsButton]; }; _settingsView = view; @@ -1429,13 +1607,14 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; if (_canvasView.state.eraser) { - if (_canvasView.state.brush.lightSaber) + if (_canvasView.state.brush.lightSaber || _canvasView.state.brush.arrow) [_canvasView setBrush:_brushes.firstObject]; } [_portraitSettingsView setHighlighted:_canvasView.state.isEraser]; [_landscapeSettingsView setHighlighted:_canvasView.state.isEraser]; + [self updateSettingsButton]; [self _updateTabs]; } @@ -1934,17 +2113,22 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; [_dimView.superview insertSubview:_dimView belowSubview:_currentEntityView]; else [_dimView.superview bringSubviewToFront:_dimView]; + + [_doneButton.superview bringSubviewToFront:_doneButton]; } else { [_entitySelectionView fadeIn]; [_dimView.superview bringSubviewToFront:_dimView]; + + [_doneButton.superview bringSubviewToFront:_doneButton]; } void (^changeBlock)(void) = ^ { _dimView.alpha = hidden ? 0.0f : 1.0f; + _doneButton.alpha = hidden ? 0.0f : 1.0f; }; if (animated) @@ -2016,6 +2200,8 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; _settingsViewWrapper.frame = self.parentViewController.view.bounds; + _doneButton.frame = CGRectMake(screenEdges.right - _doneButton.frame.size.width - 8.0, screenEdges.top + 2.0, _doneButton.frame.size.width, _doneButton.frame.size.height); + if (_settingsView != nil) [_settingsView setInterfaceOrientation:orientation]; @@ -2151,6 +2337,7 @@ const CGFloat TGPhotoPaintStickerKeyboardSize = 260.0f; _selectionContainerView.transform = CGAffineTransformRotate(rotationTransform, rotation); _selectionContainerView.frame = previewFrame; + _eyedropperView.frame = _selectionContainerView.bounds; _containerView.frame = CGRectMake(containerFrame.origin.x, containerFrame.origin.y + offsetHeight, containerFrame.size.width, containerFrame.size.height); } diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintEntityView.m b/submodules/LegacyComponents/Sources/TGPhotoPaintEntityView.m index 5bddd5fc36..17f7d1d52a 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoPaintEntityView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintEntityView.m @@ -221,3 +221,27 @@ const CGFloat TGPhotoPaintEntityMinScale = 0.12f; } @end + +@implementation UIView (PixelColor) + +- (UIColor *)colorAtPoint:(CGPoint)point +{ + if (point.x > self.bounds.size.width || point.y > self.bounds.size.height) + return nil; + + unsigned char pixel[4] = {0}; + + CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); + CGContextRef context = CGBitmapContextCreate(pixel, 1, 1, 8, 4, colorSpace, kCGBitmapAlphaInfoMask & kCGImageAlphaPremultipliedLast); + + CGContextTranslateCTM(context, -point.x, -point.y); + + [self.layer renderInContext:context]; + + CGContextRelease(context); + CGColorSpaceRelease(colorSpace); + + return [UIColor colorWithRed:pixel[0] / 255.0 green:pixel[1] / 255.0 blue:pixel[2] / 255.0 alpha:pixel[3] / 255.0]; +} + +@end diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.h b/submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.h new file mode 100644 index 0000000000..31317aa742 --- /dev/null +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.h @@ -0,0 +1,13 @@ +#import + +@interface TGPhotoPaintEyedropperView : UIView + +@property (nonatomic, strong) UIColor *color; +@property (nonatomic, copy) void(^locationChanged)(CGPoint, bool); + +- (void)update; +- (void)present; +- (void)dismiss; + +@end + diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.m b/submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.m new file mode 100644 index 0000000000..2b99e6a9ff --- /dev/null +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.m @@ -0,0 +1,157 @@ +#import "TGPhotoPaintEyedropperView.h" + +#import "TGImageUtils.h" + +@interface TGPhotoPaintEyedropperIndicatorView : UIView + +@property (nonatomic, strong) UIColor *color; + +@end + +@implementation TGPhotoPaintEyedropperIndicatorView + +-(instancetype)initWithFrame:(CGRect)frame { + self = [super initWithFrame:frame]; + if (self != nil) { + self.backgroundColor = [UIColor clearColor]; + self.opaque = false; + self.userInteractionEnabled = false; + } + return self; +} + +- (void)setColor:(UIColor *)color { + _color = color; + [self setNeedsDisplay]; +} + +- (void)drawRect:(CGRect)rect { + CGContextRef context = UIGraphicsGetCurrentContext(); + + CGFloat lineWidth = 1.0f + TGScreenPixel; + + CGContextSetFillColorWithColor(context, _color.CGColor); + CGContextSetStrokeColorWithColor(context, [UIColor whiteColor].CGColor); + + CGContextSaveGState(context); + + CGContextScaleCTM(context, 0.333333, 0.333333); + CGContextSetLineWidth(context, lineWidth * 3.0); + + TGDrawSvgPath(context, @"M75,0.5 C54.4273931,0.5 35.8023931,8.83869653 22.3205448,22.3205448 C8.83869653,35.8023931 0.5,54.4273931 0.5,75 C0.5,94.6543797 10.7671345,116.856807 23.8111444,136.192682 C42.4188317,163.77591 66.722394,185.676747 75,185.676747 C83.277606,185.676747 107.581168,163.77591 126.188856,136.192682 C139.232866,116.856807 149.5,94.6543797 149.5,75 C149.5,54.4273931 141.161303,35.8023931 127.679455,22.3205448 C114.197607,8.83869653 95.5726069,0.5 75,0.5 Z"); + + TGDrawSvgPath(context, @"M75,0.5 C54.4273931,0.5 35.8023931,8.83869653 22.3205448,22.3205448 C8.83869653,35.8023931 0.5,54.4273931 0.5,75 C0.5,94.6543797 10.7671345,116.856807 23.8111444,136.192682 C42.4188317,163.77591 66.722394,185.676747 75,185.676747 C83.277606,185.676747 107.581168,163.77591 126.188856,136.192682 C139.232866,116.856807 149.5,94.6543797 149.5,75 C149.5,54.4273931 141.161303,35.8023931 127.679455,22.3205448 C114.197607,8.83869653 95.5726069,0.5 75,0.5 S"); + + CGContextRestoreGState(context); + + CGContextSetLineWidth(context, lineWidth); + CGContextFillEllipseInRect(context, CGRectMake(20.0, 68.0, 11.0, 11.0)); + CGContextStrokeEllipseInRect(context, CGRectMake(20.0, 68.0, 11.0, 11.0)); +} + +@end + +@interface TGPhotoPaintEyedropperView() + +@end + +@implementation TGPhotoPaintEyedropperView +{ + TGPhotoPaintEyedropperIndicatorView *_indicatorView; + + UITapGestureRecognizer *_tapGestureRecognizer; + UIPanGestureRecognizer *_panGestureRecognizer; +} + +- (instancetype)initWithFrame:(CGRect)frame +{ + self = [super initWithFrame:frame]; + if (self != nil) { + _indicatorView = [[TGPhotoPaintEyedropperIndicatorView alloc] initWithFrame:CGRectMake(0.0, 0.0, 51.0, 81.0)]; + _indicatorView.layer.anchorPoint = CGPointMake(0.5, 0.92); + [self addSubview:_indicatorView]; + + _tapGestureRecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleTap:)]; + [self addGestureRecognizer:_tapGestureRecognizer]; + + _panGestureRecognizer = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(handlePan:)]; + _panGestureRecognizer.delegate = self; + [self addGestureRecognizer:_panGestureRecognizer]; + } + return self; +} + +- (void)setColor:(UIColor *)color { + _color = color; + _indicatorView.color = color; +} + +- (void)handleTap:(UITapGestureRecognizer *)gestureRecognizer { + CGPoint location = [gestureRecognizer locationInView:self]; + [self layoutIndicator:location]; + self.locationChanged(location, true); +} + +- (void)handlePan:(UIPanGestureRecognizer *)gestureRecognizer { + CGPoint location = [gestureRecognizer locationInView:self]; + switch (gestureRecognizer.state) + { + case UIGestureRecognizerStateChanged: + { + [self layoutIndicator:location]; + self.locationChanged(location, false); + + } + break; + + case UIGestureRecognizerStateEnded: + { + [self layoutIndicator:location]; + self.locationChanged(location, true); + } + break; + + default: + break; + } +} + +- (void)update { + CGPoint location = CGPointMake(self.bounds.size.width / 2.0, self.bounds.size.height / 2.0); + self.locationChanged(location, false); + [self layoutIndicator:location]; +} + +- (void)present { + self.hidden = false; + + _indicatorView.alpha = 0.0f; + _indicatorView.transform = CGAffineTransformMakeScale(0.2, 0.2); + [UIView animateWithDuration:0.2 animations:^ + { + _indicatorView.alpha = 1.0f; + _indicatorView.transform = CGAffineTransformIdentity; + } completion:^(__unused BOOL finished) + { + }]; +} + +- (void)dismiss { + if (self.hidden) + return; + + [UIView animateWithDuration:0.15 animations:^ + { + _indicatorView.alpha = 0.0f; + _indicatorView.transform = CGAffineTransformMakeScale(0.2, 0.2); + } completion:^(__unused BOOL finished) + { + self.hidden = true; + }]; +} + +- (void)layoutIndicator:(CGPoint)point { + _indicatorView.center = CGPointMake(point.x, point.y); +} + +@end diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.h b/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.h index 1dd4f3322b..bc962f881f 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.h +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.h @@ -6,8 +6,13 @@ typedef enum { - TGPhotoPaintSettingsViewIconBrush, - TGPhotoPaintSettingsViewIconText, + TGPhotoPaintSettingsViewIconBrushPen, + TGPhotoPaintSettingsViewIconBrushMarker, + TGPhotoPaintSettingsViewIconBrushNeon, + TGPhotoPaintSettingsViewIconBrushArrow, + TGPhotoPaintSettingsViewIconTextRegular, + TGPhotoPaintSettingsViewIconTextOutlined, + TGPhotoPaintSettingsViewIconTextFramed, TGPhotoPaintSettingsViewIconMirror } TGPhotoPaintSettingsViewIcon; @@ -17,7 +22,9 @@ typedef enum @property (nonatomic, copy) void (^changedColor)(TGPhotoPaintSettingsView *sender, TGPaintSwatch *swatch); @property (nonatomic, copy) void (^finishedColorPicking)(TGPhotoPaintSettingsView *sender, TGPaintSwatch *swatch); +@property (nonatomic, copy) void (^eyedropperPressed)(void); @property (nonatomic, copy) void (^settingsPressed)(void); + @property (nonatomic, readonly) UIButton *settingsButton; @property (nonatomic, strong) TGPaintSwatch *swatch; diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.m b/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.m index b39238cf07..6a9489a2ed 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.m @@ -14,6 +14,7 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; @interface TGPhotoPaintSettingsView () { TGPhotoPaintColorPicker *_colorPicker; + TGModernButton *_eyedropperButton; TGModernButton *_settingsButton; TGPhotoPaintSettingsViewIcon _icon; @@ -54,7 +55,13 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; }; [self addSubview:_colorPicker]; - _icon = TGPhotoPaintSettingsViewIconBrush; + _icon = TGPhotoPaintSettingsViewIconBrushPen; + + _eyedropperButton = [[TGModernButton alloc] initWithFrame:CGRectMake(0, 0, 44.0f, 44.0f)]; + _eyedropperButton.exclusiveTouch = true; + [_eyedropperButton setImage:TGTintedImage([UIImage imageNamed:@"Editor/Eyedropper"], [UIColor whiteColor]) forState:UIControlStateNormal]; + [_eyedropperButton addTarget:self action:@selector(eyedropperButtonPressed) forControlEvents:UIControlEventTouchUpInside]; +// [self addSubview:_eyedropperButton]; _settingsButton = [[TGModernButton alloc] initWithFrame:CGRectMake(0, 0, 44.0f, 44.0f)]; _settingsButton.exclusiveTouch = true; @@ -85,6 +92,12 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; _colorPicker.orientation = interfaceOrientation; } +- (void)eyedropperButtonPressed +{ + if (self.eyedropperPressed != nil) + self.eyedropperPressed(); +} + - (void)settingsButtonPressed { if (self.settingsPressed != nil) @@ -143,25 +156,35 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; - (UIImage *)_imageForIcon:(TGPhotoPaintSettingsViewIcon)icon highlighted:(bool)highlighted { + UIColor *color = highlighted ? [TGPhotoEditorInterfaceAssets accentColor] : [UIColor whiteColor]; UIImage *iconImage = nil; switch (icon) { - case TGPhotoPaintSettingsViewIconBrush: - iconImage = TGTintedImage([UIImage imageNamed:@"Editor/Brush"], [UIColor whiteColor]); + case TGPhotoPaintSettingsViewIconBrushPen: + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/BrushSelectedPen"], color); break; - - case TGPhotoPaintSettingsViewIconText: - iconImage = TGTintedImage([UIImage imageNamed:@"Editor/Font"], [UIColor whiteColor]); + case TGPhotoPaintSettingsViewIconBrushMarker: + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/BrushSelectedMarker"], color); + break; + case TGPhotoPaintSettingsViewIconBrushNeon: + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/BrushSelectedNeon"], color); + break; + case TGPhotoPaintSettingsViewIconBrushArrow: + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/BrushSelectedArrow"], color); + break; + case TGPhotoPaintSettingsViewIconTextRegular: + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/TextSelectedRegular"], color); + break; + case TGPhotoPaintSettingsViewIconTextOutlined: + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/TextSelectedOutlined"], color); + break; + case TGPhotoPaintSettingsViewIconTextFramed: + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/TextSelectedFramed"], color); break; - case TGPhotoPaintSettingsViewIconMirror: - iconImage = TGTintedImage([UIImage imageNamed:@"Editor/Flip"], [UIColor whiteColor]); + iconImage = TGTintedImage([UIImage imageNamed:@"Editor/Flip"], color); break; } - - if (highlighted) - iconImage = TGTintedImage(iconImage, [TGPhotoEditorInterfaceAssets accentColor]); - return iconImage; } @@ -188,22 +211,27 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; - (void)layoutSubviews { + CGFloat leftInset = 23.0f; + CGFloat rightInset = 66.0f; + CGFloat colorPickerHeight = 10.0f; if (self.frame.size.width > self.frame.size.height) { if ([_context currentSizeClass] == UIUserInterfaceSizeClassRegular) { - _colorPicker.frame = CGRectMake(ceil((self.frame.size.width - TGPhotoPaintSettingsPadPickerWidth) / 2.0f), ceil((self.frame.size.height - 18.0f) / 2.0f), TGPhotoPaintSettingsPadPickerWidth, 18.0f); + _colorPicker.frame = CGRectMake(ceil((self.frame.size.width - TGPhotoPaintSettingsPadPickerWidth) / 2.0f), ceil((self.frame.size.height - colorPickerHeight) / 2.0f), TGPhotoPaintSettingsPadPickerWidth, colorPickerHeight); _settingsButton.frame = CGRectMake(CGRectGetMaxX(_colorPicker.frame) + 11.0f, floor((self.frame.size.height - _settingsButton.frame.size.height) / 2.0f) + 1.0f, _settingsButton.frame.size.width, _settingsButton.frame.size.height); } else { - _colorPicker.frame = CGRectMake(23.0f, ceil((self.frame.size.height - 18.0f) / 2.0f), self.frame.size.width - 23.0f - 66.0f, 18.0f); + _colorPicker.frame = CGRectMake(leftInset, ceil((self.frame.size.height - colorPickerHeight) / 2.0f), self.frame.size.width - leftInset - rightInset, colorPickerHeight); + _eyedropperButton.frame = CGRectMake(10.0f, floor((self.frame.size.height - _eyedropperButton.frame.size.height) / 2.0f) + 1.0f, _eyedropperButton.frame.size.width, _eyedropperButton.frame.size.height); _settingsButton.frame = CGRectMake(self.frame.size.width - _settingsButton.frame.size.width - 10.0f, floor((self.frame.size.height - _settingsButton.frame.size.height) / 2.0f) + 1.0f, _settingsButton.frame.size.width, _settingsButton.frame.size.height); } } else { - _colorPicker.frame = CGRectMake(ceil((self.frame.size.width - 18.0f) / 2.0f), 66.0f, 18.0f, self.frame.size.height - 23.0f - 66.0f); + _colorPicker.frame = CGRectMake(ceil((self.frame.size.width - colorPickerHeight) / 2.0f), rightInset, colorPickerHeight, self.frame.size.height - leftInset - rightInset); + _eyedropperButton.frame = CGRectMake(floor((self.frame.size.width - _eyedropperButton.frame.size.width) / 2.0f), self.frame.size.height - _eyedropperButton.frame.size.height - 10.0, _eyedropperButton.frame.size.width, _eyedropperButton.frame.size.height); _settingsButton.frame = CGRectMake(floor((self.frame.size.width - _settingsButton.frame.size.width) / 2.0f), 10.0f, _settingsButton.frame.size.width, _settingsButton.frame.size.height); } } diff --git a/submodules/LegacyComponents/Sources/TGPhotoQualityController.m b/submodules/LegacyComponents/Sources/TGPhotoQualityController.m index 348146e4b1..f738961b0b 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoQualityController.m +++ b/submodules/LegacyComponents/Sources/TGPhotoQualityController.m @@ -128,8 +128,8 @@ const NSTimeInterval TGPhotoQualityPreviewDuration = 15.0f; CGSize dimensions = CGSizeZero; if ([self.item isKindOfClass:[TGMediaAsset class]]) dimensions = ((TGMediaAsset *)self.item).dimensions; - else if ([self.item isKindOfClass:[TGCameraCapturedVideo class]]) - dimensions = [((TGCameraCapturedVideo *)self.item).avAsset tracksWithMediaType:AVMediaTypeVideo].firstObject.naturalSize; +// else if ([self.item isKindOfClass:[TGCameraCapturedVideo class]]) +// dimensions = [((TGCameraCapturedVideo *)self.item).avAsset tracksWithMediaType:AVMediaTypeVideo].firstObject.naturalSize; if (!CGSizeEqualToSize(dimensions, CGSizeZero)) _quality.maximumValue = [TGMediaVideoConverter bestAvailablePresetForDimensions:dimensions] - 1; @@ -641,7 +641,7 @@ const NSTimeInterval TGPhotoQualityPreviewDuration = 15.0f; [self updateInfo]; - SSignal *assetSignal = [self.item isKindOfClass:[TGMediaAsset class]] ? [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)self.item] : [SSignal single:((TGCameraCapturedVideo *)self.item).avAsset]; + SSignal *assetSignal = [self.item isKindOfClass:[TGMediaAsset class]] ? [TGMediaAssetImageSignals avAssetForVideoAsset:(TGMediaAsset *)self.item] : ((TGCameraCapturedVideo *)self.item).avAsset; if ([self.item isKindOfClass:[TGMediaAsset class]]) [self _updateVideoDuration:((TGMediaAsset *)self.item).videoDuration hasAudio:true]; diff --git a/submodules/LegacyComponents/Sources/TGPhotoStickerEntityView.m b/submodules/LegacyComponents/Sources/TGPhotoStickerEntityView.m index bd632b6631..a89a23735d 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoStickerEntityView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoStickerEntityView.m @@ -120,7 +120,11 @@ const CGFloat TGPhotoStickerSelectionViewHandleSide = 30.0f; - (bool)precisePointInside:(CGPoint)point { - return [_stickerView pointInside:[_stickerView convertPoint:point fromView:self] withEvent:nil]; + CGPoint imagePoint = [_stickerView convertPoint:point fromView:self]; + if (![_stickerView pointInside:[_stickerView convertPoint:point fromView:self] withEvent:nil]) + return false; + + return [_stickerView isOpaqueAtPoint:imagePoint]; } - (void)mirror diff --git a/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m b/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m index 5746b580f2..c65161751b 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m @@ -184,7 +184,7 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; { _style = style; switch (_style) { - case TGPhotoPaintTextEntityStyleClassic: + case TGPhotoPaintTextEntityStyleRegular: _textView.layer.shadowColor = [[UIColor blackColor] CGColor]; _textView.layer.shadowOffset = CGSizeMake(0.0f, 4.0f); _textView.layer.shadowOpacity = 0.4f; @@ -206,7 +206,7 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; - (void)updateColor { switch (_style) { - case TGPhotoPaintTextEntityStyleClassic: + case TGPhotoPaintTextEntityStyleRegular: { _textView.textColor = _swatch.color; _textView.strokeColor = nil; @@ -214,7 +214,7 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; } break; - case TGPhotoPaintTextEntityStyleBorder: + case TGPhotoPaintTextEntityStyleOutlined: { _textView.textColor = [UIColor whiteColor]; _textView.strokeColor = _swatch.color; @@ -222,7 +222,7 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; } break; - case TGPhotoPaintTextEntityStyleFrame: + case TGPhotoPaintTextEntityStyleFramed: { CGFloat lightness = 0.0f; CGFloat r = 0.0f; @@ -601,15 +601,35 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; [super showCGGlyphs:glyphs positions:positions count:glyphCount font:font matrix:textMatrix attributes:attributes inContext:context]; } +- (void)prepare { + _path = nil; + [self.rectArray removeAllObjects]; + + [self enumerateLineFragmentsForGlyphRange:NSMakeRange(0, self.textStorage.string) usingBlock:^(CGRect rect, CGRect usedRect, NSTextContainer * _Nonnull textContainer, NSRange glyphRange, BOOL * _Nonnull stop) { + bool ignoreRange = false; + NSRange characterRange = [self characterRangeForGlyphRange:glyphRange actualGlyphRange:nil]; + NSString *substring = [[self.textStorage string] substringWithRange:characterRange]; + if ([substring stringByTrimmingCharactersInSet:[NSCharacterSet newlineCharacterSet]].length == 0) { + ignoreRange = true; + } + + if (!ignoreRange) { + CGRect newRect = CGRectMake(usedRect.origin.x - self.frameWidthInset, usedRect.origin.y, usedRect.size.width + self.frameWidthInset * 2, usedRect.size.height); + NSValue *value = [NSValue valueWithCGRect:newRect]; + [self.rectArray addObject:value]; + } + }]; + + [self preProccess]; +} + - (void)drawBackgroundForGlyphRange:(NSRange)glyphsToShow atPoint:(CGPoint)origin { - [super drawBackgroundForGlyphRange:glyphsToShow atPoint:origin]; +// [super drawBackgroundForGlyphRange:glyphsToShow atPoint:origin]; if (self.frameColor != nil) { NSRange range = [self characterRangeForGlyphRange:glyphsToShow actualGlyphRange:NULL]; NSRange glyphRange = [self glyphRangeForCharacterRange:range actualCharacterRange:NULL]; - - CGContextRef context = UIGraphicsGetCurrentContext(); CGContextSaveGState(context); CGContextTranslateCTM(context, origin.x, origin.y); @@ -618,22 +638,23 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; CGContextSetFillColorWithColor(context, self.frameColor.CGColor); CGContextSetStrokeColorWithColor(context, self.frameColor.CGColor); - _path = nil; - [self.rectArray removeAllObjects]; - - [self enumerateLineFragmentsForGlyphRange:glyphRange usingBlock:^(CGRect rect, CGRect usedRect, NSTextContainer * _Nonnull textContainer, NSRange glyphRange, BOOL * _Nonnull stop) { - bool ignoreRange = false; - NSString *substring = [[self.textStorage string] substringWithRange:glyphRange]; - if ([substring stringByTrimmingCharactersInSet:[NSCharacterSet newlineCharacterSet]].length == 0) { - ignoreRange = true; - } - - if (!ignoreRange) { - CGRect newRect = CGRectMake(usedRect.origin.x - self.frameWidthInset, usedRect.origin.y, usedRect.size.width + self.frameWidthInset * 2, usedRect.size.height); - NSValue *value = [NSValue valueWithCGRect:newRect]; - [self.rectArray addObject:value]; - } - }]; + [self prepare]; +// _path = nil; +// [self.rectArray removeAllObjects]; +// +// [self enumerateLineFragmentsForGlyphRange:glyphRange usingBlock:^(CGRect rect, CGRect usedRect, NSTextContainer * _Nonnull textContainer, NSRange glyphRange, BOOL * _Nonnull stop) { +// bool ignoreRange = false; +// NSString *substring = [[self.textStorage string] substringWithRange:glyphRange]; +// if ([substring stringByTrimmingCharactersInSet:[NSCharacterSet newlineCharacterSet]].length == 0) { +// ignoreRange = true; +// } +// +// if (!ignoreRange) { +// CGRect newRect = CGRectMake(usedRect.origin.x - self.frameWidthInset, usedRect.origin.y, usedRect.size.width + self.frameWidthInset * 2, usedRect.size.height); +// NSValue *value = [NSValue valueWithCGRect:newRect]; +// [self.rectArray addObject:value]; +// } +// }]; [self preProccess]; @@ -646,8 +667,6 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; if (i == 0) { last = cur; } else if (i > 0 && fabs(CGRectGetMaxY(last) - CGRectGetMinY(cur)) < 10.0) { - NSValue *lastValue = [self.rectArray objectAtIndex:i-1]; - last = lastValue.CGRectValue; CGPoint a = cur.origin; CGPoint b = CGPointMake(CGRectGetMaxX(cur), cur.origin.y); CGPoint c = CGPointMake(last.origin.x, CGRectGetMaxY(last)); @@ -690,6 +709,8 @@ const CGFloat TGPhotoTextSelectionViewHandleSide = 30.0f; [addPath addLineToPoint:CGPointMake(d.x + _radius, d.y)]; [self.path appendPath:addPath]; } + + last = cur; } } [self.path fill]; diff --git a/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.h b/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.h index 3b26cb50f8..8881778372 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.h +++ b/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.h @@ -8,9 +8,6 @@ @property (nonatomic, copy) void (^fontChanged)(TGPhotoPaintFont *font); @property (nonatomic, copy) void (^styleChanged)(TGPhotoPaintTextEntityStyle style); -@property (nonatomic, strong) TGPhotoPaintFont *font; -@property (nonatomic, assign) TGPhotoPaintTextEntityStyle style; - - (instancetype)initWithFonts:(NSArray *)fonts selectedFont:(TGPhotoPaintFont *)font selectedStyle:(TGPhotoPaintTextEntityStyle)selectedStyle; @end diff --git a/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.m b/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.m index 241fdbbec8..b05b2d5bd2 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoTextSettingsView.m @@ -8,7 +8,7 @@ #import #import "TGPhotoTextEntityView.h" -const CGFloat TGPhotoTextSettingsViewMargin = 19.0f; +const CGFloat TGPhotoTextSettingsViewMargin = 10.0f; const CGFloat TGPhotoTextSettingsItemHeight = 44.0f; @interface TGPhotoTextSettingsView () @@ -17,11 +17,13 @@ const CGFloat TGPhotoTextSettingsItemHeight = 44.0f; UIInterfaceOrientation _interfaceOrientation; - UIImageView *_backgroundView; + UIView *_wrapperView; + UIView *_contentView; + UIVisualEffectView *_effectView; NSArray *_fontViews; + NSArray *_fontIconViews; NSArray *_fontSeparatorViews; - UIImageView *_selectedCheckView; } @end @@ -38,95 +40,91 @@ const CGFloat TGPhotoTextSettingsItemHeight = 44.0f; _interfaceOrientation = UIInterfaceOrientationPortrait; - _backgroundView = [[UIImageView alloc] init]; - _backgroundView.alpha = 0.98f; - [self addSubview:_backgroundView]; + _wrapperView = [[UIView alloc] init]; + _wrapperView.clipsToBounds = true; + _wrapperView.layer.cornerRadius = 12.0; + [self addSubview:_wrapperView]; + + _effectView = [[UIVisualEffectView alloc] initWithEffect:[UIBlurEffect effectWithStyle:UIBlurEffectStyleDark]]; + _effectView.alpha = 0.0f; + _effectView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; + [_wrapperView addSubview:_effectView]; + + _contentView = [[UIView alloc] init]; + _contentView.alpha = 0.0f; + _contentView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; + [_wrapperView addSubview:_contentView]; NSMutableArray *fontViews = [[NSMutableArray alloc] init]; + NSMutableArray *fontIconViews = [[NSMutableArray alloc] init]; NSMutableArray *separatorViews = [[NSMutableArray alloc] init]; - UIFont *font = [UIFont boldSystemFontOfSize:18]; + UIFont *font = [UIFont systemFontOfSize:17]; - TGModernButton *outlineButton = [[TGModernButton alloc] initWithFrame:CGRectMake(0, TGPhotoTextSettingsViewMargin, 0, 0)]; - outlineButton.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft; - outlineButton.titleLabel.font = font; - outlineButton.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 44.0f, 0.0f, 0.0f); - outlineButton.tag = TGPhotoPaintTextEntityStyleBorder; - [outlineButton setTitle:@"" forState:UIControlStateNormal]; - [outlineButton setTitleColor:[UIColor clearColor]]; - [outlineButton addTarget:self action:@selector(styleValueChanged:) forControlEvents:UIControlEventTouchUpInside]; - [self addSubview:outlineButton]; - [fontViews addObject:outlineButton]; - - TGPhotoTextView *textView = [[TGPhotoTextView alloc] init]; - textView.backgroundColor = [UIColor clearColor]; - textView.textColor = [UIColor whiteColor]; - textView.strokeWidth = 3.0f; - textView.strokeColor = [UIColor blackColor]; - textView.strokeOffset = CGPointMake(0.0f, 0.5f); - textView.font = font; - textView.text = TGLocalized(@"Paint.Outlined"); - [textView sizeToFit]; - textView.frame = CGRectMake(39.0f, ceil((TGPhotoTextSettingsItemHeight - textView.frame.size.height) / 2.0f) - 1.0f, ceil(textView.frame.size.width), ceil(textView.frame.size.height + 0.5f)); - [outlineButton addSubview:textView]; - - UIView *separatorView = [[UIView alloc] init]; - separatorView.backgroundColor = UIColorRGB(0xd6d6da); - [self addSubview:separatorView]; - [separatorViews addObject:separatorView]; - - TGModernButton *regularButton = [[TGModernButton alloc] initWithFrame:CGRectMake(0, TGPhotoTextSettingsViewMargin + TGPhotoTextSettingsItemHeight, 0, 0)]; - regularButton.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft; - regularButton.titleLabel.font = font; - regularButton.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 44.0f, 0.0f, 0.0f); - regularButton.tag = TGPhotoPaintTextEntityStyleClassic; - [regularButton setTitle:TGLocalized(@"Paint.Regular") forState:UIControlStateNormal]; - [regularButton setTitleColor:[UIColor blackColor]]; - [regularButton addTarget:self action:@selector(styleValueChanged:) forControlEvents:UIControlEventTouchUpInside]; - [self addSubview:regularButton]; - [fontViews addObject:regularButton]; - - separatorView = [[UIView alloc] init]; - separatorView.backgroundColor = UIColorRGB(0xd6d6da); - [self addSubview:separatorView]; - [separatorViews addObject:separatorView]; - - TGModernButton *frameButton = [[TGModernButton alloc] initWithFrame:CGRectMake(0, TGPhotoTextSettingsViewMargin + TGPhotoTextSettingsItemHeight + TGPhotoTextSettingsItemHeight, 0, 0)]; + TGModernButton *frameButton = [[TGModernButton alloc] initWithFrame:CGRectZero]; frameButton.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft; frameButton.titleLabel.font = font; - frameButton.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 44.0f, 0.0f, 0.0f); - frameButton.tag = TGPhotoPaintTextEntityStyleFrame; - [frameButton setTitle:@"" forState:UIControlStateNormal]; - [frameButton setTitleColor:[UIColor blackColor]]; + frameButton.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 16.0f, 0.0f, 0.0f); + frameButton.tag = TGPhotoPaintTextEntityStyleFramed; + [frameButton setTitle:TGLocalized(@"Paint.Framed") forState:UIControlStateNormal]; + [frameButton setTitleColor:[UIColor whiteColor]]; [frameButton addTarget:self action:@selector(styleValueChanged:) forControlEvents:UIControlEventTouchUpInside]; - [self addSubview:frameButton]; + [_contentView addSubview:frameButton]; [fontViews addObject:frameButton]; - textView = [[TGPhotoTextView alloc] init]; - textView.backgroundColor = [UIColor clearColor]; - textView.textColor = [UIColor whiteColor]; - textView.frameColor = [UIColor blackColor]; - textView.font = font; - textView.text = TGLocalized(@"Paint.Framed"); - [textView sizeToFit]; - textView.frame = CGRectMake(39.0f, ceil((TGPhotoTextSettingsItemHeight - textView.frame.size.height) / 2.0f) - 1.0f, ceil(textView.frame.size.width), ceil(textView.frame.size.height + 0.5f)); - [frameButton addSubview:textView]; + UIImageView *iconView = [[UIImageView alloc] initWithImage:TGTintedImage([UIImage imageNamed:@"Editor/TextFramed"], [UIColor whiteColor])]; + [frameButton addSubview:iconView]; + [fontIconViews addObject:iconView]; + + TGModernButton *outlineButton = [[TGModernButton alloc] initWithFrame:CGRectZero]; + outlineButton.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft; + outlineButton.titleLabel.font = font; + outlineButton.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 16.0f, 0.0f, 0.0f); + outlineButton.tag = TGPhotoPaintTextEntityStyleOutlined; + [outlineButton setTitle:TGLocalized(@"Paint.Outlined") forState:UIControlStateNormal]; + [outlineButton setTitleColor:[UIColor whiteColor]]; + [outlineButton addTarget:self action:@selector(styleValueChanged:) forControlEvents:UIControlEventTouchUpInside]; + [_contentView addSubview:outlineButton]; + [fontViews addObject:outlineButton]; + + iconView = [[UIImageView alloc] initWithImage:TGTintedImage([UIImage imageNamed:@"Editor/TextOutlined"], [UIColor whiteColor])]; + [outlineButton addSubview:iconView]; + [fontIconViews addObject:iconView]; + + UIView *separatorView = [[UIView alloc] init]; + separatorView.backgroundColor = UIColorRGBA(0xffffff, 0.2); + [_contentView addSubview:separatorView]; + [separatorViews addObject:separatorView]; + + TGModernButton *regularButton = [[TGModernButton alloc] initWithFrame:CGRectZero]; + regularButton.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft; + regularButton.titleLabel.font = font; + regularButton.contentEdgeInsets = UIEdgeInsetsMake(0.0f, 16.0f, 0.0f, 0.0f); + regularButton.tag = TGPhotoPaintTextEntityStyleRegular; + [regularButton setTitle:TGLocalized(@"Paint.Regular") forState:UIControlStateNormal]; + [regularButton setTitleColor:[UIColor whiteColor]]; + [regularButton addTarget:self action:@selector(styleValueChanged:) forControlEvents:UIControlEventTouchUpInside]; + [_contentView addSubview:regularButton]; + [fontViews addObject:regularButton]; + + iconView = [[UIImageView alloc] initWithImage:TGTintedImage([UIImage imageNamed:@"Editor/TextRegular"], [UIColor whiteColor])]; + [regularButton addSubview:iconView]; + [fontIconViews addObject:iconView]; + + separatorView = [[UIView alloc] init]; + separatorView.backgroundColor = UIColorRGBA(0xffffff, 0.2); + [_contentView addSubview:separatorView]; + [separatorViews addObject:separatorView]; _fontViews = fontViews; + _fontIconViews = fontIconViews; _fontSeparatorViews = separatorViews; - - _selectedCheckView = [[UIImageView alloc] initWithImage:TGComponentsImageNamed(@"PaintCheck")]; - _selectedCheckView.frame = CGRectMake(15.0f, 16.0f, _selectedCheckView.frame.size.width, _selectedCheckView.frame.size.height); - - [self setStyle:selectedStyle]; } return self; } - (void)fontButtonPressed:(TGModernButton *)sender { - [sender addSubview:_selectedCheckView]; - if (self.fontChanged != nil) self.fontChanged(_fonts[sender.tag]); } @@ -139,28 +137,22 @@ const CGFloat TGPhotoTextSettingsItemHeight = 44.0f; - (void)present { - self.alpha = 0.0f; - - self.layer.rasterizationScale = TGScreenScaling(); - self.layer.shouldRasterize = true; - - [UIView animateWithDuration:0.2 animations:^ + [UIView animateWithDuration:0.25 animations:^ { - self.alpha = 1.0f; + _effectView.alpha = 1.0f; + _contentView.alpha = 1.0f; } completion:^(__unused BOOL finished) { - self.layer.shouldRasterize = false; + }]; } - (void)dismissWithCompletion:(void (^)(void))completion { - self.layer.rasterizationScale = TGScreenScaling(); - self.layer.shouldRasterize = true; - - [UIView animateWithDuration:0.15 animations:^ + [UIView animateWithDuration:0.2 animations:^ { - self.alpha = 0.0f; + _effectView.alpha = 0.0f; + _contentView.alpha = 0.0f; } completion:^(__unused BOOL finished) { if (completion != nil) @@ -168,81 +160,38 @@ const CGFloat TGPhotoTextSettingsItemHeight = 44.0f; }]; } -- (TGPhotoPaintTextEntityStyle)style -{ - return (TGPhotoPaintTextEntityStyle)_selectedCheckView.superview.tag; -} - -- (void)setStyle:(TGPhotoPaintTextEntityStyle)style -{ - [_fontViews[style] addSubview:_selectedCheckView]; -} - -- (NSString *)font -{ - return _fonts[_selectedCheckView.superview.tag]; -} - -- (void)setFont:(TGPhotoPaintFont *)__unused font -{ - -} - - (CGSize)sizeThatFits:(CGSize)__unused size { - return CGSizeMake(256, _fontViews.count * TGPhotoTextSettingsItemHeight + TGPhotoTextSettingsViewMargin * 2); + return CGSizeMake(220, _fontViews.count * TGPhotoTextSettingsItemHeight + TGPhotoTextSettingsViewMargin * 2); } - (void)setInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation { _interfaceOrientation = interfaceOrientation; - switch (self.interfaceOrientation) - { - case UIInterfaceOrientationLandscapeLeft: - { - _backgroundView.image = [TGPhotoPaintSettingsView landscapeLeftBackgroundImage]; - } - break; - - case UIInterfaceOrientationLandscapeRight: - { - _backgroundView.image = [TGPhotoPaintSettingsView landscapeRightBackgroundImage]; - } - break; - - default: - { - _backgroundView.image = [TGPhotoPaintSettingsView portraitBackgroundImage]; - } - break; - } - [self setNeedsLayout]; } - (void)layoutSubviews { + CGFloat arrowSize = 0.0f; switch (self.interfaceOrientation) { case UIInterfaceOrientationLandscapeLeft: { - _backgroundView.image = [TGTintedImage(TGComponentsImageNamed(@"PaintPopupLandscapeLeftBackground"), UIColorRGB(0xf7f7f7)) resizableImageWithCapInsets:UIEdgeInsetsMake(32.0f, 32.0f, 32.0f, 32.0f)]; - _backgroundView.frame = CGRectMake(TGPhotoTextSettingsViewMargin - 13.0f, TGPhotoTextSettingsViewMargin, self.frame.size.width - TGPhotoTextSettingsViewMargin * 2 + 13.0f, self.frame.size.height - TGPhotoTextSettingsViewMargin * 2); + _wrapperView.frame = CGRectMake(TGPhotoTextSettingsViewMargin - arrowSize, TGPhotoTextSettingsViewMargin, self.frame.size.width - TGPhotoTextSettingsViewMargin * 2 + arrowSize, self.frame.size.height - TGPhotoTextSettingsViewMargin * 2); } break; case UIInterfaceOrientationLandscapeRight: { - _backgroundView.image = [TGTintedImage(TGComponentsImageNamed(@"PaintPopupLandscapeRightBackground"), UIColorRGB(0xf7f7f7)) resizableImageWithCapInsets:UIEdgeInsetsMake(32.0f, 32.0f, 32.0f, 32.0f)]; - _backgroundView.frame = CGRectMake(TGPhotoTextSettingsViewMargin, TGPhotoTextSettingsViewMargin, self.frame.size.width - TGPhotoTextSettingsViewMargin * 2 + 13.0f, self.frame.size.height - TGPhotoTextSettingsViewMargin * 2); + _wrapperView.frame = CGRectMake(TGPhotoTextSettingsViewMargin, TGPhotoTextSettingsViewMargin, self.frame.size.width - TGPhotoTextSettingsViewMargin * 2 + arrowSize, self.frame.size.height - TGPhotoTextSettingsViewMargin * 2); } break; default: { - _backgroundView.image = [TGTintedImage(TGComponentsImageNamed(@"PaintPopupPortraitBackground"), UIColorRGB(0xf7f7f7)) resizableImageWithCapInsets:UIEdgeInsetsMake(32.0f, 32.0f, 32.0f, 32.0f)]; - _backgroundView.frame = CGRectMake(TGPhotoTextSettingsViewMargin, TGPhotoTextSettingsViewMargin, self.frame.size.width - TGPhotoTextSettingsViewMargin * 2, self.frame.size.height - TGPhotoTextSettingsViewMargin * 2 + 13.0f); + _wrapperView.frame = CGRectMake(TGPhotoTextSettingsViewMargin, TGPhotoTextSettingsViewMargin, self.frame.size.width - TGPhotoTextSettingsViewMargin * 2, self.frame.size.height - TGPhotoTextSettingsViewMargin * 2 + arrowSize); } break; } @@ -251,13 +200,17 @@ const CGFloat TGPhotoTextSettingsItemHeight = 44.0f; [_fontViews enumerateObjectsUsingBlock:^(TGModernButton *view, NSUInteger index, __unused BOOL *stop) { - view.frame = CGRectMake(TGPhotoTextSettingsViewMargin, TGPhotoTextSettingsViewMargin + TGPhotoTextSettingsItemHeight * index, self.frame.size.width - TGPhotoTextSettingsViewMargin * 2, TGPhotoTextSettingsItemHeight); - + view.frame = CGRectMake(0.0, TGPhotoTextSettingsItemHeight * index, _contentView.frame.size.width, TGPhotoTextSettingsItemHeight); + }]; + + [_fontIconViews enumerateObjectsUsingBlock:^(UIImageView *view, NSUInteger index, __unused BOOL *stop) + { + view.frame = CGRectMake(_contentView.frame.size.width - 42.0f, (TGPhotoTextSettingsItemHeight - view.frame.size.height) / 2.0, view.frame.size.width, view.frame.size.height); }]; [_fontSeparatorViews enumerateObjectsUsingBlock:^(UIView *view, NSUInteger index, __unused BOOL *stop) { - view.frame = CGRectMake(TGPhotoTextSettingsViewMargin + 44.0f, TGPhotoTextSettingsViewMargin + TGPhotoTextSettingsItemHeight * (index + 1), self.frame.size.width - TGPhotoTextSettingsViewMargin * 2 - 44.0f, thickness); + view.frame = CGRectMake(0.0, TGPhotoTextSettingsItemHeight * (index + 1), _contentView.frame.size.width, thickness); }]; } diff --git a/submodules/LegacyComponents/Sources/TGPhotoVideoEditor.m b/submodules/LegacyComponents/Sources/TGPhotoVideoEditor.m index b5584c04d0..d346771c1b 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoVideoEditor.m +++ b/submodules/LegacyComponents/Sources/TGPhotoVideoEditor.m @@ -32,6 +32,7 @@ TGMediaPickerGalleryModel *model = [[TGMediaPickerGalleryModel alloc] initWithContext:windowContext items:@[galleryItem] focusItem:galleryItem selectionContext:nil editingContext:editingContext hasCaptions:true allowCaptionEntities:true hasTimer:false onlyCrop:false inhibitDocumentCaptions:false hasSelectionPanel:false hasCamera:false recipientName:recipientName]; model.controller = galleryController; + model.stickersContext = stickersContext; //model.suggestionContext = self.suggestionContext; model.willFinishEditingItem = ^(id editableItem, id adjustments, id representation, bool hasChanges) diff --git a/submodules/LegacyComponents/Sources/TGVideoEditAdjustments.m b/submodules/LegacyComponents/Sources/TGVideoEditAdjustments.m index 6eea7c1f53..5b309d7646 100644 --- a/submodules/LegacyComponents/Sources/TGVideoEditAdjustments.m +++ b/submodules/LegacyComponents/Sources/TGVideoEditAdjustments.m @@ -91,7 +91,7 @@ const NSTimeInterval TGVideoEditMaximumGifDuration = 30.5; } else if ([dict[@"type"] isEqualToString:@"text"]) { UIImage *renderImage = [[UIImage alloc] initWithData:dict[@"data"]]; if (renderImage != nil) { - TGPhotoPaintTextEntity *entity = [[TGPhotoPaintTextEntity alloc] initWithText:nil font:nil swatch:nil baseFontSize:0.0 maxWidth:0.0 style:TGPhotoPaintTextEntityStyleClassic]; + TGPhotoPaintTextEntity *entity = [[TGPhotoPaintTextEntity alloc] initWithText:nil font:nil swatch:nil baseFontSize:0.0 maxWidth:0.0 style:TGPhotoPaintTextEntityStyleRegular]; entity.uuid = [dict[@"uuid"] integerValue]; entity.position = [dict[@"position"] CGPointValue]; entity.scale = [dict[@"scale"] floatValue]; diff --git a/submodules/LegacyComponents/Sources/TGVideoMessageCaptureController.m b/submodules/LegacyComponents/Sources/TGVideoMessageCaptureController.m index 7d97dd2d28..329de8d797 100644 --- a/submodules/LegacyComponents/Sources/TGVideoMessageCaptureController.m +++ b/submodules/LegacyComponents/Sources/TGVideoMessageCaptureController.m @@ -833,7 +833,7 @@ typedef enum _didPlayToEndObserver = [[TGObserverProxy alloc] initWithTarget:self targetSelector:@selector(playerItemDidPlayToEndTime:) name:AVPlayerItemDidPlayToEndTimeNotification object:_player.currentItem]; - _videoView = [[TGModernGalleryVideoView alloc] initWithFrame: CGRectInset(_previewView.frame, -1.0, -1.0) player:_player]; + _videoView = [[TGModernGalleryVideoView alloc] initWithFrame: CGRectInset(_previewView.frame, -3.0, -3.0) player:_player]; [_previewView.superview insertSubview:_videoView belowSubview:_previewView]; UITapGestureRecognizer *gestureRecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(unmutePressed)]; diff --git a/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift b/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift index 374e395b36..3769f545e4 100644 --- a/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift +++ b/submodules/MediaPlayer/Sources/MediaPlayerScrubbingNode.swift @@ -710,12 +710,13 @@ public final class MediaPlayerScrubbingNode: ASDisplayNode { } else if let _ = self.scrubbingTimestampValue { needsAnimation = false } else if let statusValue = self.statusValue { - if case .buffering(true, _) = statusValue.status { + switch statusValue.status { + case .buffering: needsAnimation = false - } else if Double(0.0).isLess(than: statusValue.duration) { + case .paused: + needsAnimation = false + case .playing: needsAnimation = true - } else { - needsAnimation = false } } else { needsAnimation = false diff --git a/submodules/MediaPlayer/Sources/UniversalSoftwareVideoSource.swift b/submodules/MediaPlayer/Sources/UniversalSoftwareVideoSource.swift index ef33d6d613..de74237eac 100644 --- a/submodules/MediaPlayer/Sources/UniversalSoftwareVideoSource.swift +++ b/submodules/MediaPlayer/Sources/UniversalSoftwareVideoSource.swift @@ -10,7 +10,6 @@ private func readPacketCallback(userData: UnsafeMutableRawPointer?, buffer: Unsa let data: Signal<(Data, Bool), NoError> - let resourceSize: Int = context.size let readCount = min(256 * 1024, Int(bufferSize)) let requestRange: Range = context.readingOffset ..< (context.readingOffset + readCount) @@ -22,7 +21,7 @@ private func readPacketCallback(userData: UnsafeMutableRawPointer?, buffer: Unsa let requiredDataIsNotLocallyAvailable = context.requiredDataIsNotLocallyAvailable var fetchedData: Data? let fetchDisposable = MetaDisposable() - let isInitialized = context.videoStream != nil + let isInitialized = context.videoStream != nil || context.automaticallyFetchHeader let mediaBox = context.mediaBox let reference = context.fileReference.resourceReference(context.fileReference.media.resource) let disposable = data.start(next: { result in @@ -94,6 +93,7 @@ private final class UniversalSoftwareVideoSourceImpl { fileprivate let mediaBox: MediaBox fileprivate let fileReference: FileMediaReference fileprivate let size: Int + fileprivate let automaticallyFetchHeader: Bool fileprivate let state: ValuePromise @@ -108,7 +108,7 @@ private final class UniversalSoftwareVideoSourceImpl { fileprivate var currentNumberOfReads: Int = 0 fileprivate var currentReadBytes: Int = 0 - init?(mediaBox: MediaBox, fileReference: FileMediaReference, state: ValuePromise, cancelInitialization: Signal) { + init?(mediaBox: MediaBox, fileReference: FileMediaReference, state: ValuePromise, cancelInitialization: Signal, automaticallyFetchHeader: Bool) { guard let size = fileReference.media.size else { return nil } @@ -116,6 +116,7 @@ private final class UniversalSoftwareVideoSourceImpl { self.mediaBox = mediaBox self.fileReference = fileReference self.size = size + self.automaticallyFetchHeader = automaticallyFetchHeader self.state = state state.set(.initializing) @@ -140,6 +141,9 @@ private final class UniversalSoftwareVideoSourceImpl { return nil } + print("Header read in \(self.currentReadBytes) bytes") + self.currentReadBytes = 0 + self.avFormatContext = avFormatContext var videoStream: SoftwareVideoStream? @@ -251,15 +255,17 @@ private final class UniversalSoftwareVideoSourceImpl { self.currentNumberOfReads = 0 self.currentReadBytes = 0 - for _ in 0 ..< 10 { + for i in 0 ..< 10 { + let _ = i let (decodableFrame, loop) = self.readDecodableFrame() if let decodableFrame = decodableFrame { if let renderedFrame = videoStream.decoder.render(frame: decodableFrame) { - //print("Frame rendered in \(self.currentNumberOfReads) reads, \(self.currentReadBytes) bytes, total frames read: \(i + 1)") + print("Frame rendered in \(self.currentNumberOfReads) reads, \(self.currentReadBytes) bytes, total frames read: \(i + 1)") return (renderedFrame, CGFloat(videoStream.rotationAngle), CGFloat(videoStream.aspect), loop) } } } + print("No frame in \(self.currentReadBytes / 1024) KB") return (nil, CGFloat(videoStream.rotationAngle), CGFloat(videoStream.aspect), true) } } @@ -276,12 +282,20 @@ private final class UniversalSoftwareVideoSourceThreadParams: NSObject { let fileReference: FileMediaReference let state: ValuePromise let cancelInitialization: Signal + let automaticallyFetchHeader: Bool - init(mediaBox: MediaBox, fileReference: FileMediaReference, state: ValuePromise, cancelInitialization: Signal) { + init( + mediaBox: MediaBox, + fileReference: FileMediaReference, + state: ValuePromise, + cancelInitialization: Signal, + automaticallyFetchHeader: Bool + ) { self.mediaBox = mediaBox self.fileReference = fileReference self.state = state self.cancelInitialization = cancelInitialization + self.automaticallyFetchHeader = automaticallyFetchHeader } } @@ -306,7 +320,7 @@ private final class UniversalSoftwareVideoSourceThread: NSObject { let timer = Timer(fireAt: .distantFuture, interval: 0.0, target: UniversalSoftwareVideoSourceThread.self, selector: #selector(UniversalSoftwareVideoSourceThread.none), userInfo: nil, repeats: false) runLoop.add(timer, forMode: .common) - let source = UniversalSoftwareVideoSourceImpl(mediaBox: params.mediaBox, fileReference: params.fileReference, state: params.state, cancelInitialization: params.cancelInitialization) + let source = UniversalSoftwareVideoSourceImpl(mediaBox: params.mediaBox, fileReference: params.fileReference, state: params.state, cancelInitialization: params.cancelInitialization, automaticallyFetchHeader: params.automaticallyFetchHeader) Thread.current.threadDictionary["source"] = source while true { @@ -342,17 +356,17 @@ private final class UniversalSoftwareVideoSourceThread: NSObject { } } -enum UniversalSoftwareVideoSourceTakeFrameResult { +public enum UniversalSoftwareVideoSourceTakeFrameResult { case waitingForData case image(UIImage?) } -final class UniversalSoftwareVideoSource { +public final class UniversalSoftwareVideoSource { private let thread: Thread private let stateValue: ValuePromise = ValuePromise(.initializing, ignoreRepeated: true) private let cancelInitialization: ValuePromise = ValuePromise(false) - var ready: Signal { + public var ready: Signal { return self.stateValue.get() |> map { value -> Bool in switch value { @@ -364,8 +378,8 @@ final class UniversalSoftwareVideoSource { } } - init(mediaBox: MediaBox, fileReference: FileMediaReference) { - self.thread = Thread(target: UniversalSoftwareVideoSourceThread.self, selector: #selector(UniversalSoftwareVideoSourceThread.entryPoint(_:)), object: UniversalSoftwareVideoSourceThreadParams(mediaBox: mediaBox, fileReference: fileReference, state: self.stateValue, cancelInitialization: self.cancelInitialization.get())) + public init(mediaBox: MediaBox, fileReference: FileMediaReference, automaticallyFetchHeader: Bool = false) { + self.thread = Thread(target: UniversalSoftwareVideoSourceThread.self, selector: #selector(UniversalSoftwareVideoSourceThread.entryPoint(_:)), object: UniversalSoftwareVideoSourceThreadParams(mediaBox: mediaBox, fileReference: fileReference, state: self.stateValue, cancelInitialization: self.cancelInitialization.get(), automaticallyFetchHeader: automaticallyFetchHeader)) self.thread.name = "UniversalSoftwareVideoSource" self.thread.start() } diff --git a/submodules/PeerInfoUI/Sources/ChannelVisibilityController.swift b/submodules/PeerInfoUI/Sources/ChannelVisibilityController.swift index c18bf1bccd..1d2d08580a 100644 --- a/submodules/PeerInfoUI/Sources/ChannelVisibilityController.swift +++ b/submodules/PeerInfoUI/Sources/ChannelVisibilityController.swift @@ -615,7 +615,7 @@ private func channelVisibilityControllerEntries(presentationData: PresentationDa } } else if let _ = view.peers[view.peerId] as? TelegramGroup { switch mode { - case .privateLink, .generic: + case .privateLink: let link = (view.cachedData as? CachedGroupData)?.exportedInvitation?.link let text: String if let link = link { @@ -640,7 +640,7 @@ private func channelVisibilityControllerEntries(presentationData: PresentationDa if let current = state.selectedType { selectedType = current } else { - selectedType = .publicChannel + selectedType = .privateChannel } let currentAddressName: String diff --git a/submodules/PeersNearbyUI/Sources/PeersNearbyController.swift b/submodules/PeersNearbyUI/Sources/PeersNearbyController.swift index 65cfe0e213..f2264f3c5f 100644 --- a/submodules/PeersNearbyUI/Sources/PeersNearbyController.swift +++ b/submodules/PeersNearbyUI/Sources/PeersNearbyController.swift @@ -661,7 +661,7 @@ public func peersNearbyController(context: AccountContext) -> ViewController { } navigateToChatImpl = { [weak controller] peer in if let navigationController = controller?.navigationController as? NavigationController { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peer.id), keepStack: .always, purposefulAction: {})) + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peer.id), keepStack: .always, purposefulAction: {}, peekData: nil)) } } pushControllerImpl = { [weak controller] c in diff --git a/submodules/PhotoResources/Sources/PhotoResources.swift b/submodules/PhotoResources/Sources/PhotoResources.swift index 13cfd291de..bdaf6dca19 100644 --- a/submodules/PhotoResources/Sources/PhotoResources.swift +++ b/submodules/PhotoResources/Sources/PhotoResources.swift @@ -27,16 +27,20 @@ public func largestRepresentationForPhoto(_ photo: TelegramMediaImage) -> Telegr return photo.representationForDisplayAtSize(PixelDimensions(width: 1280, height: 1280)) } -public func chatMessagePhotoDatas(postbox: Postbox, photoReference: ImageMediaReference, fullRepresentationSize: CGSize = CGSize(width: 1280.0, height: 1280.0), autoFetchFullSize: Bool = false, tryAdditionalRepresentations: Bool = false, synchronousLoad: Bool = false) -> Signal, NoError> { - if let smallestRepresentation = smallestImageRepresentation(photoReference.media.representations), let largestRepresentation = photoReference.media.representationForDisplayAtSize(PixelDimensions(width: Int32(fullRepresentationSize.width), height: Int32(fullRepresentationSize.height))) { +public func chatMessagePhotoDatas(postbox: Postbox, photoReference: ImageMediaReference, fullRepresentationSize: CGSize = CGSize(width: 1280.0, height: 1280.0), autoFetchFullSize: Bool = false, tryAdditionalRepresentations: Bool = false, synchronousLoad: Bool = false, useMiniThumbnailIfAvailable: Bool = false) -> Signal, NoError> { + if let smallestRepresentation = smallestImageRepresentation(photoReference.media.representations), let largestRepresentation = photoReference.media.representationForDisplayAtSize(PixelDimensions(width: Int32(fullRepresentationSize.width), height: Int32(fullRepresentationSize.height))), let fullRepresentation = largestImageRepresentation(photoReference.media.representations) { let maybeFullSize = postbox.mediaBox.resourceData(largestRepresentation.resource, option: .complete(waitUntilFetchStatus: false), attemptSynchronously: synchronousLoad) + let maybeLargestSize = postbox.mediaBox.resourceData(fullRepresentation.resource, option: .complete(waitUntilFetchStatus: false), attemptSynchronously: synchronousLoad) - let signal = maybeFullSize + let signal = combineLatest(maybeFullSize, maybeLargestSize) |> take(1) - |> mapToSignal { maybeData -> Signal, NoError> in + |> mapToSignal { maybeData, maybeLargestData -> Signal, NoError> in if maybeData.complete { let loadedData: Data? = try? Data(contentsOf: URL(fileURLWithPath: maybeData.path), options: []) return .single(Tuple(nil, loadedData, .full, true)) + } else if maybeLargestData.complete { + let loadedData: Data? = try? Data(contentsOf: URL(fileURLWithPath: maybeLargestData.path), options: []) + return .single(Tuple(nil, loadedData, .full, true)) } else { let decodedThumbnailData = photoReference.media.immediateThumbnailData.flatMap(decodeTinyThumbnail) let fetchedThumbnail: Signal @@ -99,7 +103,7 @@ public func chatMessagePhotoDatas(postbox: Postbox, photoReference: ImageMediaRe let fullSizeData: Signal, NoError> - if autoFetchFullSize { + if autoFetchFullSize && !useMiniThumbnailIfAvailable { fullSizeData = Signal, NoError> { subscriber in let fetchedFullSizeDisposable = fetchedFullSize.start() let fullSizeDisposable = postbox.mediaBox.resourceData(largestRepresentation.resource, option: .complete(waitUntilFetchStatus: false), attemptSynchronously: synchronousLoad).start(next: { next in @@ -1152,7 +1156,8 @@ public func avatarGalleryThumbnailPhoto(account: Account, representations: [Imag } public func mediaGridMessagePhoto(account: Account, photoReference: ImageMediaReference, fullRepresentationSize: CGSize = CGSize(width: 127.0, height: 127.0), synchronousLoad: Bool = false) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { - let signal = chatMessagePhotoDatas(postbox: account.postbox, photoReference: photoReference, fullRepresentationSize: fullRepresentationSize, autoFetchFullSize: true, synchronousLoad: synchronousLoad) + let useMiniThumbnailIfAvailable: Bool = fullRepresentationSize.width < 40.0 + let signal = chatMessagePhotoDatas(postbox: account.postbox, photoReference: photoReference, fullRepresentationSize: fullRepresentationSize, autoFetchFullSize: true, tryAdditionalRepresentations: useMiniThumbnailIfAvailable, synchronousLoad: synchronousLoad, useMiniThumbnailIfAvailable: useMiniThumbnailIfAvailable) return signal |> map { value in @@ -1197,16 +1202,22 @@ public func mediaGridMessagePhoto(account: Account, photoReference: ImageMediaRe var blurredThumbnailImage: UIImage? if let thumbnailImage = thumbnailImage { - let thumbnailSize = CGSize(width: thumbnailImage.width, height: thumbnailImage.height) - let thumbnailContextSize = thumbnailSize.aspectFilled(CGSize(width: 90.0, height: 90.0)) - let thumbnailContext = DrawingContext(size: thumbnailContextSize, scale: 1.0) - thumbnailContext.withFlippedContext { c in - c.interpolationQuality = .none - c.draw(thumbnailImage, in: CGRect(origin: CGPoint(), size: thumbnailContextSize)) + if useMiniThumbnailIfAvailable { + blurredThumbnailImage = UIImage(cgImage: thumbnailImage) + } else { + let thumbnailSize = CGSize(width: thumbnailImage.width, height: thumbnailImage.height) + let thumbnailContextSize = thumbnailSize.aspectFilled(CGSize(width: 90.0, height: 90.0)) + let thumbnailContext = DrawingContext(size: thumbnailContextSize, scale: 1.0) + thumbnailContext.withFlippedContext { c in + c.interpolationQuality = .none + c.draw(thumbnailImage, in: CGRect(origin: CGPoint(), size: thumbnailContextSize)) + } + if !useMiniThumbnailIfAvailable { + telegramFastBlurMore(Int32(thumbnailContextSize.width), Int32(thumbnailContextSize.height), Int32(thumbnailContext.bytesPerRow), thumbnailContext.bytes) + } + + blurredThumbnailImage = thumbnailContext.generateImage() } - telegramFastBlurMore(Int32(thumbnailContextSize.width), Int32(thumbnailContextSize.height), Int32(thumbnailContext.bytesPerRow), thumbnailContext.bytes) - - blurredThumbnailImage = thumbnailContext.generateImage() } context.withFlippedContext { c in @@ -1305,14 +1316,14 @@ public func gifPaneVideoThumbnail(account: Account, videoReference: FileMediaRef } } -public func mediaGridMessageVideo(postbox: Postbox, videoReference: FileMediaReference, onlyFullSize: Bool = false, synchronousLoad: Bool = false, autoFetchFullSizeThumbnail: Bool = false, overlayColor: UIColor? = nil, nilForEmptyResult: Bool = false) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { - return internalMediaGridMessageVideo(postbox: postbox, videoReference: videoReference, onlyFullSize: onlyFullSize, synchronousLoad: synchronousLoad, autoFetchFullSizeThumbnail: autoFetchFullSizeThumbnail, overlayColor: overlayColor, nilForEmptyResult: nilForEmptyResult) +public func mediaGridMessageVideo(postbox: Postbox, videoReference: FileMediaReference, onlyFullSize: Bool = false, synchronousLoad: Bool = false, autoFetchFullSizeThumbnail: Bool = false, overlayColor: UIColor? = nil, nilForEmptyResult: Bool = false, useMiniThumbnailIfAvailable: Bool = false) -> Signal<(TransformImageArguments) -> DrawingContext?, NoError> { + return internalMediaGridMessageVideo(postbox: postbox, videoReference: videoReference, onlyFullSize: onlyFullSize, synchronousLoad: synchronousLoad, autoFetchFullSizeThumbnail: autoFetchFullSizeThumbnail, overlayColor: overlayColor, nilForEmptyResult: nilForEmptyResult, useMiniThumbnailIfAvailable: useMiniThumbnailIfAvailable) |> map { return $0.1 } } -public func internalMediaGridMessageVideo(postbox: Postbox, videoReference: FileMediaReference, imageReference: ImageMediaReference? = nil, onlyFullSize: Bool = false, synchronousLoad: Bool = false, autoFetchFullSizeThumbnail: Bool = false, overlayColor: UIColor? = nil, nilForEmptyResult: Bool = false) -> Signal<(() -> CGSize?, (TransformImageArguments) -> DrawingContext?), NoError> { +public func internalMediaGridMessageVideo(postbox: Postbox, videoReference: FileMediaReference, imageReference: ImageMediaReference? = nil, onlyFullSize: Bool = false, synchronousLoad: Bool = false, autoFetchFullSizeThumbnail: Bool = false, overlayColor: UIColor? = nil, nilForEmptyResult: Bool = false, useMiniThumbnailIfAvailable: Bool = false) -> Signal<(() -> CGSize?, (TransformImageArguments) -> DrawingContext?), NoError> { let signal: Signal?, Bool>, NoError> if let imageReference = imageReference { signal = chatMessagePhotoDatas(postbox: postbox, photoReference: imageReference, tryAdditionalRepresentations: true, synchronousLoad: synchronousLoad) @@ -1398,7 +1409,7 @@ public func internalMediaGridMessageVideo(postbox: Postbox, videoReference: File var blurredThumbnailImage: UIImage? if let thumbnailImage = thumbnailImage { - if max(thumbnailImage.width, thumbnailImage.height) > Int(min(200.0, min(drawingSize.width, drawingSize.height))) { + if max(thumbnailImage.width, thumbnailImage.height) > Int(min(200.0, min(drawingSize.width, drawingSize.height))) || useMiniThumbnailIfAvailable { blurredThumbnailImage = UIImage(cgImage: thumbnailImage) } else { let thumbnailSize = CGSize(width: thumbnailImage.width, height: thumbnailImage.height) @@ -2129,7 +2140,7 @@ private func avatarGalleryPhotoDatas(account: Account, fileReference: FileMediaR } } } - } |> filter({ $0._0 != nil || $0._1 != nil }) + } return signal } else { diff --git a/submodules/Postbox/Sources/ChatListView.swift b/submodules/Postbox/Sources/ChatListView.swift index 74bead9528..9cc854f9fd 100644 --- a/submodules/Postbox/Sources/ChatListView.swift +++ b/submodules/Postbox/Sources/ChatListView.swift @@ -88,7 +88,7 @@ public struct ChatListGroupReferenceEntry: Equatable { } public enum ChatListEntry: Comparable { - case MessageEntry(index: ChatListIndex, message: Message?, readState: CombinedPeerReadState?, isRemovedFromTotalUnreadCount: Bool, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, renderedPeer: RenderedPeer, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, hasFailed: Bool, isContact: Bool) + case MessageEntry(index: ChatListIndex, messages: [Message], readState: CombinedPeerReadState?, isRemovedFromTotalUnreadCount: Bool, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, renderedPeer: RenderedPeer, presence: PeerPresence?, summaryInfo: ChatListMessageTagSummaryInfo, hasFailed: Bool, isContact: Bool) case HoleEntry(ChatListHole) public var index: ChatListIndex { @@ -102,18 +102,23 @@ public enum ChatListEntry: Comparable { public static func ==(lhs: ChatListEntry, rhs: ChatListEntry) -> Bool { switch lhs { - case let .MessageEntry(lhsIndex, lhsMessage, lhsReadState, lhsIsRemovedFromTotalUnreadCount, lhsEmbeddedState, lhsPeer, lhsPresence, lhsInfo, lhsHasFailed, lhsIsContact): + case let .MessageEntry(lhsIndex, lhsMessages, lhsReadState, lhsIsRemovedFromTotalUnreadCount, lhsEmbeddedState, lhsPeer, lhsPresence, lhsInfo, lhsHasFailed, lhsIsContact): switch rhs { - case let .MessageEntry(rhsIndex, rhsMessage, rhsReadState, rhsIsRemovedFromTotalUnreadCount, rhsEmbeddedState, rhsPeer, rhsPresence, rhsInfo, rhsHasFailed, rhsIsContact): + case let .MessageEntry(rhsIndex, rhsMessages, rhsReadState, rhsIsRemovedFromTotalUnreadCount, rhsEmbeddedState, rhsPeer, rhsPresence, rhsInfo, rhsHasFailed, rhsIsContact): if lhsIndex != rhsIndex { return false } if lhsReadState != rhsReadState { return false } - if lhsMessage?.stableVersion != rhsMessage?.stableVersion { + if lhsMessages.count != rhsMessages.count { return false } + for i in 0 ..< lhsMessages.count { + if lhsMessages[i].stableVersion != rhsMessages[i].stableVersion { + return false + } + } if lhsIsRemovedFromTotalUnreadCount != rhsIsRemovedFromTotalUnreadCount { return false } @@ -180,7 +185,7 @@ public enum ChatListEntry: Comparable { enum MutableChatListEntry: Equatable { case IntermediateMessageEntry(index: ChatListIndex, messageIndex: MessageIndex?) - case MessageEntry(index: ChatListIndex, message: Message?, readState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, isRemovedFromTotalUnreadCount: Bool, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, renderedPeer: RenderedPeer, presence: PeerPresence?, tagSummaryInfo: ChatListMessageTagSummaryInfo, hasFailedMessages: Bool, isContact: Bool) + case MessageEntry(index: ChatListIndex, messages: [Message], readState: CombinedPeerReadState?, notificationSettings: PeerNotificationSettings?, isRemovedFromTotalUnreadCount: Bool, embeddedInterfaceState: PeerChatListEmbeddedInterfaceState?, renderedPeer: RenderedPeer, presence: PeerPresence?, tagSummaryInfo: ChatListMessageTagSummaryInfo, hasFailedMessages: Bool, isContact: Bool) case HoleEntry(ChatListHole) init(_ intermediateEntry: ChatListIntermediateEntry, cachedDataTable: CachedPeerDataTable, readStateTable: MessageHistoryReadStateTable, messageHistoryTable: MessageHistoryTable) { @@ -557,11 +562,11 @@ final class MutableChatListView { private func renderEntry(_ entry: MutableChatListEntry, postbox: Postbox, renderMessage: (IntermediateMessage) -> Message, getPeer: (PeerId) -> Peer?, getPeerNotificationSettings: (PeerId) -> PeerNotificationSettings?, getPeerPresence: (PeerId) -> PeerPresence?) -> MutableChatListEntry? { switch entry { case let .IntermediateMessageEntry(index, messageIndex): - let renderedMessage: Message? + var renderedMessages: [Message] = [] if let messageIndex = messageIndex { - renderedMessage = postbox.messageHistoryTable.getMessage(messageIndex).flatMap(renderMessage) - } else { - renderedMessage = nil + if let messageGroup = postbox.messageHistoryTable.getMessageGroup(at: messageIndex, limit: 10) { + renderedMessages.append(contentsOf: messageGroup.compactMap(renderMessage)) + } } var peers = SimpleDictionary() var notificationSettings: PeerNotificationSettings? @@ -586,7 +591,7 @@ final class MutableChatListView { let tagSummaryCount: Int32? = nil let actionsSummaryCount: Int32? = nil - return .MessageEntry(index: index, message: renderedMessage, readState: postbox.readStateTable.getCombinedState(index.messageIndex.id.peerId), notificationSettings: notificationSettings, isRemovedFromTotalUnreadCount: false, embeddedInterfaceState: postbox.peerChatInterfaceStateTable.get(index.messageIndex.id.peerId)?.chatListEmbeddedState, renderedPeer: RenderedPeer(peerId: index.messageIndex.id.peerId, peers: peers), presence: presence, tagSummaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: tagSummaryCount, actionsSummaryCount: actionsSummaryCount), hasFailedMessages: postbox.messageHistoryFailedTable.contains(peerId: index.messageIndex.id.peerId), isContact: isContact) + return .MessageEntry(index: index, messages: renderedMessages, readState: postbox.readStateTable.getCombinedState(index.messageIndex.id.peerId), notificationSettings: notificationSettings, isRemovedFromTotalUnreadCount: false, embeddedInterfaceState: postbox.peerChatInterfaceStateTable.get(index.messageIndex.id.peerId)?.chatListEmbeddedState, renderedPeer: RenderedPeer(peerId: index.messageIndex.id.peerId, peers: peers), presence: presence, tagSummaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: tagSummaryCount, actionsSummaryCount: actionsSummaryCount), hasFailedMessages: postbox.messageHistoryFailedTable.contains(peerId: index.messageIndex.id.peerId), isContact: isContact) default: return nil } @@ -615,8 +620,8 @@ public final class ChatListView { var entries: [ChatListEntry] = [] for entry in mutableView.sampledState.entries { switch entry { - case let .MessageEntry(index, message, combinedReadState, _, isRemovedFromTotalUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): - entries.append(.MessageEntry(index: index, message: message, readState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: embeddedState, renderedPeer: peer, presence: peerPresence, summaryInfo: summaryInfo, hasFailed: hasFailed, isContact: isContact)) + case let .MessageEntry(index, messages, combinedReadState, _, isRemovedFromTotalUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): + entries.append(.MessageEntry(index: index, messages: messages, readState: combinedReadState, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: embeddedState, renderedPeer: peer, presence: peerPresence, summaryInfo: summaryInfo, hasFailed: hasFailed, isContact: isContact)) case let .HoleEntry(hole): entries.append(.HoleEntry(hole)) case .IntermediateMessageEntry: @@ -633,9 +638,9 @@ public final class ChatListView { var additionalItemEntries: [ChatListAdditionalItemEntry] = [] for entry in mutableView.additionalItemEntries { switch entry.entry { - case let .MessageEntry(index, message, combinedReadState, _, isExcludedFromUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): + case let .MessageEntry(index, messages, combinedReadState, _, isExcludedFromUnreadCount, embeddedState, peer, peerPresence, summaryInfo, hasFailed, isContact): additionalItemEntries.append(ChatListAdditionalItemEntry( - entry: .MessageEntry(index: index, message: message, readState: combinedReadState, isRemovedFromTotalUnreadCount: isExcludedFromUnreadCount, embeddedInterfaceState: embeddedState, renderedPeer: peer, presence: peerPresence, summaryInfo: summaryInfo, hasFailed: hasFailed, isContact: isContact), + entry: .MessageEntry(index: index, messages: messages, readState: combinedReadState, isRemovedFromTotalUnreadCount: isExcludedFromUnreadCount, embeddedInterfaceState: embeddedState, renderedPeer: peer, presence: peerPresence, summaryInfo: summaryInfo, hasFailed: hasFailed, isContact: isContact), info: entry.info )) case .HoleEntry: diff --git a/submodules/Postbox/Sources/ChatListViewState.swift b/submodules/Postbox/Sources/ChatListViewState.swift index a0ec7f2f07..926feed837 100644 --- a/submodules/Postbox/Sources/ChatListViewState.swift +++ b/submodules/Postbox/Sources/ChatListViewState.swift @@ -601,13 +601,13 @@ private final class ChatListViewSpaceState { if self.orderedEntries.mutableScan({ entry in switch entry { - case let .MessageEntry(messageEntry): - if let peer = messageEntry.renderedPeer.peer { + case let .MessageEntry(index, messages, readState, notificationSettings, isRemovedFromTotalUnreadCount, embeddedInterfaceState, renderedPeer, presence, tagSummaryInfo, hasFailedMessages, isContact): + if let peer = renderedPeer.peer { let notificationsPeerId = peer.notificationSettingsPeerId ?? peer.id if let (_, updated) = transaction.currentUpdatedPeerNotificationSettings[notificationsPeerId] { let isRemovedFromTotalUnreadCount = resolvedIsRemovedFromTotalUnreadCount(globalSettings: globalNotificationSettings, peer: peer, peerSettings: updated) - return .MessageEntry(index: messageEntry.index, message: messageEntry.message, readState: messageEntry.readState, notificationSettings: updated, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: messageEntry.renderedPeer, presence: messageEntry.presence, tagSummaryInfo: messageEntry.tagSummaryInfo, hasFailedMessages: messageEntry.hasFailedMessages, isContact: messageEntry.isContact) + return .MessageEntry(index: index, messages: messages, readState: readState, notificationSettings: updated, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: embeddedInterfaceState, renderedPeer: renderedPeer, presence: presence, tagSummaryInfo: tagSummaryInfo, hasFailedMessages: hasFailedMessages, isContact: isContact) } else { return nil } @@ -627,7 +627,7 @@ private final class ChatListViewSpaceState { switch entry { case let .MessageEntry(messageEntry): if transaction.updatedFailedMessagePeerIds.contains(messageEntry.index.messageIndex.id.peerId) { - return .MessageEntry(index: messageEntry.index, message: messageEntry.message, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: messageEntry.renderedPeer, presence: messageEntry.presence, tagSummaryInfo: messageEntry.tagSummaryInfo, hasFailedMessages: postbox.messageHistoryFailedTable.contains(peerId: messageEntry.index.messageIndex.id.peerId), isContact: messageEntry.isContact) + return .MessageEntry(index: messageEntry.index, messages: messageEntry.messages, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: messageEntry.renderedPeer, presence: messageEntry.presence, tagSummaryInfo: messageEntry.tagSummaryInfo, hasFailedMessages: postbox.messageHistoryFailedTable.contains(peerId: messageEntry.index.messageIndex.id.peerId), isContact: messageEntry.isContact) } else { return nil } @@ -643,14 +643,18 @@ private final class ChatListViewSpaceState { if self.orderedEntries.mutableScan({ entry in switch entry { case let .MessageEntry(messageEntry): - var updatedMessage: Message? - if let message = messageEntry.message { - updatedMessage = updateMessagePeers(message, updatedPeers: transaction.currentUpdatedPeers) + var updatedMessages: [Message] = messageEntry.messages + var hasUpdatedMessages = false + for i in 0 ..< updatedMessages.count { + if let updatedMessage = updateMessagePeers(updatedMessages[i], updatedPeers: transaction.currentUpdatedPeers) { + updatedMessages[i] = updatedMessage + hasUpdatedMessages = true + } } let renderedPeer = updatedRenderedPeer(messageEntry.renderedPeer, updatedPeers: transaction.currentUpdatedPeers) - if updatedMessage != nil || renderedPeer != nil { - return .MessageEntry(index: messageEntry.index, message: updatedMessage ?? messageEntry.message, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: renderedPeer ?? messageEntry.renderedPeer, presence: messageEntry.presence, tagSummaryInfo: messageEntry.tagSummaryInfo, hasFailedMessages: messageEntry.hasFailedMessages, isContact: messageEntry.isContact) + if hasUpdatedMessages || renderedPeer != nil { + return .MessageEntry(index: messageEntry.index, messages: updatedMessages, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: renderedPeer ?? messageEntry.renderedPeer, presence: messageEntry.presence, tagSummaryInfo: messageEntry.tagSummaryInfo, hasFailedMessages: messageEntry.hasFailedMessages, isContact: messageEntry.isContact) } else { return nil } @@ -671,7 +675,7 @@ private final class ChatListViewSpaceState { presencePeerId = associatedPeerId } if let presence = transaction.currentUpdatedPeerPresences[presencePeerId] { - return .MessageEntry(index: messageEntry.index, message: messageEntry.message, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: messageEntry.renderedPeer, presence: presence, tagSummaryInfo: messageEntry.tagSummaryInfo, hasFailedMessages: messageEntry.hasFailedMessages, isContact: messageEntry.isContact) + return .MessageEntry(index: messageEntry.index, messages: messageEntry.messages, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: messageEntry.renderedPeer, presence: presence, tagSummaryInfo: messageEntry.tagSummaryInfo, hasFailedMessages: messageEntry.hasFailedMessages, isContact: messageEntry.isContact) } else { return nil } @@ -821,7 +825,7 @@ private final class ChatListViewSpaceState { if updatedTagSummaryCount != nil || updatedActionsSummaryCount != nil { let summaryInfo = ChatListMessageTagSummaryInfo(tagSummaryCount: updatedTagSummaryCount ?? messageEntry.tagSummaryInfo.tagSummaryCount, actionsSummaryCount: updatedActionsSummaryCount ?? messageEntry.tagSummaryInfo.actionsSummaryCount) - return .MessageEntry(index: messageEntry.index, message: messageEntry.message, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: messageEntry.renderedPeer, presence: messageEntry.presence, tagSummaryInfo: summaryInfo, hasFailedMessages: messageEntry.hasFailedMessages, isContact: messageEntry.isContact) + return .MessageEntry(index: messageEntry.index, messages: messageEntry.messages, readState: messageEntry.readState, notificationSettings: messageEntry.notificationSettings, isRemovedFromTotalUnreadCount: messageEntry.isRemovedFromTotalUnreadCount, embeddedInterfaceState: messageEntry.embeddedInterfaceState, renderedPeer: messageEntry.renderedPeer, presence: messageEntry.presence, tagSummaryInfo: summaryInfo, hasFailedMessages: messageEntry.hasFailedMessages, isContact: messageEntry.isContact) } else { return nil } @@ -1376,7 +1380,14 @@ struct ChatListViewState { isRemovedFromTotalUnreadCount = false } - let updatedEntry: MutableChatListEntry = .MessageEntry(index: index, message: messageIndex.flatMap(postbox.messageHistoryTable.getMessage).flatMap(postbox.renderIntermediateMessage), readState: postbox.readStateTable.getCombinedState(index.messageIndex.id.peerId), notificationSettings: notificationSettings, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: postbox.peerChatInterfaceStateTable.get(index.messageIndex.id.peerId)?.chatListEmbeddedState, renderedPeer: renderedPeer, presence: postbox.peerPresenceTable.get(index.messageIndex.id.peerId), tagSummaryInfo: tagSummaryInfo, hasFailedMessages: false, isContact: postbox.contactsTable.isContact(peerId: index.messageIndex.id.peerId)) + var renderedMessages: [Message] = [] + if let messageIndex = messageIndex { + if let messageGroup = postbox.messageHistoryTable.getMessageGroup(at: messageIndex, limit: 10) { + renderedMessages.append(contentsOf: messageGroup.compactMap(postbox.renderIntermediateMessage)) + } + } + + let updatedEntry: MutableChatListEntry = .MessageEntry(index: index, messages: renderedMessages, readState: postbox.readStateTable.getCombinedState(index.messageIndex.id.peerId), notificationSettings: notificationSettings, isRemovedFromTotalUnreadCount: isRemovedFromTotalUnreadCount, embeddedInterfaceState: postbox.peerChatInterfaceStateTable.get(index.messageIndex.id.peerId)?.chatListEmbeddedState, renderedPeer: renderedPeer, presence: postbox.peerPresenceTable.get(index.messageIndex.id.peerId), tagSummaryInfo: tagSummaryInfo, hasFailedMessages: false, isContact: postbox.contactsTable.isContact(peerId: index.messageIndex.id.peerId)) if directionIndex == 0 { self.stateBySpace[space]!.orderedEntries.setLowerOrAtAnchorAtArrayIndex(listIndex, to: updatedEntry) } else { diff --git a/submodules/PresentationDataUtils/Sources/AlertTheme.swift b/submodules/PresentationDataUtils/Sources/AlertTheme.swift index 9a0c25b108..cc5f0907fc 100644 --- a/submodules/PresentationDataUtils/Sources/AlertTheme.swift +++ b/submodules/PresentationDataUtils/Sources/AlertTheme.swift @@ -4,8 +4,8 @@ import AlertUI import AccountContext import SwiftSignalKit -public func textAlertController(context: AccountContext, title: String?, text: String, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, allowInputInset: Bool = true) -> AlertController { - return textAlertController(alertContext: AlertControllerContext(theme: AlertControllerTheme(presentationData: context.sharedContext.currentPresentationData.with { $0 }), themeSignal: context.sharedContext.presentationData |> map { presentationData in AlertControllerTheme(presentationData: presentationData) }), title: title, text: text, actions: actions, actionLayout: actionLayout, allowInputInset: allowInputInset) +public func textAlertController(context: AccountContext, title: String?, text: String, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, allowInputInset: Bool = true, dismissOnOutsideTap: Bool = true) -> AlertController { + return textAlertController(alertContext: AlertControllerContext(theme: AlertControllerTheme(presentationData: context.sharedContext.currentPresentationData.with { $0 }), themeSignal: context.sharedContext.presentationData |> map { presentationData in AlertControllerTheme(presentationData: presentationData) }), title: title, text: text, actions: actions, actionLayout: actionLayout, allowInputInset: allowInputInset, dismissOnOutsideTap: dismissOnOutsideTap) } public func richTextAlertController(context: AccountContext, title: NSAttributedString?, text: NSAttributedString, actions: [TextAlertAction], actionLayout: TextAlertContentActionLayout = .horizontal, allowInputInset: Bool = true, dismissAutomatically: Bool = true) -> AlertController { diff --git a/submodules/SettingsUI/Sources/DebugController.swift b/submodules/SettingsUI/Sources/DebugController.swift index f9436ca6bf..e4dafcf84d 100644 --- a/submodules/SettingsUI/Sources/DebugController.swift +++ b/submodules/SettingsUI/Sources/DebugController.swift @@ -512,7 +512,7 @@ private enum DebugControllerEntry: ItemListNodeEntry { }) }) case let .photoPreview(theme, value): - return ItemListSwitchItem(presentationData: presentationData, title: "Photo Preview", value: value, sectionId: self.section, style: .blocks, updated: { value in + return ItemListSwitchItem(presentationData: presentationData, title: "Media Preview (Updated)", value: value, sectionId: self.section, style: .blocks, updated: { value in let _ = arguments.sharedContext.accountManager.transaction ({ transaction in transaction.updateSharedData(ApplicationSpecificSharedDataKeys.experimentalUISettings, { settings in var settings = settings as? ExperimentalUISettings ?? ExperimentalUISettings.defaultSettings diff --git a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift index 309deaa769..f2b4aafdf5 100644 --- a/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift +++ b/submodules/SettingsUI/Sources/Text Size/TextSizeSelectionController.swift @@ -235,22 +235,22 @@ private final class TextSizeSelectionControllerNode: ASDisplayNode, UIScrollView let timestamp = self.referenceTimestamp let timestamp1 = timestamp + 120 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let presenceTimestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 + 60 * 60) let timestamp2 = timestamp + 3660 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer2), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp3 = timestamp + 3200 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer3), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp4 = timestamp + 3000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer4), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp5 = timestamp + 1000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer5), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer5), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let width: CGFloat if case .regular = layout.metrics.widthClass { diff --git a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift index d693773115..d30215f04e 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemeAccentColorControllerNode.swift @@ -786,17 +786,17 @@ final class ThemeAccentColorControllerNode: ASDisplayNode, UIScrollViewDelegate let timestamp = self.referenceTimestamp let timestamp1 = timestamp + 120 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let presenceTimestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 + 60 * 60) let timestamp2 = timestamp + 3660 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_2_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_2_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer2), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp3 = timestamp + 3200 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer3), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp4 = timestamp + 3000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer4), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let params = ListViewItemLayoutParams(width: layout.size.width, leftInset: layout.safeInsets.left, rightInset: layout.safeInsets.right, availableHeight: layout.size.height) if let chatNodes = self.chatNodes { diff --git a/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift b/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift index 30ef3e814f..c273166376 100644 --- a/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift +++ b/submodules/SettingsUI/Sources/Themes/ThemePreviewControllerNode.swift @@ -373,24 +373,24 @@ final class ThemePreviewControllerNode: ASDisplayNode, UIScrollViewDelegate { let timestamp = self.referenceTimestamp let timestamp1 = timestamp + 120 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: 0, messageIndex: MessageIndex(id: MessageId(peerId: peer1.id, namespace: 0, id: 0), timestamp: timestamp1)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer1.id, namespace: 0, id: 0), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp1, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: selfPeer, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_1_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer1), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 0, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let presenceTimestamp = Int32(CFAbsoluteTimeGetCurrent() + NSTimeIntervalSince1970 + 60 * 60) let timestamp2 = timestamp + 3660 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer2), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer2.id, namespace: 0, id: 0), timestamp: timestamp2)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer2.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp2, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer2, text: "", attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer2), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: TelegramUserPresence(status: .present(until: presenceTimestamp), lastActivity: presenceTimestamp), summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: [(peer2, .typingText)], promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp3 = timestamp + 3200 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer3), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer3.id, namespace: 0, id: 0), timestamp: timestamp3)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer3.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp3, flags: [], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer3Author, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_3_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer3), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp4 = timestamp + 3000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer4), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer4.id, namespace: 0, id: 0), timestamp: timestamp4)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp4, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer4, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_4_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer4), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let timestamp5 = timestamp + 1000 - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer5), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer5.id, namespace: 0, id: 0), timestamp: timestamp5)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer4.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp5, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer5, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_5_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer5), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer6.id, namespace: 0, id: 0), timestamp: timestamp - 360)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer6.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 360, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_6_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer6), combinedReadState: CombinedPeerReadState(states: [(Namespaces.Message.Cloud, PeerReadState.idBased(maxIncomingReadId: 0, maxOutgoingReadId: 0, maxKnownId: 0, count: 1, markedUnread: false))]), isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) - items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer7.id, namespace: 0, id: 0), timestamp: timestamp - 420)), content: .peer(message: Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer7.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 420, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_7_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: []), peer: RenderedPeer(peer: peer7), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) + items.append(ChatListItem(presentationData: chatListPresentationData, context: self.context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: MessageIndex(id: MessageId(peerId: peer7.id, namespace: 0, id: 0), timestamp: timestamp - 420)), content: .peer(messages: [Message(stableId: 0, stableVersion: 0, id: MessageId(peerId: peer7.id, namespace: 0, id: 1), globallyUniqueId: nil, groupingKey: nil, groupInfo: nil, timestamp: timestamp - 420, flags: [.Incoming], tags: [], globalTags: [], localTags: [], forwardInfo: nil, author: peer6, text: self.presentationData.strings.Appearance_ThemePreview_ChatList_7_Text, attributes: [], media: [], peers: peers, associatedMessages: messages, associatedMessageIds: [])], peer: RenderedPeer(peer: peer7), combinedReadState: nil, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(tagSummaryCount: nil, actionsSummaryCount: nil), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: false, displayAsMessage: false, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction)) let width: CGFloat if case .regular = layout.metrics.widthClass { diff --git a/submodules/StatisticsUI/Sources/StatsController.swift b/submodules/StatisticsUI/Sources/StatsController.swift index cabf15469f..3fc5195b9d 100644 --- a/submodules/StatisticsUI/Sources/StatsController.swift +++ b/submodules/StatisticsUI/Sources/StatsController.swift @@ -514,7 +514,7 @@ public func channelStatsController(context: AccountContext, peerId: PeerId, cach } navigateToMessageImpl = { [weak controller] messageId in if let navigationController = controller?.navigationController as? NavigationController { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(messageId.peerId), subject: .message(messageId), keepStack: .always, useExisting: false, purposefulAction: {})) + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(messageId.peerId), subject: .message(messageId), keepStack: .always, useExisting: false, purposefulAction: {}, peekData: nil)) } } return controller diff --git a/submodules/TelegramApi/Sources/Api0.swift b/submodules/TelegramApi/Sources/Api0.swift index 97cca53302..2ac9823c4d 100644 --- a/submodules/TelegramApi/Sources/Api0.swift +++ b/submodules/TelegramApi/Sources/Api0.swift @@ -71,6 +71,7 @@ fileprivate let parsers: [Int32 : (BufferReader) -> Any?] = { dict[1202287072] = { return Api.StatsURL.parse_statsURL($0) } dict[1516793212] = { return Api.ChatInvite.parse_chatInviteAlready($0) } dict[-540871282] = { return Api.ChatInvite.parse_chatInvite($0) } + dict[1634294960] = { return Api.ChatInvite.parse_chatInvitePeek($0) } dict[-532532493] = { return Api.AutoDownloadSettings.parse_autoDownloadSettings($0) } dict[1678812626] = { return Api.StickerSetCovered.parse_stickerSetCovered($0) } dict[872932635] = { return Api.StickerSetCovered.parse_stickerSetMultiCovered($0) } diff --git a/submodules/TelegramApi/Sources/Api1.swift b/submodules/TelegramApi/Sources/Api1.swift index d501ad509f..c6865d9f52 100644 --- a/submodules/TelegramApi/Sources/Api1.swift +++ b/submodules/TelegramApi/Sources/Api1.swift @@ -3624,6 +3624,7 @@ public extension Api { public enum ChatInvite: TypeConstructorDescription { case chatInviteAlready(chat: Api.Chat) case chatInvite(flags: Int32, title: String, photo: Api.Photo, participantsCount: Int32, participants: [Api.User]?) + case chatInvitePeek(chat: Api.Chat, expires: Int32) public func serialize(_ buffer: Buffer, _ boxed: Swift.Bool) { switch self { @@ -3647,6 +3648,13 @@ public extension Api { item.serialize(buffer, true) }} break + case .chatInvitePeek(let chat, let expires): + if boxed { + buffer.appendInt32(1634294960) + } + chat.serialize(buffer, true) + serializeInt32(expires, buffer: buffer, boxed: false) + break } } @@ -3656,6 +3664,8 @@ public extension Api { return ("chatInviteAlready", [("chat", chat)]) case .chatInvite(let flags, let title, let photo, let participantsCount, let participants): return ("chatInvite", [("flags", flags), ("title", title), ("photo", photo), ("participantsCount", participantsCount), ("participants", participants)]) + case .chatInvitePeek(let chat, let expires): + return ("chatInvitePeek", [("chat", chat), ("expires", expires)]) } } @@ -3699,6 +3709,22 @@ public extension Api { return nil } } + public static func parse_chatInvitePeek(_ reader: BufferReader) -> ChatInvite? { + var _1: Api.Chat? + if let signature = reader.readInt32() { + _1 = Api.parse(reader, signature: signature) as? Api.Chat + } + var _2: Int32? + _2 = reader.readInt32() + let _c1 = _1 != nil + let _c2 = _2 != nil + if _c1 && _c2 { + return Api.ChatInvite.chatInvitePeek(chat: _1!, expires: _2!) + } + else { + return nil + } + } } public enum AutoDownloadSettings: TypeConstructorDescription { diff --git a/submodules/TelegramCore/Sources/AccountStateManagementUtils.swift b/submodules/TelegramCore/Sources/AccountStateManagementUtils.swift index 0d08a5a43c..430fdbec38 100644 --- a/submodules/TelegramCore/Sources/AccountStateManagementUtils.swift +++ b/submodules/TelegramCore/Sources/AccountStateManagementUtils.swift @@ -3006,7 +3006,9 @@ func replayFinalState(accountManager: AccountManager, postbox: Postbox, accountP return $0.0 < $1.0 }).map({ $0.1 }) for file in gifFiles { - transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentGifs, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 200) + if !file.hasLinkedStickers { + transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentGifs, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 200) + } } } diff --git a/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift b/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift index 9a282a9325..44bc111807 100644 --- a/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift +++ b/submodules/TelegramCore/Sources/ApplyUpdateMessage.swift @@ -218,7 +218,9 @@ func applyUpdateMessage(postbox: Postbox, stateManager: AccountStateManager, mes transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentStickers, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 20) } for file in sentGifs { - transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentGifs, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 200) + if !file.hasLinkedStickers { + transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentGifs, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 200) + } } stateManager.addUpdates(result) @@ -356,7 +358,9 @@ func applyUpdateGroupMessages(postbox: Postbox, stateManager: AccountStateManage transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentStickers, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 20) } for file in sentGifs { - transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentGifs, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 200) + if !file.hasLinkedStickers { + transaction.addOrMoveToFirstPositionOrderedItemListItem(collectionId: Namespaces.OrderedItemList.CloudRecentGifs, item: OrderedItemListEntry(id: RecentMediaItemId(file.fileId).rawValue, contents: RecentMediaItem(file)), removeTailIfCountExceeds: 200) + } } stateManager.addUpdates(result) stateManager.addUpdateGroups([.ensurePeerHasLocalState(id: messages[0].id.peerId)]) diff --git a/submodules/TelegramCore/Sources/JoinLink.swift b/submodules/TelegramCore/Sources/JoinLink.swift index b037b017c5..fc994d80bc 100644 --- a/submodules/TelegramCore/Sources/JoinLink.swift +++ b/submodules/TelegramCore/Sources/JoinLink.swift @@ -25,6 +25,7 @@ public enum ExternalJoiningChatState { case invite(title: String, photoRepresentation: TelegramMediaImageRepresentation?, participantsCount: Int32, participants: [Peer]?) case alreadyJoined(PeerId) case invalidHash + case peek(PeerId, Int32) } public func joinChatInteractively(with hash: String, account: Account) -> Signal { @@ -66,7 +67,7 @@ public func joinLinkInformation(_ hash: String, account: Account) -> Signal ExternalJoiningChatState in updatePeers(transaction: transaction, peers: [peer], update: { (previous, updated) -> Peer? in @@ -77,6 +78,17 @@ public func joinLinkInformation(_ hash: String, account: Account) -> Signal ExternalJoiningChatState in + updatePeers(transaction: transaction, peers: [peer], update: { (previous, updated) -> Peer? in + return updated + }) + + return .peek(peer.id, expires) + }) + } + return .single(.invalidHash) } } else { return .single(.invalidHash) diff --git a/submodules/TelegramCore/Sources/RequestEditMessage.swift b/submodules/TelegramCore/Sources/RequestEditMessage.swift index 592b0203a1..495e7401c0 100644 --- a/submodules/TelegramCore/Sources/RequestEditMessage.swift +++ b/submodules/TelegramCore/Sources/RequestEditMessage.swift @@ -24,6 +24,7 @@ private enum RequestEditMessageInternalError { public enum RequestEditMessageError { case generic case restricted + case textTooLong } public func requestEditMessage(account: Account, messageId: MessageId, text: String, media: RequestEditMessageMedia, entities: TextEntitiesMessageAttribute? = nil, disableUrlPreview: Bool = false, scheduleTime: Int32? = nil) -> Signal { @@ -173,6 +174,8 @@ private func requestEditMessageInternal(postbox: Postbox, network: Network, stat |> mapError { error -> RequestEditMessageInternalError in if error.errorDescription.hasPrefix("FILEREF_INVALID") || error.errorDescription.hasPrefix("FILE_REFERENCE_") { return .invalidReference + } else if error.errorDescription.hasSuffix("_TOO_LONG") { + return .error(.textTooLong) } else if error.errorDescription.hasPrefix("CHAT_SEND_") && error.errorDescription.hasSuffix("_FORBIDDEN") { return .error(.restricted) } diff --git a/submodules/TelegramCore/Sources/Serialization.swift b/submodules/TelegramCore/Sources/Serialization.swift index 55bda07a9d..b02855f76f 100644 --- a/submodules/TelegramCore/Sources/Serialization.swift +++ b/submodules/TelegramCore/Sources/Serialization.swift @@ -210,7 +210,7 @@ public class BoxedMessage: NSObject { public class Serialization: NSObject, MTSerialization { public func currentLayer() -> UInt { - return 114 + return 115 } public func parseMessage(_ data: Data!) -> Any! { diff --git a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 54f0e30679..c8202c96e7 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -250,4716 +250,4724 @@ public final class PresentationStrings: Equatable { public var Conversation_LiveLocation: String { return self._s[60]! } public var Wallet_Month_ShortNovember: String { return self._s[61]! } public var PrivacyLastSeenSettings_CustomShareSettingsHelp: String { return self._s[62]! } - public var NetworkUsageSettings_BytesReceived: String { return self._s[64]! } - public var Stickers_Search: String { return self._s[66]! } - public var NotificationsSound_Synth: String { return self._s[67]! } - public var LogoutOptions_LogOutInfo: String { return self._s[68]! } + public var NetworkUsageSettings_BytesReceived: String { return self._s[65]! } + public var Stickers_Search: String { return self._s[67]! } + public var NotificationsSound_Synth: String { return self._s[68]! } + public var LogoutOptions_LogOutInfo: String { return self._s[69]! } public func VoiceOver_Chat_ForwardedFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[70]!, self._r[70]!, [_0]) + return formatWithArgumentRanges(self._s[71]!, self._r[71]!, [_0]) } - public var NetworkUsageSettings_MediaAudioDataSection: String { return self._s[71]! } - public var ChatListFolder_NameBots: String { return self._s[72]! } - public var ChatList_EmptyChatListFilterText: String { return self._s[73]! } - public var ChatList_Context_HideArchive: String { return self._s[75]! } - public var AutoNightTheme_UseSunsetSunrise: String { return self._s[76]! } - public var FastTwoStepSetup_Title: String { return self._s[77]! } - public var EditTheme_Create_Preview_IncomingReplyText: String { return self._s[78]! } - public var Channel_Info_BlackList: String { return self._s[79]! } - public var Channel_AdminLog_InfoPanelTitle: String { return self._s[80]! } - public var Conversation_OpenFile: String { return self._s[82]! } - public var SecretTimer_ImageDescription: String { return self._s[83]! } - public var StickerSettings_ContextInfo: String { return self._s[84]! } - public var TwoStepAuth_GenericHelp: String { return self._s[86]! } - public var AutoDownloadSettings_Unlimited: String { return self._s[87]! } - public var PrivacyLastSeenSettings_NeverShareWith_Title: String { return self._s[88]! } - public var AutoDownloadSettings_DataUsageHigh: String { return self._s[89]! } + public var NetworkUsageSettings_MediaAudioDataSection: String { return self._s[72]! } + public var ChatListFolder_NameBots: String { return self._s[73]! } + public var ChatList_EmptyChatListFilterText: String { return self._s[74]! } + public var ChatList_Context_HideArchive: String { return self._s[76]! } + public var AutoNightTheme_UseSunsetSunrise: String { return self._s[77]! } + public var FastTwoStepSetup_Title: String { return self._s[78]! } + public var EditTheme_Create_Preview_IncomingReplyText: String { return self._s[79]! } + public var Channel_Info_BlackList: String { return self._s[80]! } + public var Channel_AdminLog_InfoPanelTitle: String { return self._s[81]! } + public var Conversation_OpenFile: String { return self._s[83]! } + public var SecretTimer_ImageDescription: String { return self._s[84]! } + public var StickerSettings_ContextInfo: String { return self._s[85]! } + public var TwoStepAuth_GenericHelp: String { return self._s[87]! } + public var AutoDownloadSettings_Unlimited: String { return self._s[88]! } + public var PrivacyLastSeenSettings_NeverShareWith_Title: String { return self._s[89]! } + public var AutoDownloadSettings_DataUsageHigh: String { return self._s[90]! } public func PUSH_CHAT_MESSAGE_VIDEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[90]!, self._r[90]!, [_1, _2]) + return formatWithArgumentRanges(self._s[91]!, self._r[91]!, [_1, _2]) } - public var AuthSessions_AddDevice_ScanInfo: String { return self._s[91]! } - public var Notifications_AddExceptionTitle: String { return self._s[92]! } - public var Watch_MessageView_Reply: String { return self._s[93]! } - public var Tour_Text6: String { return self._s[94]! } - public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[95]! } + public var AuthSessions_AddDevice_ScanInfo: String { return self._s[92]! } + public var Notifications_AddExceptionTitle: String { return self._s[93]! } + public var Watch_MessageView_Reply: String { return self._s[94]! } + public var Tour_Text6: String { return self._s[95]! } + public var TwoStepAuth_SetupPasswordEnterPasswordChange: String { return self._s[96]! } public func Notification_PinnedAnimationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[96]!, self._r[96]!, [_0]) - } - public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[97]!, self._r[97]!, [_0]) } - public var Wallet_Configuration_BlockchainIdPlaceholder: String { return self._s[98]! } - public var AccessDenied_LocationDenied: String { return self._s[99]! } - public var CallSettings_RecentCalls: String { return self._s[100]! } - public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[101]! } - public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[103]! } - public var Passport_Authorize: String { return self._s[104]! } - public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[105]! } - public var AutoDownloadSettings_Videos: String { return self._s[106]! } - public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[107]! } - public var Wallet_Info_Send: String { return self._s[108]! } - public var AuthSessions_AddDevice_UrlLoginHint: String { return self._s[109]! } - public var Wallet_TransactionInfo_SendGrams: String { return self._s[110]! } - public var Tour_StartButton: String { return self._s[111]! } - public var Watch_AppName: String { return self._s[113]! } - public var StickerPack_ErrorNotFound: String { return self._s[114]! } - public var Channel_Info_Subscribers: String { return self._s[115]! } - public func Channel_AdminLog_MessageGroupPreHistoryVisible(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[116]!, self._r[116]!, [_0]) + public func ShareFileTip_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[98]!, self._r[98]!, [_0]) } - public func DialogList_PinLimitError(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Wallet_Configuration_BlockchainIdPlaceholder: String { return self._s[99]! } + public var AccessDenied_LocationDenied: String { return self._s[100]! } + public var CallSettings_RecentCalls: String { return self._s[101]! } + public var ConversationProfile_LeaveDeleteAndExit: String { return self._s[102]! } + public var Channel_Members_AddAdminErrorBlacklisted: String { return self._s[104]! } + public var Passport_Authorize: String { return self._s[105]! } + public var StickerPacksSettings_ArchivedMasks_Info: String { return self._s[106]! } + public var AutoDownloadSettings_Videos: String { return self._s[107]! } + public var TwoStepAuth_ReEnterPasswordTitle: String { return self._s[108]! } + public var Wallet_Info_Send: String { return self._s[109]! } + public var AuthSessions_AddDevice_UrlLoginHint: String { return self._s[110]! } + public var Wallet_TransactionInfo_SendGrams: String { return self._s[111]! } + public var Tour_StartButton: String { return self._s[112]! } + public var Watch_AppName: String { return self._s[114]! } + public var StickerPack_ErrorNotFound: String { return self._s[115]! } + public var Channel_Info_Subscribers: String { return self._s[116]! } + public func Channel_AdminLog_MessageGroupPreHistoryVisible(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[117]!, self._r[117]!, [_0]) } - public var Appearance_RemoveTheme: String { return self._s[118]! } + public func DialogList_PinLimitError(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[118]!, self._r[118]!, [_0]) + } + public var Appearance_RemoveTheme: String { return self._s[119]! } public func Wallet_Info_TransactionBlockchainFee(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[119]!, self._r[119]!, [_0]) + return formatWithArgumentRanges(self._s[120]!, self._r[120]!, [_0]) } - public var Conversation_StopLiveLocation: String { return self._s[122]! } - public var Channel_AdminLogFilter_EventsAll: String { return self._s[123]! } - public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[125]! } - public var Username_LinkCopied: String { return self._s[127]! } - public var GroupRemoved_Title: String { return self._s[128]! } - public var SecretVideo_Title: String { return self._s[129]! } + public var Conversation_StopLiveLocation: String { return self._s[123]! } + public var Channel_AdminLogFilter_EventsAll: String { return self._s[124]! } + public var GroupInfo_InviteLink_CopyAlert_Success: String { return self._s[126]! } + public var Username_LinkCopied: String { return self._s[128]! } + public var GroupRemoved_Title: String { return self._s[129]! } + public var SecretVideo_Title: String { return self._s[130]! } public func PUSH_PINNED_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[130]!, self._r[130]!, [_1]) + return formatWithArgumentRanges(self._s[131]!, self._r[131]!, [_1]) } - public var AccessDenied_PhotosAndVideos: String { return self._s[131]! } - public var Appearance_ThemePreview_Chat_1_Text: String { return self._s[132]! } + public var AccessDenied_PhotosAndVideos: String { return self._s[132]! } + public var Appearance_ThemePreview_Chat_1_Text: String { return self._s[133]! } public func PUSH_CHANNEL_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[134]!, self._r[134]!, [_1]) + return formatWithArgumentRanges(self._s[135]!, self._r[135]!, [_1]) } - public var Map_OpenInGoogleMaps: String { return self._s[136]! } + public var Map_OpenInGoogleMaps: String { return self._s[137]! } public func Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[137]!, self._r[137]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[138]!, self._r[138]!, [_1, _2, _3]) } public func Channel_AdminLog_MessageKickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[138]!, self._r[138]!, [_1, _2]) + return formatWithArgumentRanges(self._s[139]!, self._r[139]!, [_1, _2]) } - public var Call_StatusRinging: String { return self._s[139]! } - public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[140]! } - public var Group_Username_InvalidStartsWithNumber: String { return self._s[141]! } - public var UserInfo_NotificationsEnabled: String { return self._s[142]! } - public var PeopleNearby_MakeVisibleDescription: String { return self._s[143]! } - public var ChatListFolder_CategoryRead: String { return self._s[144]! } - public var Map_Search: String { return self._s[145]! } - public var ClearCache_StorageFree: String { return self._s[147]! } - public var Login_TermsOfServiceHeader: String { return self._s[148]! } + public var Call_StatusRinging: String { return self._s[140]! } + public var SettingsSearch_Synonyms_EditProfile_Username: String { return self._s[141]! } + public var Group_Username_InvalidStartsWithNumber: String { return self._s[142]! } + public var UserInfo_NotificationsEnabled: String { return self._s[143]! } + public var PeopleNearby_MakeVisibleDescription: String { return self._s[144]! } + public var ChatListFolder_CategoryRead: String { return self._s[145]! } + public var Map_Search: String { return self._s[146]! } + public var ClearCache_StorageFree: String { return self._s[148]! } + public var Login_TermsOfServiceHeader: String { return self._s[149]! } public func Notification_PinnedVideoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[149]!, self._r[149]!, [_0]) + return formatWithArgumentRanges(self._s[150]!, self._r[150]!, [_0]) } public func Channel_AdminLog_MessageToggleSignaturesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[151]!, self._r[151]!, [_0]) + return formatWithArgumentRanges(self._s[152]!, self._r[152]!, [_0]) } - public var ChatList_GenericPsaAlert: String { return self._s[152]! } - public var Wallet_Sent_Title: String { return self._s[153]! } - public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[154]! } - public var Weekday_Today: String { return self._s[155]! } - public var Stats_InstantViewInteractionsTitle: String { return self._s[156]! } + public var ChatList_GenericPsaAlert: String { return self._s[153]! } + public var Wallet_Sent_Title: String { return self._s[154]! } + public var TwoStepAuth_SetupPasswordConfirmPassword: String { return self._s[155]! } + public var Weekday_Today: String { return self._s[156]! } + public var Stats_InstantViewInteractionsTitle: String { return self._s[157]! } public func InstantPage_AuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[158]!, self._r[158]!, [_1, _2]) + return formatWithArgumentRanges(self._s[159]!, self._r[159]!, [_1, _2]) } public func Conversation_MessageDialogRetryAll(_ _1: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[159]!, self._r[159]!, ["\(_1)"]) + return formatWithArgumentRanges(self._s[160]!, self._r[160]!, ["\(_1)"]) } - public var Notification_PassportValuePersonalDetails: String { return self._s[161]! } - public var Channel_AdminLog_MessagePreviousLink: String { return self._s[162]! } - public var ChangePhoneNumberNumber_NewNumber: String { return self._s[163]! } - public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[164]! } - public var TwoStepAuth_ChangePasswordDescription: String { return self._s[165]! } - public var PhotoEditor_BlurToolLinear: String { return self._s[166]! } - public var Contacts_PermissionsAllowInSettings: String { return self._s[167]! } - public var Weekday_ShortMonday: String { return self._s[168]! } - public var Cache_KeepMedia: String { return self._s[169]! } - public var Passport_FieldIdentitySelfieHelp: String { return self._s[170]! } + public var Notification_PassportValuePersonalDetails: String { return self._s[162]! } + public var Channel_AdminLog_MessagePreviousLink: String { return self._s[163]! } + public var ChangePhoneNumberNumber_NewNumber: String { return self._s[164]! } + public var ApplyLanguage_LanguageNotSupportedError: String { return self._s[165]! } + public var TwoStepAuth_ChangePasswordDescription: String { return self._s[166]! } + public var PhotoEditor_BlurToolLinear: String { return self._s[167]! } + public var Contacts_PermissionsAllowInSettings: String { return self._s[168]! } + public var Weekday_ShortMonday: String { return self._s[169]! } + public var Cache_KeepMedia: String { return self._s[170]! } + public var Passport_FieldIdentitySelfieHelp: String { return self._s[171]! } public func PUSH_PINNED_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[171]!, self._r[171]!, [_1, _2]) + return formatWithArgumentRanges(self._s[172]!, self._r[172]!, [_1, _2]) } public func Chat_SlowmodeTooltip(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[172]!, self._r[172]!, [_0]) + return formatWithArgumentRanges(self._s[173]!, self._r[173]!, [_0]) } - public var Wallet_Receive_ShareUrlInfo: String { return self._s[173]! } - public var Conversation_ClousStorageInfo_Description4: String { return self._s[174]! } - public var Wallet_RestoreFailed_Title: String { return self._s[175]! } - public var Passport_Language_ru: String { return self._s[176]! } + public var Wallet_Receive_ShareUrlInfo: String { return self._s[174]! } + public var Conversation_ClousStorageInfo_Description4: String { return self._s[175]! } + public var Wallet_RestoreFailed_Title: String { return self._s[176]! } + public var Passport_Language_ru: String { return self._s[177]! } public func Notification_CreatedChatWithTitle(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[177]!, self._r[177]!, [_0, _1]) + return formatWithArgumentRanges(self._s[178]!, self._r[178]!, [_0, _1]) } - public var WallpaperPreview_PatternIntensity: String { return self._s[178]! } - public var ChatList_EditFolder: String { return self._s[181]! } - public var WebBrowser_InAppSafari: String { return self._s[182]! } - public var TwoStepAuth_RecoveryUnavailable: String { return self._s[183]! } - public var EnterPasscode_TouchId: String { return self._s[184]! } - public var PhotoEditor_QualityVeryHigh: String { return self._s[187]! } - public var Checkout_NewCard_SaveInfo: String { return self._s[189]! } - public var Gif_NoGifsPlaceholder: String { return self._s[191]! } + public var WallpaperPreview_PatternIntensity: String { return self._s[179]! } + public var ChatList_EditFolder: String { return self._s[182]! } + public var WebBrowser_InAppSafari: String { return self._s[183]! } + public var TwoStepAuth_RecoveryUnavailable: String { return self._s[184]! } + public var EnterPasscode_TouchId: String { return self._s[185]! } + public var PhotoEditor_QualityVeryHigh: String { return self._s[188]! } + public var Checkout_NewCard_SaveInfo: String { return self._s[190]! } + public var Gif_NoGifsPlaceholder: String { return self._s[192]! } public func Notification_InvitedMultiple(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[193]!, self._r[193]!, [_0, _1]) + return formatWithArgumentRanges(self._s[194]!, self._r[194]!, [_0, _1]) } - public var ChatSettings_AutoDownloadEnabled: String { return self._s[194]! } - public var NetworkUsageSettings_BytesSent: String { return self._s[195]! } - public var Checkout_PasswordEntry_Pay: String { return self._s[196]! } - public var AuthSessions_TerminateSession: String { return self._s[197]! } - public var Message_File: String { return self._s[198]! } - public var MediaPicker_VideoMuteDescription: String { return self._s[199]! } - public var SocksProxySetup_ProxyStatusConnected: String { return self._s[200]! } - public var TwoStepAuth_RecoveryCode: String { return self._s[201]! } - public var EnterPasscode_EnterCurrentPasscode: String { return self._s[202]! } + public var ChatSettings_AutoDownloadEnabled: String { return self._s[195]! } + public var NetworkUsageSettings_BytesSent: String { return self._s[196]! } + public var Checkout_PasswordEntry_Pay: String { return self._s[197]! } + public var AuthSessions_TerminateSession: String { return self._s[198]! } + public var Message_File: String { return self._s[199]! } + public var MediaPicker_VideoMuteDescription: String { return self._s[200]! } + public var SocksProxySetup_ProxyStatusConnected: String { return self._s[201]! } + public var TwoStepAuth_RecoveryCode: String { return self._s[202]! } + public var EnterPasscode_EnterCurrentPasscode: String { return self._s[203]! } public func TwoStepAuth_EnterPasswordHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[203]!, self._r[203]!, [_0]) + return formatWithArgumentRanges(self._s[204]!, self._r[204]!, [_0]) } - public var Conversation_Moderate_Report: String { return self._s[205]! } - public var TwoStepAuth_EmailInvalid: String { return self._s[206]! } - public var Passport_Language_ms: String { return self._s[207]! } - public var Channel_Edit_AboutItem: String { return self._s[209]! } - public var DialogList_SearchSectionGlobal: String { return self._s[213]! } - public var AttachmentMenu_WebSearch: String { return self._s[214]! } - public var ChatState_WaitingForNetwork: String { return self._s[215]! } - public var Channel_BanUser_Title: String { return self._s[216]! } - public var PasscodeSettings_TurnPasscodeOn: String { return self._s[217]! } - public var WallpaperPreview_SwipeTopText: String { return self._s[218]! } - public var ChatList_DeleteSavedMessagesConfirmationText: String { return self._s[219]! } - public var ArchivedChats_IntroText2: String { return self._s[220]! } - public var ChatSearch_SearchPlaceholder: String { return self._s[222]! } - public var Conversation_OpenBotLinkTitle: String { return self._s[223]! } - public var Passport_FieldAddressTranslationHelp: String { return self._s[224]! } - public var NotificationsSound_Aurora: String { return self._s[225]! } - public var Notification_Exceptions_DeleteAll: String { return self._s[226]! } + public var Conversation_Moderate_Report: String { return self._s[206]! } + public var TwoStepAuth_EmailInvalid: String { return self._s[207]! } + public var Passport_Language_ms: String { return self._s[208]! } + public var Channel_Edit_AboutItem: String { return self._s[210]! } + public var DialogList_SearchSectionGlobal: String { return self._s[214]! } + public var AttachmentMenu_WebSearch: String { return self._s[215]! } + public var ChatState_WaitingForNetwork: String { return self._s[216]! } + public var Channel_BanUser_Title: String { return self._s[217]! } + public var PasscodeSettings_TurnPasscodeOn: String { return self._s[218]! } + public var WallpaperPreview_SwipeTopText: String { return self._s[219]! } + public var ChatList_DeleteSavedMessagesConfirmationText: String { return self._s[220]! } + public var ArchivedChats_IntroText2: String { return self._s[221]! } + public var ChatSearch_SearchPlaceholder: String { return self._s[223]! } + public var Conversation_OpenBotLinkTitle: String { return self._s[224]! } + public var Passport_FieldAddressTranslationHelp: String { return self._s[225]! } + public var NotificationsSound_Aurora: String { return self._s[226]! } + public var Notification_Exceptions_DeleteAll: String { return self._s[227]! } public func FileSize_GB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[227]!, self._r[227]!, [_0]) + return formatWithArgumentRanges(self._s[228]!, self._r[228]!, [_0]) } - public var AuthSessions_LoggedInWithTelegram: String { return self._s[230]! } + public var AuthSessions_LoggedInWithTelegram: String { return self._s[231]! } public func Privacy_GroupsAndChannels_InviteToGroupError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[231]!, self._r[231]!, [_0, _1]) + return formatWithArgumentRanges(self._s[232]!, self._r[232]!, [_0, _1]) } - public var Passport_PasswordNext: String { return self._s[232]! } - public var Bot_GroupStatusReadsHistory: String { return self._s[233]! } - public var EmptyGroupInfo_Line2: String { return self._s[234]! } + public var Passport_PasswordNext: String { return self._s[233]! } + public var Bot_GroupStatusReadsHistory: String { return self._s[234]! } + public var EmptyGroupInfo_Line2: String { return self._s[235]! } public func Channel_AdminLog_MessageTransferedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[235]!, self._r[235]!, [_1, _2]) + return formatWithArgumentRanges(self._s[236]!, self._r[236]!, [_1, _2]) } - public var VoiceOver_Chat_SeenByRecipients: String { return self._s[236]! } - public var Settings_FAQ_Intro: String { return self._s[239]! } - public var PrivacySettings_PasscodeAndTouchId: String { return self._s[241]! } - public var FeaturedStickerPacks_Title: String { return self._s[242]! } - public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[244]! } - public var Username_Title: String { return self._s[245]! } + public var VoiceOver_Chat_SeenByRecipients: String { return self._s[237]! } + public var Settings_FAQ_Intro: String { return self._s[240]! } + public var PrivacySettings_PasscodeAndTouchId: String { return self._s[242]! } + public var FeaturedStickerPacks_Title: String { return self._s[243]! } + public var TwoStepAuth_PasswordRemoveConfirmation: String { return self._s[245]! } + public var Username_Title: String { return self._s[246]! } public func Message_StickerText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[246]!, self._r[246]!, [_0]) + return formatWithArgumentRanges(self._s[247]!, self._r[247]!, [_0]) } - public var PeerInfo_PaneFiles: String { return self._s[247]! } - public var PasscodeSettings_AlphanumericCode: String { return self._s[248]! } - public var Localization_LanguageOther: String { return self._s[249]! } - public var Stickers_SuggestStickers: String { return self._s[250]! } + public var PeerInfo_PaneFiles: String { return self._s[248]! } + public var PasscodeSettings_AlphanumericCode: String { return self._s[249]! } + public var Localization_LanguageOther: String { return self._s[250]! } + public var Stickers_SuggestStickers: String { return self._s[251]! } public func Channel_AdminLog_MessageRemovedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[251]!, self._r[251]!, [_0]) + return formatWithArgumentRanges(self._s[252]!, self._r[252]!, [_0]) } - public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[252]! } - public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[253]! } - public var Conversation_DefaultRestrictedStickers: String { return self._s[254]! } + public var NotificationSettings_ShowNotificationsFromAccountsSection: String { return self._s[253]! } + public var Channel_AdminLogFilter_EventsAdmins: String { return self._s[254]! } + public var Conversation_DefaultRestrictedStickers: String { return self._s[255]! } public func Notification_PinnedDeletedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[255]!, self._r[255]!, [_0]) + return formatWithArgumentRanges(self._s[256]!, self._r[256]!, [_0]) } - public var Wallet_TransactionInfo_CopyAddress: String { return self._s[257]! } - public var Group_UpgradeConfirmation: String { return self._s[258]! } - public var DialogList_Unpin: String { return self._s[259]! } - public var Passport_Identity_DateOfBirth: String { return self._s[260]! } - public var Month_ShortOctober: String { return self._s[261]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[262]! } - public var TwoFactorSetup_Done_Text: String { return self._s[263]! } - public var Notification_CallCanceledShort: String { return self._s[264]! } - public var Conversation_StopQuiz: String { return self._s[265]! } - public var Passport_Phone_Help: String { return self._s[266]! } - public var Passport_Language_az: String { return self._s[268]! } - public var CreatePoll_TextPlaceholder: String { return self._s[270]! } - public var VoiceOver_Chat_AnonymousPoll: String { return self._s[271]! } - public var Passport_Identity_DocumentNumber: String { return self._s[272]! } - public var PhotoEditor_CurvesRed: String { return self._s[273]! } - public var PhoneNumberHelp_Alert: String { return self._s[275]! } - public var SocksProxySetup_Port: String { return self._s[276]! } - public var Checkout_PayNone: String { return self._s[277]! } - public var AutoDownloadSettings_WiFi: String { return self._s[278]! } - public var GroupInfo_GroupType: String { return self._s[279]! } - public var StickerSettings_ContextHide: String { return self._s[280]! } - public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[281]! } - public var Group_Setup_HistoryTitle: String { return self._s[283]! } - public var Passport_Identity_FilesUploadNew: String { return self._s[284]! } - public var PasscodeSettings_AutoLock: String { return self._s[285]! } - public var Passport_Title: String { return self._s[286]! } - public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[287]! } - public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[288]! } - public var GroupPermission_NoSendGifs: String { return self._s[289]! } - public var PrivacySettings_PasscodeOn: String { return self._s[290]! } + public var Wallet_TransactionInfo_CopyAddress: String { return self._s[258]! } + public var Group_UpgradeConfirmation: String { return self._s[259]! } + public var DialogList_Unpin: String { return self._s[260]! } + public var Passport_Identity_DateOfBirth: String { return self._s[261]! } + public var Month_ShortOctober: String { return self._s[262]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsSync: String { return self._s[263]! } + public var TwoFactorSetup_Done_Text: String { return self._s[264]! } + public var Notification_CallCanceledShort: String { return self._s[265]! } + public var Conversation_StopQuiz: String { return self._s[266]! } + public var Passport_Phone_Help: String { return self._s[267]! } + public var Passport_Language_az: String { return self._s[269]! } + public var CreatePoll_TextPlaceholder: String { return self._s[271]! } + public var VoiceOver_Chat_AnonymousPoll: String { return self._s[272]! } + public var Passport_Identity_DocumentNumber: String { return self._s[273]! } + public var PhotoEditor_CurvesRed: String { return self._s[274]! } + public var PhoneNumberHelp_Alert: String { return self._s[276]! } + public var SocksProxySetup_Port: String { return self._s[277]! } + public var Checkout_PayNone: String { return self._s[278]! } + public var AutoDownloadSettings_WiFi: String { return self._s[279]! } + public var GroupInfo_GroupType: String { return self._s[280]! } + public var StickerSettings_ContextHide: String { return self._s[281]! } + public var Passport_Address_OneOfTypeTemporaryRegistration: String { return self._s[282]! } + public var Group_Setup_HistoryTitle: String { return self._s[284]! } + public var Passport_Identity_FilesUploadNew: String { return self._s[285]! } + public var PasscodeSettings_AutoLock: String { return self._s[286]! } + public var Passport_Title: String { return self._s[287]! } + public var VoiceOver_Chat_ContactPhoneNumber: String { return self._s[288]! } + public var Channel_AdminLogFilter_EventsNewSubscribers: String { return self._s[289]! } + public var GroupPermission_NoSendGifs: String { return self._s[290]! } + public var PrivacySettings_PasscodeOn: String { return self._s[291]! } public func Conversation_ScheduleMessage_SendTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[291]!, self._r[291]!, [_0]) + return formatWithArgumentRanges(self._s[292]!, self._r[292]!, [_0]) } - public var ChatList_PeerTypeNonContact: String { return self._s[294]! } - public var State_WaitingForNetwork: String { return self._s[295]! } + public var ChatList_PeerTypeNonContact: String { return self._s[295]! } + public var State_WaitingForNetwork: String { return self._s[296]! } public func Notification_Invited(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[296]!, self._r[296]!, [_0, _1]) + return formatWithArgumentRanges(self._s[297]!, self._r[297]!, [_0, _1]) } - public var Calls_NotNow: String { return self._s[298]! } + public var Calls_NotNow: String { return self._s[299]! } public func Channel_DiscussionGroup_HeaderSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[299]!, self._r[299]!, [_0]) + return formatWithArgumentRanges(self._s[300]!, self._r[300]!, [_0]) } - public var UserInfo_SendMessage: String { return self._s[300]! } - public var TwoStepAuth_PasswordSet: String { return self._s[301]! } - public var Passport_DeleteDocument: String { return self._s[302]! } - public var SocksProxySetup_AddProxyTitle: String { return self._s[303]! } + public var UserInfo_SendMessage: String { return self._s[301]! } + public var TwoStepAuth_PasswordSet: String { return self._s[302]! } + public var Passport_DeleteDocument: String { return self._s[303]! } + public var SocksProxySetup_AddProxyTitle: String { return self._s[304]! } public func PUSH_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[304]!, self._r[304]!, [_1]) + return formatWithArgumentRanges(self._s[305]!, self._r[305]!, [_1]) } - public var AuthSessions_AddedDeviceTitle: String { return self._s[305]! } - public var GroupRemoved_Remove: String { return self._s[306]! } - public var Passport_FieldIdentity: String { return self._s[307]! } - public var Group_Setup_TypePrivateHelp: String { return self._s[308]! } - public var Conversation_Processing: String { return self._s[311]! } - public var Wallet_Settings_BackupWallet: String { return self._s[313]! } - public var ChatListFolder_NameNonMuted: String { return self._s[314]! } - public var ChatSettings_AutoPlayAnimations: String { return self._s[315]! } - public var AuthSessions_LogOutApplicationsHelp: String { return self._s[318]! } - public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[319]! } - public var Month_GenFebruary: String { return self._s[320]! } - public var ChatListFilter_AddChatsTitle: String { return self._s[321]! } - public var Wallet_Send_NetworkErrorTitle: String { return self._s[322]! } + public var AuthSessions_AddedDeviceTitle: String { return self._s[306]! } + public var GroupRemoved_Remove: String { return self._s[307]! } + public var Passport_FieldIdentity: String { return self._s[308]! } + public var Group_Setup_TypePrivateHelp: String { return self._s[309]! } + public var Conversation_Processing: String { return self._s[312]! } + public var Wallet_Settings_BackupWallet: String { return self._s[314]! } + public var ChatListFolder_NameNonMuted: String { return self._s[315]! } + public var ChatSettings_AutoPlayAnimations: String { return self._s[316]! } + public var AuthSessions_LogOutApplicationsHelp: String { return self._s[319]! } + public var Forward_ErrorPublicQuizDisabledInChannels: String { return self._s[320]! } + public var Month_GenFebruary: String { return self._s[321]! } + public var ChatListFilter_AddChatsTitle: String { return self._s[322]! } + public var Wallet_Send_NetworkErrorTitle: String { return self._s[323]! } public func Login_InvalidPhoneEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[324]!, self._r[324]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[325]!, self._r[325]!, [_1, _2, _3, _4, _5]) } - public var Passport_Identity_TypeIdentityCard: String { return self._s[325]! } - public var Wallet_Month_ShortJune: String { return self._s[327]! } - public var AutoDownloadSettings_DataUsageMedium: String { return self._s[328]! } - public var GroupInfo_AddParticipant: String { return self._s[329]! } - public var KeyCommand_SendMessage: String { return self._s[330]! } - public var VoiceOver_Chat_YourContact: String { return self._s[332]! } - public var Map_LiveLocationShowAll: String { return self._s[333]! } - public var WallpaperSearch_ColorOrange: String { return self._s[335]! } - public var Appearance_AppIconDefaultX: String { return self._s[336]! } - public var Checkout_Receipt_Title: String { return self._s[337]! } - public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[338]! } - public var WallpaperPreview_PreviewTopText: String { return self._s[339]! } - public var Message_Contact: String { return self._s[340]! } - public var Call_StatusIncoming: String { return self._s[341]! } - public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[342]! } + public var Passport_Identity_TypeIdentityCard: String { return self._s[326]! } + public var Wallet_Month_ShortJune: String { return self._s[328]! } + public var AutoDownloadSettings_DataUsageMedium: String { return self._s[329]! } + public var GroupInfo_AddParticipant: String { return self._s[330]! } + public var KeyCommand_SendMessage: String { return self._s[331]! } + public var VoiceOver_Chat_YourContact: String { return self._s[333]! } + public var Map_LiveLocationShowAll: String { return self._s[334]! } + public var WallpaperSearch_ColorOrange: String { return self._s[336]! } + public var Appearance_AppIconDefaultX: String { return self._s[337]! } + public var Checkout_Receipt_Title: String { return self._s[338]! } + public var Group_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[339]! } + public var WallpaperPreview_PreviewTopText: String { return self._s[340]! } + public var Message_Contact: String { return self._s[341]! } + public var Call_StatusIncoming: String { return self._s[342]! } + public var Wallet_TransactionInfo_StorageFeeInfo: String { return self._s[343]! } public func Channel_AdminLog_MessageKickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[343]!, self._r[343]!, [_1]) + return formatWithArgumentRanges(self._s[344]!, self._r[344]!, [_1]) } public func PUSH_ENCRYPTED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[345]!, self._r[345]!, [_1]) + return formatWithArgumentRanges(self._s[346]!, self._r[346]!, [_1]) } - public var VoiceOver_Media_PlaybackRate: String { return self._s[346]! } - public var Passport_FieldIdentityDetailsHelp: String { return self._s[347]! } - public var Conversation_ViewChannel: String { return self._s[348]! } + public var VoiceOver_Media_PlaybackRate: String { return self._s[347]! } + public var Passport_FieldIdentityDetailsHelp: String { return self._s[348]! } + public var Conversation_ViewChannel: String { return self._s[349]! } public func Time_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[349]!, self._r[349]!, [_0]) + return formatWithArgumentRanges(self._s[350]!, self._r[350]!, [_0]) } - public var Theme_Colors_Accent: String { return self._s[350]! } - public var Passport_Language_nl: String { return self._s[352]! } - public var Camera_Retake: String { return self._s[353]! } + public var Theme_Colors_Accent: String { return self._s[351]! } + public var Paint_Arrow: String { return self._s[352]! } + public var Passport_Language_nl: String { return self._s[354]! } + public var Camera_Retake: String { return self._s[355]! } public func UserInfo_BlockActionTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[354]!, self._r[354]!, [_0]) + return formatWithArgumentRanges(self._s[356]!, self._r[356]!, [_0]) } - public var AuthSessions_LogOutApplications: String { return self._s[355]! } - public var ApplyLanguage_ApplySuccess: String { return self._s[356]! } - public var Tour_Title6: String { return self._s[357]! } - public var Map_ChooseAPlace: String { return self._s[358]! } - public var CallSettings_Never: String { return self._s[360]! } + public var AuthSessions_LogOutApplications: String { return self._s[357]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[358]! } + public var Tour_Title6: String { return self._s[359]! } + public var Map_ChooseAPlace: String { return self._s[360]! } + public var CallSettings_Never: String { return self._s[362]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[361]!, self._r[361]!, [_0]) - } - public var ChannelRemoved_RemoveInfo: String { return self._s[362]! } - public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[363]!, self._r[363]!, [_0]) } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[364]! } - public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + public var ChannelRemoved_RemoveInfo: String { return self._s[364]! } + public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[365]!, self._r[365]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[366]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[366]! } + public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[367]!, self._r[367]!, [_0]) + } + public var GroupInfo_InviteLink_Title: String { return self._s[368]! } public func Channel_AdminLog_MessageUnkickedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[367]!, self._r[367]!, [_1, _2]) + return formatWithArgumentRanges(self._s[369]!, self._r[369]!, [_1, _2]) } - public var KeyCommand_ScrollUp: String { return self._s[368]! } - public var ContactInfo_URLLabelHomepage: String { return self._s[369]! } - public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[370]! } + public var KeyCommand_ScrollUp: String { return self._s[370]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[371]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[372]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[371]!, self._r[371]!, [_0]) - } - public var TwoFactorSetup_Done_Title: String { return self._s[372]! } - public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[373]!, self._r[373]!, [_0]) } - public var CallFeedback_ReasonDistortedSpeech: String { return self._s[374]! } - public var Watch_LastSeen_WithinAWeek: String { return self._s[375]! } - public var ContactList_Context_SendMessage: String { return self._s[377]! } - public var Weekday_Tuesday: String { return self._s[378]! } - public var Wallet_Created_Title: String { return self._s[380]! } - public var ScheduledMessages_Delete: String { return self._s[381]! } - public var UserInfo_StartSecretChat: String { return self._s[382]! } - public var Passport_Identity_FilesTitle: String { return self._s[383]! } - public var Permissions_NotificationsAllow_v0: String { return self._s[384]! } - public var DialogList_DeleteConversationConfirmation: String { return self._s[386]! } - public var ChatList_UndoArchiveRevealedTitle: String { return self._s[387]! } + public var TwoFactorSetup_Done_Title: String { return self._s[374]! } + public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[375]!, self._r[375]!, [_0]) + } + public var CallFeedback_ReasonDistortedSpeech: String { return self._s[376]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[377]! } + public var ContactList_Context_SendMessage: String { return self._s[379]! } + public var Weekday_Tuesday: String { return self._s[380]! } + public var Wallet_Created_Title: String { return self._s[382]! } + public var ScheduledMessages_Delete: String { return self._s[383]! } + public var UserInfo_StartSecretChat: String { return self._s[384]! } + public var Passport_Identity_FilesTitle: String { return self._s[385]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[386]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[388]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[389]! } public func Wallet_Configuration_ApplyErrorTextURLUnreachable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[388]!, self._r[388]!, [_0]) + return formatWithArgumentRanges(self._s[390]!, self._r[390]!, [_0]) } - public var AuthSessions_Sessions: String { return self._s[389]! } + public var AuthSessions_Sessions: String { return self._s[391]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[391]!, self._r[391]!, [_0]) + return formatWithArgumentRanges(self._s[393]!, self._r[393]!, [_0]) } - public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[392]! } - public var Call_StatusWaiting: String { return self._s[393]! } - public var CreateGroup_SoftUserLimitAlert: String { return self._s[394]! } - public var FastTwoStepSetup_HintHelp: String { return self._s[395]! } - public var WallpaperPreview_CustomColorBottomText: String { return self._s[396]! } - public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[397]! } - public var LogoutOptions_AddAccountText: String { return self._s[398]! } - public var PasscodeSettings_6DigitCode: String { return self._s[399]! } - public var Settings_LogoutConfirmationText: String { return self._s[400]! } - public var Passport_Identity_TypePassport: String { return self._s[402]! } - public var Map_Work: String { return self._s[405]! } + public var TwoStepAuth_RecoveryEmailChangeDescription: String { return self._s[394]! } + public var Call_StatusWaiting: String { return self._s[395]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[396]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[397]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[398]! } + public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[399]! } + public var LogoutOptions_AddAccountText: String { return self._s[400]! } + public var PasscodeSettings_6DigitCode: String { return self._s[401]! } + public var Settings_LogoutConfirmationText: String { return self._s[402]! } + public var Passport_Identity_TypePassport: String { return self._s[404]! } + public var Map_Work: String { return self._s[407]! } public func PUSH_MESSAGE_VIDEOS(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[406]!, self._r[406]!, [_1, _2]) + return formatWithArgumentRanges(self._s[408]!, self._r[408]!, [_1, _2]) } - public var SocksProxySetup_SaveProxy: String { return self._s[407]! } - public var AccessDenied_SaveMedia: String { return self._s[408]! } - public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[410]! } - public var CreatePoll_MultipleChoice: String { return self._s[411]! } - public var Settings_Title: String { return self._s[413]! } - public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[414]! } - public var Contacts_InviteSearchLabel: String { return self._s[416]! } - public var PrivacySettings_WebSessions: String { return self._s[417]! } - public var ConvertToSupergroup_Title: String { return self._s[418]! } + public var SocksProxySetup_SaveProxy: String { return self._s[409]! } + public var AccessDenied_SaveMedia: String { return self._s[410]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[412]! } + public var CreatePoll_MultipleChoice: String { return self._s[413]! } + public var Settings_Title: String { return self._s[415]! } + public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[416]! } + public var Contacts_InviteSearchLabel: String { return self._s[418]! } + public var PrivacySettings_WebSessions: String { return self._s[419]! } + public var ConvertToSupergroup_Title: String { return self._s[420]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[419]!, self._r[419]!, [_0]) + return formatWithArgumentRanges(self._s[421]!, self._r[421]!, [_0]) } - public var TwoFactorSetup_Hint_Text: String { return self._s[420]! } - public var InfoPlist_NSSiriUsageDescription: String { return self._s[421]! } + public var TwoFactorSetup_Hint_Text: String { return self._s[422]! } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[423]! } public func PUSH_MESSAGE_CHANNEL_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[422]!, self._r[422]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[424]!, self._r[424]!, [_1, _2, _3]) } - public var ChatSettings_AutomaticPhotoDownload: String { return self._s[423]! } - public var UserInfo_BotHelp: String { return self._s[424]! } - public var PrivacySettings_LastSeenEverybody: String { return self._s[425]! } - public var Checkout_Name: String { return self._s[426]! } - public var AutoDownloadSettings_DataUsage: String { return self._s[427]! } - public var Channel_BanUser_BlockFor: String { return self._s[428]! } - public var Checkout_ShippingAddress: String { return self._s[429]! } - public var AutoDownloadSettings_MaxVideoSize: String { return self._s[430]! } - public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[431]! } - public var Privacy_Forwards: String { return self._s[432]! } - public var Channel_BanUser_PermissionSendPolls: String { return self._s[433]! } - public var Appearance_ThemeCarouselNewNight: String { return self._s[434]! } + public var ChatSettings_AutomaticPhotoDownload: String { return self._s[425]! } + public var UserInfo_BotHelp: String { return self._s[426]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[427]! } + public var Checkout_Name: String { return self._s[428]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[429]! } + public var Channel_BanUser_BlockFor: String { return self._s[430]! } + public var Checkout_ShippingAddress: String { return self._s[431]! } + public var AutoDownloadSettings_MaxVideoSize: String { return self._s[432]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[433]! } + public var Privacy_Forwards: String { return self._s[434]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[435]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[436]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[437]!, self._r[437]!, [_0]) + return formatWithArgumentRanges(self._s[439]!, self._r[439]!, [_0]) } - public var Contacts_SortedByName: String { return self._s[438]! } - public var Group_OwnershipTransfer_Title: String { return self._s[439]! } - public var PeerInfo_BioExpand: String { return self._s[441]! } - public var VoiceOver_Chat_OpenHint: String { return self._s[442]! } - public var Group_LeaveGroup: String { return self._s[443]! } - public var Settings_UsernameEmpty: String { return self._s[444]! } + public var Contacts_SortedByName: String { return self._s[440]! } + public var Group_OwnershipTransfer_Title: String { return self._s[441]! } + public var PeerInfo_BioExpand: String { return self._s[443]! } + public var VoiceOver_Chat_OpenHint: String { return self._s[444]! } + public var Group_LeaveGroup: String { return self._s[445]! } + public var Settings_UsernameEmpty: String { return self._s[446]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[445]!, self._r[445]!, [_0]) + return formatWithArgumentRanges(self._s[447]!, self._r[447]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[446]!, self._r[446]!, [_1]) + return formatWithArgumentRanges(self._s[448]!, self._r[448]!, [_1]) } public func Channel_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[447]!, self._r[447]!, [_1, _2]) + return formatWithArgumentRanges(self._s[449]!, self._r[449]!, [_1, _2]) } - public var Message_ImageExpired: String { return self._s[448]! } - public var TwoStepAuth_RecoveryFailed: String { return self._s[450]! } - public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[451]! } - public var UserInfo_AddToExisting: String { return self._s[452]! } - public var TwoStepAuth_EnabledSuccess: String { return self._s[453]! } - public var Wallet_Send_SyncInProgress: String { return self._s[454]! } - public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[455]! } - public var ChatListFolder_IncludeSectionInfo: String { return self._s[456]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[457]! } + public var Message_ImageExpired: String { return self._s[450]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[452]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[453]! } + public var UserInfo_AddToExisting: String { return self._s[454]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[455]! } + public var Wallet_Send_SyncInProgress: String { return self._s[456]! } + public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[457]! } + public var ChatListFolder_IncludeSectionInfo: String { return self._s[458]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[459]! } public func PUSH_CHANNEL_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[458]!, self._r[458]!, [_1]) + return formatWithArgumentRanges(self._s[460]!, self._r[460]!, [_1]) } - public var Notifications_GroupNotificationsAlert: String { return self._s[459]! } - public var Passport_Language_km: String { return self._s[460]! } - public var SocksProxySetup_AdNoticeHelp: String { return self._s[462]! } - public var VoiceOver_Media_PlaybackPlay: String { return self._s[463]! } - public var Notification_CallMissedShort: String { return self._s[464]! } - public var Wallet_Info_YourBalance: String { return self._s[465]! } - public var ReportPeer_ReasonOther_Send: String { return self._s[467]! } - public var Watch_Compose_Send: String { return self._s[468]! } - public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[471]! } - public var TwoFactorSetup_Email_Action: String { return self._s[472]! } - public var Conversation_HoldForVideo: String { return self._s[473]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[474]! } - public var AuthSessions_OtherDevices: String { return self._s[475]! } - public var Wallet_TransactionInfo_CommentHeader: String { return self._s[476]! } - public var CheckoutInfo_ErrorCityInvalid: String { return self._s[478]! } - public var Appearance_AutoNightThemeDisabled: String { return self._s[480]! } - public var Channel_LinkItem: String { return self._s[481]! } + public var Notifications_GroupNotificationsAlert: String { return self._s[461]! } + public var Passport_Language_km: String { return self._s[462]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[464]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[465]! } + public var Notification_CallMissedShort: String { return self._s[466]! } + public var Wallet_Info_YourBalance: String { return self._s[467]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[469]! } + public var Watch_Compose_Send: String { return self._s[470]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[473]! } + public var TwoFactorSetup_Email_Action: String { return self._s[474]! } + public var Conversation_HoldForVideo: String { return self._s[475]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[476]! } + public var AuthSessions_OtherDevices: String { return self._s[477]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[478]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[480]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[482]! } + public var Channel_LinkItem: String { return self._s[483]! } public func PrivacySettings_LastSeenContactsMinusPlus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[482]!, self._r[482]!, [_0, _1]) + return formatWithArgumentRanges(self._s[484]!, self._r[484]!, [_0, _1]) } public func Passport_Identity_NativeNameTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[485]!, self._r[485]!, [_0]) + return formatWithArgumentRanges(self._s[487]!, self._r[487]!, [_0]) } - public var VoiceOver_Recording_StopAndPreview: String { return self._s[486]! } - public var Passport_Language_dv: String { return self._s[487]! } - public var Undo_LeftChannel: String { return self._s[488]! } - public var Notifications_ExceptionsMuted: String { return self._s[489]! } - public var ChatList_UnhideAction: String { return self._s[490]! } - public var Conversation_ContextMenuShare: String { return self._s[491]! } - public var Conversation_ContextMenuStickerPackInfo: String { return self._s[492]! } - public var ShareFileTip_Title: String { return self._s[493]! } - public var NotificationsSound_Chord: String { return self._s[494]! } - public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[495]! } + public var VoiceOver_Recording_StopAndPreview: String { return self._s[488]! } + public var Passport_Language_dv: String { return self._s[489]! } + public var Undo_LeftChannel: String { return self._s[490]! } + public var Notifications_ExceptionsMuted: String { return self._s[491]! } + public var ChatList_UnhideAction: String { return self._s[492]! } + public var Conversation_ContextMenuShare: String { return self._s[493]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[494]! } + public var ShareFileTip_Title: String { return self._s[495]! } + public var NotificationsSound_Chord: String { return self._s[496]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[497]! } public func PUSH_CHAT_RETURNED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[496]!, self._r[496]!, [_1, _2]) + return formatWithArgumentRanges(self._s[498]!, self._r[498]!, [_1, _2]) } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[497]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[499]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[498]!, self._r[498]!, [_0]) + return formatWithArgumentRanges(self._s[500]!, self._r[500]!, [_0]) } public func Wallet_Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[499]!, self._r[499]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[501]!, self._r[501]!, [_1, _2, _3]) } - public var Wallet_Settings_ConfigurationInfo: String { return self._s[500]! } - public var Wallpaper_ErrorNotFound: String { return self._s[501]! } - public var Notification_CallOutgoingShort: String { return self._s[503]! } - public var Wallet_WordImport_IncorrectText: String { return self._s[504]! } + public var Wallet_Settings_ConfigurationInfo: String { return self._s[502]! } + public var Wallpaper_ErrorNotFound: String { return self._s[503]! } + public var Notification_CallOutgoingShort: String { return self._s[505]! } + public var Wallet_WordImport_IncorrectText: String { return self._s[506]! } public func Watch_Time_ShortFullAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[505]!, self._r[505]!, [_1, _2]) + return formatWithArgumentRanges(self._s[507]!, self._r[507]!, [_1, _2]) } - public var Passport_Address_TypeUtilityBill: String { return self._s[506]! } - public var Privacy_Forwards_LinkIfAllowed: String { return self._s[507]! } - public var ReportPeer_Report: String { return self._s[508]! } - public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[509]! } - public var GroupInfo_DeactivatedStatus: String { return self._s[510]! } + public var Passport_Address_TypeUtilityBill: String { return self._s[508]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[509]! } + public var ReportPeer_Report: String { return self._s[510]! } + public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[511]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[512]! } public func VoiceOver_Chat_MusicTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[511]!, self._r[511]!, [_1, _2]) + return formatWithArgumentRanges(self._s[513]!, self._r[513]!, [_1, _2]) } - public var StickerPack_Send: String { return self._s[512]! } - public var Login_CodeSentInternal: String { return self._s[513]! } - public var Wallet_Month_GenJanuary: String { return self._s[514]! } - public var GroupInfo_InviteLink_LinkSection: String { return self._s[515]! } + public var StickerPack_Send: String { return self._s[514]! } + public var Login_CodeSentInternal: String { return self._s[515]! } + public var Wallet_Month_GenJanuary: String { return self._s[516]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[517]! } public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[516]!, self._r[516]!, [_0]) - } - public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[518]!, self._r[518]!, [_0]) } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[519]! } - public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[520]!, self._r[520]!, [_1]) + public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[520]!, self._r[520]!, [_0]) } - public var ReportPeer_ReasonViolence: String { return self._s[522]! } - public var Appearance_ShareThemeColor: String { return self._s[523]! } - public var Map_Locating: String { return self._s[524]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[521]! } + public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[522]!, self._r[522]!, [_1]) + } + public var ReportPeer_ReasonViolence: String { return self._s[524]! } + public var Appearance_ShareThemeColor: String { return self._s[525]! } + public var Map_Locating: String { return self._s[526]! } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[525]!, self._r[525]!, [_0]) + return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_0]) } public func PUSH_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[526]!, self._r[526]!, [_1]) + return formatWithArgumentRanges(self._s[528]!, self._r[528]!, [_1]) } - public var ChatListFolderSettings_FoldersSection: String { return self._s[527]! } - public var AutoDownloadSettings_GroupChats: String { return self._s[529]! } - public var CheckoutInfo_SaveInfo: String { return self._s[530]! } - public var ChatList_ChatTypesSection: String { return self._s[531]! } - public var SharedMedia_EmptyLinksText: String { return self._s[533]! } - public var Passport_Address_CityPlaceholder: String { return self._s[534]! } - public var CheckoutInfo_ErrorStateInvalid: String { return self._s[535]! } - public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[536]! } - public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[538]! } - public var Channel_AdminLog_CanAddAdmins: String { return self._s[539]! } + public var ChatListFolderSettings_FoldersSection: String { return self._s[529]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[531]! } + public var CheckoutInfo_SaveInfo: String { return self._s[532]! } + public var ChatList_ChatTypesSection: String { return self._s[533]! } + public var SharedMedia_EmptyLinksText: String { return self._s[535]! } + public var Passport_Address_CityPlaceholder: String { return self._s[536]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[537]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[538]! } + public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[540]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[541]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[540]!, self._r[540]!, [_1]) + return formatWithArgumentRanges(self._s[542]!, self._r[542]!, [_1]) } public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_0]) + return formatWithArgumentRanges(self._s[543]!, self._r[543]!, [_0]) } - public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[542]! } - public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[543]! } - public var ChangePhoneNumberCode_Code: String { return self._s[544]! } - public var Appearance_CreateTheme: String { return self._s[545]! } + public var InfoPlist_NSLocationWhenInUseUsageDescription: String { return self._s[544]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[545]! } + public var ChangePhoneNumberCode_Code: String { return self._s[546]! } + public var Appearance_CreateTheme: String { return self._s[547]! } public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[546]!, self._r[546]!, [_0]) + return formatWithArgumentRanges(self._s[548]!, self._r[548]!, [_0]) } - public var TwoStepAuth_SetupEmail: String { return self._s[547]! } - public var HashtagSearch_AllChats: String { return self._s[548]! } - public var MediaPlayer_UnknownTrack: String { return self._s[549]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[551]! } + public var TwoStepAuth_SetupEmail: String { return self._s[549]! } + public var HashtagSearch_AllChats: String { return self._s[550]! } + public var MediaPlayer_UnknownTrack: String { return self._s[551]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[553]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[552]!, self._r[552]!, [_0]) + return formatWithArgumentRanges(self._s[554]!, self._r[554]!, [_0]) } - public var Chat_Gifs_SavedSectionHeader: String { return self._s[553]! } - public var PhotoEditor_QualityHigh: String { return self._s[555]! } + public var Chat_Gifs_SavedSectionHeader: String { return self._s[555]! } + public var PhotoEditor_QualityHigh: String { return self._s[557]! } public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[556]!, self._r[556]!, [_0]) + return formatWithArgumentRanges(self._s[558]!, self._r[558]!, [_0]) } - public var ApplyLanguage_ApplyLanguageAction: String { return self._s[557]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[558]! } - public var Message_LiveLocation: String { return self._s[559]! } - public var Cache_LowDiskSpaceText: String { return self._s[560]! } - public var Wallet_Receive_ShareAddress: String { return self._s[561]! } - public var EditTheme_ErrorLinkTaken: String { return self._s[563]! } - public var Conversation_SendMessage: String { return self._s[564]! } - public var AuthSessions_EmptyTitle: String { return self._s[565]! } - public var Privacy_PhoneNumber: String { return self._s[566]! } - public var PeopleNearby_CreateGroup: String { return self._s[567]! } - public var Stats_SharesPerPost: String { return self._s[569]! } - public var CallSettings_UseLessData: String { return self._s[570]! } - public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[571]! } - public var Stickers_AddToFavorites: String { return self._s[572]! } - public var Wallet_WordImport_Title: String { return self._s[573]! } - public var PhotoEditor_QualityLow: String { return self._s[574]! } - public var Watch_UserInfo_Unblock: String { return self._s[575]! } - public var Settings_Logout: String { return self._s[576]! } + public var ApplyLanguage_ApplyLanguageAction: String { return self._s[559]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[560]! } + public var Message_LiveLocation: String { return self._s[561]! } + public var Cache_LowDiskSpaceText: String { return self._s[562]! } + public var Wallet_Receive_ShareAddress: String { return self._s[563]! } + public var EditTheme_ErrorLinkTaken: String { return self._s[565]! } + public var Conversation_SendMessage: String { return self._s[566]! } + public var AuthSessions_EmptyTitle: String { return self._s[567]! } + public var Privacy_PhoneNumber: String { return self._s[568]! } + public var PeopleNearby_CreateGroup: String { return self._s[569]! } + public var Stats_SharesPerPost: String { return self._s[571]! } + public var CallSettings_UseLessData: String { return self._s[572]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[573]! } + public var Stickers_AddToFavorites: String { return self._s[574]! } + public var Wallet_WordImport_Title: String { return self._s[575]! } + public var PhotoEditor_QualityLow: String { return self._s[576]! } + public var Watch_UserInfo_Unblock: String { return self._s[577]! } + public var Settings_Logout: String { return self._s[578]! } public func PUSH_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[577]!, self._r[577]!, [_1]) + return formatWithArgumentRanges(self._s[579]!, self._r[579]!, [_1]) } - public var ContactInfo_PhoneLabelWork: String { return self._s[578]! } - public var ChannelInfo_Stats: String { return self._s[579]! } - public var TextFormat_Link: String { return self._s[580]! } + public var ContactInfo_PhoneLabelWork: String { return self._s[580]! } + public var ChannelInfo_Stats: String { return self._s[581]! } + public var TextFormat_Link: String { return self._s[582]! } public func Date_ChatDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[581]!, self._r[581]!, [_1, _2]) + return formatWithArgumentRanges(self._s[583]!, self._r[583]!, [_1, _2]) } - public var Paint_Framed: String { return self._s[582]! } - public var Wallet_TransactionInfo_Title: String { return self._s[583]! } + public var Paint_Framed: String { return self._s[584]! } + public var Wallet_TransactionInfo_Title: String { return self._s[585]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[584]!, self._r[584]!, [_0]) + return formatWithArgumentRanges(self._s[586]!, self._r[586]!, [_0]) } - public var Watch_Notification_Joined: String { return self._s[585]! } - public var Group_Setup_TypePublicHelp: String { return self._s[586]! } - public var Passport_Scans_UploadNew: String { return self._s[587]! } - public var Checkout_LiabilityAlertTitle: String { return self._s[588]! } - public var DialogList_Title: String { return self._s[591]! } - public var NotificationSettings_ContactJoined: String { return self._s[592]! } - public var GroupInfo_LabelAdmin: String { return self._s[593]! } - public var KeyCommand_ChatInfo: String { return self._s[594]! } - public var Conversation_EditingCaptionPanelTitle: String { return self._s[595]! } - public var Call_ReportIncludeLog: String { return self._s[596]! } + public var Watch_Notification_Joined: String { return self._s[587]! } + public var Group_Setup_TypePublicHelp: String { return self._s[588]! } + public var Passport_Scans_UploadNew: String { return self._s[589]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[590]! } + public var DialogList_Title: String { return self._s[593]! } + public var NotificationSettings_ContactJoined: String { return self._s[594]! } + public var GroupInfo_LabelAdmin: String { return self._s[595]! } + public var KeyCommand_ChatInfo: String { return self._s[596]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[597]! } + public var Call_ReportIncludeLog: String { return self._s[598]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[599]!, self._r[599]!, [_0]) + return formatWithArgumentRanges(self._s[601]!, self._r[601]!, [_0]) } - public var Stats_Followers: String { return self._s[600]! } - public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[601]! } - public var ChatAdmins_AllMembersAreAdmins: String { return self._s[602]! } - public var LocalGroup_IrrelevantWarning: String { return self._s[603]! } - public var Conversation_DefaultRestrictedInline: String { return self._s[604]! } - public var Message_Sticker: String { return self._s[605]! } - public var LastSeen_JustNow: String { return self._s[607]! } - public var Passport_Email_EmailPlaceholder: String { return self._s[609]! } - public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[610]! } - public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[612]! } - public var Channel_EditAdmin_PermissionsHeader: String { return self._s[613]! } - public var TwoStepAuth_Email: String { return self._s[614]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[615]! } - public var PhotoEditor_BlurToolOff: String { return self._s[616]! } - public var Message_PinnedStickerMessage: String { return self._s[617]! } - public var ContactInfo_PhoneLabelPager: String { return self._s[618]! } - public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[619]! } - public var Passport_DiscardMessageTitle: String { return self._s[620]! } - public var Privacy_PaymentsTitle: String { return self._s[621]! } - public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[622]! } - public var ClearCache_StorageCache: String { return self._s[623]! } - public var Appearance_TextSizeSetting: String { return self._s[624]! } - public var Channel_DiscussionGroup_Header: String { return self._s[626]! } - public var VoiceOver_Chat_OptionSelected: String { return self._s[627]! } - public var Appearance_ColorTheme: String { return self._s[628]! } - public var UserInfo_ShareContact: String { return self._s[629]! } - public var Passport_Address_TypePassportRegistration: String { return self._s[630]! } - public var Common_More: String { return self._s[631]! } - public var Watch_Message_Call: String { return self._s[632]! } - public var Profile_EncryptionKey: String { return self._s[635]! } - public var Privacy_TopPeers: String { return self._s[636]! } - public var Conversation_StopPollConfirmation: String { return self._s[637]! } - public var Wallet_Words_NotDoneText: String { return self._s[639]! } - public var Privacy_TopPeersWarning: String { return self._s[641]! } - public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[642]! } - public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[643]! } - public var Media_SendWithTimer: String { return self._s[646]! } - public var Wallet_RestoreFailed_EnterWords: String { return self._s[647]! } - public var DialogList_SearchSectionMessages: String { return self._s[648]! } - public var ChatList_Context_AddToFolder: String { return self._s[649]! } - public var Notifications_ChannelNotifications: String { return self._s[650]! } - public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[651]! } - public var Passport_Language_sk: String { return self._s[652]! } - public var Notification_MessageLifetime1h: String { return self._s[653]! } - public var Wallpaper_ResetWallpapersInfo: String { return self._s[654]! } - public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[655]! } - public var PeerInfo_PaneGifs: String { return self._s[656]! } - public var Call_ReportSkip: String { return self._s[658]! } - public var Cache_ServiceFiles: String { return self._s[659]! } - public var Group_ErrorAddTooMuchAdmins: String { return self._s[660]! } - public var VoiceOver_Chat_YourFile: String { return self._s[661]! } - public var Map_Hybrid: String { return self._s[662]! } - public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[664]! } + public var Stats_Followers: String { return self._s[602]! } + public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[603]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[604]! } + public var LocalGroup_IrrelevantWarning: String { return self._s[605]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[606]! } + public var Message_Sticker: String { return self._s[607]! } + public var LastSeen_JustNow: String { return self._s[609]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[611]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[612]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[614]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[615]! } + public var TwoStepAuth_Email: String { return self._s[616]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[617]! } + public var PhotoEditor_BlurToolOff: String { return self._s[618]! } + public var Message_PinnedStickerMessage: String { return self._s[619]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[620]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[621]! } + public var Passport_DiscardMessageTitle: String { return self._s[622]! } + public var Privacy_PaymentsTitle: String { return self._s[623]! } + public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[624]! } + public var ClearCache_StorageCache: String { return self._s[625]! } + public var Appearance_TextSizeSetting: String { return self._s[626]! } + public var Channel_DiscussionGroup_Header: String { return self._s[628]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[629]! } + public var Appearance_ColorTheme: String { return self._s[630]! } + public var UserInfo_ShareContact: String { return self._s[631]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[632]! } + public var Common_More: String { return self._s[633]! } + public var Watch_Message_Call: String { return self._s[634]! } + public var Profile_EncryptionKey: String { return self._s[637]! } + public var Privacy_TopPeers: String { return self._s[638]! } + public var Conversation_StopPollConfirmation: String { return self._s[639]! } + public var Wallet_Words_NotDoneText: String { return self._s[641]! } + public var Privacy_TopPeersWarning: String { return self._s[643]! } + public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[644]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[645]! } + public var Media_SendWithTimer: String { return self._s[648]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[649]! } + public var DialogList_SearchSectionMessages: String { return self._s[650]! } + public var ChatList_Context_AddToFolder: String { return self._s[651]! } + public var Notifications_ChannelNotifications: String { return self._s[652]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[653]! } + public var Passport_Language_sk: String { return self._s[654]! } + public var Notification_MessageLifetime1h: String { return self._s[655]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[656]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[657]! } + public var PeerInfo_PaneGifs: String { return self._s[658]! } + public var Call_ReportSkip: String { return self._s[660]! } + public var Cache_ServiceFiles: String { return self._s[661]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[662]! } + public var VoiceOver_Chat_YourFile: String { return self._s[663]! } + public var Map_Hybrid: String { return self._s[664]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[666]! } public func PUSH_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[665]!, self._r[665]!, [_1]) + return formatWithArgumentRanges(self._s[667]!, self._r[667]!, [_1]) } - public var ChatSettings_AutoDownloadVideos: String { return self._s[667]! } - public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[668]! } - public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[669]! } - public var SocksProxySetup_ProxyTelegram: String { return self._s[672]! } + public var ChatSettings_AutoDownloadVideos: String { return self._s[669]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[670]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[671]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[674]! } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[673]!, self._r[673]!, [_1]) + return formatWithArgumentRanges(self._s[675]!, self._r[675]!, [_1]) } - public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[675]! } - public var ScheduledMessages_ScheduledToday: String { return self._s[676]! } + public var Channel_Username_CreatePrivateLinkHelp: String { return self._s[677]! } + public var ScheduledMessages_ScheduledToday: String { return self._s[678]! } public func PUSH_CHAT_TITLE_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[677]!, self._r[677]!, [_1, _2]) + return formatWithArgumentRanges(self._s[679]!, self._r[679]!, [_1, _2]) } - public var Conversation_LiveLocationYou: String { return self._s[678]! } - public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[679]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[680]! } - public var UserInfo_ShareBot: String { return self._s[683]! } + public var Conversation_LiveLocationYou: String { return self._s[680]! } + public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[681]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[682]! } + public var UserInfo_ShareBot: String { return self._s[685]! } public func PUSH_AUTH_REGION(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[684]!, self._r[684]!, [_1, _2]) + return formatWithArgumentRanges(self._s[686]!, self._r[686]!, [_1, _2]) } - public var Conversation_ClearCache: String { return self._s[685]! } - public var PhotoEditor_ShadowsTint: String { return self._s[686]! } - public var ChatListFolderSettings_EditFoldersInfo: String { return self._s[687]! } - public var Message_Audio: String { return self._s[688]! } - public var Passport_Language_lt: String { return self._s[689]! } + public var Conversation_ClearCache: String { return self._s[687]! } + public var PhotoEditor_ShadowsTint: String { return self._s[688]! } + public var ChatListFolderSettings_EditFoldersInfo: String { return self._s[689]! } + public var Message_Audio: String { return self._s[690]! } + public var Passport_Language_lt: String { return self._s[691]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[690]!, self._r[690]!, [_0]) + return formatWithArgumentRanges(self._s[692]!, self._r[692]!, [_0]) } - public var Permissions_SiriText_v0: String { return self._s[691]! } - public var Conversation_FileICloudDrive: String { return self._s[692]! } - public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[693]! } - public var Notifications_Badge_IncludeMutedChats: String { return self._s[694]! } + public var Permissions_SiriText_v0: String { return self._s[693]! } + public var Conversation_FileICloudDrive: String { return self._s[694]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[695]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[696]! } public func Notification_NewAuthDetected(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[695]!, self._r[695]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[697]!, self._r[697]!, [_1, _2, _3, _4, _5, _6]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[696]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[698]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[697]!, self._r[697]!, [_0]) + return formatWithArgumentRanges(self._s[699]!, self._r[699]!, [_0]) } - public var Channel_SignMessages: String { return self._s[698]! } + public var Channel_SignMessages: String { return self._s[700]! } public func PUSH_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[699]!, self._r[699]!, [_1]) + return formatWithArgumentRanges(self._s[701]!, self._r[701]!, [_1]) } - public var Compose_ChannelTokenListPlaceholder: String { return self._s[700]! } - public var Passport_ScanPassport: String { return self._s[701]! } - public var Watch_Suggestion_Thanks: String { return self._s[702]! } - public var BlockedUsers_AddNew: String { return self._s[703]! } + public var Compose_ChannelTokenListPlaceholder: String { return self._s[702]! } + public var Passport_ScanPassport: String { return self._s[703]! } + public var Watch_Suggestion_Thanks: String { return self._s[704]! } + public var BlockedUsers_AddNew: String { return self._s[705]! } public func PUSH_CHAT_MESSAGE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[704]!, self._r[704]!, [_1, _2]) + return formatWithArgumentRanges(self._s[706]!, self._r[706]!, [_1, _2]) } - public var Watch_Message_Invoice: String { return self._s[705]! } - public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[706]! } - public var Month_GenJuly: String { return self._s[707]! } - public var CreatePoll_QuizInfo: String { return self._s[708]! } - public var UserInfo_StartSecretChatStart: String { return self._s[709]! } - public var SocksProxySetup_ProxySocks5: String { return self._s[710]! } - public var IntentsSettings_SuggestByShare: String { return self._s[712]! } - public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[713]! } - public var Notification_ChannelInviterSelf: String { return self._s[714]! } - public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[715]! } + public var Watch_Message_Invoice: String { return self._s[707]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[708]! } + public var Month_GenJuly: String { return self._s[709]! } + public var CreatePoll_QuizInfo: String { return self._s[710]! } + public var UserInfo_StartSecretChatStart: String { return self._s[711]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[712]! } + public var IntentsSettings_SuggestByShare: String { return self._s[714]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[715]! } + public var Notification_ChannelInviterSelf: String { return self._s[716]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[717]! } public func ApplyLanguage_ChangeLanguageUnofficialText(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[716]!, self._r[716]!, [_1, _2]) + return formatWithArgumentRanges(self._s[718]!, self._r[718]!, [_1, _2]) } - public var Stats_FollowersTitle: String { return self._s[717]! } - public var CheckoutInfo_Title: String { return self._s[718]! } - public var Watch_Stickers_RecentPlaceholder: String { return self._s[719]! } + public var Stats_FollowersTitle: String { return self._s[719]! } + public var CheckoutInfo_Title: String { return self._s[720]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[721]! } public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[720]!, self._r[720]!, [_0]) + return formatWithArgumentRanges(self._s[722]!, self._r[722]!, [_0]) } - public var Passport_Identity_MainPage: String { return self._s[721]! } - public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[722]! } - public var Passport_Language_de: String { return self._s[723]! } - public var Update_Title: String { return self._s[724]! } - public var ContactInfo_PhoneLabelWorkFax: String { return self._s[725]! } - public var Channel_AdminLog_BanEmbedLinks: String { return self._s[726]! } - public var Passport_Email_UseTelegramEmailHelp: String { return self._s[727]! } - public var Notifications_ChannelNotificationsPreview: String { return self._s[728]! } - public var NotificationsSound_Telegraph: String { return self._s[729]! } - public var Watch_LastSeen_ALongTimeAgo: String { return self._s[730]! } - public var ChannelMembers_WhoCanAddMembers: String { return self._s[731]! } + public var Passport_Identity_MainPage: String { return self._s[723]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[724]! } + public var Passport_Language_de: String { return self._s[725]! } + public var Update_Title: String { return self._s[726]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[727]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[728]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[729]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[730]! } + public var NotificationsSound_Telegraph: String { return self._s[731]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[732]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[733]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[732]!, self._r[732]!, [_0]) + return formatWithArgumentRanges(self._s[734]!, self._r[734]!, [_0]) } - public var ClearCache_Description: String { return self._s[733]! } - public var Stickers_SuggestAll: String { return self._s[734]! } - public var Conversation_ForwardTitle: String { return self._s[735]! } - public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[736]! } + public var ClearCache_Description: String { return self._s[735]! } + public var Stickers_SuggestAll: String { return self._s[736]! } + public var Conversation_ForwardTitle: String { return self._s[737]! } + public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[738]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[737]!, self._r[737]!, [_0]) + return formatWithArgumentRanges(self._s[739]!, self._r[739]!, [_0]) } - public var Calls_NewCall: String { return self._s[738]! } - public var Call_StatusEnded: String { return self._s[739]! } - public var AutoDownloadSettings_DataUsageLow: String { return self._s[740]! } - public var Settings_ProxyConnected: String { return self._s[741]! } - public var Channel_AdminLogFilter_EventsPinned: String { return self._s[742]! } - public var PhotoEditor_QualityVeryLow: String { return self._s[743]! } - public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[744]! } - public var Passport_PasswordPlaceholder: String { return self._s[745]! } - public var Message_PinnedInvoice: String { return self._s[746]! } - public var Passport_Identity_IssueDate: String { return self._s[747]! } - public var Passport_Language_pl: String { return self._s[748]! } + public var Calls_NewCall: String { return self._s[740]! } + public var Call_StatusEnded: String { return self._s[741]! } + public var AutoDownloadSettings_DataUsageLow: String { return self._s[742]! } + public var Settings_ProxyConnected: String { return self._s[743]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[744]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[745]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[746]! } + public var Passport_PasswordPlaceholder: String { return self._s[747]! } + public var Message_PinnedInvoice: String { return self._s[748]! } + public var Passport_Identity_IssueDate: String { return self._s[749]! } + public var Passport_Language_pl: String { return self._s[750]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[749]!, self._r[749]!, [_0]) + return formatWithArgumentRanges(self._s[751]!, self._r[751]!, [_0]) } - public var Call_StatusConnecting: String { return self._s[750]! } - public var SocksProxySetup_PasteFromClipboard: String { return self._s[751]! } + public var Call_StatusConnecting: String { return self._s[752]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[753]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[752]!, self._r[752]!, [_0]) + return formatWithArgumentRanges(self._s[754]!, self._r[754]!, [_0]) } - public var ChatSettings_ConnectionType_UseProxy: String { return self._s[754]! } - public var Common_Edit: String { return self._s[755]! } - public var PrivacySettings_LastSeenNobody: String { return self._s[756]! } + public var ChatSettings_ConnectionType_UseProxy: String { return self._s[756]! } + public var Common_Edit: String { return self._s[757]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[758]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[757]!, self._r[757]!, [_0]) + return formatWithArgumentRanges(self._s[759]!, self._r[759]!, [_0]) } - public var GroupInfo_ChatAdmins: String { return self._s[758]! } - public var PrivateDataSettings_Title: String { return self._s[759]! } - public var Login_CancelPhoneVerificationStop: String { return self._s[760]! } - public var ChatList_Read: String { return self._s[761]! } - public var Wallet_WordImport_Text: String { return self._s[762]! } - public var Undo_ChatClearedForBothSides: String { return self._s[763]! } - public var ChatListFolder_AddChats: String { return self._s[764]! } - public var GroupPermission_SectionTitle: String { return self._s[765]! } - public var TwoFactorSetup_Intro_Title: String { return self._s[767]! } + public var GroupInfo_ChatAdmins: String { return self._s[760]! } + public var PrivateDataSettings_Title: String { return self._s[761]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[762]! } + public var ChatList_Read: String { return self._s[763]! } + public var Wallet_WordImport_Text: String { return self._s[764]! } + public var Undo_ChatClearedForBothSides: String { return self._s[765]! } + public var ChatListFolder_AddChats: String { return self._s[766]! } + public var GroupPermission_SectionTitle: String { return self._s[767]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[769]! } public func PUSH_CHAT_LEFT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[768]!, self._r[768]!, [_1, _2]) + return formatWithArgumentRanges(self._s[770]!, self._r[770]!, [_1, _2]) } - public var Checkout_ErrorPaymentFailed: String { return self._s[769]! } - public var Update_UpdateApp: String { return self._s[771]! } - public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[772]! } - public var Settings_Appearance: String { return self._s[773]! } - public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[777]! } - public var Watch_Location_Access: String { return self._s[778]! } - public var ShareMenu_CopyShareLink: String { return self._s[780]! } - public var TwoStepAuth_SetupHintTitle: String { return self._s[781]! } - public var Conversation_Theme: String { return self._s[783]! } + public var Checkout_ErrorPaymentFailed: String { return self._s[771]! } + public var Update_UpdateApp: String { return self._s[773]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[774]! } + public var Settings_Appearance: String { return self._s[775]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[779]! } + public var Watch_Location_Access: String { return self._s[780]! } + public var ShareMenu_CopyShareLink: String { return self._s[782]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[783]! } + public var Conversation_Theme: String { return self._s[785]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[784]!, self._r[784]!, [_0]) + return formatWithArgumentRanges(self._s[786]!, self._r[786]!, [_0]) } - public var Notifications_ClassicTones: String { return self._s[785]! } - public var Weekday_ShortWednesday: String { return self._s[786]! } - public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[787]! } - public var Undo_LeftGroup: String { return self._s[790]! } - public var ChatListFolder_DiscardCancel: String { return self._s[791]! } - public var Wallet_RestoreFailed_Text: String { return self._s[792]! } - public var Conversation_LinkDialogCopy: String { return self._s[793]! } - public var Wallet_TransactionInfo_NoAddress: String { return self._s[795]! } - public var Wallet_Navigation_Back: String { return self._s[796]! } - public var KeyCommand_FocusOnInputField: String { return self._s[797]! } - public var Contacts_SelectAll: String { return self._s[798]! } - public var Preview_SaveToCameraRoll: String { return self._s[799]! } - public var PrivacySettings_PasscodeOff: String { return self._s[800]! } - public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[801]! } + public var Notifications_ClassicTones: String { return self._s[787]! } + public var Weekday_ShortWednesday: String { return self._s[788]! } + public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[789]! } + public var Undo_LeftGroup: String { return self._s[792]! } + public var ChatListFolder_DiscardCancel: String { return self._s[793]! } + public var Wallet_RestoreFailed_Text: String { return self._s[794]! } + public var Conversation_LinkDialogCopy: String { return self._s[795]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[797]! } + public var Wallet_Navigation_Back: String { return self._s[798]! } + public var KeyCommand_FocusOnInputField: String { return self._s[799]! } + public var Contacts_SelectAll: String { return self._s[800]! } + public var Preview_SaveToCameraRoll: String { return self._s[801]! } + public var PrivacySettings_PasscodeOff: String { return self._s[802]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[803]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[802]!, self._r[802]!, [_1]) + return formatWithArgumentRanges(self._s[804]!, self._r[804]!, [_1]) } - public var Wallpaper_Title: String { return self._s[803]! } - public var Conversation_FilePhotoOrVideo: String { return self._s[804]! } - public var AccessDenied_Camera: String { return self._s[805]! } - public var Watch_Compose_CurrentLocation: String { return self._s[806]! } - public var PeerInfo_ButtonMessage: String { return self._s[808]! } - public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[809]! } + public var Wallpaper_Title: String { return self._s[805]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[806]! } + public var AccessDenied_Camera: String { return self._s[807]! } + public var Watch_Compose_CurrentLocation: String { return self._s[808]! } + public var PeerInfo_ButtonMessage: String { return self._s[810]! } + public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[811]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[810]!, self._r[810]!, [_0]) + return formatWithArgumentRanges(self._s[812]!, self._r[812]!, [_0]) } - public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[811]! } - public var Passport_Language_ro: String { return self._s[812]! } - public var EditTheme_UploadNewTheme: String { return self._s[813]! } - public var CheckoutInfo_SaveInfoHelp: String { return self._s[814]! } - public var Wallet_Intro_Terms: String { return self._s[815]! } + public var GroupInfo_InvitationLinkDoesNotExist: String { return self._s[813]! } + public var Passport_Language_ro: String { return self._s[814]! } + public var EditTheme_UploadNewTheme: String { return self._s[815]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[816]! } + public var Wallet_Intro_Terms: String { return self._s[817]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[816]!, self._r[816]!, [_0]) + return formatWithArgumentRanges(self._s[818]!, self._r[818]!, [_0]) } - public var Login_CancelPhoneVerification: String { return self._s[817]! } - public var State_ConnectingToProxy: String { return self._s[818]! } - public var Calls_RatingTitle: String { return self._s[819]! } - public var Generic_ErrorMoreInfo: String { return self._s[820]! } - public var ChatList_Search_ShowMore: String { return self._s[821]! } - public var Appearance_PreviewReplyText: String { return self._s[822]! } - public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[823]! } + public var Login_CancelPhoneVerification: String { return self._s[819]! } + public var State_ConnectingToProxy: String { return self._s[820]! } + public var Calls_RatingTitle: String { return self._s[821]! } + public var Generic_ErrorMoreInfo: String { return self._s[822]! } + public var ChatList_Search_ShowMore: String { return self._s[823]! } + public var Appearance_PreviewReplyText: String { return self._s[824]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[825]! } public func Wallet_Send_Balance(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[824]!, self._r[824]!, [_0]) + return formatWithArgumentRanges(self._s[826]!, self._r[826]!, [_0]) } - public var IntentsSettings_SuggestedChatsContacts: String { return self._s[825]! } - public var SharedMedia_CategoryLinks: String { return self._s[826]! } - public var Calls_Missed: String { return self._s[827]! } - public var Cache_Photos: String { return self._s[831]! } - public var GroupPermission_NoAddMembers: String { return self._s[832]! } - public var ScheduledMessages_Title: String { return self._s[833]! } + public var IntentsSettings_SuggestedChatsContacts: String { return self._s[827]! } + public var SharedMedia_CategoryLinks: String { return self._s[828]! } + public var Calls_Missed: String { return self._s[829]! } + public var Cache_Photos: String { return self._s[833]! } + public var GroupPermission_NoAddMembers: String { return self._s[834]! } + public var ScheduledMessages_Title: String { return self._s[835]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[834]!, self._r[834]!, [_0]) + return formatWithArgumentRanges(self._s[836]!, self._r[836]!, [_0]) } - public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[835]! } - public var Settings_ProxyDisabled: String { return self._s[836]! } + public var Conversation_ShareBotLocationConfirmationTitle: String { return self._s[837]! } + public var Settings_ProxyDisabled: String { return self._s[838]! } public func Settings_ApplyProxyAlertCredentials(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[837]!, self._r[837]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[839]!, self._r[839]!, [_1, _2, _3, _4]) } public func Conversation_RestrictedMediaTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[838]!, self._r[838]!, [_0]) + return formatWithArgumentRanges(self._s[840]!, self._r[840]!, [_0]) } - public var Stats_ViewsPerPost: String { return self._s[840]! } - public var ChatList_Context_RemoveFromRecents: String { return self._s[841]! } - public var Appearance_Title: String { return self._s[842]! } + public var Stats_ViewsPerPost: String { return self._s[842]! } + public var ChatList_Context_RemoveFromRecents: String { return self._s[843]! } + public var Appearance_Title: String { return self._s[844]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[844]!, self._r[844]!, [_0]) + return formatWithArgumentRanges(self._s[846]!, self._r[846]!, [_0]) } - public var Conversation_WalletRequiredText: String { return self._s[845]! } - public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[846]! } - public var OldChannels_NoticeCreateText: String { return self._s[847]! } - public var Channel_EditMessageErrorGeneric: String { return self._s[848]! } - public var Privacy_Calls_IntegrationHelp: String { return self._s[849]! } - public var Preview_DeletePhoto: String { return self._s[850]! } - public var Appearance_AppIconFilledX: String { return self._s[851]! } - public var PrivacySettings_PrivacyTitle: String { return self._s[852]! } + public var Conversation_WalletRequiredText: String { return self._s[847]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[848]! } + public var OldChannels_NoticeCreateText: String { return self._s[849]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[850]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[851]! } + public var Preview_DeletePhoto: String { return self._s[852]! } + public var Appearance_AppIconFilledX: String { return self._s[853]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[854]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[853]!, self._r[853]!, [_0]) + return formatWithArgumentRanges(self._s[855]!, self._r[855]!, [_0]) } - public var ChatListFolder_TitleEdit: String { return self._s[856]! } - public var MuteFor_Forever: String { return self._s[857]! } - public var Coub_TapForSound: String { return self._s[858]! } - public var Map_LocatingError: String { return self._s[859]! } - public var TwoStepAuth_EmailChangeSuccess: String { return self._s[861]! } - public var Conversation_SendMessage_SendSilently: String { return self._s[862]! } - public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[863]! } + public var ChatListFolder_TitleEdit: String { return self._s[858]! } + public var MuteFor_Forever: String { return self._s[859]! } + public var Coub_TapForSound: String { return self._s[860]! } + public var Map_LocatingError: String { return self._s[861]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[863]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[864]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[865]! } public func Wallet_Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[864]!, self._r[864]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[866]!, self._r[866]!, [_1, _2, _3]) } - public var Passport_ForgottenPassword: String { return self._s[865]! } - public var GroupInfo_InviteLink_RevokeLink: String { return self._s[866]! } - public var StickerPacksSettings_ArchivedPacks: String { return self._s[867]! } - public var Login_TermsOfServiceSignupDecline: String { return self._s[869]! } - public var Channel_Moderator_AccessLevelRevoke: String { return self._s[870]! } - public var Message_Location: String { return self._s[871]! } - public var Passport_Identity_NamePlaceholder: String { return self._s[872]! } - public var Channel_Management_Title: String { return self._s[873]! } - public var DialogList_SearchSectionDialogs: String { return self._s[875]! } - public var Compose_NewChannel_Members: String { return self._s[876]! } + public var Passport_ForgottenPassword: String { return self._s[867]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[868]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[869]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[871]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[872]! } + public var Message_Location: String { return self._s[873]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[874]! } + public var Channel_Management_Title: String { return self._s[875]! } + public var DialogList_SearchSectionDialogs: String { return self._s[877]! } + public var Compose_NewChannel_Members: String { return self._s[878]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[877]!, self._r[877]!, [_0]) + return formatWithArgumentRanges(self._s[879]!, self._r[879]!, [_0]) } - public var GroupInfo_Location: String { return self._s[878]! } - public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[879]! } - public var ClearCache_Clear: String { return self._s[880]! } - public var InstantPage_FeedbackButtonShort: String { return self._s[881]! } - public var AutoNightTheme_ScheduledFrom: String { return self._s[882]! } - public var PhotoEditor_WarmthTool: String { return self._s[883]! } - public var Passport_Language_tr: String { return self._s[884]! } + public var GroupInfo_Location: String { return self._s[880]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[881]! } + public var ClearCache_Clear: String { return self._s[882]! } + public var InstantPage_FeedbackButtonShort: String { return self._s[883]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[884]! } + public var PhotoEditor_WarmthTool: String { return self._s[885]! } + public var Passport_Language_tr: String { return self._s[886]! } public func PUSH_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[885]!, self._r[885]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[887]!, self._r[887]!, [_1, _2, _3]) } - public var OldChannels_NoticeUpgradeText: String { return self._s[886]! } - public var Login_ResetAccountProtected_Reset: String { return self._s[888]! } - public var Watch_PhotoView_Title: String { return self._s[889]! } - public var Passport_Phone_Delete: String { return self._s[890]! } - public var Undo_ChatDeletedForBothSides: String { return self._s[891]! } - public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[892]! } - public var GroupInfo_Permissions: String { return self._s[893]! } - public var PasscodeSettings_TurnPasscodeOff: String { return self._s[894]! } - public var Profile_ShareContactButton: String { return self._s[895]! } - public var ChatSettings_Other: String { return self._s[896]! } - public var UserInfo_NotificationsDisabled: String { return self._s[897]! } - public var CheckoutInfo_ShippingInfoCity: String { return self._s[898]! } - public var LastSeen_WithinAMonth: String { return self._s[899]! } - public var VoiceOver_Chat_PlayHint: String { return self._s[900]! } - public var Conversation_ReportGroupLocation: String { return self._s[901]! } - public var Conversation_EncryptionCanceled: String { return self._s[902]! } - public var MediaPicker_GroupDescription: String { return self._s[903]! } - public var WebSearch_Images: String { return self._s[904]! } + public var OldChannels_NoticeUpgradeText: String { return self._s[888]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[890]! } + public var Watch_PhotoView_Title: String { return self._s[891]! } + public var Passport_Phone_Delete: String { return self._s[892]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[893]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[894]! } + public var GroupInfo_Permissions: String { return self._s[895]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[896]! } + public var Profile_ShareContactButton: String { return self._s[897]! } + public var ChatSettings_Other: String { return self._s[898]! } + public var UserInfo_NotificationsDisabled: String { return self._s[899]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[900]! } + public var LastSeen_WithinAMonth: String { return self._s[901]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[902]! } + public var Conversation_ReportGroupLocation: String { return self._s[903]! } + public var Conversation_EncryptionCanceled: String { return self._s[904]! } + public var MediaPicker_GroupDescription: String { return self._s[905]! } + public var WebSearch_Images: String { return self._s[906]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[905]!, self._r[905]!, [_0]) + return formatWithArgumentRanges(self._s[907]!, self._r[907]!, [_0]) } - public var Message_Photo: String { return self._s[906]! } - public var PasscodeSettings_HelpBottom: String { return self._s[907]! } - public var AutoDownloadSettings_VideosTitle: String { return self._s[908]! } - public var VoiceOver_Media_PlaybackRateChange: String { return self._s[909]! } - public var Passport_Identity_AddDriversLicense: String { return self._s[910]! } - public var TwoStepAuth_EnterPasswordPassword: String { return self._s[911]! } - public var NotificationsSound_Calypso: String { return self._s[912]! } - public var Map_Map: String { return self._s[913]! } + public var Message_Photo: String { return self._s[908]! } + public var PasscodeSettings_HelpBottom: String { return self._s[909]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[910]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[911]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[912]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[913]! } + public var NotificationsSound_Calypso: String { return self._s[914]! } + public var Map_Map: String { return self._s[915]! } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[914]!, self._r[914]!, [_0]) + return formatWithArgumentRanges(self._s[916]!, self._r[916]!, [_0]) } - public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[916]! } - public var ChatSettings_TextSizeUnits: String { return self._s[917]! } + public var CheckoutInfo_ReceiverInfoTitle: String { return self._s[918]! } + public var ChatSettings_TextSizeUnits: String { return self._s[919]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[918]!, self._r[918]!, [_0]) + return formatWithArgumentRanges(self._s[920]!, self._r[920]!, [_0]) } - public var Common_of: String { return self._s[919]! } - public var Conversation_ForwardContacts: String { return self._s[922]! } - public var IntentsSettings_SuggestByAll: String { return self._s[924]! } + public var Common_of: String { return self._s[921]! } + public var Conversation_ForwardContacts: String { return self._s[924]! } + public var IntentsSettings_SuggestByAll: String { return self._s[926]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[925]!, self._r[925]!, [_0]) + return formatWithArgumentRanges(self._s[927]!, self._r[927]!, [_0]) } - public var Passport_Language_hy: String { return self._s[926]! } - public var Notifications_MessageNotificationsHelp: String { return self._s[927]! } - public var AutoDownloadSettings_Reset: String { return self._s[928]! } - public var Wallet_TransactionInfo_AddressCopied: String { return self._s[929]! } - public var Paint_ClearConfirm: String { return self._s[930]! } - public var Camera_VideoMode: String { return self._s[931]! } + public var Passport_Language_hy: String { return self._s[928]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[929]! } + public var AutoDownloadSettings_Reset: String { return self._s[930]! } + public var Wallet_TransactionInfo_AddressCopied: String { return self._s[931]! } + public var Paint_ClearConfirm: String { return self._s[932]! } + public var Camera_VideoMode: String { return self._s[933]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[932]!, self._r[932]!, [_0]) + return formatWithArgumentRanges(self._s[934]!, self._r[934]!, [_0]) } - public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[933]! } - public var Conversation_ViewBackground: String { return self._s[934]! } + public var Privacy_Calls_AlwaysAllow_Placeholder: String { return self._s[935]! } + public var Conversation_ViewBackground: String { return self._s[936]! } public func Wallet_Info_TransactionDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[935]!, self._r[935]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[937]!, self._r[937]!, [_1, _2, _3]) } - public var Passport_Language_el: String { return self._s[936]! } - public var PhotoEditor_Original: String { return self._s[937]! } - public var Settings_FAQ_Button: String { return self._s[939]! } - public var Channel_Setup_PublicNoLink: String { return self._s[941]! } - public var Conversation_UnsupportedMedia: String { return self._s[942]! } - public var Conversation_SlideToCancel: String { return self._s[943]! } - public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[944]! } - public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[945]! } - public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[946]! } - public var Conversation_ReportSpamChannelConfirmation: String { return self._s[947]! } - public var AutoNightTheme_NotAvailable: String { return self._s[948]! } - public var Conversation_Owner: String { return self._s[949]! } - public var Common_Create: String { return self._s[950]! } - public var Settings_ApplyProxyAlertEnable: String { return self._s[951]! } - public var ContactList_Context_Call: String { return self._s[952]! } - public var Localization_ChooseLanguage: String { return self._s[954]! } - public var ChatList_Context_AddToContacts: String { return self._s[956]! } - public var OldChannels_NoticeTitle: String { return self._s[957]! } - public var Settings_Proxy: String { return self._s[959]! } - public var Privacy_TopPeersHelp: String { return self._s[960]! } - public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[961]! } - public var Chat_UnsendMyMessages: String { return self._s[962]! } + public var Passport_Language_el: String { return self._s[938]! } + public var PhotoEditor_Original: String { return self._s[939]! } + public var Settings_FAQ_Button: String { return self._s[941]! } + public var Channel_Setup_PublicNoLink: String { return self._s[943]! } + public var Conversation_UnsupportedMedia: String { return self._s[944]! } + public var Conversation_SlideToCancel: String { return self._s[945]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[946]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[947]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[948]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[949]! } + public var AutoNightTheme_NotAvailable: String { return self._s[950]! } + public var Conversation_Owner: String { return self._s[951]! } + public var Common_Create: String { return self._s[952]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[953]! } + public var ContactList_Context_Call: String { return self._s[954]! } + public var Localization_ChooseLanguage: String { return self._s[956]! } + public var ChatList_Context_AddToContacts: String { return self._s[958]! } + public var OldChannels_NoticeTitle: String { return self._s[959]! } + public var Settings_Proxy: String { return self._s[961]! } + public var Privacy_TopPeersHelp: String { return self._s[962]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[963]! } + public var Chat_UnsendMyMessages: String { return self._s[964]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[963]!, self._r[963]!, [_0]) + return formatWithArgumentRanges(self._s[965]!, self._r[965]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[964]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[966]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[966]!, self._r[966]!, [_0]) + return formatWithArgumentRanges(self._s[968]!, self._r[968]!, [_0]) } - public var Contacts_SortedByPresence: String { return self._s[967]! } - public var Passport_Identity_SurnamePlaceholder: String { return self._s[968]! } - public var Cache_Title: String { return self._s[969]! } + public var Contacts_SortedByPresence: String { return self._s[969]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[970]! } + public var Cache_Title: String { return self._s[971]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[970]!, self._r[970]!, [_0]) + return formatWithArgumentRanges(self._s[972]!, self._r[972]!, [_0]) } - public var TwoStepAuth_EmailCodeExpired: String { return self._s[971]! } - public var Channel_Moderator_Title: String { return self._s[972]! } - public var InstantPage_AutoNightTheme: String { return self._s[974]! } + public var TwoStepAuth_EmailCodeExpired: String { return self._s[973]! } + public var Channel_Moderator_Title: String { return self._s[974]! } + public var InstantPage_AutoNightTheme: String { return self._s[976]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[977]!, self._r[977]!, [_1]) + return formatWithArgumentRanges(self._s[979]!, self._r[979]!, [_1]) } - public var Passport_Scans_Upload: String { return self._s[978]! } - public var Undo_Undo: String { return self._s[980]! } - public var Contacts_AccessDeniedHelpON: String { return self._s[981]! } - public var TwoStepAuth_RemovePassword: String { return self._s[982]! } - public var Common_Delete: String { return self._s[983]! } - public var Contacts_AddPeopleNearby: String { return self._s[985]! } - public var Conversation_ContextMenuDelete: String { return self._s[986]! } - public var SocksProxySetup_Credentials: String { return self._s[987]! } - public var Appearance_EditTheme: String { return self._s[989]! } - public var ClearCache_StorageOtherApps: String { return self._s[990]! } - public var PasscodeSettings_AutoLock_Disabled: String { return self._s[992]! } - public var Wallet_Send_NetworkErrorText: String { return self._s[993]! } - public var AuthSessions_DevicesTitle: String { return self._s[995]! } - public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[997]! } - public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[998]! } - public var Passport_Language_id: String { return self._s[1000]! } - public var Chat_Gifs_TrendingSectionHeader: String { return self._s[1001]! } - public var WallpaperSearch_ColorTeal: String { return self._s[1002]! } - public var ChannelIntro_Title: String { return self._s[1003]! } + public var Passport_Scans_Upload: String { return self._s[980]! } + public var Undo_Undo: String { return self._s[982]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[983]! } + public var TwoStepAuth_RemovePassword: String { return self._s[984]! } + public var Common_Delete: String { return self._s[985]! } + public var Contacts_AddPeopleNearby: String { return self._s[987]! } + public var Conversation_ContextMenuDelete: String { return self._s[988]! } + public var SocksProxySetup_Credentials: String { return self._s[989]! } + public var Appearance_EditTheme: String { return self._s[991]! } + public var ClearCache_StorageOtherApps: String { return self._s[992]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[994]! } + public var Wallet_Send_NetworkErrorText: String { return self._s[995]! } + public var AuthSessions_DevicesTitle: String { return self._s[997]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[999]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[1000]! } + public var Passport_Language_id: String { return self._s[1002]! } + public var Chat_Gifs_TrendingSectionHeader: String { return self._s[1003]! } + public var WallpaperSearch_ColorTeal: String { return self._s[1004]! } + public var ChannelIntro_Title: String { return self._s[1005]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1004]!, self._r[1004]!, [_0]) + return formatWithArgumentRanges(self._s[1006]!, self._r[1006]!, [_0]) } - public var VoiceOver_Chat_OpenLinkHint: String { return self._s[1006]! } - public var VoiceOver_Chat_Reply: String { return self._s[1007]! } - public var ScheduledMessages_BotActionUnavailable: String { return self._s[1008]! } - public var Channel_Info_Description: String { return self._s[1009]! } - public var Stickers_FavoriteStickers: String { return self._s[1010]! } - public var Channel_BanUser_PermissionAddMembers: String { return self._s[1011]! } - public var Notifications_DisplayNamesOnLockScreen: String { return self._s[1012]! } - public var ChatSearch_ResultsTooltip: String { return self._s[1013]! } - public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[1014]! } - public var Calls_NoMissedCallsPlacehoder: String { return self._s[1015]! } - public var Group_PublicLink_Placeholder: String { return self._s[1016]! } - public var Notifications_ExceptionsDefaultSound: String { return self._s[1017]! } + public var VoiceOver_Chat_OpenLinkHint: String { return self._s[1008]! } + public var VoiceOver_Chat_Reply: String { return self._s[1009]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[1010]! } + public var Channel_Info_Description: String { return self._s[1011]! } + public var Stickers_FavoriteStickers: String { return self._s[1012]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[1013]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[1014]! } + public var ChatSearch_ResultsTooltip: String { return self._s[1015]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[1016]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[1017]! } + public var Group_PublicLink_Placeholder: String { return self._s[1018]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[1019]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1018]!, self._r[1018]!, [_1]) + return formatWithArgumentRanges(self._s[1020]!, self._r[1020]!, [_1]) } - public var TextFormat_Underline: String { return self._s[1019]! } + public var TextFormat_Underline: String { return self._s[1021]! } public func DialogList_SearchSubtitleFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1021]!, self._r[1021]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1023]!, self._r[1023]!, [_1, _2]) } public func Channel_AdminLog_MessageRemovedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1022]!, self._r[1022]!, [_0]) + return formatWithArgumentRanges(self._s[1024]!, self._r[1024]!, [_0]) } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1023]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1025]! } public func Channel_OwnershipTransfer_TransferCompleted(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1024]!, self._r[1024]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1026]!, self._r[1026]!, [_1, _2]) } - public var Wallet_Intro_ImportExisting: String { return self._s[1025]! } - public var GroupPermission_Delete: String { return self._s[1026]! } - public var Passport_Language_uk: String { return self._s[1027]! } - public var StickerPack_HideStickers: String { return self._s[1029]! } - public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1030]! } + public var Wallet_Intro_ImportExisting: String { return self._s[1027]! } + public var GroupPermission_Delete: String { return self._s[1028]! } + public var Passport_Language_uk: String { return self._s[1029]! } + public var StickerPack_HideStickers: String { return self._s[1031]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1032]! } public func PUSH_CHAT_MESSAGE_PHOTO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1031]!, self._r[1031]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1033]!, self._r[1033]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[1032]! } + public var Activity_UploadingVideoMessage: String { return self._s[1034]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1033]!, self._r[1033]!, [_0]) + return formatWithArgumentRanges(self._s[1035]!, self._r[1035]!, [_0]) } - public var Channel_TitleInfo: String { return self._s[1034]! } - public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1035]! } - public var Settings_CallSettings: String { return self._s[1036]! } - public var Camera_SquareMode: String { return self._s[1037]! } - public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1038]! } - public var GroupInfo_SharedMediaNone: String { return self._s[1039]! } + public var Channel_TitleInfo: String { return self._s[1036]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1037]! } + public var Settings_CallSettings: String { return self._s[1038]! } + public var Camera_SquareMode: String { return self._s[1039]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1040]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1041]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1040]!, self._r[1040]!, [_1]) + return formatWithArgumentRanges(self._s[1042]!, self._r[1042]!, [_1]) } - public var Bot_GenericBotStatus: String { return self._s[1041]! } - public var Application_Update: String { return self._s[1043]! } - public var Month_ShortJanuary: String { return self._s[1044]! } - public var Contacts_PermissionsKeepDisabled: String { return self._s[1045]! } - public var Channel_AdminLog_BanReadMessages: String { return self._s[1046]! } - public var Settings_AppLanguage_Unofficial: String { return self._s[1047]! } - public var Passport_Address_Street2Placeholder: String { return self._s[1048]! } + public var Bot_GenericBotStatus: String { return self._s[1043]! } + public var Application_Update: String { return self._s[1045]! } + public var Month_ShortJanuary: String { return self._s[1046]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[1047]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[1048]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1049]! } + public var Passport_Address_Street2Placeholder: String { return self._s[1050]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1049]!, self._r[1049]!, [_0]) + return formatWithArgumentRanges(self._s[1051]!, self._r[1051]!, [_0]) } - public var NetworkUsageSettings_Cellular: String { return self._s[1050]! } - public var Appearance_PreviewOutgoingText: String { return self._s[1051]! } + public var NetworkUsageSettings_Cellular: String { return self._s[1052]! } + public var Appearance_PreviewOutgoingText: String { return self._s[1053]! } public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1052]!, self._r[1052]!, [_0]) + return formatWithArgumentRanges(self._s[1054]!, self._r[1054]!, [_0]) } - public var Notifications_PermissionsAllowInSettings: String { return self._s[1053]! } - public var AutoDownloadSettings_OnForAll: String { return self._s[1055]! } - public var Map_Directions: String { return self._s[1056]! } - public var Passport_FieldIdentityTranslationHelp: String { return self._s[1058]! } - public var Appearance_ThemeDay: String { return self._s[1059]! } - public var LogoutOptions_LogOut: String { return self._s[1060]! } - public var Group_PublicLink_Title: String { return self._s[1062]! } - public var Channel_AddBotErrorNoRights: String { return self._s[1063]! } - public var ChatList_Search_ShowLess: String { return self._s[1064]! } - public var Passport_Identity_AddPassport: String { return self._s[1065]! } - public var LocalGroup_ButtonTitle: String { return self._s[1066]! } - public var Stats_InteractionsTitle: String { return self._s[1067]! } - public var Call_Message: String { return self._s[1068]! } - public var PhotoEditor_ExposureTool: String { return self._s[1069]! } - public var Wallet_Receive_CommentInfo: String { return self._s[1071]! } - public var Passport_FieldOneOf_Delimeter: String { return self._s[1072]! } - public var Channel_AdminLog_CanBanUsers: String { return self._s[1074]! } - public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1075]! } - public var Appearance_Preview: String { return self._s[1076]! } - public var Compose_ChannelMembers: String { return self._s[1077]! } - public var Conversation_DeleteManyMessages: String { return self._s[1078]! } - public var ReportPeer_ReasonOther_Title: String { return self._s[1079]! } - public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1080]! } - public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1081]! } - public var Channel_Stickers_CreateYourOwn: String { return self._s[1084]! } - public var Conversation_UpdateTelegram: String { return self._s[1085]! } - public var EditTheme_Create_TopInfo: String { return self._s[1086]! } + public var Notifications_PermissionsAllowInSettings: String { return self._s[1055]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[1057]! } + public var Map_Directions: String { return self._s[1058]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1060]! } + public var Appearance_ThemeDay: String { return self._s[1061]! } + public var LogoutOptions_LogOut: String { return self._s[1062]! } + public var Group_PublicLink_Title: String { return self._s[1064]! } + public var Channel_AddBotErrorNoRights: String { return self._s[1065]! } + public var ChatList_Search_ShowLess: String { return self._s[1066]! } + public var Passport_Identity_AddPassport: String { return self._s[1067]! } + public var LocalGroup_ButtonTitle: String { return self._s[1068]! } + public var Stats_InteractionsTitle: String { return self._s[1069]! } + public var Call_Message: String { return self._s[1070]! } + public var PhotoEditor_ExposureTool: String { return self._s[1071]! } + public var Wallet_Receive_CommentInfo: String { return self._s[1073]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1074]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[1076]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1077]! } + public var Appearance_Preview: String { return self._s[1078]! } + public var Compose_ChannelMembers: String { return self._s[1079]! } + public var Conversation_DeleteManyMessages: String { return self._s[1080]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1081]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1082]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1083]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1086]! } + public var Conversation_UpdateTelegram: String { return self._s[1087]! } + public var EditTheme_Create_TopInfo: String { return self._s[1088]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1087]!, self._r[1087]!, [_0]) + return formatWithArgumentRanges(self._s[1089]!, self._r[1089]!, [_0]) } - public var Wallet_WordCheck_Continue: String { return self._s[1088]! } - public var TwoFactorSetup_Hint_Action: String { return self._s[1089]! } - public var IntentsSettings_ResetAll: String { return self._s[1090]! } + public var Wallet_WordCheck_Continue: String { return self._s[1090]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1091]! } + public var IntentsSettings_ResetAll: String { return self._s[1092]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1091]!, self._r[1091]!, [_1]) + return formatWithArgumentRanges(self._s[1093]!, self._r[1093]!, [_1]) } - public var ChatList_RemoveFolder: String { return self._s[1092]! } - public var GroupInfo_Administrators_Title: String { return self._s[1093]! } - public var Privacy_Forwards_PreviewMessageText: String { return self._s[1094]! } + public var ChatList_RemoveFolder: String { return self._s[1094]! } + public var GroupInfo_Administrators_Title: String { return self._s[1095]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1096]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1095]!, self._r[1095]!, [_0]) + return formatWithArgumentRanges(self._s[1097]!, self._r[1097]!, [_0]) } - public var Tour_Title3: String { return self._s[1096]! } - public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1097]! } - public var Clipboard_SendPhoto: String { return self._s[1101]! } - public var MediaPicker_Videos: String { return self._s[1102]! } - public var Passport_Email_Title: String { return self._s[1103]! } + public var Tour_Title3: String { return self._s[1098]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1099]! } + public var Clipboard_SendPhoto: String { return self._s[1103]! } + public var MediaPicker_Videos: String { return self._s[1104]! } + public var Passport_Email_Title: String { return self._s[1105]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1104]!, self._r[1104]!, [_0]) + return formatWithArgumentRanges(self._s[1106]!, self._r[1106]!, [_0]) } - public var StickerPacksSettings_Title: String { return self._s[1105]! } - public var Conversation_MessageDialogDelete: String { return self._s[1106]! } - public var Privacy_Calls_CustomHelp: String { return self._s[1108]! } - public var Message_Wallpaper: String { return self._s[1109]! } - public var MemberSearch_BotSection: String { return self._s[1110]! } - public var GroupInfo_SetSound: String { return self._s[1111]! } - public var Wallet_Send_EncryptComment: String { return self._s[1112]! } + public var StickerPacksSettings_Title: String { return self._s[1107]! } + public var Conversation_MessageDialogDelete: String { return self._s[1108]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1110]! } + public var Message_Wallpaper: String { return self._s[1111]! } + public var MemberSearch_BotSection: String { return self._s[1112]! } + public var GroupInfo_SetSound: String { return self._s[1113]! } + public var Wallet_Send_EncryptComment: String { return self._s[1114]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1113]!, self._r[1113]!, [_0]) + return formatWithArgumentRanges(self._s[1115]!, self._r[1115]!, [_0]) } - public var Core_ServiceUserStatus: String { return self._s[1114]! } - public var LiveLocationUpdated_JustNow: String { return self._s[1115]! } - public var Call_StatusFailed: String { return self._s[1116]! } - public var TwoFactorSetup_Email_Placeholder: String { return self._s[1117]! } - public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1118]! } - public var TwoStepAuth_SetPassword: String { return self._s[1119]! } - public var Permissions_PeopleNearbyText_v0: String { return self._s[1120]! } + public var Core_ServiceUserStatus: String { return self._s[1116]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1117]! } + public var Call_StatusFailed: String { return self._s[1118]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1119]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1120]! } + public var TwoStepAuth_SetPassword: String { return self._s[1121]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1122]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1122]!, self._r[1122]!, [_0]) + return formatWithArgumentRanges(self._s[1124]!, self._r[1124]!, [_0]) } - public var Calls_SubmitRating: String { return self._s[1123]! } - public var Map_NoPlacesNearby: String { return self._s[1124]! } - public var Profile_Username: String { return self._s[1125]! } - public var Bot_DescriptionTitle: String { return self._s[1126]! } - public var MaskStickerSettings_Title: String { return self._s[1127]! } - public var SharedMedia_CategoryOther: String { return self._s[1128]! } - public var GroupInfo_SetGroupPhoto: String { return self._s[1129]! } - public var Common_NotNow: String { return self._s[1130]! } - public var CallFeedback_IncludeLogsInfo: String { return self._s[1131]! } - public var Conversation_ShareMyPhoneNumber: String { return self._s[1132]! } - public var Map_Location: String { return self._s[1133]! } - public var Invitation_JoinGroup: String { return self._s[1134]! } - public var AutoDownloadSettings_Title: String { return self._s[1136]! } - public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1137]! } - public var Channel_ErrorAddBlocked: String { return self._s[1138]! } - public var ChatList_AddChatsToFolder: String { return self._s[1139]! } - public var Conversation_UnblockUser: String { return self._s[1140]! } - public var EditTheme_Edit_TopInfo: String { return self._s[1141]! } - public var Watch_Bot_Restart: String { return self._s[1142]! } - public var TwoStepAuth_Title: String { return self._s[1143]! } - public var Channel_AdminLog_BanSendMessages: String { return self._s[1144]! } - public var Checkout_ShippingMethod: String { return self._s[1145]! } - public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1146]! } + public var Calls_SubmitRating: String { return self._s[1125]! } + public var Map_NoPlacesNearby: String { return self._s[1126]! } + public var Profile_Username: String { return self._s[1127]! } + public var Bot_DescriptionTitle: String { return self._s[1128]! } + public var MaskStickerSettings_Title: String { return self._s[1129]! } + public var SharedMedia_CategoryOther: String { return self._s[1130]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1131]! } + public var Common_NotNow: String { return self._s[1132]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1133]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1134]! } + public var Map_Location: String { return self._s[1135]! } + public var Invitation_JoinGroup: String { return self._s[1136]! } + public var AutoDownloadSettings_Title: String { return self._s[1138]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1139]! } + public var Channel_ErrorAddBlocked: String { return self._s[1140]! } + public var ChatList_AddChatsToFolder: String { return self._s[1141]! } + public var Conversation_UnblockUser: String { return self._s[1142]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1143]! } + public var Watch_Bot_Restart: String { return self._s[1144]! } + public var TwoStepAuth_Title: String { return self._s[1145]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1146]! } + public var Checkout_ShippingMethod: String { return self._s[1147]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1148]! } public func PUSH_CHAT_MESSAGE_STICKER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1147]!, self._r[1147]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1149]!, self._r[1149]!, [_1, _2, _3]) } - public var PeerInfo_ButtonDiscuss: String { return self._s[1148]! } - public var EditTheme_ChangeColors: String { return self._s[1150]! } + public var PeerInfo_ButtonDiscuss: String { return self._s[1150]! } + public var EditTheme_ChangeColors: String { return self._s[1152]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1151]!, self._r[1151]!, [_0]) + return formatWithArgumentRanges(self._s[1153]!, self._r[1153]!, [_0]) } public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1152]!, self._r[1152]!, [_0]) + return formatWithArgumentRanges(self._s[1154]!, self._r[1154]!, [_0]) } - public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1153]! } - public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1155]! } - public var AuthSessions_TerminateOtherSessions: String { return self._s[1156]! } - public var Contacts_FailedToSendInvitesMessage: String { return self._s[1157]! } - public var PrivacySettings_TwoStepAuth: String { return self._s[1158]! } - public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1159]! } - public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1160]! } - public var Conversation_EditingMessagePanelMedia: String { return self._s[1161]! } - public var Checkout_PaymentMethod_Title: String { return self._s[1162]! } - public var SocksProxySetup_Connection: String { return self._s[1163]! } - public var Group_MessagePhotoRemoved: String { return self._s[1164]! } - public var PeopleNearby_MakeInvisible: String { return self._s[1166]! } - public var Channel_Stickers_NotFound: String { return self._s[1168]! } - public var Group_About_Help: String { return self._s[1169]! } - public var Notification_PassportValueProofOfIdentity: String { return self._s[1170]! } - public var PeopleNearby_Title: String { return self._s[1172]! } + public var Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1155]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1157]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1158]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1159]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1160]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1161]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1162]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1163]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1164]! } + public var SocksProxySetup_Connection: String { return self._s[1165]! } + public var Group_MessagePhotoRemoved: String { return self._s[1166]! } + public var PeopleNearby_MakeInvisible: String { return self._s[1168]! } + public var Channel_Stickers_NotFound: String { return self._s[1170]! } + public var Group_About_Help: String { return self._s[1171]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1172]! } + public var PeopleNearby_Title: String { return self._s[1174]! } public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1173]!, self._r[1173]!, [_1]) + return formatWithArgumentRanges(self._s[1175]!, self._r[1175]!, [_1]) } - public var Map_Home: String { return self._s[1174]! } - public var Stats_ZoomOut: String { return self._s[1175]! } - public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1177]! } - public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1178]! } - public var SocksProxySetup_Password: String { return self._s[1179]! } - public var Notifications_PermissionsEnable: String { return self._s[1180]! } - public var TwoStepAuth_ChangeEmail: String { return self._s[1182]! } + public var Map_Home: String { return self._s[1176]! } + public var Stats_ZoomOut: String { return self._s[1177]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1179]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1180]! } + public var SocksProxySetup_Password: String { return self._s[1181]! } + public var Notifications_PermissionsEnable: String { return self._s[1182]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1184]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1183]!, self._r[1183]!, [_1]) + return formatWithArgumentRanges(self._s[1185]!, self._r[1185]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1185]!, self._r[1185]!, [_0]) + return formatWithArgumentRanges(self._s[1187]!, self._r[1187]!, [_0]) } - public var Passport_Identity_TypeDriversLicense: String { return self._s[1186]! } - public var ArchivedPacksAlert_Title: String { return self._s[1187]! } - public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1188]! } - public var Map_PlacesNearby: String { return self._s[1189]! } + public var Passport_Identity_TypeDriversLicense: String { return self._s[1188]! } + public var ArchivedPacksAlert_Title: String { return self._s[1189]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1190]! } + public var Map_PlacesNearby: String { return self._s[1191]! } public func Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1190]!, self._r[1190]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1192]!, self._r[1192]!, [_1, _2, _3]) } - public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1191]! } - public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1194]! } - public var Conversation_StatusTyping: String { return self._s[1195]! } - public var Widget_ApplicationStartRequired: String { return self._s[1196]! } - public var Broadcast_AdminLog_EmptyText: String { return self._s[1197]! } - public var Notification_PassportValueProofOfAddress: String { return self._s[1198]! } - public var UserInfo_CreateNewContact: String { return self._s[1199]! } - public var Passport_Identity_FrontSide: String { return self._s[1200]! } - public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1201]! } - public var Calls_CallTabTitle: String { return self._s[1202]! } - public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1203]! } + public var PrivacyLastSeenSettings_GroupsAndChannelsHelp: String { return self._s[1193]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1196]! } + public var Conversation_StatusTyping: String { return self._s[1197]! } + public var Widget_ApplicationStartRequired: String { return self._s[1198]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1199]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1200]! } + public var UserInfo_CreateNewContact: String { return self._s[1201]! } + public var Passport_Identity_FrontSide: String { return self._s[1202]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1203]! } + public var Calls_CallTabTitle: String { return self._s[1204]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1205]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1205]!, self._r[1205]!, [_0]) + return formatWithArgumentRanges(self._s[1207]!, self._r[1207]!, [_0]) } - public var Watch_UserInfo_MuteTitle: String { return self._s[1206]! } - public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1207]! } - public var SharedMedia_EmptyMusicText: String { return self._s[1208]! } - public var Wallet_Completed_Text: String { return self._s[1209]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1210]! } - public var Paint_Stickers: String { return self._s[1211]! } - public var Privacy_GroupsAndChannels: String { return self._s[1212]! } - public var ChatList_Context_Delete: String { return self._s[1214]! } - public var UserInfo_AddContact: String { return self._s[1215]! } + public var Watch_UserInfo_MuteTitle: String { return self._s[1208]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1209]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1210]! } + public var Wallet_Completed_Text: String { return self._s[1211]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1212]! } + public var Paint_Stickers: String { return self._s[1213]! } + public var Privacy_GroupsAndChannels: String { return self._s[1214]! } + public var ChatList_Context_Delete: String { return self._s[1216]! } + public var UserInfo_AddContact: String { return self._s[1217]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1216]!, self._r[1216]!, [_0]) + return formatWithArgumentRanges(self._s[1218]!, self._r[1218]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1218]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1220]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1220]!, self._r[1220]!, [_0]) + return formatWithArgumentRanges(self._s[1222]!, self._r[1222]!, [_0]) } - public var DialogList_NoMessagesTitle: String { return self._s[1221]! } - public var EditProfile_NameAndPhotoHelp: String { return self._s[1222]! } - public var BlockedUsers_BlockUser: String { return self._s[1223]! } - public var Notifications_PermissionsOpenSettings: String { return self._s[1224]! } - public var MediaPicker_UngroupDescription: String { return self._s[1226]! } - public var Watch_NoConnection: String { return self._s[1227]! } - public var Month_GenSeptember: String { return self._s[1228]! } - public var Conversation_ViewGroup: String { return self._s[1230]! } - public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1233]! } - public var Privacy_Forwards_AlwaysLink: String { return self._s[1234]! } - public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1235]! } - public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1236]! } - public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1237]! } - public var MediaPicker_CameraRoll: String { return self._s[1239]! } - public var Month_GenAugust: String { return self._s[1240]! } - public var Wallet_Configuration_SourceHeader: String { return self._s[1241]! } - public var AccessDenied_VideoMessageMicrophone: String { return self._s[1242]! } - public var SharedMedia_EmptyText: String { return self._s[1243]! } - public var Map_ShareLiveLocation: String { return self._s[1244]! } - public var Calls_All: String { return self._s[1245]! } - public var Map_SendThisPlace: String { return self._s[1247]! } - public var Appearance_ThemeNight: String { return self._s[1249]! } - public var Conversation_HoldForAudio: String { return self._s[1250]! } - public var SettingsSearch_Synonyms_Support: String { return self._s[1253]! } - public var GroupInfo_GroupHistoryHidden: String { return self._s[1254]! } - public var SocksProxySetup_Secret: String { return self._s[1255]! } + public var DialogList_NoMessagesTitle: String { return self._s[1223]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1224]! } + public var BlockedUsers_BlockUser: String { return self._s[1225]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1226]! } + public var MediaPicker_UngroupDescription: String { return self._s[1228]! } + public var Watch_NoConnection: String { return self._s[1229]! } + public var Month_GenSeptember: String { return self._s[1230]! } + public var Conversation_ViewGroup: String { return self._s[1232]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1235]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1236]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1237]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1238]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1239]! } + public var MediaPicker_CameraRoll: String { return self._s[1241]! } + public var Month_GenAugust: String { return self._s[1242]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1243]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1244]! } + public var SharedMedia_EmptyText: String { return self._s[1245]! } + public var Map_ShareLiveLocation: String { return self._s[1246]! } + public var Calls_All: String { return self._s[1247]! } + public var Map_SendThisPlace: String { return self._s[1249]! } + public var Appearance_ThemeNight: String { return self._s[1251]! } + public var Conversation_HoldForAudio: String { return self._s[1252]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1255]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1256]! } + public var SocksProxySetup_Secret: String { return self._s[1257]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1256]!, self._r[1256]!, [_0]) + return formatWithArgumentRanges(self._s[1258]!, self._r[1258]!, [_0]) } - public var Channel_BanList_RestrictedTitle: String { return self._s[1258]! } - public var Conversation_Location: String { return self._s[1259]! } + public var Channel_BanList_RestrictedTitle: String { return self._s[1260]! } + public var Conversation_Location: String { return self._s[1261]! } public func AutoDownloadSettings_UpToFor(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1260]!, self._r[1260]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1262]!, self._r[1262]!, [_1, _2]) } - public var ChatSettings_AutoDownloadPhotos: String { return self._s[1262]! } - public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1263]! } - public var Notifications_PermissionsText: String { return self._s[1264]! } - public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1265]! } - public var Call_Flip: String { return self._s[1266]! } - public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1268]! } - public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1269]! } - public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1270]! } - public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1271]! } - public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1273]! } - public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1275]! } - public var ChatList_EditFolders: String { return self._s[1277]! } - public var Channel_TooMuchBots: String { return self._s[1278]! } - public var Passport_DeletePassportConfirmation: String { return self._s[1279]! } - public var Login_InvalidCodeError: String { return self._s[1280]! } - public var StickerPacksSettings_FeaturedPacks: String { return self._s[1281]! } + public var ChatSettings_AutoDownloadPhotos: String { return self._s[1264]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1265]! } + public var Notifications_PermissionsText: String { return self._s[1266]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1267]! } + public var Call_Flip: String { return self._s[1268]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1270]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1271]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1272]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1273]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1275]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1277]! } + public var ChatList_EditFolders: String { return self._s[1279]! } + public var Channel_TooMuchBots: String { return self._s[1280]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1281]! } + public var Login_InvalidCodeError: String { return self._s[1282]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1283]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1282]!, self._r[1282]!, [_0]) + return formatWithArgumentRanges(self._s[1284]!, self._r[1284]!, [_0]) } public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1283]!, self._r[1283]!, [_0]) + return formatWithArgumentRanges(self._s[1285]!, self._r[1285]!, [_0]) } - public var VoiceOver_Navigation_ProxySettings: String { return self._s[1284]! } - public var Call_CallInProgressTitle: String { return self._s[1285]! } - public var Month_ShortSeptember: String { return self._s[1286]! } - public var Watch_ChannelInfo_Title: String { return self._s[1287]! } - public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1290]! } - public var DialogList_PasscodeLockHelp: String { return self._s[1291]! } - public var Chat_MultipleTextMessagesDisabled: String { return self._s[1292]! } - public var Wallet_Receive_Title: String { return self._s[1293]! } - public var Notifications_Badge_IncludePublicGroups: String { return self._s[1294]! } - public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1295]! } - public var PhotoEditor_CropReset: String { return self._s[1296]! } - public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1298]! } - public var Channel_Management_LabelEditor: String { return self._s[1299]! } - public var Passport_Identity_LatinNameHelp: String { return self._s[1301]! } - public var PhotoEditor_HighlightsTool: String { return self._s[1302]! } - public var Wallet_Info_WalletCreated: String { return self._s[1303]! } - public var UserInfo_Title: String { return self._s[1304]! } - public var ChatList_HideAction: String { return self._s[1305]! } - public var AccessDenied_Title: String { return self._s[1306]! } - public var DialogList_SearchLabel: String { return self._s[1307]! } - public var Group_Setup_HistoryHidden: String { return self._s[1308]! } - public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1309]! } - public var State_Updating: String { return self._s[1311]! } - public var Contacts_TabTitle: String { return self._s[1312]! } - public var Notifications_Badge_CountUnreadMessages: String { return self._s[1314]! } - public var GroupInfo_GroupHistory: String { return self._s[1315]! } - public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1316]! } - public var Wallpaper_SetColor: String { return self._s[1317]! } - public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1318]! } - public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1319]! } - public var ChatList_ReorderTabs: String { return self._s[1320]! } - public var ChatListFolder_IncludeChatsTitle: String { return self._s[1321]! } - public var Chat_AttachmentLimitReached: String { return self._s[1322]! } - public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1323]! } - public var Contacts_NotRegisteredSection: String { return self._s[1324]! } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1286]! } + public var Call_CallInProgressTitle: String { return self._s[1287]! } + public var Month_ShortSeptember: String { return self._s[1288]! } + public var Watch_ChannelInfo_Title: String { return self._s[1289]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1292]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1293]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1294]! } + public var Wallet_Receive_Title: String { return self._s[1295]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1296]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1297]! } + public var PhotoEditor_CropReset: String { return self._s[1298]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1300]! } + public var Channel_Management_LabelEditor: String { return self._s[1301]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1303]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1304]! } + public var Wallet_Info_WalletCreated: String { return self._s[1305]! } + public var UserInfo_Title: String { return self._s[1306]! } + public var ChatList_HideAction: String { return self._s[1307]! } + public var AccessDenied_Title: String { return self._s[1308]! } + public var DialogList_SearchLabel: String { return self._s[1309]! } + public var Group_Setup_HistoryHidden: String { return self._s[1310]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1311]! } + public var State_Updating: String { return self._s[1313]! } + public var Contacts_TabTitle: String { return self._s[1314]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1316]! } + public var GroupInfo_GroupHistory: String { return self._s[1317]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1318]! } + public var Wallpaper_SetColor: String { return self._s[1319]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1320]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1321]! } + public var ChatList_ReorderTabs: String { return self._s[1322]! } + public var ChatListFolder_IncludeChatsTitle: String { return self._s[1323]! } + public var Chat_AttachmentLimitReached: String { return self._s[1324]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1325]! } + public var Contacts_NotRegisteredSection: String { return self._s[1326]! } public func Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1325]!, self._r[1325]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1327]!, self._r[1327]!, [_1, _2, _3]) } - public var Paint_Clear: String { return self._s[1326]! } - public var StickerPacksSettings_ArchivedMasks: String { return self._s[1327]! } - public var SocksProxySetup_Connecting: String { return self._s[1328]! } - public var ExplicitContent_AlertChannel: String { return self._s[1329]! } - public var CreatePoll_AllOptionsAdded: String { return self._s[1330]! } - public var Conversation_Contact: String { return self._s[1331]! } - public var Login_CodeExpired: String { return self._s[1332]! } - public var Passport_DiscardMessageAction: String { return self._s[1333]! } - public var ChatList_Context_Unpin: String { return self._s[1334]! } - public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1335]! } + public var Paint_Clear: String { return self._s[1328]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1329]! } + public var SocksProxySetup_Connecting: String { return self._s[1330]! } + public var ExplicitContent_AlertChannel: String { return self._s[1331]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1332]! } + public var Conversation_Contact: String { return self._s[1333]! } + public var Login_CodeExpired: String { return self._s[1334]! } + public var Passport_DiscardMessageAction: String { return self._s[1335]! } + public var ChatList_Context_Unpin: String { return self._s[1336]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1337]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1336]!, self._r[1336]!, [_0]) + return formatWithArgumentRanges(self._s[1338]!, self._r[1338]!, [_0]) } - public var Channel_AdminLog_EmptyMessageText: String { return self._s[1337]! } - public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1338]! } + public var Channel_AdminLog_EmptyMessageText: String { return self._s[1339]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1340]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1339]!, self._r[1339]!, [_0]) + return formatWithArgumentRanges(self._s[1341]!, self._r[1341]!, [_0]) } - public var Month_ShortApril: String { return self._s[1340]! } - public var AuthSessions_CurrentSession: String { return self._s[1341]! } - public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1344]! } - public var Wallet_Navigation_Cancel: String { return self._s[1346]! } - public var WallpaperPreview_CropTopText: String { return self._s[1347]! } - public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1348]! } - public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1349]! } + public var Month_ShortApril: String { return self._s[1342]! } + public var AuthSessions_CurrentSession: String { return self._s[1343]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1346]! } + public var Wallet_Navigation_Cancel: String { return self._s[1348]! } + public var WallpaperPreview_CropTopText: String { return self._s[1349]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1350]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1351]! } public func Conversation_ScheduleMessage_SendOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1350]!, self._r[1350]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1352]!, self._r[1352]!, [_0, _1]) } - public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1351]! } - public var Channel_Setup_TypePrivate: String { return self._s[1353]! } - public var Forward_ChannelReadOnly: String { return self._s[1356]! } - public var PhotoEditor_CurvesBlue: String { return self._s[1357]! } - public var AddContact_SharedContactException: String { return self._s[1358]! } - public var UserInfo_BotPrivacy: String { return self._s[1360]! } - public var Wallet_CreateInvoice_Title: String { return self._s[1361]! } - public var Notification_PassportValueEmail: String { return self._s[1362]! } - public var EmptyGroupInfo_Subtitle: String { return self._s[1363]! } - public var GroupPermission_NewTitle: String { return self._s[1364]! } - public var CallFeedback_ReasonDropped: String { return self._s[1365]! } - public var GroupInfo_Permissions_AddException: String { return self._s[1366]! } - public var Channel_SignMessages_Help: String { return self._s[1368]! } - public var Undo_ChatDeleted: String { return self._s[1370]! } - public var Conversation_ChatBackground: String { return self._s[1371]! } + public var Appearance_ThemePreview_Chat_2_Text: String { return self._s[1353]! } + public var Channel_Setup_TypePrivate: String { return self._s[1355]! } + public var Forward_ChannelReadOnly: String { return self._s[1358]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1359]! } + public var AddContact_SharedContactException: String { return self._s[1360]! } + public var UserInfo_BotPrivacy: String { return self._s[1362]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1363]! } + public var Notification_PassportValueEmail: String { return self._s[1364]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1365]! } + public var GroupPermission_NewTitle: String { return self._s[1366]! } + public var CallFeedback_ReasonDropped: String { return self._s[1367]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1368]! } + public var Channel_SignMessages_Help: String { return self._s[1370]! } + public var Undo_ChatDeleted: String { return self._s[1372]! } + public var Conversation_ChatBackground: String { return self._s[1373]! } public func Wallet_WordCheck_Text(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1372]!, self._r[1372]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1374]!, self._r[1374]!, [_1, _2, _3]) } public func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1373]!, self._r[1373]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1375]!, self._r[1375]!, [_1, _2, _3]) } - public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1374]! } - public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1375]! } - public var Passport_Language_pt: String { return self._s[1376]! } - public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1377]! } - public var NotificationsSound_Popcorn: String { return self._s[1380]! } - public var AutoNightTheme_Disabled: String { return self._s[1381]! } - public var BlockedUsers_LeavePrefix: String { return self._s[1382]! } - public var WallpaperPreview_CustomColorTopText: String { return self._s[1383]! } - public var Contacts_PermissionsSuppressWarningText: String { return self._s[1384]! } - public var WallpaperSearch_ColorBlue: String { return self._s[1385]! } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1376]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1377]! } + public var Passport_Language_pt: String { return self._s[1378]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1379]! } + public var NotificationsSound_Popcorn: String { return self._s[1382]! } + public var AutoNightTheme_Disabled: String { return self._s[1383]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1384]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1385]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1386]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1387]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1386]!, self._r[1386]!, [_0]) + return formatWithArgumentRanges(self._s[1388]!, self._r[1388]!, [_0]) } - public var ChatListFolder_TitleCreate: String { return self._s[1387]! } - public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1388]! } - public var SocksProxySetup_UseForCalls: String { return self._s[1389]! } - public var Passport_DeleteDocumentConfirmation: String { return self._s[1391]! } - public var PeerInfo_PaneGroups: String { return self._s[1392]! } + public var ChatListFolder_TitleCreate: String { return self._s[1389]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1390]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1391]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1393]! } + public var PeerInfo_PaneGroups: String { return self._s[1394]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1393]!, self._r[1393]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1395]!, self._r[1395]!, ["\(_0)"]) } - public var SocksProxySetup_Hostname: String { return self._s[1396]! } - public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1397]! } - public var Compose_NewEncryptedChat: String { return self._s[1398]! } - public var Login_CodeFloodError: String { return self._s[1399]! } - public var Calls_TabTitle: String { return self._s[1400]! } - public var Privacy_ProfilePhoto: String { return self._s[1401]! } - public var Passport_Language_he: String { return self._s[1402]! } + public var SocksProxySetup_Hostname: String { return self._s[1398]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1399]! } + public var Compose_NewEncryptedChat: String { return self._s[1400]! } + public var Login_CodeFloodError: String { return self._s[1401]! } + public var Calls_TabTitle: String { return self._s[1402]! } + public var Privacy_ProfilePhoto: String { return self._s[1403]! } + public var Passport_Language_he: String { return self._s[1404]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1403]!, self._r[1403]!, [_0]) + return formatWithArgumentRanges(self._s[1405]!, self._r[1405]!, [_0]) } - public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[1404]! } - public var GroupPermission_Title: String { return self._s[1405]! } + public var ChatList_TabIconFoldersTooltipNonEmptyFolders: String { return self._s[1406]! } + public var GroupPermission_Title: String { return self._s[1407]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1406]!, self._r[1406]!, [_0]) + return formatWithArgumentRanges(self._s[1408]!, self._r[1408]!, [_0]) } - public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1407]! } - public var GroupPermission_NoChangeInfo: String { return self._s[1408]! } - public var ChatList_DeleteForCurrentUser: String { return self._s[1409]! } - public var Tour_Text1: String { return self._s[1410]! } - public var Channel_EditAdmin_TransferOwnership: String { return self._s[1411]! } - public var Month_ShortFebruary: String { return self._s[1412]! } - public var TwoStepAuth_EmailSkip: String { return self._s[1413]! } + public var Wallet_TransactionInfo_SenderHeader: String { return self._s[1409]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1410]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1411]! } + public var Tour_Text1: String { return self._s[1412]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1413]! } + public var Month_ShortFebruary: String { return self._s[1414]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1415]! } public func Wallet_Time_PreciseDate_m4(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1414]!, self._r[1414]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1416]!, self._r[1416]!, [_1, _2, _3]) } - public var Stats_LanguagesTitle: String { return self._s[1415]! } - public var NotificationsSound_Glass: String { return self._s[1416]! } - public var Appearance_ThemeNightBlue: String { return self._s[1417]! } - public var CheckoutInfo_Pay: String { return self._s[1418]! } - public var PeerInfo_ButtonLeave: String { return self._s[1420]! } - public var Invite_LargeRecipientsCountWarning: String { return self._s[1421]! } - public var Call_CallAgain: String { return self._s[1423]! } - public var AttachmentMenu_SendAsFile: String { return self._s[1424]! } - public var AccessDenied_MicrophoneRestricted: String { return self._s[1425]! } - public var Passport_InvalidPasswordError: String { return self._s[1426]! } - public var Watch_Message_Game: String { return self._s[1427]! } - public var Stickers_Install: String { return self._s[1428]! } - public var VoiceOver_Chat_Message: String { return self._s[1429]! } - public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1430]! } - public var Passport_Identity_ResidenceCountry: String { return self._s[1432]! } - public var Notifications_GroupNotificationsHelp: String { return self._s[1433]! } - public var AuthSessions_OtherSessions: String { return self._s[1434]! } - public var Channel_Username_Help: String { return self._s[1435]! } - public var Camera_Title: String { return self._s[1436]! } - public var IntentsSettings_Title: String { return self._s[1437]! } - public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1439]! } - public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1440]! } - public var Channel_AdminLog_SendPolls: String { return self._s[1441]! } - public var Channel_AdminLog_TitleAllEvents: String { return self._s[1442]! } - public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1443]! } - public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1444]! } - public var ScheduledMessages_DeleteMany: String { return self._s[1445]! } - public var Conversation_RestrictedStickers: String { return self._s[1446]! } - public var Notifications_ExceptionsResetToDefaults: String { return self._s[1448]! } - public var UserInfo_TelegramCall: String { return self._s[1450]! } - public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1451]! } - public var CreatePoll_OptionsHeader: String { return self._s[1452]! } - public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1453]! } - public var ArchivedChats_IntroTitle1: String { return self._s[1454]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1455]! } - public var Theme_Colors_Proceed: String { return self._s[1456]! } - public var Passport_Identity_EditPersonalDetails: String { return self._s[1457]! } + public var Stats_LanguagesTitle: String { return self._s[1417]! } + public var NotificationsSound_Glass: String { return self._s[1418]! } + public var Appearance_ThemeNightBlue: String { return self._s[1419]! } + public var CheckoutInfo_Pay: String { return self._s[1420]! } + public var PeerInfo_ButtonLeave: String { return self._s[1422]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1423]! } + public var Call_CallAgain: String { return self._s[1425]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1426]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1427]! } + public var Passport_InvalidPasswordError: String { return self._s[1428]! } + public var Watch_Message_Game: String { return self._s[1429]! } + public var Stickers_Install: String { return self._s[1430]! } + public var VoiceOver_Chat_Message: String { return self._s[1431]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1432]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1434]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1435]! } + public var AuthSessions_OtherSessions: String { return self._s[1436]! } + public var Channel_Username_Help: String { return self._s[1437]! } + public var Camera_Title: String { return self._s[1438]! } + public var IntentsSettings_Title: String { return self._s[1439]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1441]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1442]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1443]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1444]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1445]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1446]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1447]! } + public var Conversation_RestrictedStickers: String { return self._s[1448]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1450]! } + public var UserInfo_TelegramCall: String { return self._s[1452]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1453]! } + public var CreatePoll_OptionsHeader: String { return self._s[1454]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1455]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1456]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1457]! } + public var Theme_Colors_Proceed: String { return self._s[1458]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1459]! } public func Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1458]!, self._r[1458]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1460]!, self._r[1460]!, [_1, _2, _3]) } - public var Wallet_Month_GenAugust: String { return self._s[1459]! } - public var Settings_SaveEditedPhotos: String { return self._s[1460]! } - public var Stats_FollowersBySourceTitle: String { return self._s[1461]! } - public var TwoStepAuth_ConfirmationTitle: String { return self._s[1462]! } - public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1463]! } - public var Conversation_MessageDialogRetry: String { return self._s[1464]! } - public var ChatList_Context_MarkAsUnread: String { return self._s[1465]! } - public var MessagePoll_SubmitVote: String { return self._s[1466]! } - public var Conversation_DiscardVoiceMessageAction: String { return self._s[1467]! } - public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1468]! } - public var ChatList_Context_Back: String { return self._s[1469]! } - public var Group_Setup_TypeHeader: String { return self._s[1470]! } - public var Paint_RecentStickers: String { return self._s[1471]! } - public var PhotoEditor_GrainTool: String { return self._s[1472]! } - public var CheckoutInfo_ShippingInfoState: String { return self._s[1473]! } - public var EmptyGroupInfo_Line4: String { return self._s[1474]! } - public var Watch_AuthRequired: String { return self._s[1476]! } + public var Wallet_Month_GenAugust: String { return self._s[1461]! } + public var Settings_SaveEditedPhotos: String { return self._s[1462]! } + public var Stats_FollowersBySourceTitle: String { return self._s[1463]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1464]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1465]! } + public var Conversation_MessageDialogRetry: String { return self._s[1466]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1467]! } + public var MessagePoll_SubmitVote: String { return self._s[1468]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1469]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1470]! } + public var ChatList_Context_Back: String { return self._s[1471]! } + public var Group_Setup_TypeHeader: String { return self._s[1472]! } + public var Paint_RecentStickers: String { return self._s[1473]! } + public var PhotoEditor_GrainTool: String { return self._s[1474]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1475]! } + public var EmptyGroupInfo_Line4: String { return self._s[1476]! } + public var Watch_AuthRequired: String { return self._s[1478]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_0]) + return formatWithArgumentRanges(self._s[1479]!, self._r[1479]!, [_0]) } - public var Conversation_EncryptedDescriptionTitle: String { return self._s[1478]! } - public var ChannelIntro_Text: String { return self._s[1479]! } - public var DialogList_DeleteBotConfirmation: String { return self._s[1480]! } - public var GroupPermission_NoSendMedia: String { return self._s[1481]! } - public var Calls_AddTab: String { return self._s[1482]! } - public var Message_ReplyActionButtonShowReceipt: String { return self._s[1483]! } - public var Channel_AdminLog_EmptyFilterText: String { return self._s[1484]! } - public var Conversation_WalletRequiredSetup: String { return self._s[1485]! } - public var Notification_MessageLifetime1d: String { return self._s[1486]! } - public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1487]! } - public var Channel_BanUser_PermissionsHeader: String { return self._s[1488]! } - public var Passport_Identity_GenderFemale: String { return self._s[1489]! } - public var BlockedUsers_BlockTitle: String { return self._s[1490]! } + public var Conversation_EncryptedDescriptionTitle: String { return self._s[1480]! } + public var ChannelIntro_Text: String { return self._s[1481]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1482]! } + public var GroupPermission_NoSendMedia: String { return self._s[1483]! } + public var Calls_AddTab: String { return self._s[1484]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1485]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1486]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1487]! } + public var Notification_MessageLifetime1d: String { return self._s[1488]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1489]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1490]! } + public var Passport_Identity_GenderFemale: String { return self._s[1491]! } + public var BlockedUsers_BlockTitle: String { return self._s[1492]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1491]!, self._r[1491]!, [_1]) + return formatWithArgumentRanges(self._s[1493]!, self._r[1493]!, [_1]) } - public var Weekday_Yesterday: String { return self._s[1492]! } - public var WallpaperSearch_ColorBlack: String { return self._s[1493]! } - public var Settings_Context_Logout: String { return self._s[1494]! } - public var Wallet_Info_UnknownTransaction: String { return self._s[1495]! } - public var ChatList_ArchiveAction: String { return self._s[1496]! } - public var AutoNightTheme_Scheduled: String { return self._s[1497]! } - public var TwoFactorSetup_Email_SkipAction: String { return self._s[1498]! } - public var Settings_Devices: String { return self._s[1499]! } - public var ContactInfo_Note: String { return self._s[1500]! } + public var Weekday_Yesterday: String { return self._s[1494]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1495]! } + public var Settings_Context_Logout: String { return self._s[1496]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1497]! } + public var ChatList_ArchiveAction: String { return self._s[1498]! } + public var AutoNightTheme_Scheduled: String { return self._s[1499]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1500]! } + public var Settings_Devices: String { return self._s[1501]! } + public var ContactInfo_Note: String { return self._s[1502]! } public func Login_PhoneGenericEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String, _ _6: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1501]!, self._r[1501]!, [_1, _2, _3, _4, _5, _6]) + return formatWithArgumentRanges(self._s[1503]!, self._r[1503]!, [_1, _2, _3, _4, _5, _6]) } - public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1502]! } - public var Wallet_Receive_CreateInvoice: String { return self._s[1503]! } - public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1504]! } - public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1505]! } + public var EditTheme_ThemeTemplateAlertTitle: String { return self._s[1504]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1505]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1506]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1507]! } public func PUSH_CHAT_JOINED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1506]!, self._r[1506]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1508]!, self._r[1508]!, [_1, _2]) } - public var CreatePoll_Create: String { return self._s[1507]! } - public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1508]! } + public var CreatePoll_Create: String { return self._s[1509]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1510]! } public func Notification_CallFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1509]!, self._r[1509]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1511]!, self._r[1511]!, [_1, _2]) } - public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1510]! } - public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1511]! } - public var Notifications_InAppNotificationsSounds: String { return self._s[1513]! } + public var ScheduledMessages_ClearAllConfirmation: String { return self._s[1512]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1513]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1515]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1514]!, self._r[1514]!, [_1]) + return formatWithArgumentRanges(self._s[1516]!, self._r[1516]!, [_1]) } - public var Preview_OpenInInstagram: String { return self._s[1515]! } - public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1516]! } + public var Preview_OpenInInstagram: String { return self._s[1517]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1518]! } public func PUSH_CHAT_ADD_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1517]!, self._r[1517]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1519]!, self._r[1519]!, [_1, _2, _3]) } public func Passport_PrivacyPolicy(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1518]!, self._r[1518]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1520]!, self._r[1520]!, [_1, _2]) } - public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1519]! } - public var ArchivedChats_IntroText3: String { return self._s[1520]! } - public var ChatList_UndoArchiveHiddenText: String { return self._s[1521]! } - public var NetworkUsageSettings_TotalSection: String { return self._s[1522]! } - public var Wallet_Month_GenSeptember: String { return self._s[1523]! } - public var Channel_Setup_TypePrivateHelp: String { return self._s[1524]! } + public var Channel_AdminLog_InfoPanelAlertTitle: String { return self._s[1521]! } + public var ArchivedChats_IntroText3: String { return self._s[1522]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1523]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1524]! } + public var Wallet_Month_GenSeptember: String { return self._s[1525]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1526]! } public func PUSH_CHAT_MESSAGE_POLL(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1525]!, self._r[1525]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1527]!, self._r[1527]!, [_1, _2, _3]) } - public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1527]! } - public var FastTwoStepSetup_HintSection: String { return self._s[1528]! } - public var Wallpaper_PhotoLibrary: String { return self._s[1529]! } - public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1530]! } - public var Gif_NoGifsFound: String { return self._s[1531]! } - public var Watch_LastSeen_WithinAMonth: String { return self._s[1532]! } - public var VoiceOver_MessageContextDelete: String { return self._s[1533]! } - public var EditTheme_Preview: String { return self._s[1534]! } + public var Privacy_GroupsAndChannels_NeverAllow_Placeholder: String { return self._s[1529]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1530]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1531]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1532]! } + public var Gif_NoGifsFound: String { return self._s[1533]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1534]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1535]! } + public var EditTheme_Preview: String { return self._s[1536]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1535]!, self._r[1535]!, [_0]) + return formatWithArgumentRanges(self._s[1537]!, self._r[1537]!, [_0]) } - public var GroupInfo_ActionPromote: String { return self._s[1536]! } - public var PasscodeSettings_SimplePasscode: String { return self._s[1537]! } - public var GroupInfo_Permissions_Title: String { return self._s[1538]! } - public var Permissions_ContactsText_v0: String { return self._s[1539]! } - public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1540]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1541]! } - public var PrivacySettings_DataSettingsHelp: String { return self._s[1544]! } - public var Passport_FieldEmailHelp: String { return self._s[1545]! } + public var GroupInfo_ActionPromote: String { return self._s[1538]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1539]! } + public var GroupInfo_Permissions_Title: String { return self._s[1540]! } + public var Permissions_ContactsText_v0: String { return self._s[1541]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1542]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1543]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1546]! } + public var Passport_FieldEmailHelp: String { return self._s[1547]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1546]!, self._r[1546]!, [_0]) + return formatWithArgumentRanges(self._s[1548]!, self._r[1548]!, [_0]) } - public var Passport_Identity_GenderPlaceholder: String { return self._s[1547]! } - public var Weekday_ShortSaturday: String { return self._s[1548]! } - public var ContactInfo_PhoneLabelMain: String { return self._s[1549]! } - public var Watch_Conversation_UserInfo: String { return self._s[1550]! } - public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1551]! } - public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1552]! } - public var PrivacyLastSeenSettings_Title: String { return self._s[1553]! } - public var Conversation_ShareBotLocationConfirmation: String { return self._s[1555]! } - public var PhotoEditor_VignetteTool: String { return self._s[1556]! } - public var Conversation_ContextMenuDiscuss: String { return self._s[1557]! } - public var Passport_Address_Street1Placeholder: String { return self._s[1558]! } - public var Passport_Language_et: String { return self._s[1559]! } - public var AppUpgrade_Running: String { return self._s[1560]! } - public var Channel_DiscussionGroup_Info: String { return self._s[1562]! } - public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1563]! } - public var Passport_Language_bg: String { return self._s[1564]! } - public var Stickers_NoStickersFound: String { return self._s[1566]! } + public var Passport_Identity_GenderPlaceholder: String { return self._s[1549]! } + public var Weekday_ShortSaturday: String { return self._s[1550]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1551]! } + public var Watch_Conversation_UserInfo: String { return self._s[1552]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1553]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1554]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1555]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1557]! } + public var PhotoEditor_VignetteTool: String { return self._s[1558]! } + public var Conversation_ContextMenuDiscuss: String { return self._s[1559]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1560]! } + public var Passport_Language_et: String { return self._s[1561]! } + public var AppUpgrade_Running: String { return self._s[1562]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1564]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1565]! } + public var Passport_Language_bg: String { return self._s[1566]! } + public var Stickers_NoStickersFound: String { return self._s[1568]! } public func PUSH_CHANNEL_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1568]!, self._r[1568]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1570]!, self._r[1570]!, [_1, _2]) } public func VoiceOver_Chat_ContactFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1569]!, self._r[1569]!, [_0]) + return formatWithArgumentRanges(self._s[1571]!, self._r[1571]!, [_0]) } - public var Wallet_Month_GenJuly: String { return self._s[1570]! } - public var Wallet_Receive_AddressHeader: String { return self._s[1571]! } - public var Wallet_Send_AmountText: String { return self._s[1572]! } - public var Settings_About: String { return self._s[1573]! } + public var Wallet_Month_GenJuly: String { return self._s[1572]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1573]! } + public var Wallet_Send_AmountText: String { return self._s[1574]! } + public var Settings_About: String { return self._s[1575]! } public func Channel_AdminLog_MessageRestricted(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1574]!, self._r[1574]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1576]!, self._r[1576]!, [_0, _1, _2]) } - public var ChatList_Context_MarkAsRead: String { return self._s[1576]! } - public var KeyCommand_NewMessage: String { return self._s[1577]! } - public var Group_ErrorAddBlocked: String { return self._s[1578]! } + public var ChatList_Context_MarkAsRead: String { return self._s[1578]! } + public var KeyCommand_NewMessage: String { return self._s[1579]! } + public var Group_ErrorAddBlocked: String { return self._s[1580]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1579]!, self._r[1579]!, [_0]) + return formatWithArgumentRanges(self._s[1581]!, self._r[1581]!, [_0]) } - public var Map_LocationTitle: String { return self._s[1580]! } - public var ReportGroupLocation_Title: String { return self._s[1581]! } - public var CallSettings_UseLessDataLongDescription: String { return self._s[1582]! } - public var Cache_ClearProgress: String { return self._s[1583]! } + public var Map_LocationTitle: String { return self._s[1582]! } + public var ReportGroupLocation_Title: String { return self._s[1583]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1584]! } + public var Cache_ClearProgress: String { return self._s[1585]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1584]!, self._r[1584]!, [_0]) - } - public var GroupRemoved_AddToGroup: String { return self._s[1585]! } - public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1586]!, self._r[1586]!, [_0]) } - public var Passport_UpdateRequiredError: String { return self._s[1587]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1588]! } + public var GroupRemoved_AddToGroup: String { return self._s[1587]! } + public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1588]!, self._r[1588]!, [_0]) + } + public var Passport_UpdateRequiredError: String { return self._s[1589]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1590]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1589]!, self._r[1589]!, [_1]) + return formatWithArgumentRanges(self._s[1591]!, self._r[1591]!, [_1]) } - public var Notifications_PermissionsSuppressWarningText: String { return self._s[1591]! } - public var Passport_Identity_MainPageHelp: String { return self._s[1592]! } - public var PeerInfo_ButtonSearch: String { return self._s[1593]! } - public var Conversation_StatusKickedFromGroup: String { return self._s[1594]! } - public var Passport_Language_ka: String { return self._s[1595]! } + public var Notifications_PermissionsSuppressWarningText: String { return self._s[1593]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1594]! } + public var PeerInfo_ButtonSearch: String { return self._s[1595]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1596]! } + public var Passport_Language_ka: String { return self._s[1597]! } public func Wallet_Time_PreciseDate_m12(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1596]!, self._r[1596]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1598]!, self._r[1598]!, [_1, _2, _3]) } - public var Call_Decline: String { return self._s[1597]! } - public var SocksProxySetup_ProxyEnabled: String { return self._s[1598]! } - public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1601]! } + public var Call_Decline: String { return self._s[1599]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1600]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1603]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1602]!, self._r[1602]!, [_0]) + return formatWithArgumentRanges(self._s[1604]!, self._r[1604]!, [_0]) } - public var CallFeedback_Send: String { return self._s[1603]! } - public var EditTheme_EditTitle: String { return self._s[1604]! } + public var CallFeedback_Send: String { return self._s[1605]! } + public var EditTheme_EditTitle: String { return self._s[1606]! } public func Channel_AdminLog_MessagePromotedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1605]!, self._r[1605]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1607]!, self._r[1607]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1606]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1608]! } public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1608]!, self._r[1608]!, [_0]) + return formatWithArgumentRanges(self._s[1610]!, self._r[1610]!, [_0]) } - public var Media_SendingOptionsTooltip: String { return self._s[1609]! } - public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1610]! } - public var Passport_DeletePassport: String { return self._s[1611]! } - public var Appearance_AppIconFilled: String { return self._s[1612]! } - public var Privacy_Calls_P2PAlways: String { return self._s[1613]! } - public var Month_ShortDecember: String { return self._s[1614]! } - public var Channel_AdminLog_CanEditMessages: String { return self._s[1616]! } + public var Media_SendingOptionsTooltip: String { return self._s[1611]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1612]! } + public var Passport_DeletePassport: String { return self._s[1613]! } + public var Appearance_AppIconFilled: String { return self._s[1614]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1615]! } + public var Month_ShortDecember: String { return self._s[1616]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1618]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1617]!, self._r[1617]!, [_0]) + return formatWithArgumentRanges(self._s[1619]!, self._r[1619]!, [_0]) } - public var Channel_Stickers_Searching: String { return self._s[1618]! } - public var Conversation_EncryptedDescription1: String { return self._s[1619]! } - public var Conversation_EncryptedDescription2: String { return self._s[1620]! } - public var PasscodeSettings_PasscodeOptions: String { return self._s[1621]! } - public var ChatListFolder_NameUnread: String { return self._s[1623]! } - public var Conversation_EncryptedDescription3: String { return self._s[1624]! } - public var PhotoEditor_SharpenTool: String { return self._s[1625]! } - public var Wallet_Configuration_Title: String { return self._s[1626]! } + public var Channel_Stickers_Searching: String { return self._s[1620]! } + public var Conversation_EncryptedDescription1: String { return self._s[1621]! } + public var Conversation_EncryptedDescription2: String { return self._s[1622]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1623]! } + public var ChatListFolder_NameUnread: String { return self._s[1625]! } + public var Conversation_EncryptedDescription3: String { return self._s[1626]! } + public var PhotoEditor_SharpenTool: String { return self._s[1627]! } + public var Wallet_Configuration_Title: String { return self._s[1628]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1627]!, self._r[1627]!, [_0]) + return formatWithArgumentRanges(self._s[1629]!, self._r[1629]!, [_0]) } - public var Conversation_EncryptedDescription4: String { return self._s[1629]! } - public var Channel_Members_AddMembers: String { return self._s[1630]! } - public var Wallpaper_Search: String { return self._s[1631]! } + public var Conversation_EncryptedDescription4: String { return self._s[1631]! } + public var Channel_Members_AddMembers: String { return self._s[1632]! } + public var Wallpaper_Search: String { return self._s[1633]! } public func Message_GenericForwardedPsa(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1633]!, self._r[1633]!, [_0]) + return formatWithArgumentRanges(self._s[1635]!, self._r[1635]!, [_0]) } - public var Weekday_Friday: String { return self._s[1634]! } - public var Privacy_ContactsSync: String { return self._s[1635]! } - public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1636]! } - public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1637]! } + public var Weekday_Friday: String { return self._s[1636]! } + public var Privacy_ContactsSync: String { return self._s[1637]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1638]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1639]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1638]!, self._r[1638]!, [_0]) + return formatWithArgumentRanges(self._s[1640]!, self._r[1640]!, [_0]) } - public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1639]! } - public var GroupInfo_Permissions_Removed: String { return self._s[1640]! } - public var ScheduledMessages_ScheduledOnline: String { return self._s[1641]! } - public var Passport_Identity_GenderMale: String { return self._s[1642]! } + public var Wallet_Configuration_BlockchainIdHeader: String { return self._s[1641]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1642]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1643]! } + public var Passport_Identity_GenderMale: String { return self._s[1644]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1643]!, self._r[1643]!, [_0]) + return formatWithArgumentRanges(self._s[1645]!, self._r[1645]!, [_0]) } - public var Notifications_PermissionsKeepDisabled: String { return self._s[1644]! } - public var Conversation_JumpToDate: String { return self._s[1645]! } - public var Contacts_GlobalSearch: String { return self._s[1646]! } - public var AutoDownloadSettings_ResetHelp: String { return self._s[1647]! } - public var SettingsSearch_Synonyms_FAQ: String { return self._s[1648]! } - public var ChatListFolderSettings_NewFolder: String { return self._s[1649]! } - public var Profile_MessageLifetime1d: String { return self._s[1650]! } + public var Notifications_PermissionsKeepDisabled: String { return self._s[1646]! } + public var Conversation_JumpToDate: String { return self._s[1647]! } + public var Contacts_GlobalSearch: String { return self._s[1648]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1649]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1650]! } + public var ChatListFolderSettings_NewFolder: String { return self._s[1651]! } + public var Profile_MessageLifetime1d: String { return self._s[1652]! } public func MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1651]!, self._r[1651]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1653]!, self._r[1653]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1654]! } + public var StickerPack_BuiltinPackName: String { return self._s[1656]! } public func PUSH_CHAT_MESSAGE_AUDIO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1655]!, self._r[1655]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1657]!, self._r[1657]!, [_1, _2]) } - public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1656]! } - public var Passport_InfoTitle: String { return self._s[1658]! } - public var Notifications_PermissionsUnreachableText: String { return self._s[1659]! } + public var VoiceOver_Chat_RecordModeVoiceMessageInfo: String { return self._s[1658]! } + public var Passport_InfoTitle: String { return self._s[1660]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1661]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1663]!, self._r[1663]!, [_0]) + return formatWithArgumentRanges(self._s[1665]!, self._r[1665]!, [_0]) } public func PUSH_CHAT_MESSAGE_GEO(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1664]!, self._r[1664]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1666]!, self._r[1666]!, [_1, _2]) } - public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1665]! } - public var Profile_BotInfo: String { return self._s[1666]! } - public var Watch_Compose_CreateMessage: String { return self._s[1667]! } - public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1668]! } - public var Month_ShortNovember: String { return self._s[1669]! } - public var Conversation_ScamWarning: String { return self._s[1670]! } - public var Wallpaper_SetCustomBackground: String { return self._s[1671]! } - public var Appearance_TextSize_Title: String { return self._s[1672]! } - public var ChatList_EmptyChatListFilterTitle: String { return self._s[1673]! } - public var Passport_Identity_TranslationsHelp: String { return self._s[1674]! } - public var NotificationsSound_Chime: String { return self._s[1675]! } - public var Passport_Language_ko: String { return self._s[1677]! } - public var InviteText_URL: String { return self._s[1678]! } - public var TextFormat_Monospace: String { return self._s[1679]! } + public var Passport_Address_TypePassportRegistrationUploadScan: String { return self._s[1667]! } + public var Profile_BotInfo: String { return self._s[1668]! } + public var Watch_Compose_CreateMessage: String { return self._s[1669]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1670]! } + public var Month_ShortNovember: String { return self._s[1671]! } + public var Conversation_ScamWarning: String { return self._s[1672]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1673]! } + public var Appearance_TextSize_Title: String { return self._s[1674]! } + public var ChatList_EmptyChatListFilterTitle: String { return self._s[1675]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1676]! } + public var NotificationsSound_Chime: String { return self._s[1677]! } + public var Passport_Language_ko: String { return self._s[1679]! } + public var InviteText_URL: String { return self._s[1680]! } + public var TextFormat_Monospace: String { return self._s[1681]! } public func Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1680]!, self._r[1680]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1681]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1683]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_0]) + return formatWithArgumentRanges(self._s[1684]!, self._r[1684]!, [_0]) } public func Watch_Time_ShortWeekdayAt(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1683]!, self._r[1683]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1685]!, self._r[1685]!, [_1, _2]) } - public var Wallet_Words_Title: String { return self._s[1684]! } - public var Wallet_Month_ShortMay: String { return self._s[1685]! } - public var EditTheme_CreateTitle: String { return self._s[1687]! } - public var Passport_InfoLearnMore: String { return self._s[1688]! } - public var TwoStepAuth_EmailPlaceholder: String { return self._s[1689]! } - public var Passport_Identity_AddIdentityCard: String { return self._s[1690]! } - public var Your_card_has_expired: String { return self._s[1691]! } - public var StickerPacksSettings_StickerPacksSection: String { return self._s[1692]! } - public var GroupInfo_InviteLink_Help: String { return self._s[1693]! } - public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1697]! } - public var Conversation_Report: String { return self._s[1699]! } - public var Notifications_MessageNotificationsSound: String { return self._s[1700]! } - public var Notification_MessageLifetime1m: String { return self._s[1701]! } - public var Privacy_ContactsTitle: String { return self._s[1702]! } - public var Conversation_ShareMyContactInfo: String { return self._s[1703]! } - public var Wallet_WordCheck_Title: String { return self._s[1704]! } - public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1705]! } - public var Channel_Members_Title: String { return self._s[1706]! } - public var Map_OpenInWaze: String { return self._s[1707]! } - public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1708]! } - public var Login_PhoneBannedError: String { return self._s[1709]! } - public var PeerInfo_GroupAboutItem: String { return self._s[1710]! } + public var Wallet_Words_Title: String { return self._s[1686]! } + public var Wallet_Month_ShortMay: String { return self._s[1687]! } + public var EditTheme_CreateTitle: String { return self._s[1689]! } + public var Passport_InfoLearnMore: String { return self._s[1690]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1691]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1692]! } + public var Your_card_has_expired: String { return self._s[1693]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1694]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1695]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1699]! } + public var Conversation_Report: String { return self._s[1701]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1702]! } + public var Notification_MessageLifetime1m: String { return self._s[1703]! } + public var Privacy_ContactsTitle: String { return self._s[1704]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1705]! } + public var Wallet_WordCheck_Title: String { return self._s[1706]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1707]! } + public var Channel_Members_Title: String { return self._s[1708]! } + public var Map_OpenInWaze: String { return self._s[1709]! } + public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1710]! } + public var Login_PhoneBannedError: String { return self._s[1711]! } + public var PeerInfo_GroupAboutItem: String { return self._s[1712]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1711]!, self._r[1711]!, [_0]) + return formatWithArgumentRanges(self._s[1713]!, self._r[1713]!, [_0]) } - public var IntentsSettings_MainAccount: String { return self._s[1712]! } - public var Group_Management_AddModeratorHelp: String { return self._s[1713]! } - public var AutoDownloadSettings_WifiTitle: String { return self._s[1714]! } - public var Common_OK: String { return self._s[1715]! } - public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1716]! } - public var Wallet_Words_NotDoneResponse: String { return self._s[1717]! } - public var Cache_Music: String { return self._s[1718]! } - public var Wallet_Configuration_SourceURL: String { return self._s[1719]! } - public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1720]! } - public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1723]! } - public var ChatList_EmptyChatListEditFilter: String { return self._s[1724]! } - public var TwoStepAuth_HintPlaceholder: String { return self._s[1725]! } + public var IntentsSettings_MainAccount: String { return self._s[1714]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1715]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1716]! } + public var Common_OK: String { return self._s[1717]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1718]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1719]! } + public var Cache_Music: String { return self._s[1720]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1721]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1722]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1725]! } + public var ChatList_EmptyChatListEditFilter: String { return self._s[1726]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1727]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1726]!, self._r[1726]!, [_1]) + return formatWithArgumentRanges(self._s[1728]!, self._r[1728]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1727]!, self._r[1727]!, [_0]) - } - public var TwoFactorSetup_Done_Action: String { return self._s[1728]! } - public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1729]!, self._r[1729]!, [_0]) } - public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1730]! } - public var Watch_MessageView_ViewOnPhone: String { return self._s[1732]! } - public var Privacy_Calls_CustomShareHelp: String { return self._s[1733]! } - public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1735]! } - public var ChangePhoneNumberNumber_Title: String { return self._s[1736]! } - public var State_ConnectingToProxyInfo: String { return self._s[1737]! } - public var Conversation_SwipeToReplyHintTitle: String { return self._s[1738]! } - public var Message_VideoMessage: String { return self._s[1740]! } - public var ChannelInfo_DeleteChannel: String { return self._s[1741]! } - public var ContactInfo_PhoneLabelOther: String { return self._s[1742]! } - public var Channel_EditAdmin_CannotEdit: String { return self._s[1743]! } - public var Passport_DeleteAddressConfirmation: String { return self._s[1744]! } - public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1745]!, self._r[1745]!, [_1, _2, _3]) + public var TwoFactorSetup_Done_Action: String { return self._s[1730]! } + public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1731]!, self._r[1731]!, [_0]) } - public var WallpaperPreview_SwipeBottomText: String { return self._s[1746]! } - public var Activity_RecordingAudio: String { return self._s[1747]! } - public var SettingsSearch_Synonyms_Watch: String { return self._s[1748]! } - public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1749]! } - public var Wallet_Info_Address: String { return self._s[1750]! } + public var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1732]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1734]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1735]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1737]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1738]! } + public var State_ConnectingToProxyInfo: String { return self._s[1739]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1740]! } + public var Message_VideoMessage: String { return self._s[1742]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1743]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1744]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1745]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1746]! } + public func Wallet_Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1747]!, self._r[1747]!, [_1, _2, _3]) + } + public var WallpaperPreview_SwipeBottomText: String { return self._s[1748]! } + public var Activity_RecordingAudio: String { return self._s[1749]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1750]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1751]! } + public var Wallet_Info_Address: String { return self._s[1752]! } public func Notification_ChangedGroupName(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1752]!, self._r[1752]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1754]!, self._r[1754]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1756]!, self._r[1756]!, [_0]) + return formatWithArgumentRanges(self._s[1758]!, self._r[1758]!, [_0]) } - public var ChatList_RemoveFolderConfirmation: String { return self._s[1757]! } - public var Conversation_ApplyLocalization: String { return self._s[1758]! } - public var TwoFactorSetup_Intro_Action: String { return self._s[1759]! } - public var UserInfo_AddPhone: String { return self._s[1760]! } - public var Map_ShareLiveLocationHelp: String { return self._s[1761]! } + public var ChatList_RemoveFolderConfirmation: String { return self._s[1759]! } + public var Conversation_ApplyLocalization: String { return self._s[1760]! } + public var TwoFactorSetup_Intro_Action: String { return self._s[1761]! } + public var UserInfo_AddPhone: String { return self._s[1762]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1763]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1762]!, self._r[1762]!, [_0]) + return formatWithArgumentRanges(self._s[1764]!, self._r[1764]!, [_0]) } - public var ChatListFolder_CategoryArchived: String { return self._s[1764]! } - public var Passport_Scans: String { return self._s[1765]! } - public var BlockedUsers_Unblock: String { return self._s[1766]! } + public var ChatListFolder_CategoryArchived: String { return self._s[1766]! } + public var Passport_Scans: String { return self._s[1767]! } + public var BlockedUsers_Unblock: String { return self._s[1768]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1767]!, self._r[1767]!, [_1]) + return formatWithArgumentRanges(self._s[1769]!, self._r[1769]!, [_1]) } - public var Channel_Management_LabelCreator: String { return self._s[1768]! } - public var Conversation_ReportSpamAndLeave: String { return self._s[1769]! } - public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1770]! } - public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1771]! } - public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1772]! } + public var Channel_Management_LabelCreator: String { return self._s[1770]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1771]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1772]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1773]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1774]! } public func Login_EmailPhoneBody(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1773]!, self._r[1773]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[1775]!, self._r[1775]!, [_0, _1, _2]) } - public var Login_PhoneNumberHelp: String { return self._s[1774]! } - public var LastSeen_ALongTimeAgo: String { return self._s[1775]! } - public var Channel_AdminLog_CanPinMessages: String { return self._s[1776]! } - public var ChannelIntro_CreateChannel: String { return self._s[1777]! } - public var Conversation_UnreadMessages: String { return self._s[1778]! } - public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1779]! } - public var Channel_AdminLog_EmptyText: String { return self._s[1780]! } - public var Theme_Context_Apply: String { return self._s[1781]! } - public var Notification_GroupActivated: String { return self._s[1782]! } - public var NotificationSettings_ContactJoinedInfo: String { return self._s[1783]! } - public var Wallet_Intro_CreateWallet: String { return self._s[1784]! } + public var Login_PhoneNumberHelp: String { return self._s[1776]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1777]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1778]! } + public var ChannelIntro_CreateChannel: String { return self._s[1779]! } + public var Conversation_UnreadMessages: String { return self._s[1780]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1781]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1782]! } + public var Theme_Context_Apply: String { return self._s[1783]! } + public var Notification_GroupActivated: String { return self._s[1784]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1785]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1786]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1785]!, self._r[1785]!, [_0]) + return formatWithArgumentRanges(self._s[1787]!, self._r[1787]!, [_0]) } public func DownloadingStatus(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1786]!, self._r[1786]!, [_0, _1]) + return formatWithArgumentRanges(self._s[1788]!, self._r[1788]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1788]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1790]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1789]!, self._r[1789]!, [_0]) + return formatWithArgumentRanges(self._s[1791]!, self._r[1791]!, [_0]) } - public var Undo_DeletedChannel: String { return self._s[1790]! } - public var CallFeedback_AddComment: String { return self._s[1791]! } + public var Undo_DeletedChannel: String { return self._s[1792]! } + public var CallFeedback_AddComment: String { return self._s[1793]! } public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1792]!, self._r[1792]!, [_0]) - } - public var Document_TargetConfirmationFormat: String { return self._s[1793]! } - public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1794]!, self._r[1794]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1795]! } + public var Document_TargetConfirmationFormat: String { return self._s[1795]! } + public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1796]!, self._r[1796]!, [_0]) + } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1797]! } public func PUSH_CHAT_MESSAGE_GAME_SCORE(_ _1: String, _ _2: String, _ _3: String, _ _4: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1796]!, self._r[1796]!, [_1, _2, _3, _4]) + return formatWithArgumentRanges(self._s[1798]!, self._r[1798]!, [_1, _2, _3, _4]) } - public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1797]! } - public var Theme_ErrorNotFound: String { return self._s[1798]! } - public var Contacts_SortByName: String { return self._s[1799]! } - public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1800]! } + public var Wallet_SecureStorageChanged_PasscodeText: String { return self._s[1799]! } + public var Theme_ErrorNotFound: String { return self._s[1800]! } + public var Contacts_SortByName: String { return self._s[1801]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1802]! } public func CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1802]!, self._r[1802]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1804]!, self._r[1804]!, [_1, _2, _3]) } - public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1803]! } - public var ScheduledMessages_EditTime: String { return self._s[1804]! } - public var Conversation_ClearSelfHistory: String { return self._s[1805]! } - public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1806]! } - public var PasscodeSettings_DoNotMatch: String { return self._s[1807]! } - public var Stickers_SuggestNone: String { return self._s[1808]! } - public var ChatSettings_Cache: String { return self._s[1809]! } - public var Settings_SaveIncomingPhotos: String { return self._s[1810]! } - public var Media_ShareThisPhoto: String { return self._s[1811]! } - public var Chat_SlowmodeTooltipPending: String { return self._s[1812]! } - public var InfoPlist_NSContactsUsageDescription: String { return self._s[1813]! } - public var Conversation_ContextMenuCopyLink: String { return self._s[1814]! } - public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1815]! } - public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1816]! } - public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1817]! } - public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1818]! } + public var Notification_Exceptions_RemoveFromExceptions: String { return self._s[1805]! } + public var ScheduledMessages_EditTime: String { return self._s[1806]! } + public var Conversation_ClearSelfHistory: String { return self._s[1807]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1808]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1809]! } + public var Stickers_SuggestNone: String { return self._s[1810]! } + public var ChatSettings_Cache: String { return self._s[1811]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1812]! } + public var Media_ShareThisPhoto: String { return self._s[1813]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1814]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1815]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1816]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1817]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1818]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1819]! } + public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1820]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1819]!, self._r[1819]!, [_0]) + return formatWithArgumentRanges(self._s[1821]!, self._r[1821]!, [_0]) } - public var Permissions_CellularDataTitle_v0: String { return self._s[1820]! } - public var WallpaperSearch_ColorWhite: String { return self._s[1822]! } - public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1823]! } - public var Conversation_ErrorInaccessibleMessage: String { return self._s[1824]! } - public var Map_OpenIn: String { return self._s[1825]! } - public var PeerInfo_ButtonCall: String { return self._s[1826]! } + public var Permissions_CellularDataTitle_v0: String { return self._s[1822]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1824]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1825]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1826]! } + public var Map_OpenIn: String { return self._s[1827]! } + public var PeerInfo_ButtonCall: String { return self._s[1828]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1830]!, self._r[1830]!, [_1]) + return formatWithArgumentRanges(self._s[1832]!, self._r[1832]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1831]!, self._r[1831]!, [_0]) + return formatWithArgumentRanges(self._s[1833]!, self._r[1833]!, [_0]) } - public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1832]! } - public var MessagePoll_LabelClosed: String { return self._s[1833]! } - public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1835]! } - public var Wallet_Send_SendAnyway: String { return self._s[1836]! } - public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1837]! } - public var UserInfo_FirstNamePlaceholder: String { return self._s[1838]! } - public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1839]! } - public var Map_SetThisPlace: String { return self._s[1840]! } - public var Login_SelectCountry_Title: String { return self._s[1841]! } - public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1842]! } + public var GroupInfo_Permissions_SlowmodeHeader: String { return self._s[1834]! } + public var MessagePoll_LabelClosed: String { return self._s[1835]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1837]! } + public var Wallet_Send_SendAnyway: String { return self._s[1838]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1839]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1840]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1841]! } + public var Map_SetThisPlace: String { return self._s[1842]! } + public var Login_SelectCountry_Title: String { return self._s[1843]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1844]! } public func Conversation_OpenBotLinkLogin(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1843]!, self._r[1843]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1845]!, self._r[1845]!, [_1, _2]) } - public var Channel_AdminLog_ChangeInfo: String { return self._s[1844]! } - public var Watch_Suggestion_BRB: String { return self._s[1845]! } - public var Passport_Identity_EditIdentityCard: String { return self._s[1846]! } - public var Contacts_PermissionsTitle: String { return self._s[1847]! } - public var Conversation_RestrictedInline: String { return self._s[1848]! } - public var Appearance_RemoveThemeColor: String { return self._s[1850]! } - public var StickerPack_ViewPack: String { return self._s[1851]! } - public var Wallet_UnknownError: String { return self._s[1852]! } + public var Channel_AdminLog_ChangeInfo: String { return self._s[1846]! } + public var Watch_Suggestion_BRB: String { return self._s[1847]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1848]! } + public var Contacts_PermissionsTitle: String { return self._s[1849]! } + public var Conversation_RestrictedInline: String { return self._s[1850]! } + public var Appearance_RemoveThemeColor: String { return self._s[1852]! } + public var StickerPack_ViewPack: String { return self._s[1853]! } + public var Wallet_UnknownError: String { return self._s[1854]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1853]!, self._r[1853]!, [_0]) + return formatWithArgumentRanges(self._s[1855]!, self._r[1855]!, [_0]) } - public var Compose_NewChannel: String { return self._s[1855]! } - public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1859]! } - public var MessagePoll_LabelQuiz: String { return self._s[1861]! } - public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1862]! } - public var Channel_Info_Stickers: String { return self._s[1863]! } - public var AutoNightTheme_PreferredTheme: String { return self._s[1864]! } - public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1865]! } - public var Passport_DeletePersonalDetails: String { return self._s[1866]! } - public var LogoutOptions_AddAccountTitle: String { return self._s[1867]! } - public var Channel_DiscussionGroupInfo: String { return self._s[1868]! } - public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1869]! } - public var Stats_LoadingText: String { return self._s[1872]! } - public var Conversation_SearchNoResults: String { return self._s[1873]! } - public var ChatList_AddFolder: String { return self._s[1874]! } - public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1875]! } - public var ChatListFolder_NameNonContacts: String { return self._s[1876]! } - public var MessagePoll_LabelAnonymous: String { return self._s[1877]! } - public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1878]! } - public var Login_Code: String { return self._s[1879]! } - public var EditTheme_Create_BottomInfo: String { return self._s[1880]! } - public var Watch_Suggestion_WhatsUp: String { return self._s[1881]! } - public var Weekday_ShortThursday: String { return self._s[1882]! } - public var Resolve_ErrorNotFound: String { return self._s[1884]! } - public var LastSeen_Offline: String { return self._s[1885]! } - public var PeopleNearby_NoMembers: String { return self._s[1886]! } - public var GroupPermission_AddMembersNotAvailable: String { return self._s[1887]! } - public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1888]! } - public var Conversation_Dice_u1F3AF: String { return self._s[1890]! } - public var GroupInfo_Title: String { return self._s[1891]! } - public var NotificationsSound_Note: String { return self._s[1892]! } - public var Conversation_EditingMessagePanelTitle: String { return self._s[1893]! } - public var Watch_Message_Poll: String { return self._s[1894]! } - public var Privacy_Calls: String { return self._s[1895]! } + public var Compose_NewChannel: String { return self._s[1857]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1861]! } + public var MessagePoll_LabelQuiz: String { return self._s[1863]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1864]! } + public var Channel_Info_Stickers: String { return self._s[1865]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1866]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1867]! } + public var Passport_DeletePersonalDetails: String { return self._s[1868]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1869]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1870]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1871]! } + public var Stats_LoadingText: String { return self._s[1874]! } + public var Conversation_SearchNoResults: String { return self._s[1875]! } + public var ChatList_AddFolder: String { return self._s[1876]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1877]! } + public var ChatListFolder_NameNonContacts: String { return self._s[1878]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1879]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1880]! } + public var Login_Code: String { return self._s[1881]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1882]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1883]! } + public var Weekday_ShortThursday: String { return self._s[1884]! } + public var Resolve_ErrorNotFound: String { return self._s[1886]! } + public var LastSeen_Offline: String { return self._s[1887]! } + public var PeopleNearby_NoMembers: String { return self._s[1888]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1889]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1890]! } + public var Conversation_Dice_u1F3AF: String { return self._s[1892]! } + public var GroupInfo_Title: String { return self._s[1893]! } + public var NotificationsSound_Note: String { return self._s[1894]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1895]! } + public var Watch_Message_Poll: String { return self._s[1896]! } + public var Privacy_Calls: String { return self._s[1897]! } public func Channel_AdminLog_MessageRankUsername(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1896]!, self._r[1896]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[1898]!, self._r[1898]!, [_1, _2, _3]) } - public var Month_ShortAugust: String { return self._s[1897]! } - public var TwoStepAuth_SetPasswordHelp: String { return self._s[1898]! } - public var Notifications_Reset: String { return self._s[1899]! } - public var Conversation_Pin: String { return self._s[1900]! } - public var Passport_Language_lv: String { return self._s[1901]! } - public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1902]! } - public var BlockedUsers_Info: String { return self._s[1903]! } - public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1905]! } - public var Watch_Conversation_Unblock: String { return self._s[1907]! } + public var Month_ShortAugust: String { return self._s[1899]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1900]! } + public var Notifications_Reset: String { return self._s[1901]! } + public var Conversation_Pin: String { return self._s[1902]! } + public var Passport_Language_lv: String { return self._s[1903]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1904]! } + public var BlockedUsers_Info: String { return self._s[1905]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1907]! } + public var Watch_Conversation_Unblock: String { return self._s[1909]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1908]!, self._r[1908]!, [_0]) + return formatWithArgumentRanges(self._s[1910]!, self._r[1910]!, [_0]) } - public var CloudStorage_Title: String { return self._s[1909]! } - public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1910]! } + public var CloudStorage_Title: String { return self._s[1911]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1912]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1911]!, self._r[1911]!, [_0]) + return formatWithArgumentRanges(self._s[1913]!, self._r[1913]!, [_0]) } - public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1912]! } - public var Watch_Suggestion_OnMyWay: String { return self._s[1913]! } - public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1914]! } - public var Passport_Address_EditBankStatement: String { return self._s[1915]! } + public var Channel_AdminLogFilter_AdminsTitle: String { return self._s[1914]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1915]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1916]! } + public var Passport_Address_EditBankStatement: String { return self._s[1917]! } public func Channel_AdminLog_MessageChangedUnlinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1916]!, self._r[1916]!, [_1, _2]) + return formatWithArgumentRanges(self._s[1918]!, self._r[1918]!, [_1, _2]) } - public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1917]! } - public var ShareMenu_Comment: String { return self._s[1918]! } - public var Permissions_ContactsTitle_v0: String { return self._s[1919]! } - public var Notifications_PermissionsTitle: String { return self._s[1920]! } - public var GroupPermission_NoSendLinks: String { return self._s[1921]! } - public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1922]! } - public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1923]! } - public var PeerInfo_PaneLinks: String { return self._s[1924]! } - public var Settings_Support: String { return self._s[1925]! } - public var Notifications_ChannelNotificationsSound: String { return self._s[1926]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1927]! } - public var Privacy_Forwards_Preview: String { return self._s[1928]! } - public var GroupPermission_ApplyAlertAction: String { return self._s[1929]! } - public var Watch_Stickers_StickerPacks: String { return self._s[1930]! } - public var Common_Select: String { return self._s[1932]! } - public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1933]! } - public var WallpaperSearch_ColorGray: String { return self._s[1936]! } - public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1937]! } - public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1938]! } - public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1939]! } - public var PollResults_Title: String { return self._s[1940]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1941]! } - public var Appearance_PreviewReplyAuthor: String { return self._s[1942]! } - public var TwoStepAuth_RecoveryTitle: String { return self._s[1943]! } - public var Widget_AuthRequired: String { return self._s[1944]! } - public var Camera_FlashOn: String { return self._s[1945]! } - public var Conversation_ContextMenuLookUp: String { return self._s[1946]! } - public var Channel_Stickers_NotFoundHelp: String { return self._s[1947]! } - public var Watch_Suggestion_OK: String { return self._s[1948]! } + public var ChatSettings_DownloadInBackgroundInfo: String { return self._s[1919]! } + public var ShareMenu_Comment: String { return self._s[1920]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1921]! } + public var Notifications_PermissionsTitle: String { return self._s[1922]! } + public var GroupPermission_NoSendLinks: String { return self._s[1923]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1924]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1925]! } + public var PeerInfo_PaneLinks: String { return self._s[1926]! } + public var Settings_Support: String { return self._s[1927]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1928]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1929]! } + public var Privacy_Forwards_Preview: String { return self._s[1930]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1931]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1932]! } + public var Common_Select: String { return self._s[1934]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1935]! } + public var WallpaperSearch_ColorGray: String { return self._s[1938]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1939]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1940]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1941]! } + public var PollResults_Title: String { return self._s[1942]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1943]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1944]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1945]! } + public var Widget_AuthRequired: String { return self._s[1946]! } + public var Camera_FlashOn: String { return self._s[1947]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1948]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1949]! } + public var Watch_Suggestion_OK: String { return self._s[1950]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1950]!, self._r[1950]!, [_0]) - } - public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1952]!, self._r[1952]!, [_0]) } - public var TextFormat_Strikethrough: String { return self._s[1953]! } - public var DialogList_AdLabel: String { return self._s[1954]! } - public var WatchRemote_NotificationText: String { return self._s[1955]! } - public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1956]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1957]! } - public var Conversation_ReportSpam: String { return self._s[1958]! } - public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1959]! } - public var Settings_LogoutConfirmationTitle: String { return self._s[1961]! } - public var PhoneLabel_Title: String { return self._s[1962]! } - public var Passport_Address_EditRentalAgreement: String { return self._s[1963]! } - public var Settings_ChangePhoneNumber: String { return self._s[1964]! } - public var Notifications_ExceptionsTitle: String { return self._s[1965]! } - public var Notifications_AlertTones: String { return self._s[1966]! } - public var Call_ReportIncludeLogDescription: String { return self._s[1967]! } - public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1968]! } - public var AutoDownloadSettings_PrivateChats: String { return self._s[1969]! } - public var VoiceOver_Chat_Photo: String { return self._s[1971]! } - public var TwoStepAuth_AddHintTitle: String { return self._s[1972]! } - public var Stats_PostsTitle: String { return self._s[1973]! } - public var ReportPeer_ReasonOther: String { return self._s[1974]! } - public var ChatList_Context_JoinChannel: String { return self._s[1975]! } - public var KeyCommand_ScrollDown: String { return self._s[1977]! } - public var Conversation_ScheduleMessage_Title: String { return self._s[1978]! } + public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1954]!, self._r[1954]!, [_0]) + } + public var TextFormat_Strikethrough: String { return self._s[1955]! } + public var DialogList_AdLabel: String { return self._s[1956]! } + public var WatchRemote_NotificationText: String { return self._s[1957]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1958]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1959]! } + public var Conversation_ReportSpam: String { return self._s[1960]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1961]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1963]! } + public var PhoneLabel_Title: String { return self._s[1964]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1965]! } + public var Settings_ChangePhoneNumber: String { return self._s[1966]! } + public var Notifications_ExceptionsTitle: String { return self._s[1967]! } + public var Notifications_AlertTones: String { return self._s[1968]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1969]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1970]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1971]! } + public var VoiceOver_Chat_Photo: String { return self._s[1973]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1974]! } + public var Stats_PostsTitle: String { return self._s[1975]! } + public var ReportPeer_ReasonOther: String { return self._s[1976]! } + public var ChatList_Context_JoinChannel: String { return self._s[1977]! } + public var KeyCommand_ScrollDown: String { return self._s[1979]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1980]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1979]!, self._r[1979]!, [_0]) + return formatWithArgumentRanges(self._s[1981]!, self._r[1981]!, [_0]) } - public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1981]! } - public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1982]! } - public var AuthSessions_LogOut: String { return self._s[1983]! } - public var Passport_Identity_TypeInternalPassport: String { return self._s[1984]! } - public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1985]! } - public var Passport_Phone_Title: String { return self._s[1986]! } - public var ContactList_Context_StartSecretChat: String { return self._s[1987]! } - public var Settings_PhoneNumber: String { return self._s[1988]! } + public var NetworkUsageSettings_MediaVideoDataSection: String { return self._s[1983]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1984]! } + public var AuthSessions_LogOut: String { return self._s[1985]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1986]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1987]! } + public var Passport_Phone_Title: String { return self._s[1988]! } + public var ContactList_Context_StartSecretChat: String { return self._s[1989]! } + public var Settings_PhoneNumber: String { return self._s[1990]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1989]!, self._r[1989]!, [_0]) + return formatWithArgumentRanges(self._s[1991]!, self._r[1991]!, [_0]) } - public var NotificationsSound_Alert: String { return self._s[1991]! } - public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1992]! } - public var WebSearch_SearchNoResults: String { return self._s[1993]! } - public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1995]! } - public var Wallet_Configuration_SourceInfo: String { return self._s[1996]! } - public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1997]! } - public var SettingsSearch_Synonyms_Passport: String { return self._s[1998]! } - public var PhotoEditor_CurvesTool: String { return self._s[1999]! } - public var Checkout_PaymentMethod: String { return self._s[2001]! } + public var NotificationsSound_Alert: String { return self._s[1993]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1994]! } + public var WebSearch_SearchNoResults: String { return self._s[1995]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1997]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[1998]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1999]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[2000]! } + public var PhotoEditor_CurvesTool: String { return self._s[2001]! } + public var Checkout_PaymentMethod: String { return self._s[2003]! } public func PUSH_CHAT_ADD_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2002]!, self._r[2002]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2004]!, self._r[2004]!, [_1, _2]) } - public var Contacts_AccessDeniedError: String { return self._s[2003]! } - public var Camera_PhotoMode: String { return self._s[2006]! } - public var EditTheme_Expand_Preview_IncomingText: String { return self._s[2007]! } - public var Appearance_TextSize_Apply: String { return self._s[2008]! } - public var Passport_Address_AddUtilityBill: String { return self._s[2010]! } - public var ChatListFolderSettings_RecommendedNewFolder: String { return self._s[2011]! } - public var CallSettings_OnMobile: String { return self._s[2012]! } - public var Tour_Text2: String { return self._s[2013]! } + public var Contacts_AccessDeniedError: String { return self._s[2005]! } + public var Camera_PhotoMode: String { return self._s[2008]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[2009]! } + public var Appearance_TextSize_Apply: String { return self._s[2010]! } + public var Passport_Address_AddUtilityBill: String { return self._s[2012]! } + public var ChatListFolderSettings_RecommendedNewFolder: String { return self._s[2013]! } + public var CallSettings_OnMobile: String { return self._s[2014]! } + public var Tour_Text2: String { return self._s[2015]! } public func PUSH_CHAT_MESSAGE_ROUND(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2014]!, self._r[2014]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2016]!, self._r[2016]!, [_1, _2]) } - public var DialogList_EncryptionProcessing: String { return self._s[2016]! } - public var Permissions_Skip: String { return self._s[2017]! } - public var Wallet_Words_NotDoneOk: String { return self._s[2018]! } - public var SecretImage_Title: String { return self._s[2019]! } - public var Watch_MessageView_Title: String { return self._s[2020]! } - public var Channel_DiscussionGroupAdd: String { return self._s[2021]! } - public var AttachmentMenu_Poll: String { return self._s[2022]! } + public var DialogList_EncryptionProcessing: String { return self._s[2018]! } + public var Permissions_Skip: String { return self._s[2019]! } + public var Wallet_Words_NotDoneOk: String { return self._s[2020]! } + public var SecretImage_Title: String { return self._s[2021]! } + public var Watch_MessageView_Title: String { return self._s[2022]! } + public var Channel_DiscussionGroupAdd: String { return self._s[2023]! } + public var AttachmentMenu_Poll: String { return self._s[2024]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2023]!, self._r[2023]!, [_0]) + return formatWithArgumentRanges(self._s[2025]!, self._r[2025]!, [_0]) } public func Channel_DiscussionGroup_PrivateChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2024]!, self._r[2024]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2026]!, self._r[2026]!, [_1, _2]) } - public var Notification_CallCanceled: String { return self._s[2025]! } - public var WallpaperPreview_Title: String { return self._s[2026]! } - public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[2027]! } - public var Settings_ProxyConnecting: String { return self._s[2028]! } - public var Settings_CheckPhoneNumberText: String { return self._s[2030]! } - public var VoiceOver_Chat_YourVideo: String { return self._s[2031]! } - public var Wallet_Intro_Title: String { return self._s[2032]! } - public var TwoFactorSetup_Password_Action: String { return self._s[2033]! } - public var Profile_MessageLifetime5s: String { return self._s[2034]! } - public var Username_InvalidCharacters: String { return self._s[2035]! } - public var VoiceOver_Media_PlaybackRateFast: String { return self._s[2036]! } - public var ScheduledMessages_ClearAll: String { return self._s[2037]! } - public var WallpaperPreview_CropBottomText: String { return self._s[2038]! } - public var AutoDownloadSettings_LimitBySize: String { return self._s[2039]! } - public var Settings_AddAccount: String { return self._s[2040]! } - public var Notification_CreatedChannel: String { return self._s[2043]! } + public var Notification_CallCanceled: String { return self._s[2027]! } + public var WallpaperPreview_Title: String { return self._s[2028]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[2029]! } + public var Settings_ProxyConnecting: String { return self._s[2030]! } + public var Settings_CheckPhoneNumberText: String { return self._s[2032]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[2033]! } + public var Wallet_Intro_Title: String { return self._s[2034]! } + public var TwoFactorSetup_Password_Action: String { return self._s[2035]! } + public var Profile_MessageLifetime5s: String { return self._s[2036]! } + public var Username_InvalidCharacters: String { return self._s[2037]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[2038]! } + public var ScheduledMessages_ClearAll: String { return self._s[2039]! } + public var WallpaperPreview_CropBottomText: String { return self._s[2040]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[2041]! } + public var Settings_AddAccount: String { return self._s[2042]! } + public var Notification_CreatedChannel: String { return self._s[2045]! } public func PUSH_CHAT_DELETE_MEMBER(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2044]!, self._r[2044]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2046]!, self._r[2046]!, [_1, _2, _3]) } - public var Passcode_AppLockedAlert: String { return self._s[2046]! } - public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[2047]! } - public var VoiceOver_Media_PlaybackStop: String { return self._s[2048]! } - public var Contacts_TopSection: String { return self._s[2049]! } - public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[2050]! } + public var Passcode_AppLockedAlert: String { return self._s[2048]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[2049]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[2050]! } + public var Contacts_TopSection: String { return self._s[2051]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[2052]! } public func Conversation_SetReminder_RemindOn(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2051]!, self._r[2051]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2053]!, self._r[2053]!, [_0, _1]) } - public var Wallet_Info_Receive: String { return self._s[2052]! } - public var Wallet_Completed_ViewWallet: String { return self._s[2053]! } + public var Wallet_Info_Receive: String { return self._s[2054]! } + public var Wallet_Completed_ViewWallet: String { return self._s[2055]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2054]!, self._r[2054]!, [_0]) + return formatWithArgumentRanges(self._s[2056]!, self._r[2056]!, [_0]) } - public var ReportPeer_ReasonSpam: String { return self._s[2055]! } - public var UserInfo_TapToCall: String { return self._s[2056]! } - public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[2058]! } - public var AutoDownloadSettings_DataUsageCustom: String { return self._s[2059]! } - public var Common_Search: String { return self._s[2060]! } - public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2061]! } + public var ReportPeer_ReasonSpam: String { return self._s[2057]! } + public var UserInfo_TapToCall: String { return self._s[2058]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[2060]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[2061]! } + public var Common_Search: String { return self._s[2062]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2063]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _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 Wallet_Month_ShortJuly: String { return self._s[2063]! } - public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2065]! } - public var Message_InvoiceLabel: String { return self._s[2066]! } - public var Conversation_InputTextPlaceholder: String { return self._s[2067]! } - public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2068]! } + public var Wallet_Month_ShortJuly: String { return self._s[2065]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2067]! } + public var Message_InvoiceLabel: String { return self._s[2068]! } + public var Conversation_InputTextPlaceholder: String { return self._s[2069]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2070]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2069]!, self._r[2069]!, [_0]) + return formatWithArgumentRanges(self._s[2071]!, self._r[2071]!, [_0]) } - public var IntentsSettings_Reset: String { return self._s[2070]! } - public var Conversation_Info: String { return self._s[2071]! } - public var Login_InfoDeletePhoto: String { return self._s[2072]! } - public var ChatListFolder_DiscardDiscard: String { return self._s[2074]! } - public var Passport_Language_vi: String { return self._s[2075]! } - public var UserInfo_ScamUserWarning: String { return self._s[2076]! } - public var Conversation_Search: String { return self._s[2077]! } - public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2079]! } - public var ChatListFolder_NameGroups: String { return self._s[2080]! } - public var ReportPeer_ReasonPornography: String { return self._s[2081]! } - public var AutoDownloadSettings_PhotosTitle: String { return self._s[2082]! } - public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2083]! } - public var Map_LiveLocationGroupDescription: String { return self._s[2084]! } - public var Channel_Setup_TypeHeader: String { return self._s[2085]! } - public var AuthSessions_LoggedIn: String { return self._s[2086]! } - public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2087]! } - public var Login_SmsRequestState3: String { return self._s[2088]! } - public var Passport_Address_EditUtilityBill: String { return self._s[2089]! } - public var Appearance_ReduceMotionInfo: String { return self._s[2090]! } - public var Join_ChannelsTooMuch: String { return self._s[2091]! } - public var Channel_Edit_LinkItem: String { return self._s[2092]! } - public var Privacy_Calls_P2PNever: String { return self._s[2093]! } - public var Conversation_AddToReadingList: String { return self._s[2095]! } - public var Share_MultipleMessagesDisabled: String { return self._s[2096]! } - public var Message_Animation: String { return self._s[2097]! } - public var Conversation_DefaultRestrictedMedia: String { return self._s[2098]! } - public var Map_Unknown: String { return self._s[2099]! } - public var AutoDownloadSettings_LastDelimeter: String { return self._s[2100]! } + public var IntentsSettings_Reset: String { return self._s[2072]! } + public var Conversation_Info: String { return self._s[2073]! } + public var Login_InfoDeletePhoto: String { return self._s[2074]! } + public var ChatListFolder_DiscardDiscard: String { return self._s[2076]! } + public var Passport_Language_vi: String { return self._s[2077]! } + public var UserInfo_ScamUserWarning: String { return self._s[2078]! } + public var Conversation_Search: String { return self._s[2079]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2081]! } + public var ChatListFolder_NameGroups: String { return self._s[2082]! } + public var ReportPeer_ReasonPornography: String { return self._s[2083]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[2084]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2085]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2086]! } + public var Channel_Setup_TypeHeader: String { return self._s[2087]! } + public var AuthSessions_LoggedIn: String { return self._s[2088]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2089]! } + public var Login_SmsRequestState3: String { return self._s[2090]! } + public var Passport_Address_EditUtilityBill: String { return self._s[2091]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2092]! } + public var Join_ChannelsTooMuch: String { return self._s[2093]! } + public var Channel_Edit_LinkItem: String { return self._s[2094]! } + public var Privacy_Calls_P2PNever: String { return self._s[2095]! } + public var Conversation_AddToReadingList: String { return self._s[2097]! } + public var Share_MultipleMessagesDisabled: String { return self._s[2098]! } + public var Message_Animation: String { return self._s[2099]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[2100]! } + public var Map_Unknown: String { return self._s[2101]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[2102]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2103]!, self._r[2103]!, [_1, _2]) } public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2102]!, self._r[2102]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2104]!, self._r[2104]!, [_1, _2]) } - public var Call_StatusRequesting: String { return self._s[2103]! } - public var Conversation_SecretChatContextBotAlert: String { return self._s[2104]! } - public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2105]! } + public var Call_StatusRequesting: String { return self._s[2105]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[2106]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2107]! } public func PUSH_CHAT_MESSAGE_DOC(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2106]!, self._r[2106]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2108]!, self._r[2108]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2107]!, self._r[2107]!, [_0]) + return formatWithArgumentRanges(self._s[2109]!, self._r[2109]!, [_0]) } - public var Update_Skip: String { return self._s[2108]! } - public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2109]! } - public var BlockedUsers_Title: String { return self._s[2110]! } - public var Weekday_Monday: String { return self._s[2111]! } + public var Update_Skip: String { return self._s[2110]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2111]! } + public var BlockedUsers_Title: String { return self._s[2112]! } + public var Weekday_Monday: String { return self._s[2113]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_1]) + return formatWithArgumentRanges(self._s[2114]!, self._r[2114]!, [_1]) } - public var Username_CheckingUsername: String { return self._s[2113]! } - public var NotificationsSound_Bell: String { return self._s[2114]! } - public var Conversation_SendMessageErrorFlood: String { return self._s[2115]! } - public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2116]! } - public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2117]! } - public var ChatSettings_Groups: String { return self._s[2118]! } - public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2119]! } - public var ChatList_PeerTypeContact: String { return self._s[2120]! } + public var Username_CheckingUsername: String { return self._s[2115]! } + public var NotificationsSound_Bell: String { return self._s[2116]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[2117]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2118]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2119]! } + public var ChatSettings_Groups: String { return self._s[2120]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2121]! } + public var ChatList_PeerTypeContact: String { return self._s[2122]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2121]!, self._r[2121]!, [_0]) + return formatWithArgumentRanges(self._s[2123]!, self._r[2123]!, [_0]) } - public var Your_card_was_declined: String { return self._s[2122]! } - public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2124]! } - public var Wallet_Month_ShortApril: String { return self._s[2125]! } - public var ChatList_Unmute: String { return self._s[2126]! } - public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2127]! } - public var PhotoEditor_CurvesAll: String { return self._s[2128]! } - public var Weekday_ShortTuesday: String { return self._s[2129]! } - public var DialogList_Read: String { return self._s[2130]! } - public var Appearance_AppIconClassic: String { return self._s[2131]! } - public var Conversation_Dice_u1F3B2: String { return self._s[2132]! } - public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2133]! } - public var Passport_Identity_Gender: String { return self._s[2134]! } + public var Your_card_was_declined: String { return self._s[2124]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2126]! } + public var Wallet_Month_ShortApril: String { return self._s[2127]! } + public var ChatList_Unmute: String { return self._s[2128]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2129]! } + public var PhotoEditor_CurvesAll: String { return self._s[2130]! } + public var Weekday_ShortTuesday: String { return self._s[2131]! } + public var DialogList_Read: String { return self._s[2132]! } + public var Appearance_AppIconClassic: String { return self._s[2133]! } + public var Conversation_Dice_u1F3B2: String { return self._s[2134]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2135]! } + public var Passport_Identity_Gender: String { return self._s[2136]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2135]!, self._r[2135]!, [_0]) + return formatWithArgumentRanges(self._s[2137]!, self._r[2137]!, [_0]) } - public var Target_SelectGroup: String { return self._s[2136]! } - public var Map_HomeAndWorkInfo: String { return self._s[2138]! } + public var Target_SelectGroup: String { return self._s[2138]! } + public var Map_HomeAndWorkInfo: String { return self._s[2140]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2139]!, self._r[2139]!, [_0]) + return formatWithArgumentRanges(self._s[2141]!, self._r[2141]!, [_0]) } - public var Passport_Language_en: String { return self._s[2140]! } - public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2141]! } - public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2142]! } - public var Login_CancelPhoneVerificationContinue: String { return self._s[2143]! } - public var ScheduledMessages_SendNow: String { return self._s[2144]! } - public var Checkout_NewCard_PaymentCard: String { return self._s[2146]! } - public var Login_InfoHelp: String { return self._s[2147]! } - public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2148]! } - public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2149]! } - public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2150]! } + public var Passport_Language_en: String { return self._s[2142]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2143]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2144]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2145]! } + public var ScheduledMessages_SendNow: String { return self._s[2146]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2148]! } + public var Login_InfoHelp: String { return self._s[2149]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2150]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2151]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2152]! } public func Channel_AdminLog_MessageChangedLinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2151]!, self._r[2151]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2153]!, self._r[2153]!, [_1, _2]) } - public var SocksProxySetup_AddProxy: String { return self._s[2154]! } - public var CreatePoll_Title: String { return self._s[2155]! } - public var MessagePoll_QuizNoUsers: String { return self._s[2156]! } - public var Conversation_ViewTheme: String { return self._s[2157]! } - public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2158]! } - public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2159]! } - public var TwoFactorSetup_Intro_Text: String { return self._s[2160]! } - public var UserInfo_GroupsInCommon: String { return self._s[2161]! } - public var TelegramWallet_Intro_TermsUrl: String { return self._s[2162]! } - public var Stats_ViewsByHoursTitle: String { return self._s[2163]! } - public var Call_AudioRouteHide: String { return self._s[2164]! } + public var SocksProxySetup_AddProxy: String { return self._s[2156]! } + public var CreatePoll_Title: String { return self._s[2157]! } + public var MessagePoll_QuizNoUsers: String { return self._s[2158]! } + public var Conversation_ViewTheme: String { return self._s[2159]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2160]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2161]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2162]! } + public var UserInfo_GroupsInCommon: String { return self._s[2163]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2164]! } + public var Stats_ViewsByHoursTitle: String { return self._s[2165]! } + public var Conversation_PrivateChannelTimeLimitedAlertTitle: String { return self._s[2166]! } + public var Call_AudioRouteHide: String { return self._s[2167]! } public func Wallet_Info_TransactionDateHeader(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2166]!, self._r[2166]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2169]!, self._r[2169]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2167]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2168]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[2169]! } + public var ContactInfo_PhoneLabelMobile: String { return self._s[2170]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2171]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[2172]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2170]!, self._r[2170]!, [_0]) + return formatWithArgumentRanges(self._s[2173]!, self._r[2173]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2171]! } - public var CreatePoll_ExplanationInfo: String { return self._s[2172]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2173]! } - public var StickerPackActionInfo_AddedTitle: String { return self._s[2174]! } - public var Notifications_Title: String { return self._s[2175]! } - public var Group_Username_InvalidTooShort: String { return self._s[2176]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2177]! } + public var TextFormat_Bold: String { return self._s[2174]! } + public var CreatePoll_ExplanationInfo: String { return self._s[2175]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2176]! } + public var StickerPackActionInfo_AddedTitle: String { return self._s[2177]! } + public var Notifications_Title: String { return self._s[2178]! } + public var Group_Username_InvalidTooShort: String { return self._s[2179]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2180]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2178]!, self._r[2178]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2181]!, self._r[2181]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2180]! } - public var Stickers_SuggestAdded: String { return self._s[2181]! } - public var Login_CountryCode: String { return self._s[2182]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2183]! } - public var Map_GetDirections: String { return self._s[2184]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2185]! } - public var Login_PhoneFloodError: String { return self._s[2186]! } + public var VoiceOver_DiscardPreparedContent: String { return self._s[2183]! } + public var Stickers_SuggestAdded: String { return self._s[2184]! } + public var Login_CountryCode: String { return self._s[2185]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2186]! } + public var Map_GetDirections: String { return self._s[2187]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2188]! } + public var Login_PhoneFloodError: String { return self._s[2189]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2187]!, self._r[2187]!, [_0]) + return formatWithArgumentRanges(self._s[2190]!, self._r[2190]!, [_0]) } public func Wallet_Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2188]!, self._r[2188]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2191]!, self._r[2191]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2189]! } - public var Settings_SetUsername: String { return self._s[2191]! } - public var Group_Location_ChangeLocation: String { return self._s[2192]! } - public var Notification_GroupInviterSelf: String { return self._s[2193]! } - public var InstantPage_TapToOpenLink: String { return self._s[2194]! } + public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2192]! } + public var Settings_SetUsername: String { return self._s[2194]! } + public var Group_Location_ChangeLocation: String { return self._s[2195]! } + public var Notification_GroupInviterSelf: String { return self._s[2196]! } + public var InstantPage_TapToOpenLink: String { return self._s[2197]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2195]!, self._r[2195]!, [_0]) + return formatWithArgumentRanges(self._s[2198]!, self._r[2198]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2196]! } - public var SecretChat_Title: String { return self._s[2197]! } - public var Group_UpgradeNoticeText1: String { return self._s[2198]! } - public var AuthSessions_Title: String { return self._s[2199]! } + public var Watch_Suggestion_TalkLater: String { return self._s[2199]! } + public var SecretChat_Title: String { return self._s[2200]! } + public var Group_UpgradeNoticeText1: String { return self._s[2201]! } + public var AuthSessions_Title: String { return self._s[2202]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2200]!, self._r[2200]!, [_0]) + return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2201]! } - public var Channel_About_Title: String { return self._s[2202]! } - public var Theme_ThemeChanged: String { return self._s[2203]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2204]! } + public var PhotoEditor_CropAuto: String { return self._s[2204]! } + public var Channel_About_Title: String { return self._s[2205]! } + public var Theme_ThemeChanged: String { return self._s[2206]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2207]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2209]!, self._r[2209]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2207]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2209]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2210]! } + public var VoiceOver_MessageContextReport: String { return self._s[2210]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2212]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2213]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2211]!, self._r[2211]!, [_1]) + return formatWithArgumentRanges(self._s[2214]!, self._r[2214]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2213]!, self._r[2213]!, [_0]) + return formatWithArgumentRanges(self._s[2216]!, self._r[2216]!, [_0]) } public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2214]!, self._r[2214]!, [_0]) + return formatWithArgumentRanges(self._s[2217]!, self._r[2217]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2215]! } - public var PeopleNearby_DiscoverDescription: String { return self._s[2217]! } - public var Presence_online: String { return self._s[2219]! } - public var PasscodeSettings_Title: String { return self._s[2220]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2221]! } - public var Web_OpenExternal: String { return self._s[2222]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2224]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2225]! } - public var LocalGroup_Title: String { return self._s[2226]! } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2218]! } + public var PeopleNearby_DiscoverDescription: String { return self._s[2220]! } + public var Presence_online: String { return self._s[2222]! } + public var PasscodeSettings_Title: String { return self._s[2223]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2224]! } + public var Web_OpenExternal: String { return self._s[2225]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2227]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2228]! } + public var LocalGroup_Title: String { return self._s[2229]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2227]!, self._r[2227]!, [_0]) + return formatWithArgumentRanges(self._s[2230]!, self._r[2230]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2228]! } - public var Conversation_StopQuizConfirmation: String { return self._s[2229]! } - public var Map_YouAreHere: String { return self._s[2230]! } + public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2231]! } + public var Conversation_StopQuizConfirmation: String { return self._s[2232]! } + public var Map_YouAreHere: String { return self._s[2233]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2231]!, self._r[2231]!, [_0]) + return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_0]) } public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2232]!, self._r[2232]!, [_0]) + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[2233]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2234]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2235]! } + public var Theme_Context_ChangeColors: String { return self._s[2236]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2237]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2238]! } public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2236]!, self._r[2236]!, [_0]) + return formatWithArgumentRanges(self._s[2239]!, self._r[2239]!, [_0]) } public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2237]!, self._r[2237]!, [_0]) - } - public var SocksProxySetup_Username: String { return self._s[2238]! } - public var Bot_Start: String { return self._s[2239]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2240]!, self._r[2240]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2241]!, self._r[2241]!, [_0]) + public var SocksProxySetup_Username: String { return self._s[2241]! } + public var Bot_Start: String { return self._s[2242]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2243]!, self._r[2243]!, [_0]) } - public var Contacts_SortByPresence: String { return self._s[2242]! } - public var AccentColor_Title: String { return self._s[2245]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2246]! } + public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2244]!, self._r[2244]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[2245]! } + public var AccentColor_Title: String { return self._s[2248]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2249]! } public func PUSH_CHAT_CREATED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2247]!, self._r[2247]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2250]!, self._r[2250]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2248]!, self._r[2248]!, [_0]) + return formatWithArgumentRanges(self._s[2251]!, self._r[2251]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2249]!, self._r[2249]!, [_1, _2]) - } - public var Passport_Email_EnterOtherEmail: String { return self._s[2250]! } - public var Login_InfoAvatarPhoto: String { return self._s[2251]! } - public func ChatList_RemovedFromFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2252]!, self._r[2252]!, [_1, _2]) } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2253]! } - public var Tour_Title4: String { return self._s[2254]! } - public var Passport_Identity_Translation: String { return self._s[2255]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2256]! } - public var Login_TermsOfServiceLabel: String { return self._s[2258]! } - public var Passport_Language_it: String { return self._s[2259]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2260]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2261]! } - public var Conversation_ClearAll: String { return self._s[2263]! } - public var Wallet_Send_UninitializedText: String { return self._s[2265]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2266]! } - public var TwoStepAuth_FloodError: String { return self._s[2267]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[2253]! } + public var Login_InfoAvatarPhoto: String { return self._s[2254]! } + public func ChatList_RemovedFromFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_1, _2]) + } + public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2256]! } + public var Tour_Title4: String { return self._s[2257]! } + public var Passport_Identity_Translation: String { return self._s[2258]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2259]! } + public var Login_TermsOfServiceLabel: String { return self._s[2261]! } + public var Passport_Language_it: String { return self._s[2262]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2263]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2264]! } + public var Conversation_ClearAll: String { return self._s[2266]! } + public var Wallet_Send_UninitializedText: String { return self._s[2268]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2269]! } + public var TwoStepAuth_FloodError: String { return self._s[2270]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2268]!, self._r[2268]!, [_1]) + return formatWithArgumentRanges(self._s[2271]!, self._r[2271]!, [_1]) } - public var Paint_Delete: String { return self._s[2269]! } + public var Paint_Delete: String { return self._s[2272]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2270]!, self._r[2270]!, [_0]) + return formatWithArgumentRanges(self._s[2273]!, self._r[2273]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2271]! } + public var Privacy_AddNewPeer: String { return self._s[2274]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2272]!, self._r[2272]!, [_1]) + return formatWithArgumentRanges(self._s[2275]!, self._r[2275]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2273]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2276]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2274]!, self._r[2274]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2277]!, self._r[2277]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2275]! } + public var Message_PinnedAudioMessage: String { return self._s[2278]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2276]!, self._r[2276]!, [_0]) + return formatWithArgumentRanges(self._s[2279]!, self._r[2279]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2277]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2278]! } - public var Wallet_Month_GenNovember: String { return self._s[2279]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2280]! } - public var Conversation_MessageEditedLabel: String { return self._s[2281]! } + public var Notification_Mute1hMin: String { return self._s[2280]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2281]! } + public var Wallet_Month_GenNovember: String { return self._s[2282]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2283]! } + public var Conversation_MessageEditedLabel: String { return self._s[2284]! } public func ClearCache_Success(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2282]!, self._r[2282]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2285]!, self._r[2285]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2283]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2284]! } + public var Notification_Exceptions_AlwaysOff: String { return self._s[2286]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2287]! } public func Channel_AdminLog_MessageAdmin(_ _0: String, _ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2285]!, self._r[2285]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2288]!, self._r[2288]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2286]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2289]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2287]!, self._r[2287]!, [_1]) + return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2288]! } - public var Month_GenOctober: String { return self._s[2289]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2290]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2291]! } - public var MediaPicker_TimerTooltip: String { return self._s[2293]! } - public var SharedMedia_TitleAll: String { return self._s[2294]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2297]! } - public var Conversation_RestrictedMedia: String { return self._s[2298]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2299]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2301]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2302]! } + public var AccessDenied_LocationTracking: String { return self._s[2291]! } + public var Month_GenOctober: String { return self._s[2292]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2293]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2294]! } + public var MediaPicker_TimerTooltip: String { return self._s[2296]! } + public var SharedMedia_TitleAll: String { return self._s[2297]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2300]! } + public var Conversation_RestrictedMedia: String { return self._s[2301]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2302]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2304]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2305]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_0]) + return formatWithArgumentRanges(self._s[2306]!, self._r[2306]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2306]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2308]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2309]! } + public var Conversation_SavedMessages: String { return self._s[2309]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2311]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2312]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2311]!, self._r[2311]!, [_0]) + return formatWithArgumentRanges(self._s[2314]!, self._r[2314]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2312]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2315]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2313]!, self._r[2313]!, [_0]) + return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[2314]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2315]! } + public var ReportPeer_AlertSuccess: String { return self._s[2317]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2318]! } public func InstantPage_RelatedArticleAuthorAndDateTitle(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2319]!, self._r[2319]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2317]! } - public var PhotoEditor_FadeTool: String { return self._s[2318]! } - public var Privacy_ContactsReset: String { return self._s[2319]! } + public var Checkout_PasswordEntry_Title: String { return self._s[2320]! } + public var PhotoEditor_FadeTool: String { return self._s[2321]! } + public var Privacy_ContactsReset: String { return self._s[2322]! } + public var Conversation_PrivateChannelTimeLimitedAlertText: String { return self._s[2323]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2321]!, self._r[2321]!, [_0]) + return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2322]! } - public var ChatList_Mute: String { return self._s[2323]! } + public var Message_PinnedVideoMessage: String { return self._s[2326]! } + public var ChatList_Mute: String { return self._s[2327]! } public func Wallet_Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2324]!, self._r[2324]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2328]!, self._r[2328]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2325]! } - public var Conversation_PinnedQuiz: String { return self._s[2327]! } - public var ShareMenu_SelectChats: String { return self._s[2329]! } - public var ChatList_Context_Unarchive: String { return self._s[2330]! } - public var MusicPlayer_VoiceNote: String { return self._s[2331]! } - public var Conversation_RestrictedText: String { return self._s[2332]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2333]! } - public var Wallet_Month_GenApril: String { return self._s[2334]! } - public var Wallet_Month_ShortMarch: String { return self._s[2335]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2336]! } - public var Chat_PsaTooltip_covid: String { return self._s[2337]! } - public var Cache_Videos: String { return self._s[2338]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2339]! } - public var Wallet_Month_GenFebruary: String { return self._s[2340]! } - public var FeatureDisabled_Oops: String { return self._s[2342]! } - public var ChatList_RemoveFolderAction: String { return self._s[2343]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2344]! } + public var Permissions_CellularDataText_v0: String { return self._s[2329]! } + public var Conversation_PinnedQuiz: String { return self._s[2331]! } + public var ShareMenu_SelectChats: String { return self._s[2333]! } + public var ChatList_Context_Unarchive: String { return self._s[2334]! } + public var MusicPlayer_VoiceNote: String { return self._s[2335]! } + public var Conversation_RestrictedText: String { return self._s[2336]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2337]! } + public var Wallet_Month_GenApril: String { return self._s[2338]! } + public var Wallet_Month_ShortMarch: String { return self._s[2339]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2340]! } + public var Chat_PsaTooltip_covid: String { return self._s[2341]! } + public var Cache_Videos: String { return self._s[2342]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2343]! } + public var Wallet_Month_GenFebruary: String { return self._s[2344]! } + public var FeatureDisabled_Oops: String { return self._s[2346]! } + public var ChatList_RemoveFolderAction: String { return self._s[2347]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2348]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2345]!, self._r[2345]!, [_0]) + return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2347]! } - public var GroupPermission_NoSendPolls: String { return self._s[2348]! } - public var Wallet_Qr_ScanCode: String { return self._s[2349]! } - public var Message_VideoExpired: String { return self._s[2351]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2352]! } - public var Notifications_Badge: String { return self._s[2353]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2354]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2355]! } - public var Username_InvalidTooShort: String { return self._s[2356]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2357]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2358]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2359]! } + public var Stickers_GroupStickersHelp: String { return self._s[2351]! } + public var GroupPermission_NoSendPolls: String { return self._s[2352]! } + public var Wallet_Qr_ScanCode: String { return self._s[2353]! } + public var Message_VideoExpired: String { return self._s[2355]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2356]! } + public var Notifications_Badge: String { return self._s[2357]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2358]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2359]! } + public var Username_InvalidTooShort: String { return self._s[2360]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2361]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2362]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2363]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2360]!, self._r[2360]!, [_1]) + return formatWithArgumentRanges(self._s[2364]!, self._r[2364]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2361]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2362]! } - public var SharedMedia_CategoryDocs: String { return self._s[2365]! } + public var Permissions_SiriAllowInSettings_v0: String { return self._s[2365]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2366]! } + public var SharedMedia_CategoryDocs: String { return self._s[2369]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2366]!, self._r[2366]!, [_1]) + return formatWithArgumentRanges(self._s[2370]!, self._r[2370]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2367]! } - public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2368]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2370]! } + public var Wallet_Send_UninitializedTitle: String { return self._s[2371]! } + public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2372]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2374]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2371]!, self._r[2371]!, [_1]) + return formatWithArgumentRanges(self._s[2375]!, self._r[2375]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2372]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2376]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_0]) + return formatWithArgumentRanges(self._s[2377]!, self._r[2377]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2374]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2375]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2376]! } - public var Channel_UpdatePhotoItem: String { return self._s[2377]! } - public var GroupInfo_LeftStatus: String { return self._s[2378]! } - public var Watch_MessageView_Forward: String { return self._s[2380]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2381]! } - public var Cache_ClearEmpty: String { return self._s[2383]! } - public var Localization_LanguageName: String { return self._s[2384]! } - public var Wallet_AccessDenied_Title: String { return self._s[2385]! } - public var WebSearch_GIFs: String { return self._s[2386]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2387]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2388]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2389]! } - public var Common_Back: String { return self._s[2390]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2391]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2392]! } - public var Wallet_Send_Send: String { return self._s[2393]! } + public var ChatSettings_PrivateChats: String { return self._s[2378]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2379]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2380]! } + public var Channel_UpdatePhotoItem: String { return self._s[2381]! } + public var GroupInfo_LeftStatus: String { return self._s[2382]! } + public var Watch_MessageView_Forward: String { return self._s[2384]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2385]! } + public var Cache_ClearEmpty: String { return self._s[2387]! } + public var Localization_LanguageName: String { return self._s[2388]! } + public var Wallet_AccessDenied_Title: String { return self._s[2389]! } + public var WebSearch_GIFs: String { return self._s[2390]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2391]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2392]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2393]! } + public var Common_Back: String { return self._s[2394]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2395]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2396]! } + public var Wallet_Send_Send: String { return self._s[2397]! } public func PUSH_CHANNEL_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2395]!, self._r[2395]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2399]!, self._r[2399]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2396]! } - public var ChatList_Tabs_All: String { return self._s[2397]! } - public var Wallet_Month_GenJune: String { return self._s[2398]! } - public var Passport_Email_Help: String { return self._s[2399]! } - public var Watch_Conversation_Reply: String { return self._s[2401]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2404]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2405]! } - public var Channel_BanUser_Unban: String { return self._s[2407]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2408]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2409]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2411]! } - public var Wallet_Send_AddressHeader: String { return self._s[2412]! } - public var Passport_Identity_Name: String { return self._s[2413]! } + public var Wallet_Info_RefreshErrorTitle: String { return self._s[2400]! } + public var ChatList_Tabs_All: String { return self._s[2401]! } + public var Wallet_Month_GenJune: String { return self._s[2402]! } + public var Passport_Email_Help: String { return self._s[2403]! } + public var Watch_Conversation_Reply: String { return self._s[2405]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2408]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2409]! } + public var Channel_BanUser_Unban: String { return self._s[2411]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2412]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2413]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2415]! } + public var Wallet_Send_AddressHeader: String { return self._s[2416]! } + public var Passport_Identity_Name: String { return self._s[2417]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2414]!, self._r[2414]!, [_0]) + return formatWithArgumentRanges(self._s[2418]!, self._r[2418]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2415]! } - public var Conversation_BlockUser: String { return self._s[2416]! } - public var Month_GenJanuary: String { return self._s[2417]! } - public var ChatSettings_TextSize: String { return self._s[2418]! } - public var Notification_PassportValuePhone: String { return self._s[2419]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2420]! } - public var Passport_Language_ne: String { return self._s[2421]! } - public var Notification_CallBack: String { return self._s[2422]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2423]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2424]! } + public var GroupRemoved_ViewUserInfo: String { return self._s[2419]! } + public var Conversation_BlockUser: String { return self._s[2420]! } + public var Month_GenJanuary: String { return self._s[2421]! } + public var ChatSettings_TextSize: String { return self._s[2422]! } + public var Notification_PassportValuePhone: String { return self._s[2423]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2424]! } + public var Passport_Language_ne: String { return self._s[2425]! } + public var Notification_CallBack: String { return self._s[2426]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2427]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2428]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2425]!, self._r[2425]!, [_0]) + return formatWithArgumentRanges(self._s[2429]!, self._r[2429]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2426]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2427]! } - public var Stickers_FrequentlyUsed: String { return self._s[2429]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2430]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2432]! } + public var Channel_Info_Management: String { return self._s[2430]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2431]! } + public var Stickers_FrequentlyUsed: String { return self._s[2433]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2434]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2436]! } public func LOCAL_CHANNEL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2433]!, self._r[2433]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2437]!, self._r[2437]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2434]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2435]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2436]! } - public var CreatePoll_TextHeader: String { return self._s[2437]! } + public var TwoFactorSetup_Password_Title: String { return self._s[2438]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2439]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2440]! } + public var CreatePoll_TextHeader: String { return self._s[2441]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2438]!, self._r[2438]!, [_0]) + return formatWithArgumentRanges(self._s[2442]!, self._r[2442]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2439]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2440]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2442]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2443]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2444]! } + public var PhotoEditor_QualityMedium: String { return self._s[2443]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2444]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2446]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2447]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2448]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2445]!, self._r[2445]!, [_0]) + return formatWithArgumentRanges(self._s[2449]!, self._r[2449]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2446]!, self._r[2446]!, [_1]) + return formatWithArgumentRanges(self._s[2450]!, self._r[2450]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2447]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2448]! } - public var Conversation_LinkDialogOpen: String { return self._s[2450]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2451]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2452]! } - public var Settings_Username: String { return self._s[2454]! } - public var Conversation_Block: String { return self._s[2456]! } - public var Wallpaper_Wallpaper: String { return self._s[2457]! } - public var SocksProxySetup_UseProxy: String { return self._s[2459]! } - public var Wallet_Send_Confirmation: String { return self._s[2460]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2461]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2462]! } - public var MessageTimer_Forever: String { return self._s[2463]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2464]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2465]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2466]! } - public var Passport_Language_da: String { return self._s[2467]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2469]! } + public var LogoutOptions_LogOutWalletInfo: String { return self._s[2451]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2452]! } + public var Conversation_LinkDialogOpen: String { return self._s[2454]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2455]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2456]! } + public var Settings_Username: String { return self._s[2458]! } + public var Conversation_Block: String { return self._s[2460]! } + public var Wallpaper_Wallpaper: String { return self._s[2461]! } + public var SocksProxySetup_UseProxy: String { return self._s[2463]! } + public var Wallet_Send_Confirmation: String { return self._s[2464]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2465]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2466]! } + public var MessageTimer_Forever: String { return self._s[2467]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2468]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2469]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2470]! } + public var Passport_Language_da: String { return self._s[2471]! } + public var Conversation_PrivateChannelTimeLimitedAlertJoin: String { return self._s[2473]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2474]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2470]!, self._r[2470]!, [_0]) + return formatWithArgumentRanges(self._s[2475]!, self._r[2475]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2471]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2476]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2473]!, self._r[2473]!, [_0]) + return formatWithArgumentRanges(self._s[2478]!, self._r[2478]!, [_0]) } - public var Settings_AddDevice: String { return self._s[2474]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2476]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2477]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2478]! } - public var Conversation_PinnedPoll: String { return self._s[2479]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2480]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2481]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2482]! } + public var Settings_AddDevice: String { return self._s[2479]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2481]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2482]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2483]! } + public var Conversation_PinnedPoll: String { return self._s[2484]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2485]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2486]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2487]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2483]!, self._r[2483]!, [_1]) + return formatWithArgumentRanges(self._s[2488]!, self._r[2488]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2484]! } - public var Cache_ByPeerHeader: String { return self._s[2485]! } + public var WallpaperSearch_ColorPurple: String { return self._s[2489]! } + public var Cache_ByPeerHeader: String { return self._s[2490]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2486]!, self._r[2486]!, [_0]) + return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2487]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2490]! } - public var Wallet_Completed_Title: String { return self._s[2491]! } - public var Notification_PinnedMessage: String { return self._s[2492]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2493]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2495]! } - public var Contacts_SortBy: String { return self._s[2496]! } + public var ChatSettings_AutoDownloadDocuments: String { return self._s[2492]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2495]! } + public var Wallet_Completed_Title: String { return self._s[2496]! } + public var Notification_PinnedMessage: String { return self._s[2497]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2498]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2500]! } + public var Contacts_SortBy: String { return self._s[2501]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2497]!, self._r[2497]!, [_1]) + return formatWithArgumentRanges(self._s[2502]!, self._r[2502]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2499]! } + public var Appearance_ColorThemeNight: String { return self._s[2504]! } public func PUSH_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2500]!, self._r[2500]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2505]!, self._r[2505]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2501]! } - public var Watch_UserInfo_Service: String { return self._s[2502]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2504]! } - public var Conversation_Unpin: String { return self._s[2506]! } - public var CancelResetAccount_Title: String { return self._s[2507]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2508]! } + public var Call_EncryptionKey_Title: String { return self._s[2506]! } + public var Watch_UserInfo_Service: String { return self._s[2507]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2509]! } + public var Conversation_Unpin: String { return self._s[2511]! } + public var CancelResetAccount_Title: String { return self._s[2512]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2513]! } public func Time_PreciseDate_m8(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2510]!, self._r[2510]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2515]!, self._r[2515]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2511]! } - public var Appearance_BubbleCorners_Title: String { return self._s[2512]! } - public var CallSettings_Title: String { return self._s[2513]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2514]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2516]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2517]! } + public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2516]! } + public var Appearance_BubbleCorners_Title: String { return self._s[2517]! } + public var CallSettings_Title: String { return self._s[2518]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2519]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2521]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2522]! } public func Channel_AdminLog_MessageRankName(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2518]!, self._r[2518]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2523]!, self._r[2523]!, [_1, _2]) } - public var ChatList_Tabs_AllChats: String { return self._s[2519]! } - public var Passport_Identity_DocumentDetails: String { return self._s[2520]! } - public var LoginPassword_PasswordHelp: String { return self._s[2521]! } - public var ChatListFolderSettings_Info: String { return self._s[2522]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2523]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2524]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2525]! } - public var ChatListFolder_CategoryGroups: String { return self._s[2526]! } - public var Checkout_TotalPaidAmount: String { return self._s[2527]! } + public var ChatList_Tabs_AllChats: String { return self._s[2524]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2525]! } + public var LoginPassword_PasswordHelp: String { return self._s[2526]! } + public var ChatListFolderSettings_Info: String { return self._s[2527]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2528]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2529]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2530]! } + public var ChatListFolder_CategoryGroups: String { return self._s[2531]! } + public var Checkout_TotalPaidAmount: String { return self._s[2532]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2528]!, self._r[2528]!, [_0]) + return formatWithArgumentRanges(self._s[2533]!, self._r[2533]!, [_0]) } - public var ChatState_Updating: String { return self._s[2529]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[2530]! } - public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2531]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2533]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2534]! } + public var ChatState_Updating: String { return self._s[2534]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2535]! } + public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2536]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2538]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2539]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2535]!, self._r[2535]!, [_1]) + return formatWithArgumentRanges(self._s[2540]!, self._r[2540]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2536]! } - public var Contacts_InviteFriends: String { return self._s[2538]! } - public var Map_ChooseLocationTitle: String { return self._s[2539]! } - public var Conversation_StopPoll: String { return self._s[2541]! } + public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2541]! } + public var Contacts_InviteFriends: String { return self._s[2543]! } + public var Map_ChooseLocationTitle: String { return self._s[2544]! } + public var Conversation_StopPoll: String { return self._s[2546]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2542]!, self._r[2542]!, [_0]) + return formatWithArgumentRanges(self._s[2547]!, self._r[2547]!, [_0]) } - public var Call_Camera: String { return self._s[2543]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2544]! } - public var AppWallet_Intro_Text: String { return self._s[2545]! } - public var Appearance_BubbleCornersSetting: String { return self._s[2546]! } - public var Calls_RatingFeedback: String { return self._s[2547]! } + public var Call_Camera: String { return self._s[2548]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2549]! } + public var AppWallet_Intro_Text: String { return self._s[2550]! } + public var Appearance_BubbleCornersSetting: String { return self._s[2551]! } + public var Calls_RatingFeedback: String { return self._s[2552]! } public func Conversation_NoticeInvitedByInGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_0]) + return formatWithArgumentRanges(self._s[2554]!, self._r[2554]!, [_0]) } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2550]! } - public var Wallet_Alert_OK: String { return self._s[2551]! } - public var NotificationsSound_Pulse: String { return self._s[2552]! } - public var Watch_LastSeen_Lately: String { return self._s[2553]! } - public var ReportGroupLocation_Report: String { return self._s[2556]! } - public var Widget_NoUsers: String { return self._s[2557]! } - public var Conversation_UnvotePoll: String { return self._s[2558]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2560]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2561]! } - public var NotificationsSound_Circles: String { return self._s[2562]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2565]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2566]! } - public var ChatListFolder_CategoryBots: String { return self._s[2567]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2568]! } - public var Proxy_TooltipUnavailable: String { return self._s[2569]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2571]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2573]! } - public var Conversation_FileDropbox: String { return self._s[2574]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2575]! } - public var Tour_Text3: String { return self._s[2577]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2580]! } - public var ChatListFolder_NamePlaceholder: String { return self._s[2581]! } - public var GroupPermission_NoSendMessages: String { return self._s[2582]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2583]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2584]! } + public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2555]! } + public var Wallet_Alert_OK: String { return self._s[2556]! } + public var NotificationsSound_Pulse: String { return self._s[2557]! } + public var Watch_LastSeen_Lately: String { return self._s[2558]! } + public var ReportGroupLocation_Report: String { return self._s[2561]! } + public var Widget_NoUsers: String { return self._s[2562]! } + public var Conversation_UnvotePoll: String { return self._s[2563]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2565]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2566]! } + public var NotificationsSound_Circles: String { return self._s[2567]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2570]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2571]! } + public var ChatListFolder_CategoryBots: String { return self._s[2572]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2573]! } + public var Proxy_TooltipUnavailable: String { return self._s[2574]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2576]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2578]! } + public var Conversation_FileDropbox: String { return self._s[2579]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2580]! } + public var Tour_Text3: String { return self._s[2582]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2585]! } + public var ChatListFolder_NamePlaceholder: String { return self._s[2586]! } + public var GroupPermission_NoSendMessages: String { return self._s[2587]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2588]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2589]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2586]!, self._r[2586]!, [_0]) - } - public var GroupInfo_AddParticipantTitle: String { return self._s[2587]! } - public var Checkout_ShippingOption_Title: String { return self._s[2588]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2589]! } - public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2590]!, self._r[2590]!, [_0]) - } - public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2591]!, self._r[2591]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2592]! } - public var EditTheme_FileReadError: String { return self._s[2593]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2594]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2595]! } - public var AutoDownloadSettings_Photos: String { return self._s[2597]! } - public var Appearance_PreviewIncomingText: String { return self._s[2598]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2599]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2600]! } - public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2601]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2602]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2603]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2604]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2605]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2606]! } - public var Notification_SecretChatScreenshot: String { return self._s[2607]! } - public var AccessDenied_Wallpapers: String { return self._s[2608]! } - public var ChatList_Context_Mute: String { return self._s[2610]! } - public var Passport_Address_City: String { return self._s[2611]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2612]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2613]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2614]! } - public var AccessDenied_LocationDisabled: String { return self._s[2615]! } - public var Group_Location_Title: String { return self._s[2616]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2618]! } - public var GroupInfo_Sound: String { return self._s[2619]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2620]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2621]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2622]! } - public var Contacts_Title: String { return self._s[2623]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2624]! } - public var Passport_Language_fr: String { return self._s[2625]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2626]! } - public var Notifications_ResetAllNotifications: String { return self._s[2627]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2629]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2631]! } - public var Checkout_NewCard_Title: String { return self._s[2632]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2633]! } - public var Conversation_ForwardChats: String { return self._s[2634]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2636]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2637]! } - public var Settings_FAQ: String { return self._s[2639]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2640]! } - public var Conversation_ContextMenuForward: String { return self._s[2641]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2644]! } - public var PrivacyPolicy_Title: String { return self._s[2647]! } - public var Notifications_TextTone: String { return self._s[2648]! } - public var Profile_CreateNewContact: String { return self._s[2649]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2650]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2652]! } - public var Call_Speaker: String { return self._s[2653]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2654]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2656]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2657]! } + public var GroupInfo_AddParticipantTitle: String { return self._s[2592]! } + public var Checkout_ShippingOption_Title: String { return self._s[2593]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2594]! } + public func DialogList_SingleTypingSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2595]!, self._r[2595]!, [_0]) + } + public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2596]!, self._r[2596]!, [_0]) + } + public var Channel_Management_LabelAdministrator: String { return self._s[2597]! } + public var EditTheme_FileReadError: String { return self._s[2598]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2599]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2600]! } + public var AutoDownloadSettings_Photos: String { return self._s[2602]! } + public var Appearance_PreviewIncomingText: String { return self._s[2603]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2604]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2605]! } + public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2606]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2607]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2608]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2609]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2610]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2611]! } + public var Notification_SecretChatScreenshot: String { return self._s[2612]! } + public var AccessDenied_Wallpapers: String { return self._s[2613]! } + public var ChatList_Context_Mute: String { return self._s[2615]! } + public var Passport_Address_City: String { return self._s[2616]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2617]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2618]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2619]! } + public var AccessDenied_LocationDisabled: String { return self._s[2620]! } + public var Group_Location_Title: String { return self._s[2621]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2623]! } + public var GroupInfo_Sound: String { return self._s[2624]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2625]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2626]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2627]! } + public var Contacts_Title: String { return self._s[2628]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2629]! } + public var Passport_Language_fr: String { return self._s[2630]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2631]! } + public var Notifications_ResetAllNotifications: String { return self._s[2632]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2634]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2636]! } + public var Checkout_NewCard_Title: String { return self._s[2637]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2638]! } + public var Conversation_ForwardChats: String { return self._s[2639]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2641]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2642]! } + public var Settings_FAQ: String { return self._s[2644]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2645]! } + public var Conversation_ContextMenuForward: String { return self._s[2646]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2649]! } + public var PrivacyPolicy_Title: String { return self._s[2652]! } + public var Notifications_TextTone: String { return self._s[2653]! } + public var Profile_CreateNewContact: String { return self._s[2654]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2655]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2657]! } + public var Call_Speaker: String { return self._s[2658]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2659]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2661]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2662]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2658]!, self._r[2658]!, [_0]) + return formatWithArgumentRanges(self._s[2663]!, self._r[2663]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2659]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2660]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2661]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2662]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2663]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2664]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2665]! } - public var Bot_Unblock: String { return self._s[2666]! } - public var TextFormat_Italic: String { return self._s[2667]! } - public var WallpaperSearch_ColorPink: String { return self._s[2668]! } - public var Settings_About_Help: String { return self._s[2670]! } - public var SearchImages_Title: String { return self._s[2671]! } - public var Weekday_Wednesday: String { return self._s[2672]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2673]! } - public var ExplicitContent_AlertTitle: String { return self._s[2674]! } + public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2664]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2665]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2666]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2667]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2668]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2669]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2670]! } + public var Bot_Unblock: String { return self._s[2671]! } + public var TextFormat_Italic: String { return self._s[2672]! } + public var WallpaperSearch_ColorPink: String { return self._s[2673]! } + public var Settings_About_Help: String { return self._s[2675]! } + public var SearchImages_Title: String { return self._s[2676]! } + public var Weekday_Wednesday: String { return self._s[2677]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2678]! } + public var ExplicitContent_AlertTitle: String { return self._s[2679]! } public func Time_PreciseDate_m5(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2675]!, self._r[2675]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2680]!, self._r[2680]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2676]! } - public var Weekday_Thursday: String { return self._s[2677]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2678]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2679]! } + public var Channel_DiscussionGroup_Create: String { return self._s[2681]! } + public var Weekday_Thursday: String { return self._s[2682]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2683]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2684]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2680]!, self._r[2680]!, [_0]) + return formatWithArgumentRanges(self._s[2685]!, self._r[2685]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2681]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2682]! } - public var Passport_RequestedInformation: String { return self._s[2683]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2684]! } - public var Conversation_EncryptionProcessing: String { return self._s[2686]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2687]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2689]! } - public var Channel_Setup_Title: String { return self._s[2690]! } - public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2691]! } - public var Conversation_SearchPlaceholder: String { return self._s[2692]! } - public var OldChannels_GroupEmptyFormat: String { return self._s[2693]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2694]! } - public var Checkout_ErrorGeneric: String { return self._s[2695]! } - public var Passport_Language_hu: String { return self._s[2696]! } - public var GroupPermission_EditingDisabled: String { return self._s[2697]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2699]! } + public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2686]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2687]! } + public var Passport_RequestedInformation: String { return self._s[2688]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2689]! } + public var Conversation_EncryptionProcessing: String { return self._s[2691]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2692]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2694]! } + public var Channel_Setup_Title: String { return self._s[2695]! } + public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2696]! } + public var Conversation_SearchPlaceholder: String { return self._s[2697]! } + public var OldChannels_GroupEmptyFormat: String { return self._s[2698]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2699]! } + public var Checkout_ErrorGeneric: String { return self._s[2700]! } + public var Passport_Language_hu: String { return self._s[2701]! } + public var GroupPermission_EditingDisabled: String { return self._s[2702]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2704]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2700]!, self._r[2700]!, [_0]) - } - public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2703]!, self._r[2703]!, [_1]) - } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2704]! } - public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2706]! } - public var Group_Location_Info: String { return self._s[2707]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2708]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2709]! } - public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { + public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2708]!, self._r[2708]!, [_1]) + } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2709]! } + public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2710]!, self._r[2710]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2711]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2712]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2713]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2714]! } - public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Conversation_CloudStorageInfo_Title: String { return self._s[2711]! } + public var Group_Location_Info: String { return self._s[2712]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2713]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2714]! } + public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2715]!, self._r[2715]!, [_0]) } + public var Conversation_ClearPrivateHistory: String { return self._s[2716]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2717]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2718]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2719]! } + public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2720]!, self._r[2720]!, [_0]) + } public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2716]!, self._r[2716]!, [_0]) + return formatWithArgumentRanges(self._s[2721]!, self._r[2721]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2717]! } - public var Message_PinnedAnimationMessage: String { return self._s[2719]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2721]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2722]! } - public var Wallet_Info_TransactionTo: String { return self._s[2724]! } - public var Stats_ViewsBySourceTitle: String { return self._s[2725]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2726]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2727]! } - public var Embed_PlayingInPIP: String { return self._s[2728]! } - public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2729]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2730]! } + public var Passport_Language_cs: String { return self._s[2722]! } + public var Message_PinnedAnimationMessage: String { return self._s[2724]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2726]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2727]! } + public var Wallet_Info_TransactionTo: String { return self._s[2729]! } + public var Stats_ViewsBySourceTitle: String { return self._s[2730]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2731]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2732]! } + public var Embed_PlayingInPIP: String { return self._s[2733]! } + public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2734]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2735]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2731]!, self._r[2731]!, [_0]) + return formatWithArgumentRanges(self._s[2736]!, self._r[2736]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2732]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2737]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_1]) + return formatWithArgumentRanges(self._s[2738]!, self._r[2738]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2734]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2735]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2736]! } - public var AutoNightTheme_System: String { return self._s[2737]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2738]! } - public var CreatePoll_QuizTitle: String { return self._s[2739]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2740]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2741]! } + public var Notification_PaymentSent: String { return self._s[2739]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2740]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2741]! } + public var AutoNightTheme_System: String { return self._s[2742]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2743]! } + public var CreatePoll_QuizTitle: String { return self._s[2744]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2745]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2746]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_1]) + return formatWithArgumentRanges(self._s[2749]!, self._r[2749]!, [_1]) } public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2745]!, self._r[2745]!, [_1]) + return formatWithArgumentRanges(self._s[2750]!, self._r[2750]!, [_1]) } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2746]!, self._r[2746]!, [_1]) + return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2748]! } - public var PasscodeSettings_HelpTop: String { return self._s[2749]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2750]! } - public var PeerInfo_AddToContacts: String { return self._s[2751]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2752]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2753]! } - public var FeaturedStickers_OtherSection: String { return self._s[2754]! } - public var EditTheme_ShortLink: String { return self._s[2755]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2756]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2757]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2758]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2759]! } - public var Call_Accept: String { return self._s[2761]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2762]! } - public var Month_GenMarch: String { return self._s[2764]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2765]! } - public var LoginPassword_Title: String { return self._s[2766]! } - public var Call_End: String { return self._s[2767]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2768]! } - public var VoiceOver_Chat_Contact: String { return self._s[2769]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2770]! } - public var CallSettings_Always: String { return self._s[2771]! } - public var CallFeedback_Success: String { return self._s[2772]! } - public var TwoStepAuth_SetupHint: String { return self._s[2773]! } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2753]! } + public var PasscodeSettings_HelpTop: String { return self._s[2754]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2755]! } + public var PeerInfo_AddToContacts: String { return self._s[2756]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2757]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2758]! } + public var FeaturedStickers_OtherSection: String { return self._s[2759]! } + public var EditTheme_ShortLink: String { return self._s[2760]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2761]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2762]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2763]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2764]! } + public var Call_Accept: String { return self._s[2766]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2767]! } + public var Month_GenMarch: String { return self._s[2769]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2770]! } + public var LoginPassword_Title: String { return self._s[2771]! } + public var Call_End: String { return self._s[2772]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2773]! } + public var VoiceOver_Chat_Contact: String { return self._s[2774]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2775]! } + public var CallSettings_Always: String { return self._s[2776]! } + public var CallFeedback_Success: String { return self._s[2777]! } + public var TwoStepAuth_SetupHint: String { return self._s[2778]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2774]!, self._r[2774]!, [_1]) + return formatWithArgumentRanges(self._s[2779]!, self._r[2779]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2775]! } - public var PeerInfo_ButtonAddMember: String { return self._s[2776]! } - public var Login_PhoneTitle: String { return self._s[2777]! } - public var Passport_FieldPhoneHelp: String { return self._s[2778]! } - public var Weekday_ShortSunday: String { return self._s[2779]! } - public var Passport_InfoFAQ_URL: String { return self._s[2780]! } - public var ContactInfo_Job: String { return self._s[2782]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2783]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2784]! } - public var CreatePoll_QuizTip: String { return self._s[2785]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2786]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2787]! } - public var Invite_ChannelsTooMuch: String { return self._s[2788]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2789]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2790]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2791]! } - public var Wallet_Receive_AmountText: String { return self._s[2792]! } - public var TwoStepAuth_Disable: String { return self._s[2793]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2794]! } - public var CallFeedback_ReasonNoise: String { return self._s[2795]! } - public var Appearance_AppIconDefault: String { return self._s[2797]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2798]! } - public var MediaPicker_AddCaption: String { return self._s[2799]! } - public var CallSettings_TabIconDescription: String { return self._s[2800]! } + public var ConversationProfile_UsersTooMuchError: String { return self._s[2780]! } + public var PeerInfo_ButtonAddMember: String { return self._s[2781]! } + public var Login_PhoneTitle: String { return self._s[2782]! } + public var Passport_FieldPhoneHelp: String { return self._s[2783]! } + public var Weekday_ShortSunday: String { return self._s[2784]! } + public var Passport_InfoFAQ_URL: String { return self._s[2785]! } + public var ContactInfo_Job: String { return self._s[2787]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2788]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2789]! } + public var CreatePoll_QuizTip: String { return self._s[2790]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2791]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2792]! } + public var Invite_ChannelsTooMuch: String { return self._s[2793]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2794]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2795]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2796]! } + public var Wallet_Receive_AmountText: String { return self._s[2797]! } + public var TwoStepAuth_Disable: String { return self._s[2798]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2799]! } + public var CallFeedback_ReasonNoise: String { return self._s[2800]! } + public var Appearance_AppIconDefault: String { return self._s[2802]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2803]! } + public var MediaPicker_AddCaption: String { return self._s[2804]! } + public var CallSettings_TabIconDescription: String { return self._s[2805]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2801]!, self._r[2801]!, [_0]) + return formatWithArgumentRanges(self._s[2806]!, self._r[2806]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2802]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2807]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2803]!, self._r[2803]!, [_0]) + return formatWithArgumentRanges(self._s[2808]!, self._r[2808]!, [_0]) } - public var CreatePoll_ExplanationHeader: String { return self._s[2805]! } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2806]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2807]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2808]! } - public var DialogList_SearchSectionRecent: String { return self._s[2809]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2810]! } - public var CreatePoll_Anonymous: String { return self._s[2811]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2814]! } - public var LastSeen_WithinAWeek: String { return self._s[2815]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2816]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2818]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2819]! } + public var CreatePoll_ExplanationHeader: String { return self._s[2810]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2811]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2812]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2813]! } + public var DialogList_SearchSectionRecent: String { return self._s[2814]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2815]! } + public var CreatePoll_Anonymous: String { return self._s[2816]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2819]! } + public var LastSeen_WithinAWeek: String { return self._s[2820]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2821]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2823]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2824]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2820]!, self._r[2820]!, [_0]) + return formatWithArgumentRanges(self._s[2825]!, self._r[2825]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2821]! } - public var Conversation_StatusLeftGroup: String { return self._s[2822]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2823]! } - public var OwnershipTransfer_Transfer: String { return self._s[2825]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2826]! } - public var GroupPermission_AddSuccess: String { return self._s[2827]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2829]! } - public var Conversation_ContextMenuCopy: String { return self._s[2830]! } - public var AccessDenied_CallMicrophone: String { return self._s[2831]! } + public var Passport_Address_TypeResidentialAddress: String { return self._s[2826]! } + public var Conversation_StatusLeftGroup: String { return self._s[2827]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2828]! } + public var OwnershipTransfer_Transfer: String { return self._s[2830]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2831]! } + public var GroupPermission_AddSuccess: String { return self._s[2832]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2834]! } + public var Conversation_ContextMenuCopy: String { return self._s[2835]! } + public var AccessDenied_CallMicrophone: String { return self._s[2836]! } public func Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2832]!, self._r[2832]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2837]!, self._r[2837]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2833]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2834]! } - public var Checkout_PaymentMethod_New: String { return self._s[2835]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2836]! } - public var PhotoEditor_QualityTool: String { return self._s[2837]! } - public var Login_SendCodeViaSms: String { return self._s[2838]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2839]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2840]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2841]! } - public var Login_EmailNotConfiguredError: String { return self._s[2842]! } - public var SocksProxySetup_Status: String { return self._s[2843]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2844]! } - public var PrivacyPolicy_Accept: String { return self._s[2845]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2846]! } - public var Appearance_AppIconClassicX: String { return self._s[2847]! } + public var Login_InvalidFirstNameError: String { return self._s[2838]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2839]! } + public var Checkout_PaymentMethod_New: String { return self._s[2840]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2841]! } + public var PhotoEditor_QualityTool: String { return self._s[2842]! } + public var Login_SendCodeViaSms: String { return self._s[2843]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2844]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2845]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2846]! } + public var Login_EmailNotConfiguredError: String { return self._s[2847]! } + public var SocksProxySetup_Status: String { return self._s[2848]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2849]! } + public var PrivacyPolicy_Accept: String { return self._s[2850]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2851]! } + public var Appearance_AppIconClassicX: String { return self._s[2852]! } public func PUSH_CHAT_MESSAGE_TEXT(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2848]!, self._r[2848]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2853]!, self._r[2853]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2849]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2851]! } - public var AutoNightTheme_Automatic: String { return self._s[2852]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2853]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2854]! } - public var Cache_Help: String { return self._s[2855]! } - public var Group_ErrorAccessDenied: String { return self._s[2856]! } - public var Passport_Language_fa: String { return self._s[2857]! } - public var Wallet_Intro_Text: String { return self._s[2858]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2859]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2860]! } - public var PrivacySettings_LastSeen: String { return self._s[2861]! } + public var OwnershipTransfer_SecurityRequirements: String { return self._s[2854]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2856]! } + public var AutoNightTheme_Automatic: String { return self._s[2857]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2858]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2859]! } + public var Cache_Help: String { return self._s[2860]! } + public var Group_ErrorAccessDenied: String { return self._s[2861]! } + public var Passport_Language_fa: String { return self._s[2862]! } + public var Wallet_Intro_Text: String { return self._s[2863]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2864]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2865]! } + public var PrivacySettings_LastSeen: String { return self._s[2866]! } public func DialogList_MultipleTyping(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2862]!, self._r[2862]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2867]!, self._r[2867]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2866]! } - public var Preview_SaveGif: String { return self._s[2867]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2868]! } - public var Profile_About: String { return self._s[2869]! } - public var Channel_About_Placeholder: String { return self._s[2870]! } - public var Login_InfoTitle: String { return self._s[2871]! } + public var Wallet_Configuration_Apply: String { return self._s[2871]! } + public var Preview_SaveGif: String { return self._s[2872]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2873]! } + public var Profile_About: String { return self._s[2874]! } + public var Channel_About_Placeholder: String { return self._s[2875]! } + public var Login_InfoTitle: String { return self._s[2876]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2872]!, self._r[2872]!, [_0]) + return formatWithArgumentRanges(self._s[2877]!, self._r[2877]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2873]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2875]! } - public var ContactInfo_Title: String { return self._s[2876]! } - public var Media_ShareThisVideo: String { return self._s[2877]! } - public var Chat_GenericPsaTooltip: String { return self._s[2878]! } - public var Weekday_ShortFriday: String { return self._s[2879]! } - public var AccessDenied_Contacts: String { return self._s[2881]! } - public var Notification_CallIncomingShort: String { return self._s[2882]! } - public var Group_Setup_TypePublic: String { return self._s[2883]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2884]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2885]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2888]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2889]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2890]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2891]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2892]! } + public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2878]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2880]! } + public var ContactInfo_Title: String { return self._s[2881]! } + public var Media_ShareThisVideo: String { return self._s[2882]! } + public var Chat_GenericPsaTooltip: String { return self._s[2883]! } + public var Weekday_ShortFriday: String { return self._s[2884]! } + public var AccessDenied_Contacts: String { return self._s[2886]! } + public var Notification_CallIncomingShort: String { return self._s[2887]! } + public var Group_Setup_TypePublic: String { return self._s[2888]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2889]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2890]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2893]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2894]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2895]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2896]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2897]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2893]!, self._r[2893]!, [_0]) + return formatWithArgumentRanges(self._s[2898]!, self._r[2898]!, [_0]) } - public var DialogList_Typing: String { return self._s[2894]! } - public var CallFeedback_IncludeLogs: String { return self._s[2896]! } - public var Checkout_Phone: String { return self._s[2898]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2901]! } - public var Privacy_Calls_Integration: String { return self._s[2902]! } - public var Notifications_PermissionsAllow: String { return self._s[2903]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2909]! } - public var Settings_ChatSettings: String { return self._s[2910]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2911]! } + public var DialogList_Typing: String { return self._s[2899]! } + public var CallFeedback_IncludeLogs: String { return self._s[2901]! } + public var Checkout_Phone: String { return self._s[2903]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2906]! } + public var Privacy_Calls_Integration: String { return self._s[2907]! } + public var Notifications_PermissionsAllow: String { return self._s[2908]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2914]! } + public var Settings_ChatSettings: String { return self._s[2915]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2916]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2913]!, self._r[2913]!, [_0]) + return formatWithArgumentRanges(self._s[2918]!, self._r[2918]!, [_0]) } public func Channel_AdminLog_MessageInvitedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2914]!, self._r[2914]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2919]!, self._r[2919]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2916]! } + public var GroupRemoved_DeleteUser: String { return self._s[2921]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2917]!, self._r[2917]!, [_0]) + return formatWithArgumentRanges(self._s[2922]!, self._r[2922]!, [_0]) } - public var ChatListFolder_CategoryMuted: String { return self._s[2918]! } + public var ChatListFolder_CategoryMuted: String { return self._s[2923]! } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2919]!, self._r[2919]!, [_1]) + return formatWithArgumentRanges(self._s[2924]!, self._r[2924]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2920]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2921]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2923]! } - public var Conversation_Unblock: String { return self._s[2924]! } - public var PrivacySettings_DataSettings: String { return self._s[2925]! } - public var WallpaperPreview_PatternPaternApply: String { return self._s[2926]! } - public var Group_PublicLink_Info: String { return self._s[2927]! } + public var Login_ContinueWithLocalization: String { return self._s[2925]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2926]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2928]! } + public var Conversation_Unblock: String { return self._s[2929]! } + public var PrivacySettings_DataSettings: String { return self._s[2930]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[2931]! } + public var Group_PublicLink_Info: String { return self._s[2932]! } public func Wallet_Time_PreciseDate_m1(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2928]!, self._r[2928]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2933]!, self._r[2933]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2929]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2934]! } public func Privacy_GroupsAndChannels_InviteToChannelError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2930]!, self._r[2930]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2935]!, self._r[2935]!, [_0, _1]) } - public var ChatList_FolderAllChats: String { return self._s[2931]! } - public var OldChannels_ChannelsHeader: String { return self._s[2933]! } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2934]! } - public var PrivacySettings_Passcode: String { return self._s[2936]! } - public var Call_Mute: String { return self._s[2937]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2938]! } - public var Passport_Language_dz: String { return self._s[2939]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2940]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2941]! } - public var Passport_Language_tk: String { return self._s[2942]! } + public var ChatList_FolderAllChats: String { return self._s[2936]! } + public var OldChannels_ChannelsHeader: String { return self._s[2938]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2939]! } + public var PrivacySettings_Passcode: String { return self._s[2941]! } + public var Call_Mute: String { return self._s[2942]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2943]! } + public var Passport_Language_dz: String { return self._s[2944]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2945]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2946]! } + public var Passport_Language_tk: String { return self._s[2947]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2943]!, self._r[2943]!, [_0]) + return formatWithArgumentRanges(self._s[2948]!, self._r[2948]!, [_0]) } - public var Settings_Search: String { return self._s[2944]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2945]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2946]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2947]! } - public var Conversation_ContextMenuReply: String { return self._s[2948]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2949]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2950]! } - public var Tour_Title1: String { return self._s[2951]! } - public var Wallet_Alert_Cancel: String { return self._s[2952]! } - public var Stats_Total: String { return self._s[2954]! } - public var Conversation_ClearGroupHistory: String { return self._s[2955]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2956]! } - public var WallpaperPreview_Motion: String { return self._s[2957]! } + public var Settings_Search: String { return self._s[2949]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2950]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2951]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2952]! } + public var Conversation_ContextMenuReply: String { return self._s[2953]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2954]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2955]! } + public var Tour_Title1: String { return self._s[2956]! } + public var Wallet_Alert_Cancel: String { return self._s[2957]! } + public var Stats_Total: String { return self._s[2959]! } + public var Conversation_ClearGroupHistory: String { return self._s[2960]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2961]! } + public var WallpaperPreview_Motion: String { return self._s[2962]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2958]!, self._r[2958]!, [_0]) + return formatWithArgumentRanges(self._s[2963]!, self._r[2963]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2959]! } - public var Call_RateCall: String { return self._s[2960]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2961]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2962]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2963]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2965]! } + public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2964]! } + public var Call_RateCall: String { return self._s[2965]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2966]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2967]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2968]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2970]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_0]) + return formatWithArgumentRanges(self._s[2972]!, self._r[2972]!, [_0]) } - public var Compose_Create: String { return self._s[2968]! } - public var Contacts_InviteToTelegram: String { return self._s[2969]! } - public var GroupInfo_Notifications: String { return self._s[2970]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2972]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2973]! } - public var Month_GenApril: String { return self._s[2974]! } - public var Appearance_AutoNightTheme: String { return self._s[2975]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2977]! } - public var Login_CodeSentSms: String { return self._s[2979]! } + public var Compose_Create: String { return self._s[2973]! } + public var Contacts_InviteToTelegram: String { return self._s[2974]! } + public var GroupInfo_Notifications: String { return self._s[2975]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2977]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2978]! } + public var Month_GenApril: String { return self._s[2979]! } + public var Appearance_AutoNightTheme: String { return self._s[2980]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2982]! } + public var Login_CodeSentSms: String { return self._s[2984]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2980]!, self._r[2980]!, [_0]) - } - public var EmptyGroupInfo_Line3: String { return self._s[2981]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2982]! } - public var Passport_Language_hr: String { return self._s[2983]! } - public var Common_ActionNotAllowedError: String { return self._s[2984]! } - public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2986]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2987]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2988]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2989]! } - public var Privacy_SecretChatsTitle: String { return self._s[2990]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2992]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2993]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2994]! } - public var ChatListFolder_NameSectionHeader: String { return self._s[2995]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2996]! } - public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2997]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[2998]! } - public var Preview_DeleteGif: String { return self._s[2999]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[3000]! } - public var Group_ErrorNotMutualContact: String { return self._s[3001]! } - public var Notification_MessageLifetime5s: String { return self._s[3002]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[3003]! } - public var OldChannels_ChannelFormat: String { return self._s[3004]! } + public var EmptyGroupInfo_Line3: String { return self._s[2986]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2987]! } + public var Passport_Language_hr: String { return self._s[2988]! } + public var Common_ActionNotAllowedError: String { return self._s[2989]! } + public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_0]) + } + public var GroupInfo_InviteLink_CopyLink: String { return self._s[2991]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2992]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2993]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2994]! } + public var Privacy_SecretChatsTitle: String { return self._s[2995]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2997]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2998]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2999]! } + public var ChatListFolder_NameSectionHeader: String { return self._s[3000]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[3001]! } + public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[3002]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[3003]! } + public var Preview_DeleteGif: String { return self._s[3004]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[3005]! } + public var Group_ErrorNotMutualContact: String { return self._s[3006]! } + public var Notification_MessageLifetime5s: String { return self._s[3007]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[3008]! } + public var OldChannels_ChannelFormat: String { return self._s[3009]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3005]!, self._r[3005]!, [_0]) + return formatWithArgumentRanges(self._s[3010]!, self._r[3010]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[3006]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3008]! } - public var ReportSpam_DeleteThisChat: String { return self._s[3009]! } - public var Passport_Address_AddBankStatement: String { return self._s[3010]! } - public var Notification_CallIncoming: String { return self._s[3011]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[3012]! } - public var Compose_NewGroupTitle: String { return self._s[3013]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3015]! } - public var Passport_Address_Postcode: String { return self._s[3017]! } + public var VoiceOver_Chat_Video: String { return self._s[3011]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3013]! } + public var ReportSpam_DeleteThisChat: String { return self._s[3014]! } + public var Passport_Address_AddBankStatement: String { return self._s[3015]! } + public var Notification_CallIncoming: String { return self._s[3016]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[3017]! } + public var Compose_NewGroupTitle: String { return self._s[3018]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3020]! } + public var Passport_Address_Postcode: String { return self._s[3022]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3018]!, self._r[3018]!, [_0]) + return formatWithArgumentRanges(self._s[3023]!, self._r[3023]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[3019]! } - public var Wallet_Month_ShortOctober: String { return self._s[3020]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[3021]! } - public var WallpaperColors_Title: String { return self._s[3022]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3023]! } - public var VoiceOver_MessageContextForward: String { return self._s[3024]! } - public var GroupPermission_Duration: String { return self._s[3025]! } + public var Checkout_NewCard_SaveInfoHelp: String { return self._s[3024]! } + public var Wallet_Month_ShortOctober: String { return self._s[3025]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[3026]! } + public var WallpaperColors_Title: String { return self._s[3027]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3028]! } + public var VoiceOver_MessageContextForward: String { return self._s[3029]! } + public var GroupPermission_Duration: String { return self._s[3030]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_0]) + return formatWithArgumentRanges(self._s[3031]!, self._r[3031]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[3027]! } - public var Username_Placeholder: String { return self._s[3028]! } - public var CallFeedback_WhatWentWrong: String { return self._s[3029]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[3030]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3031]! } + public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[3032]! } + public var Username_Placeholder: String { return self._s[3033]! } + public var CallFeedback_WhatWentWrong: String { return self._s[3034]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[3035]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3036]! } public func Channel_AdminLog_MessageChangedUnlinkedChannel(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3033]!, self._r[3033]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3038]!, self._r[3038]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[3034]! } - public var Channel_MessagePhotoUpdated: String { return self._s[3035]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[3036]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3037]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[3038]! } - public var Conversation_ContextMenuMore: String { return self._s[3039]! } - public var Privacy_PaymentsClearInfo: String { return self._s[3040]! } - public var CallSettings_TabIcon: String { return self._s[3041]! } - public var KeyCommand_Find: String { return self._s[3042]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[3043]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3044]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3045]! } + public var Passport_PasswordDescription: String { return self._s[3039]! } + public var Channel_MessagePhotoUpdated: String { return self._s[3040]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[3041]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3042]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[3043]! } + public var Conversation_ContextMenuMore: String { return self._s[3044]! } + public var Privacy_PaymentsClearInfo: String { return self._s[3045]! } + public var CallSettings_TabIcon: String { return self._s[3046]! } + public var KeyCommand_Find: String { return self._s[3047]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[3048]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3049]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3050]! } public func Conversation_NoticeInvitedByInChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3046]!, self._r[3046]!, [_0]) + return formatWithArgumentRanges(self._s[3051]!, self._r[3051]!, [_0]) } - public var Message_PinnedGame: String { return self._s[3047]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3048]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3050]! } - public var Login_CallRequestState2: String { return self._s[3052]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3054]! } + public var Message_PinnedGame: String { return self._s[3052]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3053]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3055]! } + public var Login_CallRequestState2: String { return self._s[3057]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3059]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3055]!, self._r[3055]!, [_0]) + return formatWithArgumentRanges(self._s[3060]!, self._r[3060]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3057]!, self._r[3057]!, [_0]) - } - public var AuthSessions_AddDevice: String { return self._s[3058]! } - public var WallpaperPreview_Blurred: String { return self._s[3059]! } - public var Conversation_InstantPagePreview: String { return self._s[3060]! } - public var PeerInfo_ButtonUnmute: String { return self._s[3061]! } - public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_0]) } - public var ChatList_PeerTypeChannel: String { return self._s[3063]! } - public var SecretTimer_VideoDescription: String { return self._s[3066]! } - public var WallpaperSearch_ColorRed: String { return self._s[3067]! } - public var GroupPermission_NoPinMessages: String { return self._s[3068]! } - public var Passport_Language_es: String { return self._s[3069]! } - public var Permissions_ContactsAllow_v0: String { return self._s[3071]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3072]! } + public var AuthSessions_AddDevice: String { return self._s[3063]! } + public var WallpaperPreview_Blurred: String { return self._s[3064]! } + public var Conversation_InstantPagePreview: String { return self._s[3065]! } + public var PeerInfo_ButtonUnmute: String { return self._s[3066]! } + public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3067]!, self._r[3067]!, [_0]) + } + public var ChatList_PeerTypeChannel: String { return self._s[3068]! } + public var SecretTimer_VideoDescription: String { return self._s[3071]! } + public var WallpaperSearch_ColorRed: String { return self._s[3072]! } + public var GroupPermission_NoPinMessages: String { return self._s[3073]! } + public var Passport_Language_es: String { return self._s[3074]! } + public var Permissions_ContactsAllow_v0: String { return self._s[3076]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3077]! } public func PUSH_CHAT_MESSAGE_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3073]!, self._r[3073]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3078]!, self._r[3078]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[3074]! } - public var WebPreview_GettingLinkInfo: String { return self._s[3076]! } - public var Watch_UserInfo_Unmute: String { return self._s[3077]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3078]! } - public var AccessDenied_CameraRestricted: String { return self._s[3080]! } + public var Privacy_Forwards_CustomHelp: String { return self._s[3079]! } + public var WebPreview_GettingLinkInfo: String { return self._s[3081]! } + public var Watch_UserInfo_Unmute: String { return self._s[3082]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3083]! } + public var AccessDenied_CameraRestricted: String { return self._s[3085]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3081]!, self._r[3081]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[3086]!, self._r[3086]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[3083]! } - public var Settings_CopyUsername: String { return self._s[3084]! } - public var Contacts_SearchLabel: String { return self._s[3085]! } - public var Map_OpenInYandexNavigator: String { return self._s[3087]! } - public var PasscodeSettings_EncryptData: String { return self._s[3088]! } - public var Settings_Wallet: String { return self._s[3089]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3090]! } - public var ChatList_PeerTypeBot: String { return self._s[3091]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[3092]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[3093]! } - public var DialogList_AdNoticeAlert: String { return self._s[3094]! } - public var Wallet_Month_GenMay: String { return self._s[3096]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3097]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3098]! } - public var Localization_LanguageCustom: String { return self._s[3099]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3100]! } - public var CallFeedback_Title: String { return self._s[3101]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3104]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3105]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[3106]! } - public var Conversation_InfoGroup: String { return self._s[3107]! } - public var Compose_NewMessage: String { return self._s[3108]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3109]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3110]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3111]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3112]! } + public var ChatList_ReadAll: String { return self._s[3088]! } + public var Settings_CopyUsername: String { return self._s[3089]! } + public var Contacts_SearchLabel: String { return self._s[3090]! } + public var Map_OpenInYandexNavigator: String { return self._s[3092]! } + public var PasscodeSettings_EncryptData: String { return self._s[3093]! } + public var Settings_Wallet: String { return self._s[3094]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3095]! } + public var ChatList_PeerTypeBot: String { return self._s[3096]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[3097]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[3098]! } + public var DialogList_AdNoticeAlert: String { return self._s[3099]! } + public var Wallet_Month_GenMay: String { return self._s[3101]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3102]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3103]! } + public var Localization_LanguageCustom: String { return self._s[3104]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3105]! } + public var CallFeedback_Title: String { return self._s[3106]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3109]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3110]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[3111]! } + public var Conversation_InfoGroup: String { return self._s[3112]! } + public var Compose_NewMessage: String { return self._s[3113]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3114]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3115]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3116]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3117]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3113]!, self._r[3113]!, [_0]) + return formatWithArgumentRanges(self._s[3118]!, self._r[3118]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3114]! } - public var Login_CancelSignUpConfirmation: String { return self._s[3115]! } - public var ChangePhoneNumberCode_Help: String { return self._s[3116]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[3117]! } - public var ChatList_Context_RemoveFromFolder: String { return self._s[3118]! } - public var Channel_BlackList_Title: String { return self._s[3119]! } - public var UserInfo_PhoneCall: String { return self._s[3120]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3122]! } - public var Wallet_Month_ShortJanuary: String { return self._s[3123]! } - public var State_connecting: String { return self._s[3124]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3125]! } - public var Wallet_Month_GenMarch: String { return self._s[3126]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[3127]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[3128]! } + public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3119]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3120]! } + public var ChangePhoneNumberCode_Help: String { return self._s[3121]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[3122]! } + public var ChatList_Context_RemoveFromFolder: String { return self._s[3123]! } + public var Channel_BlackList_Title: String { return self._s[3124]! } + public var UserInfo_PhoneCall: String { return self._s[3125]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3127]! } + public var Wallet_Month_ShortJanuary: String { return self._s[3128]! } + public var State_connecting: String { return self._s[3129]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3130]! } + public var Wallet_Month_GenMarch: String { return self._s[3131]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[3132]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[3133]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3129]!, self._r[3129]!, [_0]) + return formatWithArgumentRanges(self._s[3134]!, self._r[3134]!, [_0]) } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3130]!, self._r[3130]!, [_0]) + return formatWithArgumentRanges(self._s[3135]!, self._r[3135]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[3131]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3132]! } - public var Passport_Identity_EditPassport: String { return self._s[3133]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[3135]! } - public var Localization_EnglishLanguageName: String { return self._s[3136]! } - public var Share_AuthDescription: String { return self._s[3137]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3138]! } - public var Passport_Identity_Surname: String { return self._s[3139]! } - public var Compose_TokenListPlaceholder: String { return self._s[3140]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3141]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[3142]! } - public var Settings_AboutEmpty: String { return self._s[3143]! } - public var Conversation_Unmute: String { return self._s[3144]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[3146]! } - public var Wallet_Sending_Text: String { return self._s[3147]! } + public var Notifications_GroupNotifications: String { return self._s[3136]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3137]! } + public var Passport_Identity_EditPassport: String { return self._s[3138]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[3140]! } + public var Localization_EnglishLanguageName: String { return self._s[3141]! } + public var Share_AuthDescription: String { return self._s[3142]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3143]! } + public var Passport_Identity_Surname: String { return self._s[3144]! } + public var Compose_TokenListPlaceholder: String { return self._s[3145]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3146]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[3147]! } + public var Settings_AboutEmpty: String { return self._s[3148]! } + public var Conversation_Unmute: String { return self._s[3149]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[3151]! } + public var Wallet_Sending_Text: String { return self._s[3152]! } public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3148]!, self._r[3148]!, [_1]) + return formatWithArgumentRanges(self._s[3153]!, self._r[3153]!, [_1]) } - public var Login_CodeSentCall: String { return self._s[3149]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3151]! } - public var ChatSettings_Appearance: String { return self._s[3152]! } - public var ClearCache_StorageUsage: String { return self._s[3153]! } - public var ChatListFolder_NameContacts: String { return self._s[3154]! } - public var Appearance_PickAccentColor: String { return self._s[3155]! } + public var Login_CodeSentCall: String { return self._s[3154]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3156]! } + public var ChatSettings_Appearance: String { return self._s[3157]! } + public var ClearCache_StorageUsage: String { return self._s[3158]! } + public var ChatListFolder_NameContacts: String { return self._s[3159]! } + public var Appearance_PickAccentColor: String { return self._s[3160]! } public func PUSH_CHAT_MESSAGE_NOTEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3156]!, self._r[3156]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3161]!, self._r[3161]!, [_1, _2]) } public func PUSH_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3157]!, self._r[3157]!, [_1]) + return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_1]) } - public var Notification_CallMissed: String { return self._s[3158]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3159]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3160]! } - public var Wallet_Month_GenOctober: String { return self._s[3162]! } - public var ChatAdmins_AdminLabel: String { return self._s[3163]! } - public var KeyCommand_JumpToNextChat: String { return self._s[3164]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[3166]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3167]! } - public var Month_GenJune: String { return self._s[3168]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[3169]! } - public var Watch_Location_Current: String { return self._s[3170]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3171]! } - public var Conversation_TitleMute: String { return self._s[3172]! } - public var Map_PlacesInThisArea: String { return self._s[3173]! } + public var Notification_CallMissed: String { return self._s[3163]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3164]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3165]! } + public var Wallet_Month_GenOctober: String { return self._s[3167]! } + public var ChatAdmins_AdminLabel: String { return self._s[3168]! } + public var KeyCommand_JumpToNextChat: String { return self._s[3169]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[3171]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3172]! } + public var Month_GenJune: String { return self._s[3173]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[3174]! } + public var Watch_Location_Current: String { return self._s[3175]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3176]! } + public var Conversation_TitleMute: String { return self._s[3177]! } + public var Map_PlacesInThisArea: String { return self._s[3178]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3174]!, self._r[3174]!, [_1]) + return formatWithArgumentRanges(self._s[3179]!, self._r[3179]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3175]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3180]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3176]!, self._r[3176]!, [_0]) - } - public var Call_ReportPlaceholder: String { return self._s[3177]! } - public var Chat_SlowmodeSendError: String { return self._s[3178]! } - public var MaskStickerSettings_Info: String { return self._s[3179]! } - public var EditTheme_Expand_TopInfo: String { return self._s[3180]! } - public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3181]!, self._r[3181]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[3182]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3184]! } - public var Contacts_ShareTelegram: String { return self._s[3185]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3186]! } - public var Map_AddressOnMap: String { return self._s[3187]! } - public var Channel_ErrorAccessDenied: String { return self._s[3188]! } - public var UserInfo_ScamBotWarning: String { return self._s[3190]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[3191]! } - public var Call_ConnectionErrorTitle: String { return self._s[3192]! } - public var UserInfo_NotificationsEnable: String { return self._s[3193]! } - public var ArchivedChats_IntroText1: String { return self._s[3194]! } - public var Tour_Text4: String { return self._s[3197]! } - public var WallpaperSearch_Recent: String { return self._s[3198]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3199]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3200]! } - public var Profile_MessageLifetime2s: String { return self._s[3202]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3203]! } - public var Notification_MessageLifetime2s: String { return self._s[3204]! } - public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3205]!, self._r[3205]!, [_1, _2, _3]) + public var Call_ReportPlaceholder: String { return self._s[3182]! } + public var Chat_SlowmodeSendError: String { return self._s[3183]! } + public var MaskStickerSettings_Info: String { return self._s[3184]! } + public var EditTheme_Expand_TopInfo: String { return self._s[3185]! } + public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3186]!, self._r[3186]!, [_0]) } - public var Cache_ClearCache: String { return self._s[3206]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3207]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3208]! } + public var Checkout_NewCard_PostcodeTitle: String { return self._s[3187]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3189]! } + public var Contacts_ShareTelegram: String { return self._s[3190]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3191]! } + public var Map_AddressOnMap: String { return self._s[3192]! } + public var Channel_ErrorAccessDenied: String { return self._s[3193]! } + public var UserInfo_ScamBotWarning: String { return self._s[3195]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[3196]! } + public var Call_ConnectionErrorTitle: String { return self._s[3197]! } + public var UserInfo_NotificationsEnable: String { return self._s[3198]! } + public var ArchivedChats_IntroText1: String { return self._s[3199]! } + public var Tour_Text4: String { return self._s[3202]! } + public var WallpaperSearch_Recent: String { return self._s[3203]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3204]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3205]! } + public var Profile_MessageLifetime2s: String { return self._s[3207]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3208]! } + public var Notification_MessageLifetime2s: String { return self._s[3209]! } + public func Time_PreciseDate_m10(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3210]!, self._r[3210]!, [_1, _2, _3]) + } + public var Cache_ClearCache: String { return self._s[3211]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3212]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3213]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3212]!, self._r[3212]!, [_0]) + return formatWithArgumentRanges(self._s[3217]!, self._r[3217]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3214]!, self._r[3214]!, [_0]) + return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3215]! } - public var PeerInfo_PaneMembers: String { return self._s[3216]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3217]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3218]! } - public var ChatList_UnarchiveAction: String { return self._s[3219]! } - public var AutoNightTheme_Title: String { return self._s[3220]! } - public var InstantPage_FeedbackButton: String { return self._s[3221]! } - public var Passport_FieldAddress: String { return self._s[3222]! } + public var LocalGroup_Text: String { return self._s[3220]! } + public var PeerInfo_PaneMembers: String { return self._s[3221]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3222]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3223]! } + public var ChatList_UnarchiveAction: String { return self._s[3224]! } + public var AutoNightTheme_Title: String { return self._s[3225]! } + public var InstantPage_FeedbackButton: String { return self._s[3226]! } + public var Passport_FieldAddress: String { return self._s[3227]! } public func Channel_AdminLog_SetSlowmode(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3223]!, self._r[3223]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3228]!, self._r[3228]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3224]! } + public var Month_ShortMarch: String { return self._s[3229]! } public func PUSH_MESSAGE_INVOICE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3225]!, self._r[3225]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3230]!, self._r[3230]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3226]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3227]! } - public var Passport_FloodError: String { return self._s[3228]! } - public var SecretGif_Title: String { return self._s[3229]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3230]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3231]! } - public var Passport_Language_th: String { return self._s[3233]! } - public var Passport_Address_Address: String { return self._s[3234]! } - public var Login_InvalidLastNameError: String { return self._s[3235]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3236]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3237]! } - public var ChatList_Context_Archive: String { return self._s[3238]! } - public var SettingsSearch_FAQ: String { return self._s[3239]! } - public var ShareMenu_Send: String { return self._s[3240]! } - public var ChatState_Connecting: String { return self._s[3241]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3243]! } - public var Month_GenNovember: String { return self._s[3245]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3247]! } + public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3231]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3232]! } + public var Passport_FloodError: String { return self._s[3233]! } + public var SecretGif_Title: String { return self._s[3234]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3235]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3236]! } + public var Passport_Language_th: String { return self._s[3238]! } + public var Passport_Address_Address: String { return self._s[3239]! } + public var Login_InvalidLastNameError: String { return self._s[3240]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3241]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3242]! } + public var ChatList_Context_Archive: String { return self._s[3243]! } + public var SettingsSearch_FAQ: String { return self._s[3244]! } + public var ShareMenu_Send: String { return self._s[3245]! } + public var ChatState_Connecting: String { return self._s[3246]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3248]! } + public var Month_GenNovember: String { return self._s[3250]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3252]! } public func Conversation_ShareMyPhoneNumberConfirmation(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3248]!, self._r[3248]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3253]!, self._r[3253]!, [_1, _2]) } - public var ChatListFolder_CategoryChannels: String { return self._s[3249]! } - public var Conversation_SwipeToReplyHintText: String { return self._s[3250]! } - public var Checkout_Email: String { return self._s[3251]! } - public var NotificationsSound_Tritone: String { return self._s[3252]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3254]! } - public var Wallet_ContextMenuCopy: String { return self._s[3256]! } + public var ChatListFolder_CategoryChannels: String { return self._s[3254]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3255]! } + public var Checkout_Email: String { return self._s[3256]! } + public var NotificationsSound_Tritone: String { return self._s[3257]! } + public var Paint_Marker: String { return self._s[3258]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3260]! } + public var Wallet_ContextMenuCopy: String { return self._s[3262]! } public func Wallet_Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3258]!, self._r[3258]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3264]!, self._r[3264]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3259]! } - public var Stickers_Installed: String { return self._s[3261]! } + public var Appearance_TextSize_Automatic: String { return self._s[3265]! } + public var Stickers_Installed: String { return self._s[3267]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3262]!, self._r[3262]!, [_1]) + return formatWithArgumentRanges(self._s[3268]!, self._r[3268]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3263]!, self._r[3263]!, [_0]) + return formatWithArgumentRanges(self._s[3269]!, self._r[3269]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3264]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3270]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3265]!, self._r[3265]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3271]!, self._r[3271]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3266]! } - public var Notification_Exceptions_Add: String { return self._s[3267]! } - public var DialogList_You: String { return self._s[3268]! } - public var ChatList_PsaLabel_covid: String { return self._s[3270]! } - public var MediaPicker_Send: String { return self._s[3272]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3273]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3274]! } - public var Call_AudioRouteSpeaker: String { return self._s[3275]! } - public var Watch_UserInfo_Title: String { return self._s[3276]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3277]! } - public var Appearance_AccentColor: String { return self._s[3279]! } + public var ChatList_UndoArchiveTitle: String { return self._s[3272]! } + public var Notification_Exceptions_Add: String { return self._s[3273]! } + public var DialogList_You: String { return self._s[3274]! } + public var ChatList_PsaLabel_covid: String { return self._s[3276]! } + public var MediaPicker_Send: String { return self._s[3278]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3279]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3280]! } + public var Call_AudioRouteSpeaker: String { return self._s[3281]! } + public var Watch_UserInfo_Title: String { return self._s[3282]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3283]! } + public var Appearance_AccentColor: String { return self._s[3285]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3280]!, self._r[3280]!, [_0]) + return formatWithArgumentRanges(self._s[3286]!, self._r[3286]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3281]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3287]! } public func PUSH_CHANNEL_MESSAGE_GAME(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3282]!, self._r[3282]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3288]!, self._r[3288]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3283]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3284]! } - public var Notification_CallOutgoing: String { return self._s[3285]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3286]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3287]! } - public var Call_RecordingDisabledMessage: String { return self._s[3288]! } - public var Message_Game: String { return self._s[3289]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3290]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3291]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3292]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3293]! } - public var Date_DialogDateFormat: String { return self._s[3295]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3296]! } - public var Notifications_InAppNotifications: String { return self._s[3297]! } + public var Conversation_ClousStorageInfo_Description2: String { return self._s[3289]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3290]! } + public var Notification_CallOutgoing: String { return self._s[3291]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3292]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3293]! } + public var Call_RecordingDisabledMessage: String { return self._s[3294]! } + public var Message_Game: String { return self._s[3295]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3296]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3297]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3298]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3299]! } + public var Date_DialogDateFormat: String { return self._s[3301]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3302]! } + public var Notifications_InAppNotifications: String { return self._s[3303]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3298]!, self._r[3298]!, [_0]) + return formatWithArgumentRanges(self._s[3304]!, self._r[3304]!, [_0]) } public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3299]!, self._r[3299]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3305]!, self._r[3305]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3300]! } + public var NewContact_Title: String { return self._s[3306]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3301]!, self._r[3301]!, [_0]) + return formatWithArgumentRanges(self._s[3307]!, self._r[3307]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3302]! } + public var Conversation_ViewContactDetails: String { return self._s[3308]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3304]!, self._r[3304]!, [_1]) + return formatWithArgumentRanges(self._s[3310]!, self._r[3310]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3305]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3306]! } - public var PrivacySettings_Title: String { return self._s[3307]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3310]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3311]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3312]! } - public var Contacts_PhoneNumber: String { return self._s[3313]! } - public var PeerInfo_ButtonMute: String { return self._s[3314]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3316]! } - public var Map_ShowPlaces: String { return self._s[3317]! } - public var ChatAdmins_Title: String { return self._s[3318]! } - public var InstantPage_Reference: String { return self._s[3320]! } - public var Wallet_Info_Updating: String { return self._s[3321]! } - public var ReportGroupLocation_Text: String { return self._s[3322]! } + public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3311]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3312]! } + public var PrivacySettings_Title: String { return self._s[3313]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3316]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3317]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3318]! } + public var Contacts_PhoneNumber: String { return self._s[3319]! } + public var PeerInfo_ButtonMute: String { return self._s[3320]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3322]! } + public var Map_ShowPlaces: String { return self._s[3323]! } + public var ChatAdmins_Title: String { return self._s[3324]! } + public var InstantPage_Reference: String { return self._s[3326]! } + public var Wallet_Info_Updating: String { return self._s[3327]! } + public var ReportGroupLocation_Text: String { return self._s[3328]! } public func PUSH_CHAT_MESSAGE_FWD(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3323]!, self._r[3323]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3329]!, self._r[3329]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3324]! } - public var Watch_UserInfo_Block: String { return self._s[3325]! } - public var ChatSettings_Stickers: String { return self._s[3326]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3327]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3328]! } + public var Camera_FlashOff: String { return self._s[3330]! } + public var Watch_UserInfo_Block: String { return self._s[3331]! } + public var ChatSettings_Stickers: String { return self._s[3332]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3333]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3334]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3329]!, self._r[3329]!, [_0]) + return formatWithArgumentRanges(self._s[3335]!, self._r[3335]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3330]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3331]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3332]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3333]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3334]! } - public var VoiceOver_MessageContextShare: String { return self._s[3335]! } + public var Settings_ViewPhoto: String { return self._s[3336]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3337]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3338]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3339]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3340]! } + public var VoiceOver_MessageContextShare: String { return self._s[3341]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_0]) + return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) } - public var Privacy_DeleteDrafts: String { return self._s[3338]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3339]! } + public var Privacy_DeleteDrafts: String { return self._s[3344]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3345]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3340]!, self._r[3340]!, [_0]) + return formatWithArgumentRanges(self._s[3346]!, self._r[3346]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3341]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3342]! } - public var DialogList_SavedMessages: String { return self._s[3343]! } - public var GroupInfo_UpgradeButton: String { return self._s[3344]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3346]! } - public var DialogList_Pin: String { return self._s[3347]! } + public var DialogList_SavedMessagesHelp: String { return self._s[3347]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3348]! } + public var DialogList_SavedMessages: String { return self._s[3349]! } + public var GroupInfo_UpgradeButton: String { return self._s[3350]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3352]! } + public var DialogList_Pin: String { return self._s[3353]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3348]!, self._r[3348]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3354]!, self._r[3354]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3349]!, self._r[3349]!, [_0]) + return formatWithArgumentRanges(self._s[3355]!, self._r[3355]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3350]! } - public var UserInfo_NotificationsDisable: String { return self._s[3351]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[3352]! } - public var Paint_Outlined: String { return self._s[3353]! } - public var Activity_PlayingGame: String { return self._s[3354]! } - public var SearchImages_NoImagesFound: String { return self._s[3355]! } - public var SocksProxySetup_ProxyType: String { return self._s[3356]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3358]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3359]! } - public var Settings_AppLanguage: String { return self._s[3360]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3361]! } - public var Common_ChoosePhoto: String { return self._s[3362]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3363]! } - public var CallFeedback_ReasonEcho: String { return self._s[3364]! } + public var Notification_Exceptions_AlwaysOn: String { return self._s[3356]! } + public var UserInfo_NotificationsDisable: String { return self._s[3357]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[3358]! } + public var Paint_Outlined: String { return self._s[3359]! } + public var Activity_PlayingGame: String { return self._s[3360]! } + public var SearchImages_NoImagesFound: String { return self._s[3361]! } + public var SocksProxySetup_ProxyType: String { return self._s[3362]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3364]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3365]! } + public var Settings_AppLanguage: String { return self._s[3366]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3367]! } + public var Common_ChoosePhoto: String { return self._s[3368]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3369]! } + public var CallFeedback_ReasonEcho: String { return self._s[3370]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3365]!, self._r[3365]!, [_1]) + return formatWithArgumentRanges(self._s[3371]!, self._r[3371]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3366]! } - public var PollResults_Collapse: String { return self._s[3367]! } - public var Activity_UploadingVideo: String { return self._s[3368]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3369]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3370]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3371]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3372]! } - public var PUSH_SENDER_YOU: String { return self._s[3373]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3374]! } - public var Checkout_PayWithTouchId: String { return self._s[3375]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3376]! } + public var Privacy_Calls_AlwaysAllow: String { return self._s[3372]! } + public var PollResults_Collapse: String { return self._s[3373]! } + public var Activity_UploadingVideo: String { return self._s[3374]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3375]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3376]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3377]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3378]! } + public var PUSH_SENDER_YOU: String { return self._s[3379]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3380]! } + public var Checkout_PayWithTouchId: String { return self._s[3381]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3382]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3378]!, self._r[3378]!, [_1]) + return formatWithArgumentRanges(self._s[3384]!, self._r[3384]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3379]! } + public var Notifications_ExceptionsNone: String { return self._s[3385]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3380]!, self._r[3380]!, [_0]) + return formatWithArgumentRanges(self._s[3386]!, self._r[3386]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3381]!, self._r[3381]!, [_1]) + return formatWithArgumentRanges(self._s[3387]!, self._r[3387]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3383]! } - public var Passport_Address_Region: String { return self._s[3386]! } - public var ChatList_DeleteChat: String { return self._s[3387]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3388]! } - public var PhotoEditor_TiltShift: String { return self._s[3389]! } - public var Settings_FAQ_URL: String { return self._s[3390]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3391]! } - public var Passport_Language_sl: String { return self._s[3393]! } - public var Settings_PrivacySettings: String { return self._s[3395]! } - public var SharedMedia_TitleLink: String { return self._s[3396]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3397]! } - public var Settings_SetProfilePhoto: String { return self._s[3398]! } - public var Channel_About_Help: String { return self._s[3399]! } - public var Contacts_PermissionsEnable: String { return self._s[3400]! } - public var Wallet_Sending_Title: String { return self._s[3401]! } - public var PeerInfo_PaneMedia: String { return self._s[3402]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3403]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3404]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3406]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3407]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3408]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3409]! } - public var OldChannels_Title: String { return self._s[3410]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3411]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3413]! } - public var Map_OpenInYandexMaps: String { return self._s[3415]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3416]! } - public var VoiceOver_MessageContextReply: String { return self._s[3417]! } - public var ChatListFolder_DiscardConfirmation: String { return self._s[3419]! } - public var PhotoEditor_SaturationTool: String { return self._s[3420]! } + public var AuthSessions_IncompleteAttempts: String { return self._s[3389]! } + public var Passport_Address_Region: String { return self._s[3392]! } + public var ChatList_DeleteChat: String { return self._s[3393]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3394]! } + public var PhotoEditor_TiltShift: String { return self._s[3395]! } + public var Settings_FAQ_URL: String { return self._s[3396]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3397]! } + public var Passport_Language_sl: String { return self._s[3399]! } + public var Settings_PrivacySettings: String { return self._s[3401]! } + public var SharedMedia_TitleLink: String { return self._s[3402]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3403]! } + public var Settings_SetProfilePhoto: String { return self._s[3404]! } + public var Channel_About_Help: String { return self._s[3405]! } + public var Contacts_PermissionsEnable: String { return self._s[3406]! } + public var Wallet_Sending_Title: String { return self._s[3407]! } + public var PeerInfo_PaneMedia: String { return self._s[3408]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3409]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3410]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3412]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3413]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3414]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3415]! } + public var OldChannels_Title: String { return self._s[3416]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3417]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3419]! } + public var Map_OpenInYandexMaps: String { return self._s[3421]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3422]! } + public var VoiceOver_MessageContextReply: String { return self._s[3423]! } + public var ChatListFolder_DiscardConfirmation: String { return self._s[3425]! } + public var PhotoEditor_SaturationTool: String { return self._s[3426]! } public func PUSH_MESSAGE_STICKER(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3421]!, self._r[3421]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3427]!, self._r[3427]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3422]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3423]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3424]! } + public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3428]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3429]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3430]! } public func LOCAL_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3425]!, self._r[3425]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3431]!, self._r[3431]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3426]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3428]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3429]! } + public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3432]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3434]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3435]! } public func Group_OwnershipTransfer_DescriptionInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3430]!, self._r[3430]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3431]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3437]! } public func PUSH_CHAT_MESSAGE_GAME(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3432]!, self._r[3432]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3438]!, self._r[3438]!, [_1, _2, _3]) } - public var WallpaperPreview_PatternTitle: String { return self._s[3433]! } - public var GroupInfo_PublicLinkAdd: String { return self._s[3434]! } - public var Passport_PassportInformation: String { return self._s[3437]! } - public var Theme_Unsupported: String { return self._s[3438]! } - public var WatchRemote_AlertTitle: String { return self._s[3439]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3440]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3442]! } + public var WallpaperPreview_PatternTitle: String { return self._s[3439]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3440]! } + public var Passport_PassportInformation: String { return self._s[3443]! } + public var Theme_Unsupported: String { return self._s[3444]! } + public var WatchRemote_AlertTitle: String { return self._s[3445]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3446]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3448]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3443]!, self._r[3443]!, [_0]) + return formatWithArgumentRanges(self._s[3449]!, self._r[3449]!, [_0]) } public func PUSH_PHONE_CALL_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3444]!, self._r[3444]!, [_1]) + return formatWithArgumentRanges(self._s[3450]!, self._r[3450]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3445]! } - public var Wallet_Navigation_Done: String { return self._s[3447]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3448]! } - public var AccessDenied_CameraDisabled: String { return self._s[3449]! } + public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3451]! } + public var Wallet_Navigation_Done: String { return self._s[3453]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3454]! } + public var AccessDenied_CameraDisabled: String { return self._s[3455]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3450]!, self._r[3450]!, [_0]) + return formatWithArgumentRanges(self._s[3456]!, self._r[3456]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3451]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3452]! } - public var CreatePoll_Quiz: String { return self._s[3453]! } - public var PhotoEditor_ContrastTool: String { return self._s[3456]! } + public var ClearCache_Forever: String { return self._s[3457]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3458]! } + public var CreatePoll_Quiz: String { return self._s[3459]! } + public var PhotoEditor_ContrastTool: String { return self._s[3462]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3457]!, self._r[3457]!, [_1]) + return formatWithArgumentRanges(self._s[3463]!, self._r[3463]!, [_1]) } - public var DialogList_Draft: String { return self._s[3458]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3459]! } + public var DialogList_Draft: String { return self._s[3464]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3465]! } public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3460]!, self._r[3460]!, [_0]) + return formatWithArgumentRanges(self._s[3466]!, self._r[3466]!, [_0]) } - public var ChatList_PsaAlert_covid: String { return self._s[3461]! } - public var Privacy_TopPeersDelete: String { return self._s[3463]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3464]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3465]! } - public var WebSearch_RecentSectionClear: String { return self._s[3466]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3467]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3469]! } - public var PeerInfo_ButtonMore: String { return self._s[3471]! } - public var Common_Done: String { return self._s[3472]! } - public var Shortcut_SwitchAccount: String { return self._s[3473]! } - public var AuthSessions_EmptyText: String { return self._s[3474]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3475]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3476]! } - public var Tour_Title5: String { return self._s[3477]! } - public var Wallet_Settings_Title: String { return self._s[3478]! } + public var ChatList_PsaAlert_covid: String { return self._s[3467]! } + public var Privacy_TopPeersDelete: String { return self._s[3469]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3470]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3471]! } + public var WebSearch_RecentSectionClear: String { return self._s[3472]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3473]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3475]! } + public var PeerInfo_ButtonMore: String { return self._s[3477]! } + public var Common_Done: String { return self._s[3478]! } + public var Shortcut_SwitchAccount: String { return self._s[3479]! } + public var AuthSessions_EmptyText: String { return self._s[3480]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3481]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3482]! } + public var Tour_Title5: String { return self._s[3484]! } + public var Wallet_Settings_Title: String { return self._s[3485]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_0]) + return formatWithArgumentRanges(self._s[3486]!, self._r[3486]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3480]! } - public var Conversation_LinkDialogSave: String { return self._s[3481]! } - public var GroupInfo_ActionRestrict: String { return self._s[3482]! } - public var Checkout_Title: String { return self._s[3483]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3485]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3487]! } - public var Notification_RenamedGroup: String { return self._s[3488]! } - public var PeopleNearby_Groups: String { return self._s[3489]! } - public var Checkout_PayWithFaceId: String { return self._s[3490]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3491]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3493]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3494]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3495]! } + public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3487]! } + public var Conversation_LinkDialogSave: String { return self._s[3488]! } + public var GroupInfo_ActionRestrict: String { return self._s[3489]! } + public var Checkout_Title: String { return self._s[3490]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3492]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3494]! } + public var Notification_RenamedGroup: String { return self._s[3495]! } + public var PeopleNearby_Groups: String { return self._s[3496]! } + public var Checkout_PayWithFaceId: String { return self._s[3497]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3498]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3500]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3501]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3502]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3496]!, self._r[3496]!, [_0]) + return formatWithArgumentRanges(self._s[3503]!, self._r[3503]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3498]! } + public var Profile_AddToExisting: String { return self._s[3505]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3499]!, self._r[3499]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3506]!, self._r[3506]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3501]! } - public var Permissions_PrivacyPolicy: String { return self._s[3502]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3503]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3504]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3506]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3508]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3509]! } + public var Cache_Files: String { return self._s[3508]! } + public var Permissions_PrivacyPolicy: String { return self._s[3509]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3510]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3511]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3513]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3515]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3516]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3510]!, self._r[3510]!, [_0]) + return formatWithArgumentRanges(self._s[3517]!, self._r[3517]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3511]! } - public var VoiceOver_AttachMedia: String { return self._s[3514]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3515]! } + public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3518]! } + public var VoiceOver_AttachMedia: String { return self._s[3521]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3522]! } public func PUSH_CHAT_MESSAGE_INVOICE(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3516]!, self._r[3516]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3523]!, self._r[3523]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3517]! } - public var Conversation_SetReminder_Title: String { return self._s[3518]! } - public var Passport_FieldAddressHelp: String { return self._s[3519]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3520]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3521]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3524]! } + public var Conversation_SetReminder_Title: String { return self._s[3525]! } + public var Passport_FieldAddressHelp: String { return self._s[3526]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3527]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3528]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3522]!, self._r[3522]!, [_0]) + return formatWithArgumentRanges(self._s[3529]!, self._r[3529]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3523]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3524]! } - public var Login_UnknownError: String { return self._s[3525]! } - public var Group_UpgradeNoticeText2: String { return self._s[3528]! } - public var Watch_Compose_AddContact: String { return self._s[3529]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3530]! } - public var Web_Error: String { return self._s[3531]! } - public var Gif_Search: String { return self._s[3532]! } - public var Profile_MessageLifetime1h: String { return self._s[3533]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3534]! } - public var Channel_Username_CheckingUsername: String { return self._s[3535]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3536]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3537]! } - public var Channel_AboutItem: String { return self._s[3538]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3540]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3541]! } - public var GroupInfo_SharedMedia: String { return self._s[3542]! } + public var Channel_AdminLog_EmptyTitle: String { return self._s[3530]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3531]! } + public var Login_UnknownError: String { return self._s[3532]! } + public var Group_UpgradeNoticeText2: String { return self._s[3535]! } + public var Watch_Compose_AddContact: String { return self._s[3536]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3537]! } + public var Web_Error: String { return self._s[3538]! } + public var Paint_Neon: String { return self._s[3539]! } + public var Gif_Search: String { return self._s[3540]! } + public var Profile_MessageLifetime1h: String { return self._s[3541]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3542]! } + public var Channel_Username_CheckingUsername: String { return self._s[3543]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3544]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3545]! } + public var Channel_AboutItem: String { return self._s[3546]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3549]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3550]! } + public var GroupInfo_SharedMedia: String { return self._s[3551]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3543]!, self._r[3543]!, [_1]) + return formatWithArgumentRanges(self._s[3552]!, self._r[3552]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3544]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3553]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3545]!, self._r[3545]!, [_1]) + return formatWithArgumentRanges(self._s[3554]!, self._r[3554]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3546]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3547]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3548]! } - public var CreatePoll_AddOption: String { return self._s[3549]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3550]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3551]! } - public var Channel_Management_AddModerator: String { return self._s[3552]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3553]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3554]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3555]! } - public var Theme_Colors_Background: String { return self._s[3556]! } - public var NotificationsSound_Hello: String { return self._s[3559]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3561]! } - public var Channel_Stickers_Placeholder: String { return self._s[3563]! } + public var ChatList_UndoArchiveRevealedText: String { return self._s[3555]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3556]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3557]! } + public var CreatePoll_AddOption: String { return self._s[3558]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3559]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3560]! } + public var Channel_Management_AddModerator: String { return self._s[3561]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3562]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3563]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3564]! } + public var Theme_Colors_Background: String { return self._s[3565]! } + public var NotificationsSound_Hello: String { return self._s[3568]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3570]! } + public var Channel_Stickers_Placeholder: String { return self._s[3572]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3564]!, self._r[3564]!, [_0]) + return formatWithArgumentRanges(self._s[3573]!, self._r[3573]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3565]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3566]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3567]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3568]! } - public var AutoDownloadSettings_Channels: String { return self._s[3569]! } - public var Passport_Language_mn: String { return self._s[3570]! } - public var Settings_ChatFolders: String { return self._s[3571]! } + public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3574]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3575]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3576]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3577]! } + public var AutoDownloadSettings_Channels: String { return self._s[3578]! } + public var Passport_Language_mn: String { return self._s[3579]! } + public var Settings_ChatFolders: String { return self._s[3580]! } public func ChatList_AddedToFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3572]!, self._r[3572]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3581]!, self._r[3581]!, [_1, _2]) } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3575]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3576]! } - public var Passport_Language_ja: String { return self._s[3578]! } - public var Settings_About_Title: String { return self._s[3579]! } - public var Settings_NotificationsAndSounds: String { return self._s[3580]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3581]! } - public var Settings_BlockedUsers: String { return self._s[3582]! } + public var Notifications_ResetAllNotificationsHelp: String { return self._s[3584]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3585]! } + public var Passport_Language_ja: String { return self._s[3587]! } + public var Settings_About_Title: String { return self._s[3588]! } + public var Settings_NotificationsAndSounds: String { return self._s[3589]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3590]! } + public var Settings_BlockedUsers: String { return self._s[3591]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3583]!, self._r[3583]!, [_0]) + return formatWithArgumentRanges(self._s[3592]!, self._r[3592]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3584]! } - public var Wallet_Weekday_Today: String { return self._s[3585]! } - public var ChatListFolderSettings_AddRecommended: String { return self._s[3586]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3587]! } - public var Widget_ApplicationLocked: String { return self._s[3588]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3589]! } - public var Channel_Username_Title: String { return self._s[3590]! } + public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3593]! } + public var Wallet_Weekday_Today: String { return self._s[3594]! } + public var ChatListFolderSettings_AddRecommended: String { return self._s[3595]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3596]! } + public var Widget_ApplicationLocked: String { return self._s[3597]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3598]! } + public var Channel_Username_Title: String { return self._s[3599]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3591]!, self._r[3591]!, [_0]) + return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3593]! } - public var AppleWatch_Title: String { return self._s[3594]! } - public var Activity_RecordingVideoMessage: String { return self._s[3595]! } + public var AttachmentMenu_File: String { return self._s[3602]! } + public var AppleWatch_Title: String { return self._s[3603]! } + public var Activity_RecordingVideoMessage: String { return self._s[3604]! } public func Channel_DiscussionGroup_PublicChannelLink(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3596]!, self._r[3596]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3605]!, self._r[3605]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3597]! } - public var Weekday_Saturday: String { return self._s[3598]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3599]! } - public var Conversation_Timer_Send: String { return self._s[3600]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3601]! } - public var Common_Next: String { return self._s[3603]! } - public var Channel_Stickers_YourStickers: String { return self._s[3605]! } - public var Message_Theme: String { return self._s[3606]! } - public var Call_AudioRouteHeadphones: String { return self._s[3607]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3609]! } - public var Watch_Contacts_NoResults: String { return self._s[3611]! } - public var PhotoEditor_TintTool: String { return self._s[3614]! } - public var LoginPassword_ResetAccount: String { return self._s[3616]! } - public var Settings_SavedMessages: String { return self._s[3617]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3618]! } - public var Bot_GenericSupportStatus: String { return self._s[3619]! } - public var StickerPack_Add: String { return self._s[3620]! } - public var Checkout_TotalAmount: String { return self._s[3621]! } - public var Your_cards_number_is_invalid: String { return self._s[3622]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3623]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3624]! } + public var Theme_Colors_Messages: String { return self._s[3606]! } + public var Weekday_Saturday: String { return self._s[3607]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3608]! } + public var Conversation_Timer_Send: String { return self._s[3609]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3610]! } + public var Common_Next: String { return self._s[3612]! } + public var Channel_Stickers_YourStickers: String { return self._s[3614]! } + public var Message_Theme: String { return self._s[3615]! } + public var Call_AudioRouteHeadphones: String { return self._s[3616]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3618]! } + public var Watch_Contacts_NoResults: String { return self._s[3620]! } + public var PhotoEditor_TintTool: String { return self._s[3623]! } + public var LoginPassword_ResetAccount: String { return self._s[3625]! } + public var Settings_SavedMessages: String { return self._s[3626]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3627]! } + public var Bot_GenericSupportStatus: String { return self._s[3628]! } + public var StickerPack_Add: String { return self._s[3629]! } + public var Checkout_TotalAmount: String { return self._s[3630]! } + public var Your_cards_number_is_invalid: String { return self._s[3631]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3632]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3633]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3625]!, self._r[3625]!, [_0]) + return formatWithArgumentRanges(self._s[3634]!, self._r[3634]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3626]!, self._r[3626]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3635]!, self._r[3635]!, [_1, _2]) } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3627]! } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3636]! } public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3638]!, self._r[3638]!, [_1, _2]) } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3630]!, self._r[3630]!, [_0]) + return formatWithArgumentRanges(self._s[3639]!, self._r[3639]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3631]! } - public var StickerPack_Share: String { return self._s[3632]! } - public var Passport_DeleteAddress: String { return self._s[3633]! } - public var Settings_Passport: String { return self._s[3634]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3635]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3636]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3637]! } - public var Contacts_PermissionsText: String { return self._s[3638]! } - public var Group_Setup_HistoryVisible: String { return self._s[3639]! } - public var Wallet_Month_ShortDecember: String { return self._s[3641]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3642]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3643]! } - public var SocksProxySetup_Title: String { return self._s[3644]! } - public var Notification_Mute1h: String { return self._s[3645]! } + public var GroupInfo_InviteLink_ShareLink: String { return self._s[3640]! } + public var StickerPack_Share: String { return self._s[3641]! } + public var Passport_DeleteAddress: String { return self._s[3642]! } + public var Settings_Passport: String { return self._s[3643]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3644]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3645]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3646]! } + public var Contacts_PermissionsText: String { return self._s[3647]! } + public var Group_Setup_HistoryVisible: String { return self._s[3648]! } + public var Wallet_Month_ShortDecember: String { return self._s[3650]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3651]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3652]! } + public var SocksProxySetup_Title: String { return self._s[3653]! } + public var Notification_Mute1h: String { return self._s[3654]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3646]!, self._r[3646]!, [_0]) + return formatWithArgumentRanges(self._s[3655]!, self._r[3655]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3647]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3656]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3648]!, self._r[3648]!, [_1]) + return formatWithArgumentRanges(self._s[3657]!, self._r[3657]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3649]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3652]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3654]! } - public var DialogList_NoMessagesText: String { return self._s[3655]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3656]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3657]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3659]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3660]! } - public var Common_TakePhotoOrVideo: String { return self._s[3661]! } - public var Wallet_Words_Text: String { return self._s[3662]! } - public var Call_StatusBusy: String { return self._s[3663]! } - public var Conversation_PinnedMessage: String { return self._s[3664]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3665]! } - public var ChatList_EmptyChatListNewMessage: String { return self._s[3666]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3667]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3668]! } - public var Undo_ChatCleared: String { return self._s[3669]! } - public var CreatePoll_Explanation: String { return self._s[3670]! } - public var AppleWatch_ReplyPresets: String { return self._s[3671]! } - public var Passport_DiscardMessageDescription: String { return self._s[3673]! } - public var Login_NetworkError: String { return self._s[3674]! } + public var FastTwoStepSetup_PasswordSection: String { return self._s[3658]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3661]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3663]! } + public var DialogList_NoMessagesText: String { return self._s[3664]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3665]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3666]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3668]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3669]! } + public var Common_TakePhotoOrVideo: String { return self._s[3670]! } + public var Wallet_Words_Text: String { return self._s[3671]! } + public var Call_StatusBusy: String { return self._s[3672]! } + public var Conversation_PinnedMessage: String { return self._s[3673]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3674]! } + public var ChatList_EmptyChatListNewMessage: String { return self._s[3675]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3676]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3677]! } + public var Undo_ChatCleared: String { return self._s[3678]! } + public var CreatePoll_Explanation: String { return self._s[3679]! } + public var AppleWatch_ReplyPresets: String { return self._s[3680]! } + public var Passport_DiscardMessageDescription: String { return self._s[3682]! } + public var Login_NetworkError: String { return self._s[3683]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3675]!, self._r[3675]!, [_0]) + return formatWithArgumentRanges(self._s[3684]!, self._r[3684]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3676]!, self._r[3676]!, [_0]) + return formatWithArgumentRanges(self._s[3685]!, self._r[3685]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3677]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3679]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3680]! } + public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3686]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3688]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3689]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3682]!, self._r[3682]!, [_0]) + return formatWithArgumentRanges(self._s[3691]!, self._r[3691]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3683]! } - public var VoiceOver_Chat_Music: String { return self._s[3684]! } - public var ChatListFolder_CategoryContacts: String { return self._s[3685]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3686]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3688]! } - public var ConversationMedia_Title: String { return self._s[3689]! } - public var EncryptionKey_Title: String { return self._s[3691]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3692]! } - public var Notification_Exceptions_AddException: String { return self._s[3693]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3694]! } - public var Profile_MessageLifetime1m: String { return self._s[3695]! } + public var Call_ConnectionErrorMessage: String { return self._s[3692]! } + public var VoiceOver_Chat_Music: String { return self._s[3693]! } + public var ChatListFolder_CategoryContacts: String { return self._s[3694]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3695]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3697]! } + public var ConversationMedia_Title: String { return self._s[3698]! } + public var EncryptionKey_Title: String { return self._s[3700]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3701]! } + public var Notification_Exceptions_AddException: String { return self._s[3702]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3703]! } + public var Profile_MessageLifetime1m: String { return self._s[3704]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3696]!, self._r[3696]!, [_1]) + return formatWithArgumentRanges(self._s[3705]!, self._r[3705]!, [_1]) } - public var Month_GenMay: String { return self._s[3697]! } + public var Month_GenMay: String { return self._s[3706]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3698]!, self._r[3698]!, [_0]) + return formatWithArgumentRanges(self._s[3707]!, self._r[3707]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3699]! } - public var Wallet_Send_AddressInfo: String { return self._s[3700]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3701]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3702]! } + public var PeopleNearby_Users: String { return self._s[3708]! } + public var Wallet_Send_AddressInfo: String { return self._s[3709]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3710]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3711]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3704]!, self._r[3704]!, [_0]) + return formatWithArgumentRanges(self._s[3713]!, self._r[3713]!, [_0]) } - public var Stats_LoadingTitle: String { return self._s[3705]! } - public var Conversation_EmptyPlaceholder: String { return self._s[3706]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3707]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3708]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3709]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3710]! } - public var Channel_JoinChannel: String { return self._s[3712]! } - public var Appearance_Animations: String { return self._s[3715]! } + public var Stats_LoadingTitle: String { return self._s[3714]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3715]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3716]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3717]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3718]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3719]! } + public var Channel_JoinChannel: String { return self._s[3721]! } + public var Appearance_Animations: String { return self._s[3724]! } public func Notification_MessageLifetimeChanged(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3716]!, self._r[3716]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3725]!, self._r[3725]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3718]! } - public var Appearance_ShareTheme: String { return self._s[3719]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3720]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3722]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3723]! } - public var Passport_Address_Street: String { return self._s[3724]! } - public var Conversation_AddContact: String { return self._s[3725]! } - public var Login_PhonePlaceholder: String { return self._s[3726]! } - public var Channel_Members_InviteLink: String { return self._s[3728]! } - public var Bot_Stop: String { return self._s[3729]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3731]! } - public var Notification_PassportValueAddress: String { return self._s[3732]! } - public var Month_ShortJuly: String { return self._s[3733]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3734]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3735]! } - public var Passport_Identity_ReverseSide: String { return self._s[3736]! } - public var Watch_Stickers_Recents: String { return self._s[3739]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3741]! } - public var Map_SendThisLocation: String { return self._s[3742]! } + public var Stickers_GroupStickers: String { return self._s[3727]! } + public var Appearance_ShareTheme: String { return self._s[3728]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3729]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3731]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3732]! } + public var Passport_Address_Street: String { return self._s[3733]! } + public var Conversation_AddContact: String { return self._s[3734]! } + public var Login_PhonePlaceholder: String { return self._s[3735]! } + public var Channel_Members_InviteLink: String { return self._s[3737]! } + public var Bot_Stop: String { return self._s[3738]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3740]! } + public var Notification_PassportValueAddress: String { return self._s[3741]! } + public var Month_ShortJuly: String { return self._s[3742]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3743]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3744]! } + public var Passport_Identity_ReverseSide: String { return self._s[3745]! } + public var Watch_Stickers_Recents: String { return self._s[3748]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3750]! } + public var Map_SendThisLocation: String { return self._s[3751]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3743]!, self._r[3743]!, [_0]) + return formatWithArgumentRanges(self._s[3752]!, self._r[3752]!, [_0]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_0]) + return formatWithArgumentRanges(self._s[3753]!, self._r[3753]!, [_0]) } - public var ConvertToSupergroup_Note: String { return self._s[3745]! } - public var Wallet_Intro_NotNow: String { return self._s[3746]! } + public var ConvertToSupergroup_Note: String { return self._s[3754]! } + public var Wallet_Intro_NotNow: String { return self._s[3755]! } public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3747]!, self._r[3747]!, [_0]) + return formatWithArgumentRanges(self._s[3756]!, self._r[3756]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3748]! } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3757]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3749]!, self._r[3749]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3758]!, self._r[3758]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3751]! } - public var Wallpaper_SearchShort: String { return self._s[3752]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3754]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3755]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3756]! } + public var Login_CallRequestState3: String { return self._s[3760]! } + public var Wallpaper_SearchShort: String { return self._s[3761]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3763]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3764]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3765]! } public func PUSH_CHAT_MESSAGE_GEOLIVE(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3757]!, self._r[3757]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3766]!, self._r[3766]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3758]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3760]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3763]! } + public var Channel_AdminLogFilter_Title: String { return self._s[3767]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3769]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3772]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3764]!, self._r[3764]!, [_0]) + return formatWithArgumentRanges(self._s[3773]!, self._r[3773]!, [_0]) } - public var Passport_CorrectErrors: String { return self._s[3765]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3766]! } + public var Passport_CorrectErrors: String { return self._s[3774]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3775]! } public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3767]!, self._r[3767]!, [_0]) + return formatWithArgumentRanges(self._s[3776]!, self._r[3776]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3768]! } - public var Channel_DiscussionGroup: String { return self._s[3769]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3770]! } + public var Map_SendMyCurrentLocation: String { return self._s[3777]! } + public var Channel_DiscussionGroup: String { return self._s[3778]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3779]! } public func PUSH_PINNED_CONTACT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3771]!, self._r[3771]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3780]!, self._r[3780]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3772]! } - public var Permissions_NotificationsText_v0: String { return self._s[3773]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3774]! } - public var Appearance_AppIcon: String { return self._s[3775]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3776]! } - public var LoginPassword_FloodError: String { return self._s[3777]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3779]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3780]! } + public var SharedMedia_SearchNoResults: String { return self._s[3781]! } + public var Permissions_NotificationsText_v0: String { return self._s[3782]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3783]! } + public var Appearance_AppIcon: String { return self._s[3784]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3785]! } + public var LoginPassword_FloodError: String { return self._s[3786]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3788]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3789]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3781]!, self._r[3781]!, [_0]) + return formatWithArgumentRanges(self._s[3790]!, self._r[3790]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3782]! } + public var Passport_Language_bn: String { return self._s[3791]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3783]!, self._r[3783]!, [_0]) + return formatWithArgumentRanges(self._s[3792]!, self._r[3792]!, [_0]) } - public var ChatList_Context_Pin: String { return self._s[3784]! } + public var ChatList_Context_Pin: String { return self._s[3793]! } public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3785]!, self._r[3785]!, [_0]) + return formatWithArgumentRanges(self._s[3794]!, self._r[3794]!, [_0]) } public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3786]!, self._r[3786]!, [_0]) + return formatWithArgumentRanges(self._s[3795]!, self._r[3795]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3787]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3791]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3793]! } - public var Wallet_Month_GenDecember: String { return self._s[3794]! } - public var Contacts_PermissionsAllow: String { return self._s[3795]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3796]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3797]! } - public var WallpaperPreview_Pattern: String { return self._s[3798]! } - public var Paint_Duplicate: String { return self._s[3799]! } - public var Passport_Address_Country: String { return self._s[3800]! } - public var Notification_RenamedChannel: String { return self._s[3802]! } - public var DialogList_UnknownPinLimitError: String { return self._s[3803]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3804]! } - public var ChatList_Context_Unmute: String { return self._s[3805]! } - public var Group_MessagePhotoUpdated: String { return self._s[3806]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3807]! } - public var Conversation_ContextMenuBan: String { return self._s[3808]! } - public var TwoStepAuth_EmailSent: String { return self._s[3809]! } - public var MessagePoll_NoVotes: String { return self._s[3810]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3811]! } - public var Passport_Language_is: String { return self._s[3813]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3815]! } - public var Tour_Text5: String { return self._s[3816]! } + public var Wallet_Navigation_Close: String { return self._s[3796]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3800]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3802]! } + public var Wallet_Month_GenDecember: String { return self._s[3803]! } + public var Contacts_PermissionsAllow: String { return self._s[3804]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3805]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3806]! } + public var WallpaperPreview_Pattern: String { return self._s[3807]! } + public var Paint_Duplicate: String { return self._s[3808]! } + public var Passport_Address_Country: String { return self._s[3809]! } + public var Notification_RenamedChannel: String { return self._s[3811]! } + public var DialogList_UnknownPinLimitError: String { return self._s[3812]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3813]! } + public var ChatList_Context_Unmute: String { return self._s[3814]! } + public var Group_MessagePhotoUpdated: String { return self._s[3815]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3816]! } + public var Conversation_ContextMenuBan: String { return self._s[3817]! } + public var TwoStepAuth_EmailSent: String { return self._s[3818]! } + public var MessagePoll_NoVotes: String { return self._s[3819]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3820]! } + public var Passport_Language_is: String { return self._s[3822]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3824]! } + public var Tour_Text5: String { return self._s[3825]! } public func Call_GroupFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3819]!, self._r[3819]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3828]!, self._r[3828]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3820]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3821]! } + public var Undo_SecretChatDeleted: String { return self._s[3829]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3830]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3822]!, self._r[3822]!, [_0]) + return formatWithArgumentRanges(self._s[3831]!, self._r[3831]!, [_0]) } - public var Forward_ErrorDisabledForChat: String { return self._s[3823]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3824]! } - public var Paint_Edit: String { return self._s[3826]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3828]! } - public var Undo_DeletedGroup: String { return self._s[3830]! } - public var LoginPassword_ForgotPassword: String { return self._s[3831]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3832]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3833]! } + public var Forward_ErrorDisabledForChat: String { return self._s[3832]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3833]! } + public var Paint_Edit: String { return self._s[3835]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3837]! } + public var Undo_DeletedGroup: String { return self._s[3839]! } + public var LoginPassword_ForgotPassword: String { return self._s[3840]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3841]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3842]! } public func Notification_Kicked(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3834]!, self._r[3834]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3843]!, self._r[3843]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3835]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3836]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3837]! } - public var Passport_Language_uz: String { return self._s[3838]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3839]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3840]! } - public var Map_StopLiveLocation: String { return self._s[3842]! } - public var VoiceOver_MessageContextSend: String { return self._s[3844]! } - public var PasscodeSettings_Help: String { return self._s[3845]! } - public var NotificationsSound_Input: String { return self._s[3846]! } - public var Share_Title: String { return self._s[3849]! } - public var LogoutOptions_Title: String { return self._s[3850]! } - public var Wallet_Send_AddressText: String { return self._s[3851]! } - public var Login_TermsOfServiceAgree: String { return self._s[3852]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3853]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3854]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3855]! } - public var EnterPasscode_EnterTitle: String { return self._s[3856]! } + public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3844]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3845]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3846]! } + public var Passport_Language_uz: String { return self._s[3847]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3848]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3849]! } + public var Map_StopLiveLocation: String { return self._s[3851]! } + public var VoiceOver_MessageContextSend: String { return self._s[3853]! } + public var PasscodeSettings_Help: String { return self._s[3854]! } + public var NotificationsSound_Input: String { return self._s[3855]! } + public var Share_Title: String { return self._s[3858]! } + public var LogoutOptions_Title: String { return self._s[3859]! } + public var Wallet_Send_AddressText: String { return self._s[3860]! } + public var Login_TermsOfServiceAgree: String { return self._s[3861]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3862]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3863]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3864]! } + public var EnterPasscode_EnterTitle: String { return self._s[3865]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3857]!, self._r[3857]!, [_0]) + return formatWithArgumentRanges(self._s[3866]!, self._r[3866]!, [_0]) } - public var Settings_CopyPhoneNumber: String { return self._s[3858]! } - public var Conversation_AddToContacts: String { return self._s[3859]! } + public var Settings_CopyPhoneNumber: String { return self._s[3867]! } + public var Conversation_AddToContacts: String { return self._s[3868]! } public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3860]!, self._r[3860]!, [_0]) + return formatWithArgumentRanges(self._s[3869]!, self._r[3869]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3861]! } + public var NotificationsSound_Keys: String { return self._s[3870]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3862]!, self._r[3862]!, [_0]) - } - public var Notification_MessageLifetime1w: String { return self._s[3863]! } - public var Message_Video: String { return self._s[3864]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3865]! } - public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3866]!, self._r[3866]!, [_1]) - } - public var Wallet_Receive_AmountInfo: String { return self._s[3869]! } - public var Stats_Overview: String { return self._s[3870]! } - public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3871]!, self._r[3871]!, [_0]) } + public var Notification_MessageLifetime1w: String { return self._s[3872]! } + public var Message_Video: String { return self._s[3873]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3874]! } + public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3875]!, self._r[3875]!, [_1]) + } + public var Wallet_Receive_AmountInfo: String { return self._s[3878]! } + public var Stats_Overview: String { return self._s[3879]! } + public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3880]!, self._r[3880]!, [_0]) + } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3872]!, self._r[3872]!, [_0]) + return formatWithArgumentRanges(self._s[3881]!, self._r[3881]!, [_0]) } - public var ChatListFolder_ExcludeChatsTitle: String { return self._s[3873]! } - public var Passport_Language_mk: String { return self._s[3874]! } - public var ChatListFolder_CategoryNonContacts: String { return self._s[3875]! } + public var ChatListFolder_ExcludeChatsTitle: String { return self._s[3882]! } + public var Passport_Language_mk: String { return self._s[3883]! } + public var ChatListFolder_CategoryNonContacts: String { return self._s[3884]! } public func Wallet_Time_PreciseDate_m2(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3876]!, self._r[3876]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3885]!, self._r[3885]!, [_1, _2, _3]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3877]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3878]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3880]! } - public var PrivacyPolicy_Decline: String { return self._s[3881]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3882]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3883]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3884]! } - public var Permissions_SiriAllow_v0: String { return self._s[3886]! } - public var Wallet_Month_ShortAugust: String { return self._s[3887]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3888]! } + public var CreatePoll_CancelConfirmation: String { return self._s[3886]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3887]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3889]! } + public var PrivacyPolicy_Decline: String { return self._s[3890]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3891]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3892]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3893]! } + public var Permissions_SiriAllow_v0: String { return self._s[3895]! } + public var Wallet_Month_ShortAugust: String { return self._s[3896]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3897]! } public func LOCAL_CHAT_MESSAGE_FWDS(_ _1: String, _ _2: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3889]!, self._r[3889]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3898]!, self._r[3898]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3890]!, self._r[3890]!, [_0]) + return formatWithArgumentRanges(self._s[3899]!, self._r[3899]!, [_0]) } - public var Paint_Regular: String { return self._s[3891]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3892]! } - public var SocksProxySetup_ShareLink: String { return self._s[3893]! } - public var Wallet_Qr_Title: String { return self._s[3894]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3895]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3897]! } - public var Wallet_Settings_Configuration: String { return self._s[3898]! } - public var GroupInfo_InviteByLink: String { return self._s[3899]! } - public var MessageTimer_Custom: String { return self._s[3900]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3901]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[3902]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3904]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3905]! } - public var VoiceOver_Chat_Selected: String { return self._s[3906]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3907]! } - public var Channel_Username_InvalidTaken: String { return self._s[3908]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3909]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3910]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3911]! } - public var Settings_ChatBackground: String { return self._s[3912]! } - public var Channel_Subscribers_Title: String { return self._s[3913]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3914]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3915]! } - public var Watch_ConnectionDescription: String { return self._s[3916]! } - public var OldChannels_NoticeText: String { return self._s[3919]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3920]! } - public var IntentsSettings_SuggestBy: String { return self._s[3922]! } - public var Theme_ThemeChangedText: String { return self._s[3923]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3924]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3925]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3926]! } - public var Conversation_SendDice: String { return self._s[3927]! } - public var EditProfile_Title: String { return self._s[3928]! } - public var NotificationsSound_Bamboo: String { return self._s[3930]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3932]! } - public var Login_SmsRequestState2: String { return self._s[3933]! } - public var Passport_Language_ar: String { return self._s[3934]! } + public var Paint_Regular: String { return self._s[3900]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3901]! } + public var SocksProxySetup_ShareLink: String { return self._s[3902]! } + public var Wallet_Qr_Title: String { return self._s[3903]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3904]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3906]! } + public var Wallet_Settings_Configuration: String { return self._s[3907]! } + public var GroupInfo_InviteByLink: String { return self._s[3908]! } + public var MessageTimer_Custom: String { return self._s[3909]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3910]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[3911]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3913]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3914]! } + public var VoiceOver_Chat_Selected: String { return self._s[3915]! } + public var Paint_Pen: String { return self._s[3916]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3917]! } + public var Channel_Username_InvalidTaken: String { return self._s[3918]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3919]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3920]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3921]! } + public var Settings_ChatBackground: String { return self._s[3922]! } + public var Channel_Subscribers_Title: String { return self._s[3923]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3924]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3925]! } + public var Watch_ConnectionDescription: String { return self._s[3926]! } + public var OldChannels_NoticeText: String { return self._s[3929]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3930]! } + public var IntentsSettings_SuggestBy: String { return self._s[3932]! } + public var Theme_ThemeChangedText: String { return self._s[3933]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3934]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3935]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3936]! } + public var Conversation_SendDice: String { return self._s[3937]! } + public var EditProfile_Title: String { return self._s[3938]! } + public var NotificationsSound_Bamboo: String { return self._s[3940]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3942]! } + public var Login_SmsRequestState2: String { return self._s[3943]! } + public var Passport_Language_ar: String { return self._s[3944]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3935]!, self._r[3935]!, [_0]) + return formatWithArgumentRanges(self._s[3945]!, self._r[3945]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3936]! } - public var Wallet_Created_Text: String { return self._s[3937]! } - public var Conversation_MessageDialogEdit: String { return self._s[3939]! } - public var Wallet_Created_Proceed: String { return self._s[3940]! } - public var Wallet_Words_Done: String { return self._s[3941]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3942]! } - public var ChatListFolder_NameChannels: String { return self._s[3943]! } + public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3946]! } + public var Wallet_Created_Text: String { return self._s[3947]! } + public var Conversation_MessageDialogEdit: String { return self._s[3949]! } + public var Wallet_Created_Proceed: String { return self._s[3950]! } + public var Wallet_Words_Done: String { return self._s[3951]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3952]! } + public var ChatListFolder_NameChannels: String { return self._s[3953]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3944]!, self._r[3944]!, [_1]) + return formatWithArgumentRanges(self._s[3954]!, self._r[3954]!, [_1]) } - public var Common_Close: String { return self._s[3945]! } - public var GroupInfo_PublicLink: String { return self._s[3946]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3947]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3948]! } + public var Common_Close: String { return self._s[3955]! } + public var GroupInfo_PublicLink: String { return self._s[3956]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3957]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3958]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3952]!, self._r[3952]!, [_0]) + return formatWithArgumentRanges(self._s[3962]!, self._r[3962]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3953]! } + public var UserInfo_About_Placeholder: String { return self._s[3963]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3954]!, self._r[3954]!, [_0]) + return formatWithArgumentRanges(self._s[3964]!, self._r[3964]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3955]! } - public var Channel_Info_Banned: String { return self._s[3957]! } + public var GroupInfo_Permissions_SectionTitle: String { return self._s[3965]! } + public var Channel_Info_Banned: String { return self._s[3967]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3958]!, self._r[3958]!, [_0]) + return formatWithArgumentRanges(self._s[3968]!, self._r[3968]!, [_0]) } - public var Appearance_Other: String { return self._s[3959]! } - public var Passport_Language_my: String { return self._s[3960]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3961]! } + public var Appearance_Other: String { return self._s[3969]! } + public var Passport_Language_my: String { return self._s[3970]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3971]! } public func Time_PreciseDate_m9(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3962]!, self._r[3962]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3972]!, self._r[3972]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3963]! } - public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3964]! } - public var Preview_CopyAddress: String { return self._s[3965]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3973]! } + public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3974]! } + public var Preview_CopyAddress: String { return self._s[3975]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3966]!, self._r[3966]!, [_0]) + return formatWithArgumentRanges(self._s[3976]!, self._r[3976]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3967]! } - public var UserInfo_BotSettings: String { return self._s[3968]! } - public var LiveLocation_MenuStopAll: String { return self._s[3970]! } - public var Passport_PasswordCreate: String { return self._s[3971]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3972]! } - public var Message_PinnedLocationMessage: String { return self._s[3973]! } - public var Map_Satellite: String { return self._s[3974]! } - public var Watch_Message_Unsupported: String { return self._s[3975]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3976]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3977]! } + public var KeyCommand_JumpToPreviousChat: String { return self._s[3977]! } + public var UserInfo_BotSettings: String { return self._s[3978]! } + public var LiveLocation_MenuStopAll: String { return self._s[3980]! } + public var Passport_PasswordCreate: String { return self._s[3981]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3982]! } + public var Message_PinnedLocationMessage: String { return self._s[3983]! } + public var Map_Satellite: String { return self._s[3984]! } + public var Watch_Message_Unsupported: String { return self._s[3985]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3986]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3987]! } public func Notification_PinnedTextMessage(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3978]!, self._r[3978]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3988]!, self._r[3988]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3979]!, self._r[3979]!, [_0]) + return formatWithArgumentRanges(self._s[3989]!, self._r[3989]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3980]! } + public var Wallet_WordImport_Continue: String { return self._s[3990]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3981]!, self._r[3981]!, [_0]) + return formatWithArgumentRanges(self._s[3991]!, self._r[3991]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3982]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3983]! } - public var NotificationsSound_None: String { return self._s[3984]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3985]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3987]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3988]! } + public var Notifications_ChannelNotificationsHelp: String { return self._s[3992]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3993]! } + public var NotificationsSound_None: String { return self._s[3994]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3995]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3997]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3998]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3989]!, self._r[3989]!, [_1]) + return formatWithArgumentRanges(self._s[3999]!, self._r[3999]!, [_1]) } - public var Cache_Indexing: String { return self._s[3990]! } - public var DialogList_RecentTitlePeople: String { return self._s[3992]! } - public var DialogList_EncryptionRejected: String { return self._s[3993]! } - public var GroupInfo_Administrators: String { return self._s[3994]! } - public var Passport_ScanPassportHelp: String { return self._s[3995]! } - public var Application_Name: String { return self._s[3996]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[3997]! } - public var Conversation_Timer_Title: String { return self._s[3998]! } - public var ChatList_PeerTypeGroup: String { return self._s[3999]! } - public var PeopleNearby_MakeVisible: String { return self._s[4001]! } - public var Appearance_ThemeCarouselDay: String { return self._s[4002]! } - public var Stats_GrowthTitle: String { return self._s[4003]! } - public var Passport_Identity_TranslationHelp: String { return self._s[4004]! } + public var Cache_Indexing: String { return self._s[4000]! } + public var DialogList_RecentTitlePeople: String { return self._s[4002]! } + public var DialogList_EncryptionRejected: String { return self._s[4003]! } + public var GroupInfo_Administrators: String { return self._s[4004]! } + public var Passport_ScanPassportHelp: String { return self._s[4005]! } + public var Application_Name: String { return self._s[4006]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[4007]! } + public var Conversation_Timer_Title: String { return self._s[4008]! } + public var ChatList_PeerTypeGroup: String { return self._s[4009]! } + public var PeopleNearby_MakeVisible: String { return self._s[4011]! } + public var Appearance_ThemeCarouselDay: String { return self._s[4012]! } + public var Stats_GrowthTitle: String { return self._s[4013]! } + public var Passport_Identity_TranslationHelp: String { return self._s[4014]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4005]!, self._r[4005]!, [_0]) + return formatWithArgumentRanges(self._s[4015]!, self._r[4015]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4006]!, self._r[4006]!, [_0]) + return formatWithArgumentRanges(self._s[4016]!, self._r[4016]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4007]!, self._r[4007]!, [_0]) + return formatWithArgumentRanges(self._s[4017]!, self._r[4017]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[4008]! } - public var Privacy_ChatsTitle: String { return self._s[4009]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[4010]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4011]! } - public var Watch_Suggestion_HoldOn: String { return self._s[4012]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[4013]! } - public var WebBrowser_Title: String { return self._s[4014]! } - public var Group_LinkedChannel: String { return self._s[4015]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4016]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[4017]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4018]! } - public var Appearance_TextSize_UseSystem: String { return self._s[4019]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[4020]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[4022]! } - public var Channel_Setup_TypePublic: String { return self._s[4024]! } + public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[4018]! } + public var Privacy_ChatsTitle: String { return self._s[4019]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[4020]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4021]! } + public var Watch_Suggestion_HoldOn: String { return self._s[4022]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[4023]! } + public var WebBrowser_Title: String { return self._s[4024]! } + public var Group_LinkedChannel: String { return self._s[4025]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4026]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[4027]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4028]! } + public var Appearance_TextSize_UseSystem: String { return self._s[4029]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[4030]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[4032]! } + public var Channel_Setup_TypePublic: String { return self._s[4034]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4025]!, self._r[4025]!, [_0]) + return formatWithArgumentRanges(self._s[4035]!, self._r[4035]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[4027]! } - public var MessagePoll_ViewResults: String { return self._s[4028]! } - public var Map_OpenInMaps: String { return self._s[4030]! } + public var Channel_TypeSetup_Title: String { return self._s[4037]! } + public var MessagePoll_ViewResults: String { return self._s[4038]! } + public var Map_OpenInMaps: String { return self._s[4040]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4031]!, self._r[4031]!, [_1]) + return formatWithArgumentRanges(self._s[4041]!, self._r[4041]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[4033]! } + public var NotificationsSound_Tremolo: String { return self._s[4043]! } public func Date_ChatDateHeaderYear(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4034]!, self._r[4034]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4044]!, self._r[4044]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[4035]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4036]! } - public var Passport_PasswordHelp: String { return self._s[4038]! } - public var Login_CodeExpiredError: String { return self._s[4039]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4040]! } - public var Conversation_TitleUnmute: String { return self._s[4041]! } - public var Passport_Identity_ScansHelp: String { return self._s[4042]! } - public var Passport_Language_lo: String { return self._s[4043]! } - public var Camera_FlashAuto: String { return self._s[4044]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[4045]! } - public var Common_Cancel: String { return self._s[4046]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[4047]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4048]! } - public var Appearance_TintAllColors: String { return self._s[4049]! } + public var ConversationProfile_UnknownAddMemberError: String { return self._s[4045]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4046]! } + public var Passport_PasswordHelp: String { return self._s[4048]! } + public var Login_CodeExpiredError: String { return self._s[4049]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4050]! } + public var Conversation_TitleUnmute: String { return self._s[4051]! } + public var Passport_Identity_ScansHelp: String { return self._s[4052]! } + public var Passport_Language_lo: String { return self._s[4053]! } + public var Camera_FlashAuto: String { return self._s[4054]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[4055]! } + public var Common_Cancel: String { return self._s[4056]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[4057]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4058]! } + public var Appearance_TintAllColors: String { return self._s[4059]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4050]!, self._r[4050]!, [_1]) + return formatWithArgumentRanges(self._s[4060]!, self._r[4060]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[4051]! } - public var ChatSettings_Title: String { return self._s[4053]! } - public var Passport_PasswordReset: String { return self._s[4054]! } - public var SocksProxySetup_TypeNone: String { return self._s[4055]! } - public var EditTheme_Title: String { return self._s[4058]! } - public var PhoneNumberHelp_Help: String { return self._s[4059]! } - public var Checkout_EnterPassword: String { return self._s[4060]! } - public var Activity_UploadingDocument: String { return self._s[4062]! } - public var Share_AuthTitle: String { return self._s[4063]! } - public var State_Connecting: String { return self._s[4064]! } - public var Profile_MessageLifetime1w: String { return self._s[4065]! } - public var Conversation_ContextMenuReport: String { return self._s[4066]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4067]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[4068]! } + public var Conversation_ReportSpamConfirmation: String { return self._s[4061]! } + public var ChatSettings_Title: String { return self._s[4063]! } + public var Passport_PasswordReset: String { return self._s[4064]! } + public var SocksProxySetup_TypeNone: String { return self._s[4065]! } + public var EditTheme_Title: String { return self._s[4068]! } + public var PhoneNumberHelp_Help: String { return self._s[4069]! } + public var Checkout_EnterPassword: String { return self._s[4070]! } + public var Activity_UploadingDocument: String { return self._s[4072]! } + public var Share_AuthTitle: String { return self._s[4073]! } + public var State_Connecting: String { return self._s[4074]! } + public var Profile_MessageLifetime1w: String { return self._s[4075]! } + public var Conversation_ContextMenuReport: String { return self._s[4076]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4077]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[4078]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4069]!, self._r[4069]!, [_0]) + return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[4070]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[4071]! } - public var PeerInfo_PaneAudio: String { return self._s[4072]! } + public var AuthSessions_Terminate: String { return self._s[4080]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[4081]! } + public var PeerInfo_PaneAudio: String { return self._s[4082]! } public func Message_ForwardedPsa_covid(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4073]!, self._r[4073]!, [_0]) + return formatWithArgumentRanges(self._s[4083]!, self._r[4083]!, [_0]) } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[4075]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4076]! } - public var PhotoEditor_Set: String { return self._s[4077]! } - public var EmptyGroupInfo_Title: String { return self._s[4078]! } - public var Login_PadPhoneHelp: String { return self._s[4080]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4082]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4084]! } - public var NotificationsSound_Complete: String { return self._s[4085]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4086]! } - public var Group_Info_AdminLog: String { return self._s[4087]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4088]! } + public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[4085]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4086]! } + public var PhotoEditor_Set: String { return self._s[4087]! } + public var EmptyGroupInfo_Title: String { return self._s[4088]! } + public var Login_PadPhoneHelp: String { return self._s[4090]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4092]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4094]! } + public var NotificationsSound_Complete: String { return self._s[4095]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4096]! } + public var Group_Info_AdminLog: String { return self._s[4097]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4098]! } public func Wallet_Time_PreciseDate_m11(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4089]!, self._r[4089]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4099]!, self._r[4099]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[4090]! } - public var Group_Location_CreateInThisPlace: String { return self._s[4092]! } - public var Conversation_Admin: String { return self._s[4093]! } - public var Conversation_GifTooltip: String { return self._s[4094]! } - public var Passport_NotLoggedInMessage: String { return self._s[4095]! } + public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[4100]! } + public var Group_Location_CreateInThisPlace: String { return self._s[4102]! } + public var Conversation_Admin: String { return self._s[4103]! } + public var Conversation_GifTooltip: String { return self._s[4104]! } + public var Passport_NotLoggedInMessage: String { return self._s[4105]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4097]!, self._r[4097]!, [_0]) + return formatWithArgumentRanges(self._s[4107]!, self._r[4107]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[4098]! } - public var SharedMedia_EmptyTitle: String { return self._s[4100]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4102]! } - public var Username_Help: String { return self._s[4103]! } - public var DialogList_LanguageTooltip: String { return self._s[4105]! } - public var Map_LoadError: String { return self._s[4106]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4107]! } - public var Channel_AdminLog_AddMembers: String { return self._s[4108]! } - public var ArchivedChats_IntroTitle2: String { return self._s[4109]! } - public var Notification_Exceptions_NewException: String { return self._s[4110]! } - public var TwoStepAuth_EmailTitle: String { return self._s[4111]! } - public var WatchRemote_AlertText: String { return self._s[4112]! } + public var Profile_MessageLifetimeForever: String { return self._s[4108]! } + public var SharedMedia_EmptyTitle: String { return self._s[4110]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4112]! } + public var Username_Help: String { return self._s[4113]! } + public var DialogList_LanguageTooltip: String { return self._s[4115]! } + public var Map_LoadError: String { return self._s[4116]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4117]! } + public var Channel_AdminLog_AddMembers: String { return self._s[4118]! } + public var ArchivedChats_IntroTitle2: String { return self._s[4119]! } + public var Notification_Exceptions_NewException: String { return self._s[4120]! } + public var TwoStepAuth_EmailTitle: String { return self._s[4121]! } + public var WatchRemote_AlertText: String { return self._s[4122]! } public func Wallet_Send_ConfirmationText(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4113]!, self._r[4113]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4123]!, self._r[4123]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[4117]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[4127]! } public func PUSH_PINNED_QUIZ(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4118]!, self._r[4118]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4128]!, self._r[4128]!, [_1, _2]) } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4119]!, self._r[4119]!, [_0]) + return formatWithArgumentRanges(self._s[4129]!, self._r[4129]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[4120]! } - public var WebBrowser_DefaultBrowser: String { return self._s[4121]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[4122]! } + public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[4130]! } + public var WebBrowser_DefaultBrowser: String { return self._s[4131]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[4132]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4123]!, self._r[4123]!, [_0]) + return formatWithArgumentRanges(self._s[4133]!, self._r[4133]!, [_0]) } public func Time_PreciseDate_m6(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4124]!, self._r[4124]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4134]!, self._r[4134]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[4125]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4126]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[4128]! } - public var Wallet_Created_ExportErrorText: String { return self._s[4129]! } - public var ChatList_UndoArchiveText1: String { return self._s[4130]! } - public var ChatListFolder_IncludedSectionHeader: String { return self._s[4131]! } - public var AccessDenied_VideoMicrophone: String { return self._s[4132]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4133]! } - public var Cache_ClearNone: String { return self._s[4134]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[4135]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[4136]! } + public var Group_AdminLog_EmptyText: String { return self._s[4135]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4136]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[4138]! } + public var Wallet_Created_ExportErrorText: String { return self._s[4139]! } + public var ChatList_UndoArchiveText1: String { return self._s[4140]! } + public var ChatListFolder_IncludedSectionHeader: String { return self._s[4141]! } + public var AccessDenied_VideoMicrophone: String { return self._s[4142]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4143]! } + public var Cache_ClearNone: String { return self._s[4144]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[4145]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[4146]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4137]!, self._r[4137]!, [_0]) + return formatWithArgumentRanges(self._s[4147]!, self._r[4147]!, [_0]) } - public var Passport_Identity_Country: String { return self._s[4138]! } + public var Passport_Identity_Country: String { return self._s[4148]! } public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4139]!, self._r[4139]!, [_0]) + return formatWithArgumentRanges(self._s[4149]!, self._r[4149]!, [_0]) } public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4140]!, self._r[4140]!, [_0]) + return formatWithArgumentRanges(self._s[4150]!, self._r[4150]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[4141]! } - public var AccessDenied_Settings: String { return self._s[4142]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4143]! } - public var Month_ShortMay: String { return self._s[4145]! } - public var Compose_NewGroup: String { return self._s[4147]! } - public var Group_Setup_TypePrivate: String { return self._s[4149]! } - public var Login_PadPhoneHelpTitle: String { return self._s[4151]! } - public var Appearance_ThemeDayClassic: String { return self._s[4152]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4153]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[4154]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4155]! } - public var Conversation_typing: String { return self._s[4157]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[4158]! } - public var Paint_Masks: String { return self._s[4159]! } - public var Contacts_DeselectAll: String { return self._s[4160]! } + public var Exceptions_AddToExceptions: String { return self._s[4151]! } + public var AccessDenied_Settings: String { return self._s[4152]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4153]! } + public var Month_ShortMay: String { return self._s[4155]! } + public var Compose_NewGroup: String { return self._s[4157]! } + public var Group_Setup_TypePrivate: String { return self._s[4159]! } + public var Login_PadPhoneHelpTitle: String { return self._s[4161]! } + public var Appearance_ThemeDayClassic: String { return self._s[4162]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4163]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[4164]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4165]! } + public var Conversation_typing: String { return self._s[4167]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[4168]! } + public var Paint_Masks: String { return self._s[4169]! } + public var Contacts_DeselectAll: String { return self._s[4170]! } public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4161]!, self._r[4161]!, [_0]) + return formatWithArgumentRanges(self._s[4171]!, self._r[4171]!, [_0]) } - public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4162]! } - public var Username_InvalidTaken: String { return self._s[4163]! } - public var Call_StatusNoAnswer: String { return self._s[4164]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[4165]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4166]! } - public var Passport_Identity_Selfie: String { return self._s[4167]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4168]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4169]! } - public var Conversation_ClearSecretHistory: String { return self._s[4170]! } - public var PeopleNearby_Description: String { return self._s[4172]! } - public var NetworkUsageSettings_Title: String { return self._s[4173]! } - public var Your_cards_security_code_is_invalid: String { return self._s[4175]! } - public var Stats_EnabledNotifications: String { return self._s[4176]! } + public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4172]! } + public var Username_InvalidTaken: String { return self._s[4173]! } + public var Call_StatusNoAnswer: String { return self._s[4174]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[4175]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4176]! } + public var Passport_Identity_Selfie: String { return self._s[4177]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4178]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4179]! } + public var Conversation_ClearSecretHistory: String { return self._s[4180]! } + public var PeopleNearby_Description: String { return self._s[4182]! } + public var NetworkUsageSettings_Title: String { return self._s[4183]! } + public var Your_cards_security_code_is_invalid: String { return self._s[4185]! } + public var Stats_EnabledNotifications: String { return self._s[4186]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4178]!, self._r[4178]!, [_0]) + return formatWithArgumentRanges(self._s[4188]!, self._r[4188]!, [_0]) } public func Call_CallInProgressMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4179]!, self._r[4179]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4189]!, self._r[4189]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[4181]! } - public var VoiceOver_Navigation_Search: String { return self._s[4182]! } - public var Map_LiveLocationTitle: String { return self._s[4183]! } - public var Login_InfoAvatarAdd: String { return self._s[4184]! } - public var Passport_Identity_FilesView: String { return self._s[4185]! } - public var ChatListFolderSettings_Title: String { return self._s[4186]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[4187]! } - public var Privacy_Calls_NeverAllow: String { return self._s[4188]! } - public var VoiceOver_Chat_File: String { return self._s[4189]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4190]! } + public var SaveIncomingPhotosSettings_From: String { return self._s[4191]! } + public var VoiceOver_Navigation_Search: String { return self._s[4192]! } + public var Map_LiveLocationTitle: String { return self._s[4193]! } + public var Login_InfoAvatarAdd: String { return self._s[4194]! } + public var Passport_Identity_FilesView: String { return self._s[4195]! } + public var ChatListFolderSettings_Title: String { return self._s[4196]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[4197]! } + public var Privacy_Calls_NeverAllow: String { return self._s[4198]! } + public var VoiceOver_Chat_File: String { return self._s[4199]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4200]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4191]!, self._r[4191]!, [_0]) + return formatWithArgumentRanges(self._s[4201]!, self._r[4201]!, [_0]) } - public var ChatList_EmptyChatList: String { return self._s[4192]! } - public var ContactInfo_PhoneNumberHidden: String { return self._s[4193]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[4194]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4195]! } + public var ChatList_EmptyChatList: String { return self._s[4203]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[4204]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[4205]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4206]! } public func PUSH_CHAT_MESSAGE_VIDEOS(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4196]!, self._r[4196]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4207]!, self._r[4207]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4197]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[4198]! } - public var Tour_Title2: String { return self._s[4199]! } - public var Wallet_Sent_ViewWallet: String { return self._s[4200]! } - public var Conversation_FileOpenIn: String { return self._s[4201]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4202]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4203]! } - public var Wallpaper_Set: String { return self._s[4204]! } - public var Passport_Identity_Translations: String { return self._s[4206]! } + public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4208]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[4209]! } + public var Tour_Title2: String { return self._s[4210]! } + public var Wallet_Sent_ViewWallet: String { return self._s[4211]! } + public var Conversation_FileOpenIn: String { return self._s[4212]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4213]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4214]! } + public var Wallpaper_Set: String { return self._s[4215]! } + public var Passport_Identity_Translations: String { return self._s[4217]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4207]!, self._r[4207]!, [_0]) + return formatWithArgumentRanges(self._s[4218]!, self._r[4218]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4208]! } + public var Channel_LeaveChannel: String { return self._s[4219]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4209]!, self._r[4209]!, [_1]) + return formatWithArgumentRanges(self._s[4220]!, self._r[4220]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4211]! } - public var PhotoEditor_HighlightsTint: String { return self._s[4212]! } - public var MessagePoll_LabelPoll: String { return self._s[4213]! } - public var Passport_Email_Delete: String { return self._s[4214]! } - public var Conversation_Mute: String { return self._s[4216]! } - public var Channel_AddBotAsAdmin: String { return self._s[4217]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[4219]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4220]! } - public var ChatSettings_IntentsSettings: String { return self._s[4222]! } - public var Channel_Management_LabelOwner: String { return self._s[4223]! } + public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4222]! } + public var PhotoEditor_HighlightsTint: String { return self._s[4223]! } + public var MessagePoll_LabelPoll: String { return self._s[4224]! } + public var Passport_Email_Delete: String { return self._s[4225]! } + public var Conversation_Mute: String { return self._s[4227]! } + public var Channel_AddBotAsAdmin: String { return self._s[4228]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[4230]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4231]! } + public var ChatSettings_IntentsSettings: String { return self._s[4233]! } + public var Channel_Management_LabelOwner: String { return self._s[4234]! } public func Notification_PassportValuesSentMessage(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4224]!, self._r[4224]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4235]!, self._r[4235]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[4225]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[4226]! } - public var Common_No: String { return self._s[4227]! } - public var Weekday_Sunday: String { return self._s[4228]! } - public var Notification_Reply: String { return self._s[4229]! } - public var Conversation_ViewMessage: String { return self._s[4230]! } + public var Calls_CallTabDescription: String { return self._s[4236]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[4237]! } + public var Common_No: String { return self._s[4238]! } + public var Weekday_Sunday: String { return self._s[4239]! } + public var Notification_Reply: String { return self._s[4240]! } + public var Conversation_ViewMessage: String { return self._s[4241]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4231]!, self._r[4231]!, [_0]) + return formatWithArgumentRanges(self._s[4242]!, self._r[4242]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4232]!, self._r[4232]!, [_0]) + return formatWithArgumentRanges(self._s[4243]!, self._r[4243]!, [_0]) } public func Wallet_Time_PreciseDate_m7(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4233]!, self._r[4233]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4244]!, self._r[4244]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4234]! } - public var Wallet_Send_Title: String { return self._s[4235]! } - public var Message_PinnedDocumentMessage: String { return self._s[4236]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[4237]! } - public var DialogList_TabTitle: String { return self._s[4239]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4240]! } - public var Passport_FieldEmail: String { return self._s[4241]! } - public var Conversation_UnpinMessageAlert: String { return self._s[4242]! } - public var Passport_Address_TypeBankStatement: String { return self._s[4243]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[4244]! } - public var Passport_Identity_ExpiryDate: String { return self._s[4245]! } - public var Privacy_Calls_P2P: String { return self._s[4246]! } + public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4245]! } + public var Wallet_Send_Title: String { return self._s[4246]! } + public var Message_PinnedDocumentMessage: String { return self._s[4247]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[4248]! } + public var DialogList_TabTitle: String { return self._s[4250]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4251]! } + public var Passport_FieldEmail: String { return self._s[4252]! } + public var Conversation_UnpinMessageAlert: String { return self._s[4253]! } + public var Passport_Address_TypeBankStatement: String { return self._s[4254]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[4255]! } + public var Passport_Identity_ExpiryDate: String { return self._s[4256]! } + public var Privacy_Calls_P2P: String { return self._s[4257]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4248]!, self._r[4248]!, [_0]) + return formatWithArgumentRanges(self._s[4259]!, self._r[4259]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4249]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[4260]! } public func PUSH_CHAT_ALBUM(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4250]!, self._r[4250]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4261]!, self._r[4261]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[4251]! } - public var EnterPasscode_ChangeTitle: String { return self._s[4252]! } - public var TwoFactorSetup_Email_Title: String { return self._s[4253]! } - public var Passport_InfoText: String { return self._s[4254]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4255]! } + public var Stickers_ClearRecent: String { return self._s[4262]! } + public var EnterPasscode_ChangeTitle: String { return self._s[4263]! } + public var TwoFactorSetup_Email_Title: String { return self._s[4264]! } + public var Passport_InfoText: String { return self._s[4265]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4266]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4256]!, self._r[4256]!, [_0]) + return formatWithArgumentRanges(self._s[4267]!, self._r[4267]!, [_0]) } public func Time_PreciseDate_m3(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4257]!, self._r[4257]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4268]!, self._r[4268]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4258]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[4259]! } - public var VoiceOver_Navigation_Compose: String { return self._s[4260]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[4261]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4263]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4264]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4269]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4270]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4271]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4272]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4274]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4275]! } public func Notification_CallTimeFormat(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4265]!, self._r[4265]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4276]!, self._r[4276]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4268]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4269]! } - public var Map_HomeAndWorkTitle: String { return self._s[4270]! } + public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4279]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4280]! } + public var Map_HomeAndWorkTitle: String { return self._s[4281]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4272]!, self._r[4272]!, [_0]) + return formatWithArgumentRanges(self._s[4283]!, self._r[4283]!, [_0]) } - public var DialogList_Unread: String { return self._s[4273]! } + public var DialogList_Unread: String { return self._s[4284]! } public func PUSH_CHAT_MESSAGE_GIF(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4274]!, self._r[4274]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4285]!, self._r[4285]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4275]! } - public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4276]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4277]! } + public var User_DeletedAccount: String { return self._s[4286]! } + public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4287]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4288]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4278]!, self._r[4278]!, [_0]) + return formatWithArgumentRanges(self._s[4289]!, self._r[4289]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4279]! } - public var SharedMedia_CategoryMedia: String { return self._s[4280]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4281]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4282]! } - public var Watch_ChatList_Compose: String { return self._s[4283]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4284]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4285]! } - public var Watch_Microphone_Access: String { return self._s[4286]! } - public var Group_Setup_HistoryHeader: String { return self._s[4287]! } - public var Map_SetThisLocation: String { return self._s[4288]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4289]! } - public var Activity_UploadingPhoto: String { return self._s[4290]! } - public var Conversation_Edit: String { return self._s[4292]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4293]! } - public var Login_TermsOfServiceDecline: String { return self._s[4294]! } - public var Message_PinnedContactMessage: String { return self._s[4295]! } + public var UserInfo_NotificationsDefault: String { return self._s[4290]! } + public var SharedMedia_CategoryMedia: String { return self._s[4291]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4292]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4293]! } + public var Watch_ChatList_Compose: String { return self._s[4294]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4295]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4296]! } + public var Watch_Microphone_Access: String { return self._s[4297]! } + public var Group_Setup_HistoryHeader: String { return self._s[4298]! } + public var Map_SetThisLocation: String { return self._s[4299]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4300]! } + public var Activity_UploadingPhoto: String { return self._s[4301]! } + public var Conversation_Edit: String { return self._s[4303]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4304]! } + public var Login_TermsOfServiceDecline: String { return self._s[4305]! } + public var Message_PinnedContactMessage: String { return self._s[4306]! } public func Channel_AdminLog_MessageRestrictedNameUsername(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4296]!, self._r[4296]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4307]!, self._r[4307]!, [_1, _2]) } public func Login_PhoneBannedEmailBody(_ _1: String, _ _2: String, _ _3: String, _ _4: String, _ _5: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4297]!, self._r[4297]!, [_1, _2, _3, _4, _5]) + return formatWithArgumentRanges(self._s[4308]!, self._r[4308]!, [_1, _2, _3, _4, _5]) } - public var Appearance_LargeEmoji: String { return self._s[4298]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4300]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4301]! } + public var Appearance_LargeEmoji: String { return self._s[4309]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4311]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4312]! } public func PUSH_CHAT_DELETE_YOU(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4302]!, self._r[4302]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4313]!, self._r[4313]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4303]! } - public var Message_PinnedPhotoMessage: String { return self._s[4304]! } - public var Passport_FieldPhone: String { return self._s[4305]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4306]! } - public var Stats_NotificationsTitle: String { return self._s[4307]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4308]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4310]! } - public var Conversation_Call: String { return self._s[4311]! } - public var Common_TakePhoto: String { return self._s[4313]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4314]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4315]! } - public var Channel_NotificationLoading: String { return self._s[4316]! } + public var Passport_Phone_EnterOtherNumber: String { return self._s[4314]! } + public var Message_PinnedPhotoMessage: String { return self._s[4315]! } + public var Passport_FieldPhone: String { return self._s[4316]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4317]! } + public var Stats_NotificationsTitle: String { return self._s[4318]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4319]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4321]! } + public var Conversation_Call: String { return self._s[4322]! } + public var Common_TakePhoto: String { return self._s[4324]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4325]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4326]! } + public var Channel_NotificationLoading: String { return self._s[4327]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4317]!, self._r[4317]!, [_0]) + return formatWithArgumentRanges(self._s[4328]!, self._r[4328]!, [_0]) } public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4318]!, self._r[4318]!, [_0]) + return formatWithArgumentRanges(self._s[4329]!, self._r[4329]!, [_0]) } public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4319]!, self._r[4319]!, [_1]) + return formatWithArgumentRanges(self._s[4330]!, self._r[4330]!, [_1]) } - public var Permissions_SiriTitle_v0: String { return self._s[4320]! } + public var Permissions_SiriTitle_v0: String { return self._s[4331]! } public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4321]!, self._r[4321]!, [_0]) + return formatWithArgumentRanges(self._s[4332]!, self._r[4332]!, [_0]) } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4322]!, self._r[4322]!, [_0]) + return formatWithArgumentRanges(self._s[4333]!, self._r[4333]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4323]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4324]! } - public var ClearCache_FreeSpace: String { return self._s[4325]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[4326]! } - public var Common_edit: String { return self._s[4327]! } - public var PrivacySettings_AuthSessions: String { return self._s[4328]! } - public var Month_ShortJune: String { return self._s[4329]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4330]! } - public var Call_ReportSend: String { return self._s[4331]! } - public var Watch_LastSeen_JustNow: String { return self._s[4332]! } - public var Notifications_MessageNotifications: String { return self._s[4333]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4334]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4336]! } - public var Group_Status: String { return self._s[4337]! } + public var Channel_MessagePhotoRemoved: String { return self._s[4334]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4335]! } + public var ClearCache_FreeSpace: String { return self._s[4336]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[4337]! } + public var Common_edit: String { return self._s[4338]! } + public var PrivacySettings_AuthSessions: String { return self._s[4339]! } + public var Month_ShortJune: String { return self._s[4340]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4341]! } + public var Call_ReportSend: String { return self._s[4342]! } + public var Watch_LastSeen_JustNow: String { return self._s[4343]! } + public var Notifications_MessageNotifications: String { return self._s[4344]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4345]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4347]! } + public var Group_Status: String { return self._s[4348]! } public func AutoNightTheme_LocationHelp(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4338]!, self._r[4338]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4349]!, self._r[4349]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4339]! } - public var ShareMenu_ShareTo: String { return self._s[4340]! } - public var Conversation_Moderate_Ban: String { return self._s[4341]! } + public var TextFormat_AddLinkTitle: String { return self._s[4350]! } + public var ShareMenu_ShareTo: String { return self._s[4351]! } + public var Conversation_Moderate_Ban: String { return self._s[4352]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4342]!, self._r[4342]!, [_0]) + return formatWithArgumentRanges(self._s[4353]!, self._r[4353]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4343]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4344]! } + public var SharedMedia_ViewInChat: String { return self._s[4354]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4355]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4345]!, self._r[4345]!, [_1]) + return formatWithArgumentRanges(self._s[4356]!, self._r[4356]!, [_1]) } public func PUSH_PINNED_POLL(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4346]!, self._r[4346]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4357]!, self._r[4357]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4348]!, self._r[4348]!, [_0]) + return formatWithArgumentRanges(self._s[4359]!, self._r[4359]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4349]! } - public var Appearance_ReduceMotion: String { return self._s[4350]! } + public var Map_OpenInHereMaps: String { return self._s[4360]! } + public var Appearance_ReduceMotion: String { return self._s[4361]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4351]!, self._r[4351]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4362]!, self._r[4362]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4352]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4353]! } - public var PhotoEditor_Skip: String { return self._s[4354]! } - 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[0 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + public var Channel_Setup_TypePublicHelp: String { return self._s[4363]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4364]! } + public var PhotoEditor_Skip: String { return self._s[4365]! } + public func MuteExpires_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_DeleteConfirmation(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Weeks(_ 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 GroupInfo_ShowMoreMembers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) - } - public func AttachmentMenu_SendVideo(_ 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 Call_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, _1, _2) - } - 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[8 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Call_ShortMinutes(_ 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 ForwardedAudios(_ 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 UserCount(_ 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) + return String(format: self._ps[0 * 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[1 * 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[2 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Media_ShareVideo(_ 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 Conversation_StatusSubscribers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PeopleNearby_ShowMorePeople(_ 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 Notifications_Exceptions(_ 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 ChatListFilter_ShowMoreChats(_ 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 OldChannels_InactiveMonth(_ 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 PollResults_ShowMore(_ 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 ForwardedLocations(_ 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 PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func ForwardedGifs(_ 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 SharedMedia_File(_ value: Int32) -> String { + public func SharedMedia_Link(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, stringValue) } - public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { + public func Watch_UserInfo_Mute(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[14 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { + public func ChatList_MessagePhotos(_ 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 Notification_GameScoreExtended(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[16 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { + public func StickerPack_AddStickerCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[17 * 6 + Int(form.rawValue)]!, stringValue) @@ -4969,321 +4977,319 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { + public func Media_SharePhoto(_ 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 MuteExpires_Minutes(_ 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[20 * 6 + Int(form.rawValue)]!, stringValue) } - public func PollResults_ShowMore(_ value: Int32) -> String { + public func MessageTimer_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[21 * 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[22 * 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[23 * 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[24 * 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[25 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func Conversation_SelectedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Watch_UserInfo_Mute(_ 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 Media_SharePhoto(_ 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 MessageTimer_Minutes(_ 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 Notification_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 ForwardedVideos(_ 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 Conversation_StatusSubscribers(_ 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 AttachmentMenu_SendGif(_ 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 PeopleNearby_ShowMorePeople(_ 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 Forward_ConfirmMultipleFiles(_ 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 QuickSend_Photos(_ 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 OldChannels_GroupFormat(_ 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 Theme_UsersCount(_ 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 Stats_MessageForwards(_ 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 ForwardedMessages(_ 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 Notifications_ExceptionMuteExpires_Minutes(_ 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 MuteExpires_Hours(_ 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 MessageTimer_ShortMinutes(_ 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 PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PrivacyLastSeenSettings_AddUsers(_ 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 ForwardedFiles(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[46 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[47 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_ShareVideo(_ 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 Map_ETAHours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) - } public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[50 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func OldChannels_Leave(_ 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 OldChannels_InactiveYear(_ 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 PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[53 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[54 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Contacts_InviteContacts(_ 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 AttachmentMenu_SendPhoto(_ 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 ForwardedVideoMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[57 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_ShortSeconds(_ 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 StickerPack_AddStickerCount(_ 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 MessagePoll_VotedCount(_ 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 MessageTimer_Months(_ 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 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 MessageTimer_ShortDays(_ 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 Notifications_Exceptions(_ 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 SharedMedia_Link(_ 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 ChatList_SelectedChats(_ 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 VoiceOver_Chat_PollVotes(_ 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) + return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, _1, _2) } public func OldChannels_InactiveWeek(_ 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) + return String(format: self._ps[23 * 6 + Int(form.rawValue)]!, stringValue) } - public func LastSeen_HoursAgo(_ value: Int32) -> String { + 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[69 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[24 * 6 + Int(form.rawValue)]!, stringValue) } - public func Call_ShortSeconds(_ value: Int32) -> String { + public func AttachmentMenu_SendPhoto(_ 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) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) } - public func Media_ShareItem(_ value: Int32) -> String { + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[71 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[26 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteFor_Hours(_ value: Int32) -> String { + public func GroupInfo_ParticipantCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[72 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[27 * 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[73 * 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[28 * 6 + Int(form.rawValue)]!, _1, _2) } public func Call_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + public func OldChannels_Leave(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[75 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[30 * 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[31 * 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[32 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Stats_MessageForwards(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[33 * 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[34 * 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[35 * 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[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 PrivacyLastSeenSettings_AddUsers(_ 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 StickerPack_RemoveMaskCount(_ 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 ForwardedStickers(_ 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 SharedMedia_File(_ 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 PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MuteExpires_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[43 * 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[44 * 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[45 * 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[46 * 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[47 * 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[48 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func ForwardedPhotos(_ 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_Generic(_ 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) + return String(format: self._ps[50 * 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[77 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func MessageTimer_Seconds(_ value: Int32) -> String { + public func PasscodeSettings_FailedAttempts(_ 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) + return String(format: self._ps[51 * 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[52 * 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[53 * 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[54 * 6 + Int(form.rawValue)]!, stringValue) + } + public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[55 * 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[56 * 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[57 * 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[58 * 6 + Int(form.rawValue)]!, _1, _2) } public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[59 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_DeleteConfirmation(_ 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 ForwardedPolls(_ 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 MessagePoll_VotedCount(_ 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 Watch_LastSeen_HoursAgo(_ 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 ForwardedFiles(_ 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 StickerPack_AddMaskCount(_ 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_ShortSeconds(_ 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 Passport_Scans(_ 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 StickerPack_StickerCount(_ 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 PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, _1, _2) + } + 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[70 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func Contacts_ImportersCount(_ 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 DialogList_LiveLocationChatsCount(_ 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_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_ShortHours(_ 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 ChatList_MessageVideos(_ 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 LastSeen_HoursAgo(_ 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 Wallet_Updated_MinutesAgo(_ 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 ServiceMessage_GameScoreSelfSimple(_ 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 ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func MessageTimer_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[80 * 6 + Int(form.rawValue)]!, stringValue) } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + public func Media_ShareItem(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[81 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSimple(_ value: Int32) -> String { + public func ForwardedMessages(_ 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 SharedMedia_Photo(_ value: Int32) -> String { + public func ForwardedVideos(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) @@ -5293,229 +5299,240 @@ public final class PresentationStrings: Equatable { let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) } - public func Invitation_Members(_ value: Int32) -> String { + public func Call_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[85 * 6 + Int(form.rawValue)]!, stringValue) } - public func ChatListFilter_ShowMoreChats(_ value: Int32) -> String { + public func Stats_MessageViews(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[86 * 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[87 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } public func InstantPage_Views(_ 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 ServiceMessage_GameScoreSelfSimple(_ 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 GroupInfo_ParticipantCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[90 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteFor_Days(_ 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 ForwardedLocations(_ 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 StickerPack_RemoveMaskCount(_ 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 ChatList_DeletedChats(_ 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 StickerPack_StickerCount(_ 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 ForwardedContacts(_ 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 Stats_MessageViews(_ 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 MessageTimer_ShortWeeks(_ 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 MessageTimer_Days(_ 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 Contacts_ImportersCount(_ 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 Watch_LastSeen_HoursAgo(_ 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 LiveLocation_MenuChatsCount(_ 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 ForwardedPolls(_ 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 Wallpaper_DeleteConfirmation(_ 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 SharedMedia_Video(_ 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 Notification_GameScoreSelfSimple(_ 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 ForwardedGifs(_ 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_FWDS(_ 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 InviteText_ContactsCountText(_ 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 Chat_DeleteMessagesConfirmation(_ 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 PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[111 * 6 + Int(form.rawValue)]!, _1, _2) - } - 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[112 * 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[113 * 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[114 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func StickerPack_AddMaskCount(_ 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 Passport_Scans(_ 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 OldChannels_InactiveMonth(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) - } - public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[87 * 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[120 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) } - public func MuteExpires_Days(_ value: Int32) -> String { + public func SharedMedia_Video(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[89 * 6 + Int(form.rawValue)]!, stringValue) } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + public func ChatList_DeletedChats(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[90 * 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[123 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func Map_ETAMinutes(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[124 * 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[125 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[91 * 6 + Int(form.rawValue)]!, stringValue) } public func MessagePoll_QuizCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[92 * 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[127 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Conversation_StatusMembers(_ value: Int32) -> String { + public func ForwardedVideoMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[128 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func InviteText_ContactsCountText(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[94 * 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[95 * 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[96 * 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[97 * 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[98 * 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[99 * 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[100 * 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[101 * 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[102 * 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[103 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_GroupFormat(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[104 * 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[105 * 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[106 * 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[107 * 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[108 * 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[109 * 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[110 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func ForwardedContacts(_ 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_FWDS(_ 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 PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func MuteFor_Hours(_ 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 MessageTimer_Weeks(_ 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 Conversation_SelectedMessages(_ 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 CreatePoll_AddMoreOptions(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[117 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Conversation_StatusMembers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[118 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[120 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[121 * 6 + Int(form.rawValue)]!, _0, _1) + } + public func OldChannels_InactiveYear(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[122 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[123 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteExpires_Minutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[124 * 6 + Int(form.rawValue)]!, stringValue) + } + public func AttachmentMenu_SendGif(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[125 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ServiceMessage_GameScoreSelfExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[126 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notification_GameScoreSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[127 * 6 + Int(form.rawValue)]!, stringValue) + } + public func StickerPack_RemoveStickerCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[128 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Photo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocationUpdated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[130 * 6 + Int(form.rawValue)]!, stringValue) } + public func Map_ETAMinutes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[131 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[132 * 6 + Int(form.rawValue)]!, _1, _2) + } public init(primaryComponent: PresentationStringsComponent, secondaryComponent: PresentationStringsComponent?, groupingSeparator: String) { self.primaryComponent = primaryComponent diff --git a/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/Contents.json b/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/Contents.json new file mode 100644 index 0000000000..3c9e5dfc42 --- /dev/null +++ b/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/Contents.json @@ -0,0 +1,22 @@ +{ + "images" : [ + { + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "tenor@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "tenor@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@2x.png b/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@2x.png new file mode 100644 index 0000000000..2cda9ab0e9 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@2x.png differ diff --git a/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@3x.png b/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@3x.png new file mode 100644 index 0000000000..61b54741c1 Binary files /dev/null and b/submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@3x.png differ diff --git a/submodules/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Resources/PresentationStrings.mapping index 0873e9119c..2c3b952f62 100644 Binary files a/submodules/TelegramUI/Resources/PresentationStrings.mapping and b/submodules/TelegramUI/Resources/PresentationStrings.mapping differ diff --git a/submodules/TelegramUI/Sources/AudioWaveformNode.swift b/submodules/TelegramUI/Sources/AudioWaveformNode.swift index 1061f3c97f..32bd61ea81 100644 --- a/submodules/TelegramUI/Sources/AudioWaveformNode.swift +++ b/submodules/TelegramUI/Sources/AudioWaveformNode.swift @@ -23,7 +23,9 @@ final class AudioWaveformNode: ASDisplayNode { var progress: CGFloat? { didSet { - self.setNeedsDisplay() + if self.progress != oldValue { + self.setNeedsDisplay() + } } } diff --git a/submodules/TelegramUI/Sources/AuthorizationSequenceController.swift b/submodules/TelegramUI/Sources/AuthorizationSequenceController.swift index 418241b8e5..fca4df758f 100644 --- a/submodules/TelegramUI/Sources/AuthorizationSequenceController.swift +++ b/submodules/TelegramUI/Sources/AuthorizationSequenceController.swift @@ -324,7 +324,7 @@ public final class AuthorizationSequenceController: NavigationController, MFMail }).start() })]), on: .root, blockInteraction: false, completion: {}) }) - ], actionLayout: .vertical) + ], actionLayout: .vertical, dismissOnOutsideTap: true) contentNode.textAttributeAction = (NSAttributedString.Key(rawValue: TelegramTextAttributes.URL), { value in if let value = value as? String { strongSelf.openUrl(value) diff --git a/submodules/TelegramUI/Sources/ChatBotInfoItem.swift b/submodules/TelegramUI/Sources/ChatBotInfoItem.swift index 0b5a097f19..990a302f6e 100644 --- a/submodules/TelegramUI/Sources/ChatBotInfoItem.swift +++ b/submodules/TelegramUI/Sources/ChatBotInfoItem.swift @@ -302,7 +302,7 @@ final class ChatBotInfoItemNode: ListViewItemNode { case let .url(url, concealed): self.item?.controllerInteraction.openUrl(url, concealed, nil, nil) case let .peerMention(peerId, _): - self.item?.controllerInteraction.openPeer(peerId, .chat(textInputState: nil, subject: nil), nil) + self.item?.controllerInteraction.openPeer(peerId, .chat(textInputState: nil, subject: nil, peekData: nil), nil) case let .textMention(name): self.item?.controllerInteraction.openPeerMention(name) case let .botCommand(command): diff --git a/submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift b/submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift index d5ae6da4f6..dfd63fe8b1 100644 --- a/submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift +++ b/submodules/TelegramUI/Sources/ChatButtonKeyboardInputNode.swift @@ -202,7 +202,7 @@ final class ChatButtonKeyboardInputNode: ChatInputNode { peerId = message.id.peerId } if let botPeer = botPeer, let addressName = botPeer.addressName { - self.controllerInteraction.openPeer(peerId, .chat(textInputState: ChatTextInputState(inputText: NSAttributedString(string: "@\(addressName) \(query)")), subject: nil), nil) + self.controllerInteraction.openPeer(peerId, .chat(textInputState: ChatTextInputState(inputText: NSAttributedString(string: "@\(addressName) \(query)")), subject: nil, peekData: nil), nil) } } case .payment: diff --git a/submodules/TelegramUI/Sources/ChatController.swift b/submodules/TelegramUI/Sources/ChatController.swift index 26dc36ef2f..fa000fb9f4 100644 --- a/submodules/TelegramUI/Sources/ChatController.swift +++ b/submodules/TelegramUI/Sources/ChatController.swift @@ -317,6 +317,9 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G private var focusOnSearchAfterAppearance: Bool = false private let keepPeerInfoScreenDataHotDisposable = MetaDisposable() + + private let peekData: ChatPeekTimeout? + private let peekTimerDisposable = MetaDisposable() public override var customData: Any? { return self.chatLocation @@ -324,7 +327,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G var purposefulAction: (() -> Void)? - public init(context: AccountContext, chatLocation: ChatLocation, subject: ChatControllerSubject? = nil, botStart: ChatControllerInitialBotStart? = nil, mode: ChatControllerPresentationMode = .standard(previewing: false)) { + public init(context: AccountContext, chatLocation: ChatLocation, subject: ChatControllerSubject? = nil, botStart: ChatControllerInitialBotStart? = nil, mode: ChatControllerPresentationMode = .standard(previewing: false), peekData: ChatPeekTimeout? = nil) { let _ = ChatControllerCount.modify { value in return value + 1 } @@ -333,6 +336,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self.chatLocation = chatLocation self.subject = subject self.botStart = botStart + self.peekData = peekData var locationBroadcastPanelSource: LocationBroadcastPanelSource @@ -982,9 +986,9 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G return } if let botStart = strongSelf.botStart, case let .automatic(returnToPeerId, scheduled) = botStart.behavior { - strongSelf.openPeer(peerId: returnToPeerId, navigation: .chat(textInputState: ChatTextInputState(inputText: NSAttributedString(string: inputString)), subject: scheduled ? .scheduledMessages : nil), fromMessage: nil) + strongSelf.openPeer(peerId: returnToPeerId, navigation: .chat(textInputState: ChatTextInputState(inputText: NSAttributedString(string: inputString)), subject: scheduled ? .scheduledMessages : nil, peekData: nil), fromMessage: nil) } else { - strongSelf.openPeer(peerId: peerId, navigation: .chat(textInputState: ChatTextInputState(inputText: NSAttributedString(string: inputString)), subject: nil), fromMessage: nil) + strongSelf.openPeer(peerId: peerId, navigation: .chat(textInputState: ChatTextInputState(inputText: NSAttributedString(string: inputString)), subject: nil, peekData: nil), fromMessage: nil) } }, openUrl: { [weak self] url, concealed, _, message in if let strongSelf = self { @@ -1288,7 +1292,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G items.append(ActionSheetButtonItem(title: strongSelf.presentationData.strings.Conversation_LinkDialogOpen, color: .accent, action: { [weak actionSheet] in actionSheet?.dismissAnimated() if let strongSelf = self { - strongSelf.openPeer(peerId: peerId, navigation: .chat(textInputState: nil, subject: nil), fromMessage: nil) + strongSelf.openPeer(peerId: peerId, navigation: .chat(textInputState: nil, subject: nil, peekData: nil), fromMessage: nil) } })) if !mention.isEmpty { @@ -1919,8 +1923,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G break } } - let signal = requestEditMessage(account: strongSelf.context.account, messageId: messageId, text: message.text, media: .keep, entities: entities, disableUrlPreview: false, scheduleTime: time) - strongSelf.editMessageDisposable.set((signal |> deliverOnMainQueue).start(next: { result in + strongSelf.editMessageDisposable.set((requestEditMessage(account: strongSelf.context.account, messageId: messageId, text: message.text, media: .keep, entities: entities, disableUrlPreview: false, scheduleTime: time) |> deliverOnMainQueue).start(next: { result in }, error: { error in })) } @@ -2741,6 +2744,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G self.reminderActivity?.invalidate() self.updateSlowmodeStatusDisposable.dispose() self.keepPeerInfoScreenDataHotDisposable.dispose() + self.peekTimerDisposable.dispose() } public func updatePresentationMode(_ mode: ChatControllerPresentationMode) { @@ -3680,6 +3684,9 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G if let strongSelf = self, let (searchResult, searchState, searchLocation) = searchResult { let controller = ChatSearchResultsController(context: strongSelf.context, location: searchLocation, searchQuery: searchData.query, searchResult: searchResult, searchState: searchState, navigateToMessageIndex: { index in + guard let strongSelf = self else { + return + } strongSelf.interfaceInteraction?.navigateMessageSearch(.index(index)) }, resultsUpdated: { results, state in guard let strongSelf = self else { @@ -4708,7 +4715,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G let actions: [TextAlertAction] if moreInfo { actions = [TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Generic_ErrorMoreInfo, action: { - self?.openPeerMention("spambot", navigation: .chat(textInputState: nil, subject: nil)) + self?.openPeerMention("spambot", navigation: .chat(textInputState: nil, subject: nil, peekData: nil)) }), TextAlertAction(type: .genericAction, title: strongSelf.presentationData.strings.Common_OK, action: {})] } else { actions = [TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Common_OK, action: {})] @@ -4975,7 +4982,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G let text: String switch error { - case .generic: + case .generic, .textTooLong: text = strongSelf.presentationData.strings.Channel_EditMessageErrorGeneric case .restricted: text = strongSelf.presentationData.strings.Group_ErrorSendRestrictedMedia @@ -4995,6 +5002,58 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G searchNode.activate() } } + + if let peekData = self.peekData { + let timestamp = Int32(Date().timeIntervalSince1970) + let remainingTime = max(1, peekData.deadline - timestamp) + self.peekTimerDisposable.set(( + ( + Signal.single(true) + |> suspendAwareDelay(Double(remainingTime), granularity: 2.0, queue: .mainQueue()) + ) + |> deliverOnMainQueue + ).start(next: { [weak self] _ in + guard let strongSelf = self else { + return + } + strongSelf.present(textAlertController( + context: strongSelf.context, + title: strongSelf.presentationData.strings.Conversation_PrivateChannelTimeLimitedAlertTitle, + text: strongSelf.presentationData.strings.Conversation_PrivateChannelTimeLimitedAlertText, + actions: [ + TextAlertAction(type: .genericAction, title: strongSelf.presentationData.strings.Conversation_PrivateChannelTimeLimitedAlertJoin, action: { + guard let strongSelf = self else { + return + } + strongSelf.peekTimerDisposable.set( + (joinChatInteractively(with: peekData.linkData, account: strongSelf.context.account) + |> deliverOnMainQueue).start(next: { peerId in + guard let strongSelf = self else { + return + } + if peerId == nil { + strongSelf.dismiss() + } + }, error: { _ in + guard let strongSelf = self else { + return + } + strongSelf.dismiss() + }) + ) + }), + TextAlertAction(type: .defaultAction, title: strongSelf.presentationData.strings.Common_Cancel, action: { + guard let strongSelf = self else { + return + } + strongSelf.dismiss() + }) + ], + actionLayout: .vertical, + dismissOnOutsideTap: false + ), in: .window(.root)) + })) + } } override public func viewWillDisappear(_ animated: Bool) { @@ -5018,6 +5077,10 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G }) self.sendMessageActionsController?.dismiss() + + if let _ = self.peekData { + self.peekTimerDisposable.set(nil) + } } private func saveInterfaceState(includeScrollState: Bool = true) { @@ -7796,7 +7859,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G switch navigation { case .info: self.navigationButtonAction(.openChatInfo(expandAvatar: expandAvatar)) - case let .chat(textInputState, _): + case let .chat(textInputState, _, _): if let textInputState = textInputState { self.updateChatPresentationInterfaceState(animated: true, interactive: true, { return ($0.updatedInterfaceState { @@ -7843,7 +7906,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G } } })) - case let .chat(textInputState, subject): + case let .chat(textInputState, subject, peekData): if let textInputState = textInputState { let _ = (self.context.account.postbox.transaction({ transaction -> Void in transaction.updatePeerChatInterfaceState(peerId, update: { currentState in @@ -7856,7 +7919,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G }) |> deliverOnMainQueue).start(completed: { [weak self] in if let strongSelf = self, let navigationController = strongSelf.effectiveNavigationController { - strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject, updateTextInputState: textInputState)) + strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject, updateTextInputState: textInputState, peekData: peekData)) } }) } else { @@ -7874,7 +7937,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G switch navigation { case .info: break - case let .chat(textInputState, _): + case let .chat(textInputState, _, _): if let textInputState = textInputState { let controller = self.context.sharedContext.makePeerSelectionController(PeerSelectionControllerParams(context: self.context)) controller.peerSelected = { [weak self, weak controller] peerId in @@ -7979,7 +8042,7 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G var navigation = navigation if case .default = navigation { if let peer = peer as? TelegramUser, peer.botInfo != nil { - navigation = .chat(textInputState: nil, subject: nil) + navigation = .chat(textInputState: nil, subject: nil, peekData: nil) } } strongSelf.openResolved(.peer(peer.id, navigation)) @@ -8242,13 +8305,13 @@ public final class ChatControllerImpl: TelegramBaseController, ChatController, G return } switch navigation { - case let .chat(_, subject): + case let .chat(_, subject, peekData): if case .peer(peerId) = strongSelf.chatLocation { if let subject = subject, case let .message(messageId) = subject { strongSelf.navigateToMessage(from: nil, to: .id(messageId)) } } else if let navigationController = strongSelf.effectiveNavigationController { - strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject, keepStack: .always)) + strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject, keepStack: .always, peekData: peekData)) } case .info: strongSelf.navigationActionDisposable.set((strongSelf.context.account.postbox.loadedPeerWithId(peerId) diff --git a/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift index 7886645106..df87bb5181 100644 --- a/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageAnimatedStickerItemNode.swift @@ -962,7 +962,7 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { var navigate: ChatControllerInteractionNavigateToPeer if item.content.firstMessage.id.peerId == item.context.account.peerId { - navigate = .chat(textInputState: nil, subject: nil) + navigate = .chat(textInputState: nil, subject: nil, peekData: nil) } else { navigate = .info } @@ -970,7 +970,7 @@ class ChatMessageAnimatedStickerItemNode: ChatMessageItemView { for attribute in item.content.firstMessage.attributes { if let attribute = attribute as? SourceReferenceMessageAttribute { openPeerId = attribute.messageId.peerId - navigate = .chat(textInputState: nil, subject: .message(attribute.messageId)) + navigate = .chat(textInputState: nil, subject: .message(attribute.messageId), peekData: nil) } } diff --git a/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift index 079011cba9..93e995919d 100644 --- a/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageBubbleItemNode.swift @@ -2398,7 +2398,7 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode var navigate: ChatControllerInteractionNavigateToPeer if item.content.firstMessage.id.peerId == item.context.account.peerId { - navigate = .chat(textInputState: nil, subject: nil) + navigate = .chat(textInputState: nil, subject: nil, peekData: nil) } else { navigate = .info } @@ -2406,7 +2406,7 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode for attribute in item.content.firstMessage.attributes { if let attribute = attribute as? SourceReferenceMessageAttribute { openPeerId = attribute.messageId.peerId - navigate = .chat(textInputState: nil, subject: .message(attribute.messageId)) + navigate = .chat(textInputState: nil, subject: .message(attribute.messageId), peekData: nil) } } @@ -2513,7 +2513,7 @@ class ChatMessageBubbleItemNode: ChatMessageItemView, ChatMessagePrevewItemNode }) case let .peerMention(peerId, _): return .action({ - self.item?.controllerInteraction.openPeer(peerId, .chat(textInputState: nil, subject: nil), nil) + self.item?.controllerInteraction.openPeer(peerId, .chat(textInputState: nil, subject: nil, peekData: nil), nil) }) case let .textMention(name): return .action({ diff --git a/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift index 0e59bd940c..14cd68d6ef 100644 --- a/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageInstantVideoItemNode.swift @@ -671,7 +671,7 @@ class ChatMessageInstantVideoItemNode: ChatMessageItemView { var navigate: ChatControllerInteractionNavigateToPeer if item.content.firstMessage.id.peerId == item.context.account.peerId { - navigate = .chat(textInputState: nil, subject: nil) + navigate = .chat(textInputState: nil, subject: nil, peekData: nil) } else { navigate = .info } @@ -679,7 +679,7 @@ class ChatMessageInstantVideoItemNode: ChatMessageItemView { for attribute in item.content.firstMessage.attributes { if let attribute = attribute as? SourceReferenceMessageAttribute { openPeerId = attribute.messageId.peerId - navigate = .chat(textInputState: nil, subject: .message(attribute.messageId)) + navigate = .chat(textInputState: nil, subject: .message(attribute.messageId), peekData: nil) } } diff --git a/submodules/TelegramUI/Sources/ChatMessageItemView.swift b/submodules/TelegramUI/Sources/ChatMessageItemView.swift index e2f907f602..b17d83ce58 100644 --- a/submodules/TelegramUI/Sources/ChatMessageItemView.swift +++ b/submodules/TelegramUI/Sources/ChatMessageItemView.swift @@ -206,7 +206,7 @@ final class ChatMessageAccessibilityData { let authorName = item.message.author?.displayTitle(strings: item.presentationData.strings, displayOrder: item.presentationData.nameDisplayOrder) if let chatPeer = item.message.peers[item.message.id.peerId] { - let (_, _, messageText) = chatListItemStrings(strings: item.presentationData.strings, nameDisplayOrder: item.presentationData.nameDisplayOrder, message: item.message, chatPeer: RenderedPeer(peer: chatPeer), accountPeerId: item.context.account.peerId) + let (_, _, messageText) = chatListItemStrings(strings: item.presentationData.strings, nameDisplayOrder: item.presentationData.nameDisplayOrder, messages: [item.message], chatPeer: RenderedPeer(peer: chatPeer), accountPeerId: item.context.account.peerId) var text = messageText diff --git a/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift b/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift index 25ff12d5ec..3d4d47aeba 100644 --- a/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift +++ b/submodules/TelegramUI/Sources/ChatMessageStickerItemNode.swift @@ -690,7 +690,7 @@ class ChatMessageStickerItemNode: ChatMessageItemView { var navigate: ChatControllerInteractionNavigateToPeer if item.content.firstMessage.id.peerId == item.context.account.peerId { - navigate = .chat(textInputState: nil, subject: nil) + navigate = .chat(textInputState: nil, subject: nil, peekData: nil) } else { navigate = .info } @@ -698,7 +698,7 @@ class ChatMessageStickerItemNode: ChatMessageItemView { for attribute in item.content.firstMessage.attributes { if let attribute = attribute as? SourceReferenceMessageAttribute { openPeerId = attribute.messageId.peerId - navigate = .chat(textInputState: nil, subject: .message(attribute.messageId)) + navigate = .chat(textInputState: nil, subject: .message(attribute.messageId), peekData: nil) } } diff --git a/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift b/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift index 556c2b3e09..a40d43ab10 100644 --- a/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift +++ b/submodules/TelegramUI/Sources/ChatRecentActionsControllerNode.swift @@ -653,7 +653,7 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { self.eventLogContext.setFilter(self.filter) } - private func openPeer(peerId: PeerId, peer: Peer?) { + private func openPeer(peerId: PeerId, peer: Peer?, peekData: ChatPeekTimeout? = nil) { let peerSignal: Signal if let peer = peer { peerSignal = .single(peer) @@ -663,7 +663,7 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { self.navigationActionDisposable.set((peerSignal |> take(1) |> deliverOnMainQueue).start(next: { [weak self] peer in if let strongSelf = self, let peer = peer { if peer is TelegramChannel, let navigationController = strongSelf.getNavigationController() { - strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peer.id), animated: true)) + strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peer.id), peekData: peekData, animated: true)) } else { if let infoController = strongSelf.context.sharedContext.makePeerInfoController(context: strongSelf.context, peer: peer, mode: .generic, avatarInitiallyExpanded: false, fromChat: false) { strongSelf.pushController(infoController) @@ -796,9 +796,9 @@ final class ChatRecentActionsControllerNode: ViewControllerTracingNode { case let .instantView(webpage, anchor): strongSelf.pushController(InstantPageController(context: strongSelf.context, webPage: webpage, sourcePeerType: .channel, anchor: anchor)) case let .join(link): - strongSelf.presentController(JoinLinkPreviewController(context: strongSelf.context, link: link, navigateToPeer: { peerId in + strongSelf.presentController(JoinLinkPreviewController(context: strongSelf.context, link: link, navigateToPeer: { peerId, peekData in if let strongSelf = self { - strongSelf.openPeer(peerId: peerId, peer: nil) + strongSelf.openPeer(peerId: peerId, peer: nil, peekData: peekData) } }, parentNavigationController: strongSelf.getNavigationController()), nil) case let .localization(identifier): diff --git a/submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift b/submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift index 7519a8c426..399e715d5a 100644 --- a/submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift +++ b/submodules/TelegramUI/Sources/ChatSearchResultsContollerNode.swift @@ -78,7 +78,7 @@ private enum ChatListSearchEntry: Comparable, Identifiable { public func item(context: AccountContext, interaction: ChatListNodeInteraction) -> ListViewItem { switch self { case let .message(message, peer, readState, presentationData): - return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(message: message, peer: peer, combinedReadState: readState, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: true, displayAsMessage: true, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) + return ChatListItem(presentationData: presentationData, context: context, peerGroupId: .root, filterData: nil, index: ChatListIndex(pinningIndex: nil, messageIndex: message.index), content: .peer(messages: [message], peer: peer, combinedReadState: readState, isRemovedFromTotalUnreadCount: false, presence: nil, summaryInfo: ChatListMessageTagSummaryInfo(), embeddedState: nil, inputActivities: nil, promoInfo: nil, ignoreUnreadBadge: true, displayAsMessage: true, hasFailedMessages: false), editing: false, hasActiveRevealControls: false, selected: false, header: nil, enableContextActions: false, hiddenOffset: false, interaction: interaction) } } } @@ -195,7 +195,7 @@ class ChatSearchResultsControllerNode: ViewControllerTracingNode, UIScrollViewDe } switch item.content { case let .peer(peer): - if let message = peer.message { + if let message = peer.messages.first { let chatController = strongSelf.context.sharedContext.makeChatController(context: strongSelf.context, chatLocation: .peer(peer.peer.peerId), subject: .message(message.id), botStart: nil, mode: .standard(previewing: true)) chatController.canReadHistory.set(false) let contextController = ContextController(account: strongSelf.context.account, presentationData: strongSelf.presentationData, source: .controller(ContextControllerContentSourceImpl(controller: chatController, sourceNode: node)), items: .single([]), reactionItems: [], gesture: gesture) diff --git a/submodules/TelegramUI/Sources/NavigateToChatController.swift b/submodules/TelegramUI/Sources/NavigateToChatController.swift index e6a80a00c2..c238179ed5 100644 --- a/submodules/TelegramUI/Sources/NavigateToChatController.swift +++ b/submodules/TelegramUI/Sources/NavigateToChatController.swift @@ -67,7 +67,7 @@ public func navigateToChatControllerImpl(_ params: NavigateToChatControllerParam }) } } else { - controller = ChatControllerImpl(context: params.context, chatLocation: params.chatLocation, subject: params.subject, botStart: params.botStart) + controller = ChatControllerImpl(context: params.context, chatLocation: params.chatLocation, subject: params.subject, botStart: params.botStart, peekData: params.peekData) } controller.purposefulAction = params.purposefulAction if params.activateMessageSearch { diff --git a/submodules/TelegramUI/Sources/OpenResolvedUrl.swift b/submodules/TelegramUI/Sources/OpenResolvedUrl.swift index a5fdc59cf0..22df999139 100644 --- a/submodules/TelegramUI/Sources/OpenResolvedUrl.swift +++ b/submodules/TelegramUI/Sources/OpenResolvedUrl.swift @@ -25,9 +25,9 @@ private func defaultNavigationForPeerId(_ peerId: PeerId?, navigation: ChatContr if case .default = navigation { if let peerId = peerId { if peerId.namespace == Namespaces.Peer.CloudUser { - return .chat(textInputState: nil, subject: nil) + return .chat(textInputState: nil, subject: nil, peekData: nil) } else { - return .chat(textInputState: nil, subject: nil) + return .chat(textInputState: nil, subject: nil, peekData: nil) } } else { return .info @@ -88,7 +88,7 @@ func openResolvedUrlImpl(_ resolvedUrl: ResolvedUrl, context: AccountContext, ur dismissInput() navigationController?.pushViewController(controller) case let .channelMessage(peerId, messageId): - openPeer(peerId, .chat(textInputState: nil, subject: .message(messageId))) + openPeer(peerId, .chat(textInputState: nil, subject: .message(messageId), peekData: nil)) case let .stickerPack(name): dismissInput() if false { @@ -133,8 +133,8 @@ func openResolvedUrlImpl(_ resolvedUrl: ResolvedUrl, context: AccountContext, ur navigationController?.pushViewController(InstantPageController(context: context, webPage: webpage, sourcePeerType: .channel, anchor: anchor)) case let .join(link): dismissInput() - present(JoinLinkPreviewController(context: context, link: link, navigateToPeer: { peerId in - openPeer(peerId, .chat(textInputState: nil, subject: nil)) + present(JoinLinkPreviewController(context: context, link: link, navigateToPeer: { peerId, peekData in + openPeer(peerId, .chat(textInputState: nil, subject: nil, peekData: peekData)) }, parentNavigationController: navigationController), nil) case let .localization(identifier): dismissInput() diff --git a/submodules/TelegramUI/Sources/OpenUrl.swift b/submodules/TelegramUI/Sources/OpenUrl.swift index a15f80c950..67564353c8 100644 --- a/submodules/TelegramUI/Sources/OpenUrl.swift +++ b/submodules/TelegramUI/Sources/OpenUrl.swift @@ -214,10 +214,10 @@ func openExternalUrlImpl(context: AccountContext, urlContext: OpenURLContext, ur navigationController?.pushViewController(infoController) } }) - case let .chat(_, subject): + case let .chat(_, subject, peekData): context.sharedContext.applicationBindings.dismissNativeController() if let navigationController = navigationController { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId), subject: subject)) + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId), subject: subject, peekData: peekData)) } case let .withBotStartPayload(payload): context.sharedContext.applicationBindings.dismissNativeController() diff --git a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift index f1de6e484f..a779b60417 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift @@ -11,6 +11,102 @@ import PhotoResources import RadialStatusNode import TelegramStringFormatting import GridMessageSelectionNode +import UniversalMediaPlayer + +private final class FrameSequenceThumbnailNode: ASDisplayNode { + private let context: AccountContext + private let file: FileMediaReference + private let imageNode: ASImageNode + + private var isPlaying: Bool = false + private var isPlayingInternal: Bool = false + + private var frames: [Int: UIImage] = [:] + + private var frameTimes: [Double] = [] + private var sources: [UniversalSoftwareVideoSource] = [] + private var disposables: [Int: Disposable] = [:] + + private var currentFrameIndex: Int = 0 + private var timer: SwiftSignalKit.Timer? + + init( + context: AccountContext, + file: FileMediaReference + ) { + self.context = context + self.file = file + + self.imageNode = ASImageNode() + self.imageNode.isUserInteractionEnabled = false + self.imageNode.contentMode = .scaleAspectFill + self.imageNode.clipsToBounds = true + + if let duration = file.media.duration { + let frameCount = 5 + let frameInterval: Double = Double(duration) / Double(frameCount) + for i in 0 ..< frameCount { + self.frameTimes.append(Double(i) * frameInterval) + } + } + + super.init() + + self.addSubnode(self.imageNode) + + for i in 0 ..< self.frameTimes.count { + let framePts = self.frameTimes[i] + let index = i + + let source = UniversalSoftwareVideoSource( + mediaBox: self.context.account.postbox.mediaBox, + fileReference: self.file, + automaticallyFetchHeader: true + ) + self.sources.append(source) + self.disposables[index] = (source.takeFrame(at: framePts) + |> deliverOnMainQueue).start(next: { [weak self] result in + guard let strongSelf = self else { + return + } + if case let .image(image) = result { + if let image = image { + strongSelf.frames[index] = image + } + } + }) + } + } + + deinit { + for (_, disposable) in self.disposables { + disposable.dispose() + } + self.timer?.invalidate() + } + + func updateIsPlaying(_ isPlaying: Bool) { + if self.isPlaying == isPlaying { + return + } + self.isPlaying = isPlaying + } + + func updateLayout(size: CGSize) { + self.imageNode.frame = CGRect(origin: CGPoint(), size: size) + } + + func tick() { + let isPlayingInternal = self.isPlaying && self.frames.count == self.frameTimes.count + if isPlayingInternal { + self.currentFrameIndex = (self.currentFrameIndex + 1) % self.frames.count + + if self.currentFrameIndex < self.frames.count { + self.imageNode.image = self.frames[self.currentFrameIndex] + } + } + } +} private let mediaBadgeBackgroundColor = UIColor(white: 0.0, alpha: 0.6) private let mediaBadgeTextColor = UIColor.white @@ -43,6 +139,8 @@ private final class VisualMediaItemNode: ASDisplayNode { private var displayLink: ConstantDisplayLinkAnimator? private var displayLinkTimestamp: Double = 0.0 + private var frameSequenceThumbnailNode: FrameSequenceThumbnailNode? + private let containerNode: ContextControllerSourceNode private let imageNode: TransformImageNode private var statusNode: RadialStatusNode @@ -351,6 +449,37 @@ private final class VisualMediaItemNode: ASDisplayNode { } } self.displayLink?.isPaused = !self.hasVisibility || self.isHidden + + /*if isVisible { + if let item = self.item?.0, let file = self.item?.1 as? TelegramMediaFile, !file.isAnimated { + if self.frameSequenceThumbnailNode == nil { + let frameSequenceThumbnailNode = FrameSequenceThumbnailNode(context: context, file: .message(message: MessageReference(item.message), media: file)) + self.frameSequenceThumbnailNode = frameSequenceThumbnailNode + self.imageNode.addSubnode(frameSequenceThumbnailNode) + } + if let frameSequenceThumbnailNode = self.frameSequenceThumbnailNode { + let size = self.bounds.size + frameSequenceThumbnailNode.frame = CGRect(origin: CGPoint(), size: size) + frameSequenceThumbnailNode.updateLayout(size: size) + } + } else { + if let frameSequenceThumbnailNode = self.frameSequenceThumbnailNode { + self.frameSequenceThumbnailNode = nil + frameSequenceThumbnailNode.removeFromSupernode() + } + } + } else { + if let frameSequenceThumbnailNode = self.frameSequenceThumbnailNode { + self.frameSequenceThumbnailNode = nil + frameSequenceThumbnailNode.removeFromSupernode() + } + }*/ + + self.frameSequenceThumbnailNode?.updateIsPlaying(isVisible) + } + + func tick() { + self.frameSequenceThumbnailNode?.tick() } func updateSelectionState(animated: Bool) { @@ -666,6 +795,8 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro private var decelerationAnimator: ConstantDisplayLinkAnimator? + private var animationTimer: SwiftSignalKit.Timer? + init(context: AccountContext, chatControllerInteraction: ChatControllerInteraction, peerId: PeerId, contentType: ContentType) { self.context = context self.peerId = peerId @@ -720,11 +851,23 @@ final class PeerInfoVisualMediaPaneNode: ASDisplayNode, PeerInfoPaneNode, UIScro itemNode.updateHiddenMedia() } }) + + let animationTimer = SwiftSignalKit.Timer(timeout: 0.3, repeat: true, completion: { [weak self] in + guard let strongSelf = self else { + return + } + for (_, itemNode) in strongSelf.visibleMediaItems { + itemNode.tick() + } + }, queue: .mainQueue()) + self.animationTimer = animationTimer + animationTimer.start() } deinit { self.listDisposable.dispose() self.hiddenMediaDisposable?.dispose() + self.animationTimer?.invalidate() } private func requestHistoryAroundVisiblePosition() { diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift index 932bf199b0..cb579abd12 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoHeaderNode.swift @@ -814,14 +814,16 @@ final class PeerInfoAvatarListNode: ASDisplayNode { self.listContainerTransformNode.addSubnode(self.listContainerNode) self.addSubnode(self.listContainerTransformNode) - let avatarReady = self.avatarContainerNode.avatarNode.ready + let avatarReady = (self.avatarContainerNode.avatarNode.ready |> mapToSignal { _ -> Signal in return .complete() } - |> then(.single(true)) + |> then(.single(true))) let galleryReady = self.listContainerNode.isReady.get() - |> filter { $0 } + |> filter { value in + return value + } |> take(1) let combinedSignal: Signal @@ -838,7 +840,9 @@ final class PeerInfoAvatarListNode: ASDisplayNode { } self.isReady.set(combinedSignal - |> filter { $0 } + |> filter { value in + return value + } |> take(1)) } diff --git a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift index 66c7a0325b..a220a713b9 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/PeerInfoScreen.swift @@ -2176,9 +2176,9 @@ private final class PeerInfoScreenNode: ViewControllerTracingNode, UIScrollViewD if let navigationController = self.controller?.navigationController as? NavigationController { self.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: self.context, chatLocation: .peer(peerId), keepStack: .always)) } - case let .chat(_, subject): + case let .chat(_, subject, peekData): if let navigationController = self.controller?.navigationController as? NavigationController { - self.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: self.context, chatLocation: .peer(peerId), subject: subject, keepStack: .always)) + self.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: self.context, chatLocation: .peer(peerId), subject: subject, keepStack: .always, peekData: peekData)) } case .info: self.resolveUrlDisposable.set((self.context.account.postbox.loadedPeerWithId(peerId) diff --git a/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift b/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift index cbb82b7ebf..da403a4763 100644 --- a/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift +++ b/submodules/TelegramUI/Sources/PeerMediaCollectionController.swift @@ -757,9 +757,9 @@ public class PeerMediaCollectionController: TelegramBaseController { strongSelf.context.sharedContext.openResolvedUrl(result, context: strongSelf.context, urlContext: .generic, navigationController: strongSelf.navigationController as? NavigationController, openPeer: { peerId, navigation in if let strongSelf = self { switch navigation { - case let .chat(_, subject): + case let .chat(_, subject, peekData): if let navigationController = strongSelf.navigationController as? NavigationController { - strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject, keepStack: .always)) + strongSelf.context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: strongSelf.context, chatLocation: .peer(peerId), subject: subject, keepStack: .always, peekData: peekData)) } case .info: strongSelf.navigationActionDisposable.set((strongSelf.context.account.postbox.loadedPeerWithId(peerId) diff --git a/submodules/TelegramUI/Sources/TextLinkHandling.swift b/submodules/TelegramUI/Sources/TextLinkHandling.swift index 35fb0c4b32..3a0ea94e09 100644 --- a/submodules/TelegramUI/Sources/TextLinkHandling.swift +++ b/submodules/TelegramUI/Sources/TextLinkHandling.swift @@ -24,9 +24,9 @@ func handleTextLinkActionImpl(context: AccountContext, peerId: PeerId?, navigate let openResolvedPeerImpl: (PeerId?, ChatControllerInteractionNavigateToPeer) -> Void = { [weak controller] peerId, navigation in context.sharedContext.openResolvedUrl(.peer(peerId, navigation), context: context, urlContext: .generic, navigationController: (controller?.navigationController as? NavigationController), openPeer: { (peerId, navigation) in switch navigation { - case let .chat(_, subject): + case let .chat(_, subject, peekData): if let navigationController = controller?.navigationController as? NavigationController { - context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId), subject: subject, keepStack: .always)) + context.sharedContext.navigateToChatController(NavigateToChatControllerParams(navigationController: navigationController, context: context, chatLocation: .peer(peerId), subject: subject, keepStack: .always, peekData: peekData)) } case .info: let peerSignal: Signal @@ -64,8 +64,8 @@ func handleTextLinkActionImpl(context: AccountContext, peerId: PeerId?, navigate case let .instantView(webpage, anchor): (controller.navigationController as? NavigationController)?.pushViewController(InstantPageController(context: context, webPage: webpage, sourcePeerType: .group, anchor: anchor)) case let .join(link): - controller.present(JoinLinkPreviewController(context: context, link: link, navigateToPeer: { peerId in - openResolvedPeerImpl(peerId, .chat(textInputState: nil, subject: nil)) + controller.present(JoinLinkPreviewController(context: context, link: link, navigateToPeer: { peerId, peekData in + openResolvedPeerImpl(peerId, .chat(textInputState: nil, subject: nil, peekData: peekData)) }, parentNavigationController: controller.navigationController as? NavigationController), in: .window(.root)) #if ENABLE_WALLET case let .wallet(address, amount, comment): diff --git a/submodules/UrlHandling/Sources/UrlHandling.swift b/submodules/UrlHandling/Sources/UrlHandling.swift index d016af8e75..cb08db7f87 100644 --- a/submodules/UrlHandling/Sources/UrlHandling.swift +++ b/submodules/UrlHandling/Sources/UrlHandling.swift @@ -282,9 +282,9 @@ private func resolveInternalUrl(account: Account, url: ParsedInternalUrl) -> Sig } } else { if let peer = peer as? TelegramUser, peer.botInfo == nil { - return .peer(peer.id, .chat(textInputState: nil, subject: nil)) + return .peer(peer.id, .chat(textInputState: nil, subject: nil, peekData: nil)) } else { - return .peer(peer.id, .chat(textInputState: nil, subject: nil)) + return .peer(peer.id, .chat(textInputState: nil, subject: nil, peekData: nil)) } } } else { @@ -297,7 +297,7 @@ private func resolveInternalUrl(account: Account, url: ParsedInternalUrl) -> Sig } |> mapToSignal { peer -> Signal in if let peer = peer { - return .single(.peer(peer.id, .chat(textInputState: nil, subject: nil))) + return .single(.peer(peer.id, .chat(textInputState: nil, subject: nil, peekData: nil))) } else { return .single(.inaccessiblePeer) } @@ -308,12 +308,12 @@ private func resolveInternalUrl(account: Account, url: ParsedInternalUrl) -> Sig } |> mapToSignal { peer -> Signal in if let peer = peer { - return .single(.peer(peer.id, .chat(textInputState: nil, subject: .message(messageId)))) + return .single(.peer(peer.id, .chat(textInputState: nil, subject: .message(messageId), peekData: nil))) } else { return findChannelById(postbox: account.postbox, network: account.network, channelId: messageId.peerId.id) |> map { foundPeer -> ResolvedUrl? in if let foundPeer = foundPeer { - return .peer(foundPeer.id, .chat(textInputState: nil, subject: .message(messageId))) + return .peer(foundPeer.id, .chat(textInputState: nil, subject: .message(messageId), peekData: nil)) } else { return .inaccessiblePeer } diff --git a/submodules/WatchBridge/Sources/WatchBridge.swift b/submodules/WatchBridge/Sources/WatchBridge.swift index ed63d89821..29ada56d2b 100644 --- a/submodules/WatchBridge/Sources/WatchBridge.swift +++ b/submodules/WatchBridge/Sources/WatchBridge.swift @@ -319,10 +319,11 @@ func makeBridgeMedia(message: Message, strings: PresentationStrings, chatPeer: P } func makeBridgeChat(_ entry: ChatListEntry, strings: PresentationStrings) -> (TGBridgeChat, [Int64 : TGBridgeUser])? { - if case let .MessageEntry(index, message, readState, _, _, renderedPeer, _, _, hasFailed, _) = entry { + if case let .MessageEntry(index, messages, readState, _, _, renderedPeer, _, _, hasFailed, _) = entry { guard index.messageIndex.id.peerId.namespace != Namespaces.Peer.SecretChat else { return nil } + let message = messages.last let (bridgeChat, participants) = makeBridgeChat(renderedPeer.peer) bridgeChat.date = TimeInterval(index.messageIndex.timestamp) if let message = message { diff --git a/submodules/WebSearchUI/Sources/LegacyWebSearchGallery.swift b/submodules/WebSearchUI/Sources/LegacyWebSearchGallery.swift index 0107068844..c9158573a6 100644 --- a/submodules/WebSearchUI/Sources/LegacyWebSearchGallery.swift +++ b/submodules/WebSearchUI/Sources/LegacyWebSearchGallery.swift @@ -313,10 +313,23 @@ private func galleryItems(account: Account, results: [ChatContextResult], curren return (galleryItems, focusItem) } -func presentLegacyWebSearchGallery(context: AccountContext, peer: Peer?, presentationData: PresentationData, results: [ChatContextResult], current: ChatContextResult, selectionContext: TGMediaSelectionContext?, editingContext: TGMediaEditingContext, updateHiddenMedia: @escaping (String?) -> Void, initialLayout: ContainerViewLayout?, transitionHostView: @escaping () -> UIView?, transitionView: @escaping (ChatContextResult) -> UIView?, completed: @escaping (ChatContextResult) -> Void, present: (ViewController, Any?) -> Void) { +func presentLegacyWebSearchGallery(context: AccountContext, peer: Peer?, presentationData: PresentationData, results: [ChatContextResult], current: ChatContextResult, selectionContext: TGMediaSelectionContext?, editingContext: TGMediaEditingContext, updateHiddenMedia: @escaping (String?) -> Void, initialLayout: ContainerViewLayout?, transitionHostView: @escaping () -> UIView?, transitionView: @escaping (ChatContextResult) -> UIView?, completed: @escaping (ChatContextResult) -> Void, presentStickers: ((@escaping (TelegramMediaFile, Bool, UIView, CGRect) -> Void) -> TGPhotoPaintStickersScreen?)?, present: (ViewController, Any?) -> Void) { let legacyController = LegacyController(presentation: .custom, theme: presentationData.theme, initialLayout: nil) legacyController.statusBar.statusBarStyle = presentationData.theme.rootController.statusBarStyle.style + let paintStickersContext = LegacyPaintStickersContext(context: context) + paintStickersContext.presentStickersController = { completion in + if let presentStickers = presentStickers { + return presentStickers({ file, animated, view, rect in + let coder = PostboxEncoder() + coder.encodeRootObject(file) + completion?(coder.makeData(), animated, view, rect) + }) + } else { + return nil + } + } + let controller = TGModernGalleryController(context: legacyController.context)! controller.asyncTransitionIn = true legacyController.bind(controller: controller) @@ -324,6 +337,7 @@ func presentLegacyWebSearchGallery(context: AccountContext, peer: Peer?, present let (items, focusItem) = galleryItems(account: context.account, results: results, current: current, selectionContext: selectionContext, editingContext: editingContext) let model = TGMediaPickerGalleryModel(context: legacyController.context, items: items, focus: focusItem, selectionContext: selectionContext, editingContext: editingContext, hasCaptions: false, allowCaptionEntities: true, hasTimer: false, onlyCrop: false, inhibitDocumentCaptions: false, hasSelectionPanel: false, hasCamera: false, recipientName: peer?.displayTitle(strings: presentationData.strings, displayOrder: presentationData.nameDisplayOrder))! + model.stickersContext = paintStickersContext if let peer = peer { model.suggestionContext = legacySuggestionContext(context: context, peerId: peer.id) } diff --git a/submodules/WebSearchUI/Sources/WebSearchController.swift b/submodules/WebSearchUI/Sources/WebSearchController.swift index 142db4ef32..140e9fba8e 100644 --- a/submodules/WebSearchUI/Sources/WebSearchController.swift +++ b/submodules/WebSearchUI/Sources/WebSearchController.swift @@ -108,6 +108,18 @@ private func selectionChangedSignal(selectionState: TGMediaSelectionContext) -> } } +public struct WebSearchConfiguration: Equatable { + public let gifProvider: String? + + public init(appConfiguration: AppConfiguration) { + var gifProvider: String? = nil + if let data = appConfiguration.data, let value = data["gif_search_branding"] as? String { + gifProvider = value + } + self.gifProvider = gifProvider + } +} + public final class WebSearchController: ViewController { private var validLayout: ContainerViewLayout? @@ -137,6 +149,12 @@ public final class WebSearchController: ViewController { private var navigationContentNode: WebSearchNavigationContentNode? + var presentStickers: ((@escaping (TelegramMediaFile, Bool, UIView, CGRect) -> Void) -> TGPhotoPaintStickersScreen?)? { + didSet { + self.controllerNode.presentStickers = self.presentStickers + } + } + public init(context: AccountContext, peer: Peer?, configuration: SearchBotsConfiguration, mode: WebSearchControllerMode) { self.context = context self.mode = mode @@ -169,9 +187,19 @@ public final class WebSearchController: ViewController { return WebSearchSettings.defaultSettings } } + + let gifProvider = self.context.account.postbox.preferencesView(keys: [PreferencesKeys.appConfiguration]) + |> map { view -> String? in + guard let appConfiguration = view.values[PreferencesKeys.appConfiguration] as? AppConfiguration else { + return nil + } + let configuration = WebSearchConfiguration(appConfiguration: appConfiguration) + return configuration.gifProvider + } + |> distinctUntilChanged - self.disposable = ((combineLatest(settings, context.sharedContext.presentationData)) - |> deliverOnMainQueue).start(next: { [weak self] settings, presentationData in + self.disposable = ((combineLatest(settings, context.sharedContext.presentationData, gifProvider)) + |> deliverOnMainQueue).start(next: { [weak self] settings, presentationData, gifProvider in guard let strongSelf = self else { return } @@ -183,6 +211,9 @@ public final class WebSearchController: ViewController { if current.presentationData !== presentationData { updated = updated.withUpdatedPresentationData(presentationData) } + if current.gifProvider != gifProvider { + updated = updated.withUpdatedGifProvider(gifProvider) + } return updated } }) @@ -314,13 +345,14 @@ public final class WebSearchController: ViewController { let previousInterfaceState = self.interfaceState let previousTheme = self.interfaceState.presentationData.theme let previousStrings = self.interfaceState.presentationData.theme + let previousGifProvider = self.interfaceState.gifProvider let updatedInterfaceState = f(self.interfaceState) self.interfaceState = updatedInterfaceState self.interfaceStatePromise.set(updatedInterfaceState) if self.isNodeLoaded { - if previousTheme !== updatedInterfaceState.presentationData.theme || previousStrings !== updatedInterfaceState.presentationData.strings { + if previousTheme !== updatedInterfaceState.presentationData.theme || previousStrings !== updatedInterfaceState.presentationData.strings || previousGifProvider != updatedInterfaceState.gifProvider { self.controllerNode.updatePresentationData(theme: updatedInterfaceState.presentationData.theme, strings: updatedInterfaceState.presentationData.strings) } if previousInterfaceState != self.interfaceState { diff --git a/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift b/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift index 1f7ea755ef..acfa1d974b 100644 --- a/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift +++ b/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift @@ -178,6 +178,8 @@ class WebSearchControllerNode: ASDisplayNode { var cancel: (() -> Void)? var dismissInput: (() -> Void)? + var presentStickers: ((@escaping (TelegramMediaFile, Bool, UIView, CGRect) -> Void) -> TGPhotoPaintStickersScreen?)? + init(context: AccountContext, presentationData: PresentationData, controllerInteraction: WebSearchControllerInteraction, peer: Peer?, mode: WebSearchMode) { self.context = context self.theme = presentationData.theme @@ -348,8 +350,26 @@ class WebSearchControllerNode: ASDisplayNode { self.segmentedControlNode.updateTheme(SegmentedControlTheme(theme: self.theme)) self.toolbarBackgroundNode.backgroundColor = self.theme.rootController.navigationBar.backgroundColor self.toolbarSeparatorNode.backgroundColor = self.theme.rootController.navigationBar.separatorColor - - self.attributionNode.image = generateTintedImage(image: UIImage(bundleImageName: "Media Grid/Giphy"), color: self.theme.list.itemSecondaryTextColor) + } + + let gifProviderImage: UIImage? + if let gifProvider = self.webSearchInterfaceState.gifProvider { + switch gifProvider { + case "tenor": + gifProviderImage = generateTintedImage(image: UIImage(bundleImageName: "Media Grid/Tenor"), color: self.theme.list.itemSecondaryTextColor) + case "giphy": + gifProviderImage = generateTintedImage(image: UIImage(bundleImageName: "Media Grid/Giphy"), color: self.theme.list.itemSecondaryTextColor) + default: + gifProviderImage = nil + } + } else { + gifProviderImage = nil + } + let previousGifProviderImage = self.attributionNode.image + self.attributionNode.image = gifProviderImage + + if previousGifProviderImage == nil, let validLayout = self.containerLayout { + self.containerLayoutUpdated(validLayout.0, navigationBarHeight: validLayout.1, transition: .immediate) } } @@ -386,7 +406,7 @@ class WebSearchControllerNode: ASDisplayNode { transition.updateFrame(node: self.toolbarSeparatorNode, frame: CGRect(origin: CGPoint(x: 0.0, y: toolbarY), size: CGSize(width: layout.size.width, height: UIScreenPixel))) if let image = self.attributionNode.image { - transition.updateFrame(node: self.attributionNode, frame: CGRect(origin: CGPoint(x: floor((layout.size.width - image.size.width) / 2.0), y: toolbarY + floor((toolbarHeight - image.size.height) / 2.0)), size: image.size)) + self.attributionNode.frame = CGRect(origin: CGPoint(x: floor((layout.size.width - image.size.width) / 2.0), y: toolbarY + floor((toolbarHeight - image.size.height) / 2.0)), size: image.size) transition.updateAlpha(node: self.attributionNode, alpha: self.webSearchInterfaceState.state?.scope == .gifs ? 1.0 : 0.0) } @@ -456,6 +476,7 @@ class WebSearchControllerNode: ASDisplayNode { } func updateInterfaceState(_ interfaceState: WebSearchInterfaceState, animated: Bool) { + let previousGifProvider = self.webSearchInterfaceState.gifProvider self.webSearchInterfaceState = interfaceState self.webSearchInterfaceStatePromise.set(self.webSearchInterfaceState) @@ -463,6 +484,10 @@ class WebSearchControllerNode: ASDisplayNode { self.segmentedControlNode.selectedIndex = Int(state.scope.rawValue) } + if previousGifProvider != interfaceState.gifProvider { + self.applyPresentationData(themeUpdated: false) + } + if let validLayout = self.containerLayout { self.containerLayoutUpdated(validLayout.0, navigationBarHeight: validLayout.1, transition: animated ? .animated(duration: 0.4, curve: .spring) : .immediate) } @@ -680,7 +705,7 @@ class WebSearchControllerNode: ASDisplayNode { strongSelf.controllerInteraction.sendSelected(results, result) strongSelf.cancel?() } - }, present: present) + }, presentStickers: self.presentStickers, present: present) } } else { if let results = self.currentProcessedResults?.results { diff --git a/submodules/WebSearchUI/Sources/WebSearchInterfaceState.swift b/submodules/WebSearchUI/Sources/WebSearchInterfaceState.swift index bc67ae5408..ddeb5e1684 100644 --- a/submodules/WebSearchUI/Sources/WebSearchInterfaceState.swift +++ b/submodules/WebSearchUI/Sources/WebSearchInterfaceState.swift @@ -11,26 +11,33 @@ struct WebSearchInterfaceInnerState: Equatable { struct WebSearchInterfaceState: Equatable { let state: WebSearchInterfaceInnerState? let presentationData: PresentationData + let gifProvider: String? init (presentationData: PresentationData) { self.state = nil self.presentationData = presentationData + self.gifProvider = nil } - init(state: WebSearchInterfaceInnerState?, presentationData: PresentationData) { + init(state: WebSearchInterfaceInnerState?, presentationData: PresentationData, gifProvider: String? = nil) { self.state = state self.presentationData = presentationData + self.gifProvider = gifProvider } func withUpdatedScope(_ scope: WebSearchScope) -> WebSearchInterfaceState { - return WebSearchInterfaceState(state: WebSearchInterfaceInnerState(scope: scope, query: self.state?.query ?? ""), presentationData: self.presentationData) + return WebSearchInterfaceState(state: WebSearchInterfaceInnerState(scope: scope, query: self.state?.query ?? ""), presentationData: self.presentationData, gifProvider: self.gifProvider) } func withUpdatedQuery(_ query: String) -> WebSearchInterfaceState { - return WebSearchInterfaceState(state: WebSearchInterfaceInnerState(scope: self.state?.scope ?? .images, query: query), presentationData: self.presentationData) + return WebSearchInterfaceState(state: WebSearchInterfaceInnerState(scope: self.state?.scope ?? .images, query: query), presentationData: self.presentationData, gifProvider: self.gifProvider) } func withUpdatedPresentationData(_ presentationData: PresentationData) -> WebSearchInterfaceState { - return WebSearchInterfaceState(state: self.state, presentationData: presentationData) + return WebSearchInterfaceState(state: self.state, presentationData: presentationData, gifProvider: self.gifProvider) + } + + func withUpdatedGifProvider(_ gifProvider: String?) -> WebSearchInterfaceState { + return WebSearchInterfaceState(state: self.state, presentationData: self.presentationData, gifProvider: gifProvider) } }