From 4cbf51364e08a0583c59d7838a134184e66b8348 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 5 Jun 2020 17:15:40 +0400 Subject: [PATCH 1/9] UI improvements --- Makefile | 2 +- .../Telegram-iOS/en.lproj/Localizable.strings | 5 + .../AvatarNode/Sources/AvatarNode.swift | 2 +- .../Sources/ChatListControllerNode.swift | 2 +- .../Sources/ChatListSearchContainerNode.swift | 6 +- .../Sources/Node/ChatListItem.swift | 307 +- .../Sources/Node/ChatListItemStrings.swift | 334 +- .../Sources/Node/ChatListNode.swift | 8 +- .../Sources/Node/ChatListNodeEntries.swift | 38 +- submodules/Display/Source/ImageNode.swift | 10 + submodules/Display/Source/TextNode.swift | 3 + .../Sources/MediaPlayerScrubbingNode.swift | 9 +- .../UniversalSoftwareVideoSource.swift | 38 +- .../Sources/PhotoResources.swift | 2 +- submodules/Postbox/Sources/ChatListView.swift | 33 +- .../Postbox/Sources/ChatListViewState.swift | 35 +- .../TextSizeSelectionController.swift | 12 +- .../ThemeAccentColorControllerNode.swift | 8 +- .../Themes/ThemePreviewControllerNode.swift | 14 +- .../Sources/PresentationStrings.swift | 8446 +++++++++-------- .../Resources/PresentationStrings.mapping | Bin 150402 -> 150462 bytes .../Sources/AudioWaveformNode.swift | 4 +- .../TelegramUI/Sources/ChatController.swift | 3 + .../Sources/ChatMessageItemView.swift | 2 +- .../ChatSearchResultsContollerNode.swift | 4 +- .../Panes/PeerInfoVisualMediaPaneNode.swift | 143 + .../Sources/PeerInfo/PeerInfoHeaderNode.swift | 12 +- .../WalletUI/Resources/WalletStrings.mapping | Bin 8422 -> 8422 bytes .../WalletUI/Sources/WalletStrings.swift | 4 +- .../WatchBridge/Sources/WatchBridge.swift | 3 +- 30 files changed, 4926 insertions(+), 4563 deletions(-) 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/Telegram-iOS/en.lproj/Localizable.strings b/Telegram/Telegram-iOS/en.lproj/Localizable.strings index 1086610d45..3091cb033c 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -5524,3 +5524,8 @@ Any member of this group will be able to see messages in the channel."; "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"; 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..ccc27058aa 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), 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) + 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,49 @@ 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 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 +1061,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 +1115,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 +1132,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 +1202,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 +1275,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 +1332,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 +1364,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 +1376,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 +1585,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 +1624,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 +1633,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 +1824,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/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/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/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/PhotoResources/Sources/PhotoResources.swift b/submodules/PhotoResources/Sources/PhotoResources.swift index 13cfd291de..476eb07610 100644 --- a/submodules/PhotoResources/Sources/PhotoResources.swift +++ b/submodules/PhotoResources/Sources/PhotoResources.swift @@ -2129,7 +2129,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/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/TelegramPresentationData/Sources/PresentationStrings.swift b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift index 54f0e30679..0b596b8116 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -250,5272 +250,5282 @@ 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 Passport_Language_nl: String { return self._s[353]! } + public var Camera_Retake: String { return self._s[354]! } public func UserInfo_BlockActionTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[354]!, self._r[354]!, [_0]) + return formatWithArgumentRanges(self._s[355]!, self._r[355]!, [_0]) } - public var 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[356]! } + public var ApplyLanguage_ApplySuccess: String { return self._s[357]! } + public var Tour_Title6: String { return self._s[358]! } + public var Map_ChooseAPlace: String { return self._s[359]! } + public var CallSettings_Never: String { return self._s[361]! } public func Notification_ChangedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[361]!, self._r[361]!, [_0]) + return formatWithArgumentRanges(self._s[362]!, self._r[362]!, [_0]) } - public var ChannelRemoved_RemoveInfo: String { return self._s[362]! } + public var ChannelRemoved_RemoveInfo: String { return self._s[363]! } public func AutoDownloadSettings_PreloadVideoInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[363]!, self._r[363]!, [_0]) + return formatWithArgumentRanges(self._s[364]!, self._r[364]!, [_0]) } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[364]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsExceptions: String { return self._s[365]! } public func Conversation_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[365]!, self._r[365]!, [_0]) + return formatWithArgumentRanges(self._s[366]!, self._r[366]!, [_0]) } - public var GroupInfo_InviteLink_Title: String { return self._s[366]! } + public var GroupInfo_InviteLink_Title: String { return self._s[367]! } 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[368]!, self._r[368]!, [_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[369]! } + public var ContactInfo_URLLabelHomepage: String { return self._s[370]! } + public var Channel_OwnershipTransfer_ChangeOwner: String { return self._s[371]! } public func Channel_AdminLog_DisabledSlowmode(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[371]!, self._r[371]!, [_0]) + return formatWithArgumentRanges(self._s[372]!, self._r[372]!, [_0]) } - public var TwoFactorSetup_Done_Title: String { return self._s[372]! } + public var TwoFactorSetup_Done_Title: String { return self._s[373]! } public func Conversation_EncryptedPlaceholderTitleOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[373]!, self._r[373]!, [_0]) + return formatWithArgumentRanges(self._s[374]!, self._r[374]!, [_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 CallFeedback_ReasonDistortedSpeech: String { return self._s[375]! } + public var Watch_LastSeen_WithinAWeek: String { return self._s[376]! } + public var ContactList_Context_SendMessage: String { return self._s[378]! } + public var Weekday_Tuesday: String { return self._s[379]! } + public var Wallet_Created_Title: String { return self._s[381]! } + public var ScheduledMessages_Delete: String { return self._s[382]! } + public var UserInfo_StartSecretChat: String { return self._s[383]! } + public var Passport_Identity_FilesTitle: String { return self._s[384]! } + public var Permissions_NotificationsAllow_v0: String { return self._s[385]! } + public var DialogList_DeleteConversationConfirmation: String { return self._s[387]! } + public var ChatList_UndoArchiveRevealedTitle: String { return self._s[388]! } public func Wallet_Configuration_ApplyErrorTextURLUnreachable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[388]!, self._r[388]!, [_0]) + return formatWithArgumentRanges(self._s[389]!, self._r[389]!, [_0]) } - public var AuthSessions_Sessions: String { return self._s[389]! } + public var AuthSessions_Sessions: String { return self._s[390]! } public func Settings_KeepPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[391]!, self._r[391]!, [_0]) + return formatWithArgumentRanges(self._s[392]!, self._r[392]!, [_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[393]! } + public var Call_StatusWaiting: String { return self._s[394]! } + public var CreateGroup_SoftUserLimitAlert: String { return self._s[395]! } + public var FastTwoStepSetup_HintHelp: String { return self._s[396]! } + public var WallpaperPreview_CustomColorBottomText: String { return self._s[397]! } + public var EditTheme_Expand_Preview_OutgoingText: String { return self._s[398]! } + public var LogoutOptions_AddAccountText: String { return self._s[399]! } + public var PasscodeSettings_6DigitCode: String { return self._s[400]! } + public var Settings_LogoutConfirmationText: String { return self._s[401]! } + public var Passport_Identity_TypePassport: String { return self._s[403]! } + public var Map_Work: String { return self._s[406]! } 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[407]!, self._r[407]!, [_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[408]! } + public var AccessDenied_SaveMedia: String { return self._s[409]! } + public var Checkout_ErrorInvoiceAlreadyPaid: String { return self._s[411]! } + public var CreatePoll_MultipleChoice: String { return self._s[412]! } + public var Settings_Title: String { return self._s[414]! } + public var VoiceOver_Chat_RecordModeVideoMessageInfo: String { return self._s[415]! } + public var Contacts_InviteSearchLabel: String { return self._s[417]! } + public var PrivacySettings_WebSessions: String { return self._s[418]! } + public var ConvertToSupergroup_Title: String { return self._s[419]! } public func Channel_AdminLog_CaptionEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[419]!, self._r[419]!, [_0]) + return formatWithArgumentRanges(self._s[420]!, self._r[420]!, [_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[421]! } + public var InfoPlist_NSSiriUsageDescription: String { return self._s[422]! } 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[423]!, self._r[423]!, [_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[424]! } + public var UserInfo_BotHelp: String { return self._s[425]! } + public var PrivacySettings_LastSeenEverybody: String { return self._s[426]! } + public var Checkout_Name: String { return self._s[427]! } + public var AutoDownloadSettings_DataUsage: String { return self._s[428]! } + public var Channel_BanUser_BlockFor: String { return self._s[429]! } + public var Checkout_ShippingAddress: String { return self._s[430]! } + public var AutoDownloadSettings_MaxVideoSize: String { return self._s[431]! } + public var Privacy_PaymentsClearInfoDoneHelp: String { return self._s[432]! } + public var Privacy_Forwards: String { return self._s[433]! } + public var Channel_BanUser_PermissionSendPolls: String { return self._s[434]! } + public var Appearance_ThemeCarouselNewNight: String { return self._s[435]! } public func SecretVideo_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[437]!, self._r[437]!, [_0]) + return formatWithArgumentRanges(self._s[438]!, self._r[438]!, [_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[439]! } + public var Group_OwnershipTransfer_Title: String { return self._s[440]! } + public var PeerInfo_BioExpand: String { return self._s[442]! } + public var VoiceOver_Chat_OpenHint: String { return self._s[443]! } + public var Group_LeaveGroup: String { return self._s[444]! } + public var Settings_UsernameEmpty: String { return self._s[445]! } public func Notification_PinnedPollMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[445]!, self._r[445]!, [_0]) + return formatWithArgumentRanges(self._s[446]!, self._r[446]!, [_0]) } public func TwoStepAuth_ConfirmEmailDescription(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[446]!, self._r[446]!, [_1]) + return formatWithArgumentRanges(self._s[447]!, self._r[447]!, [_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[448]!, self._r[448]!, [_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[449]! } + public var TwoStepAuth_RecoveryFailed: String { return self._s[451]! } + public var EditTheme_Edit_Preview_OutgoingText: String { return self._s[452]! } + public var UserInfo_AddToExisting: String { return self._s[453]! } + public var TwoStepAuth_EnabledSuccess: String { return self._s[454]! } + public var Wallet_Send_SyncInProgress: String { return self._s[455]! } + public var ChatListFolderSettings_RecommendedFoldersSection: String { return self._s[456]! } + public var ChatListFolder_IncludeSectionInfo: String { return self._s[457]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_SetColor: String { return self._s[458]! } public func PUSH_CHANNEL_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[458]!, self._r[458]!, [_1]) + return formatWithArgumentRanges(self._s[459]!, self._r[459]!, [_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[460]! } + public var Passport_Language_km: String { return self._s[461]! } + public var SocksProxySetup_AdNoticeHelp: String { return self._s[463]! } + public var VoiceOver_Media_PlaybackPlay: String { return self._s[464]! } + public var Notification_CallMissedShort: String { return self._s[465]! } + public var Wallet_Info_YourBalance: String { return self._s[466]! } + public var ReportPeer_ReasonOther_Send: String { return self._s[468]! } + public var Watch_Compose_Send: String { return self._s[469]! } + public var Passport_Identity_TypeInternalPassportUploadScan: String { return self._s[472]! } + public var TwoFactorSetup_Email_Action: String { return self._s[473]! } + public var Conversation_HoldForVideo: String { return self._s[474]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalidData: String { return self._s[475]! } + public var AuthSessions_OtherDevices: String { return self._s[476]! } + public var Wallet_TransactionInfo_CommentHeader: String { return self._s[477]! } + public var CheckoutInfo_ErrorCityInvalid: String { return self._s[479]! } + public var Appearance_AutoNightThemeDisabled: String { return self._s[481]! } + public var Channel_LinkItem: String { return self._s[482]! } 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[483]!, self._r[483]!, [_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[486]!, self._r[486]!, [_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[487]! } + public var Passport_Language_dv: String { return self._s[488]! } + public var Undo_LeftChannel: String { return self._s[489]! } + public var Notifications_ExceptionsMuted: String { return self._s[490]! } + public var ChatList_UnhideAction: String { return self._s[491]! } + public var Conversation_ContextMenuShare: String { return self._s[492]! } + public var Conversation_ContextMenuStickerPackInfo: String { return self._s[493]! } + public var ShareFileTip_Title: String { return self._s[494]! } + public var NotificationsSound_Chord: String { return self._s[495]! } + public var Wallet_TransactionInfo_OtherFeeHeader: String { return self._s[496]! } 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[497]!, self._r[497]!, [_1, _2]) } - public var Passport_Address_EditTemporaryRegistration: String { return self._s[497]! } + public var Passport_Address_EditTemporaryRegistration: String { return self._s[498]! } public func Notification_Joined(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[498]!, self._r[498]!, [_0]) + return formatWithArgumentRanges(self._s[499]!, self._r[499]!, [_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[500]!, self._r[500]!, [_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[501]! } + public var Wallpaper_ErrorNotFound: String { return self._s[502]! } + public var Notification_CallOutgoingShort: String { return self._s[504]! } + public var Wallet_WordImport_IncorrectText: String { return self._s[505]! } 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[506]!, self._r[506]!, [_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[507]! } + public var Privacy_Forwards_LinkIfAllowed: String { return self._s[508]! } + public var ReportPeer_Report: String { return self._s[509]! } + public var SettingsSearch_Synonyms_Proxy_Title: String { return self._s[510]! } + public var GroupInfo_DeactivatedStatus: String { return self._s[511]! } 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[512]!, self._r[512]!, [_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[513]! } + public var Login_CodeSentInternal: String { return self._s[514]! } + public var Wallet_Month_GenJanuary: String { return self._s[515]! } + public var GroupInfo_InviteLink_LinkSection: String { return self._s[516]! } public func Channel_AdminLog_MessageDeleted(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[516]!, self._r[516]!, [_0]) + return formatWithArgumentRanges(self._s[517]!, self._r[517]!, [_0]) } public func Conversation_EncryptionWaiting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[518]!, self._r[518]!, [_0]) + return formatWithArgumentRanges(self._s[519]!, self._r[519]!, [_0]) } - public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[519]! } + public var Channel_BanUser_PermissionSendStickersAndGifs: String { return self._s[520]! } public func PUSH_PINNED_GAME(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[520]!, self._r[520]!, [_1]) + return formatWithArgumentRanges(self._s[521]!, self._r[521]!, [_1]) } - 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 ReportPeer_ReasonViolence: String { return self._s[523]! } + public var Appearance_ShareThemeColor: String { return self._s[524]! } + public var Map_Locating: String { return self._s[525]! } public func VoiceOver_Chat_VideoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[525]!, self._r[525]!, [_0]) + return formatWithArgumentRanges(self._s[526]!, self._r[526]!, [_0]) } public func PUSH_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[526]!, self._r[526]!, [_1]) + return formatWithArgumentRanges(self._s[527]!, self._r[527]!, [_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[528]! } + public var AutoDownloadSettings_GroupChats: String { return self._s[530]! } + public var CheckoutInfo_SaveInfo: String { return self._s[531]! } + public var ChatList_ChatTypesSection: String { return self._s[532]! } + public var SharedMedia_EmptyLinksText: String { return self._s[534]! } + public var Passport_Address_CityPlaceholder: String { return self._s[535]! } + public var CheckoutInfo_ErrorStateInvalid: String { return self._s[536]! } + public var Privacy_ProfilePhoto_CustomHelp: String { return self._s[537]! } + public var Wallet_Send_OwnAddressAlertTitle: String { return self._s[539]! } + public var Channel_AdminLog_CanAddAdmins: String { return self._s[540]! } public func PUSH_CHANNEL_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[540]!, self._r[540]!, [_1]) + return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_1]) } public func Time_MonthOfYear_m8(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[541]!, self._r[541]!, [_0]) + return formatWithArgumentRanges(self._s[542]!, self._r[542]!, [_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[543]! } + public var GroupInfo_InviteLink_RevokeAlert_Success: String { return self._s[544]! } + public var ChangePhoneNumberCode_Code: String { return self._s[545]! } + public var Appearance_CreateTheme: String { return self._s[546]! } public func UserInfo_NotificationsDefaultSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[546]!, self._r[546]!, [_0]) + return formatWithArgumentRanges(self._s[547]!, self._r[547]!, [_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[548]! } + public var HashtagSearch_AllChats: String { return self._s[549]! } + public var MediaPlayer_UnknownTrack: String { return self._s[550]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingCellular: String { return self._s[552]! } public func ChatList_DeleteForEveryone(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[552]!, self._r[552]!, [_0]) + return formatWithArgumentRanges(self._s[553]!, self._r[553]!, [_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[554]! } + public var PhotoEditor_QualityHigh: String { return self._s[556]! } public func Passport_Phone_UseTelegramNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[556]!, self._r[556]!, [_0]) + return formatWithArgumentRanges(self._s[557]!, self._r[557]!, [_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[558]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsPreview: String { return self._s[559]! } + public var Message_LiveLocation: String { return self._s[560]! } + public var Cache_LowDiskSpaceText: String { return self._s[561]! } + public var Wallet_Receive_ShareAddress: String { return self._s[562]! } + public var EditTheme_ErrorLinkTaken: String { return self._s[564]! } + public var Conversation_SendMessage: String { return self._s[565]! } + public var AuthSessions_EmptyTitle: String { return self._s[566]! } + public var Privacy_PhoneNumber: String { return self._s[567]! } + public var PeopleNearby_CreateGroup: String { return self._s[568]! } + public var Stats_SharesPerPost: String { return self._s[570]! } + public var CallSettings_UseLessData: String { return self._s[571]! } + public var NetworkUsageSettings_MediaDocumentDataSection: String { return self._s[572]! } + public var Stickers_AddToFavorites: String { return self._s[573]! } + public var Wallet_WordImport_Title: String { return self._s[574]! } + public var PhotoEditor_QualityLow: String { return self._s[575]! } + public var Watch_UserInfo_Unblock: String { return self._s[576]! } + public var Settings_Logout: String { return self._s[577]! } public func PUSH_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[577]!, self._r[577]!, [_1]) + return formatWithArgumentRanges(self._s[578]!, self._r[578]!, [_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[579]! } + public var ChannelInfo_Stats: String { return self._s[580]! } + public var TextFormat_Link: String { return self._s[581]! } 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[582]!, self._r[582]!, [_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[583]! } + public var Wallet_TransactionInfo_Title: String { return self._s[584]! } public func Message_ForwardedMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[584]!, self._r[584]!, [_0]) + return formatWithArgumentRanges(self._s[585]!, self._r[585]!, [_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[586]! } + public var Group_Setup_TypePublicHelp: String { return self._s[587]! } + public var Passport_Scans_UploadNew: String { return self._s[588]! } + public var Checkout_LiabilityAlertTitle: String { return self._s[589]! } + public var DialogList_Title: String { return self._s[592]! } + public var NotificationSettings_ContactJoined: String { return self._s[593]! } + public var GroupInfo_LabelAdmin: String { return self._s[594]! } + public var KeyCommand_ChatInfo: String { return self._s[595]! } + public var Conversation_EditingCaptionPanelTitle: String { return self._s[596]! } + public var Call_ReportIncludeLog: String { return self._s[597]! } public func Notifications_ExceptionsChangeSound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[599]!, self._r[599]!, [_0]) + return formatWithArgumentRanges(self._s[600]!, self._r[600]!, [_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[601]! } + public var Channel_AdminLog_InfoPanelChannelAlertText: String { return self._s[602]! } + public var ChatAdmins_AllMembersAreAdmins: String { return self._s[603]! } + public var LocalGroup_IrrelevantWarning: String { return self._s[604]! } + public var Conversation_DefaultRestrictedInline: String { return self._s[605]! } + public var Message_Sticker: String { return self._s[606]! } + public var LastSeen_JustNow: String { return self._s[608]! } + public var Passport_Email_EmailPlaceholder: String { return self._s[610]! } + public var SettingsSearch_Synonyms_AppLanguage: String { return self._s[611]! } + public var Channel_AdminLogFilter_EventsEditedMessages: String { return self._s[613]! } + public var Channel_EditAdmin_PermissionsHeader: String { return self._s[614]! } + public var TwoStepAuth_Email: String { return self._s[615]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsSound: String { return self._s[616]! } + public var PhotoEditor_BlurToolOff: String { return self._s[617]! } + public var Message_PinnedStickerMessage: String { return self._s[618]! } + public var ContactInfo_PhoneLabelPager: String { return self._s[619]! } + public var SettingsSearch_Synonyms_Appearance_TextSize: String { return self._s[620]! } + public var Passport_DiscardMessageTitle: String { return self._s[621]! } + public var Privacy_PaymentsTitle: String { return self._s[622]! } + public var EditTheme_Edit_Preview_IncomingReplyName: String { return self._s[623]! } + public var ClearCache_StorageCache: String { return self._s[624]! } + public var Appearance_TextSizeSetting: String { return self._s[625]! } + public var Channel_DiscussionGroup_Header: String { return self._s[627]! } + public var VoiceOver_Chat_OptionSelected: String { return self._s[628]! } + public var Appearance_ColorTheme: String { return self._s[629]! } + public var UserInfo_ShareContact: String { return self._s[630]! } + public var Passport_Address_TypePassportRegistration: String { return self._s[631]! } + public var Common_More: String { return self._s[632]! } + public var Watch_Message_Call: String { return self._s[633]! } + public var Profile_EncryptionKey: String { return self._s[636]! } + public var Privacy_TopPeers: String { return self._s[637]! } + public var Conversation_StopPollConfirmation: String { return self._s[638]! } + public var Wallet_Words_NotDoneText: String { return self._s[640]! } + public var Privacy_TopPeersWarning: String { return self._s[642]! } + public var SettingsSearch_Synonyms_Data_DownloadInBackground: String { return self._s[643]! } + public var SettingsSearch_Synonyms_Data_Storage_KeepMedia: String { return self._s[644]! } + public var Media_SendWithTimer: String { return self._s[647]! } + public var Wallet_RestoreFailed_EnterWords: String { return self._s[648]! } + public var DialogList_SearchSectionMessages: String { return self._s[649]! } + public var ChatList_Context_AddToFolder: String { return self._s[650]! } + public var Notifications_ChannelNotifications: String { return self._s[651]! } + public var CheckoutInfo_ShippingInfoAddress1Placeholder: String { return self._s[652]! } + public var Passport_Language_sk: String { return self._s[653]! } + public var Notification_MessageLifetime1h: String { return self._s[654]! } + public var Wallpaper_ResetWallpapersInfo: String { return self._s[655]! } + public var Appearance_ThemePreview_Chat_5_Text: String { return self._s[656]! } + public var PeerInfo_PaneGifs: String { return self._s[657]! } + public var Call_ReportSkip: String { return self._s[659]! } + public var Cache_ServiceFiles: String { return self._s[660]! } + public var Group_ErrorAddTooMuchAdmins: String { return self._s[661]! } + public var VoiceOver_Chat_YourFile: String { return self._s[662]! } + public var Map_Hybrid: String { return self._s[663]! } + public var Contacts_SearchUsersAndGroupsLabel: String { return self._s[665]! } public func PUSH_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[665]!, self._r[665]!, [_1]) + return formatWithArgumentRanges(self._s[666]!, self._r[666]!, [_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[668]! } + public var Channel_BanUser_PermissionEmbedLinks: String { return self._s[669]! } + public var InfoPlist_NSLocationAlwaysAndWhenInUseUsageDescription: String { return self._s[670]! } + public var SocksProxySetup_ProxyTelegram: String { return self._s[673]! } public func PUSH_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[673]!, self._r[673]!, [_1]) + return formatWithArgumentRanges(self._s[674]!, self._r[674]!, [_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[676]! } + public var ScheduledMessages_ScheduledToday: String { return self._s[677]! } 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[678]!, self._r[678]!, [_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[679]! } + public var SettingsSearch_Synonyms_Privacy_Calls: String { return self._s[680]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsPreview: String { return self._s[681]! } + public var UserInfo_ShareBot: String { return self._s[684]! } 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[685]!, self._r[685]!, [_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[686]! } + public var PhotoEditor_ShadowsTint: String { return self._s[687]! } + public var ChatListFolderSettings_EditFoldersInfo: String { return self._s[688]! } + public var Message_Audio: String { return self._s[689]! } + public var Passport_Language_lt: String { return self._s[690]! } public func Message_PinnedTextMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[690]!, self._r[690]!, [_0]) + return formatWithArgumentRanges(self._s[691]!, self._r[691]!, [_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[692]! } + public var Conversation_FileICloudDrive: String { return self._s[693]! } + public var ChatList_DeleteForEveryoneConfirmationTitle: String { return self._s[694]! } + public var Notifications_Badge_IncludeMutedChats: String { return self._s[695]! } 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[696]!, self._r[696]!, [_1, _2, _3, _4, _5, _6]) } - public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[696]! } + public var DialogList_ProxyConnectionIssuesTooltip: String { return self._s[697]! } public func Time_MonthOfYear_m5(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[697]!, self._r[697]!, [_0]) + return formatWithArgumentRanges(self._s[698]!, self._r[698]!, [_0]) } - public var Channel_SignMessages: String { return self._s[698]! } + public var Channel_SignMessages: String { return self._s[699]! } public func PUSH_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[699]!, self._r[699]!, [_1]) + return formatWithArgumentRanges(self._s[700]!, self._r[700]!, [_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[701]! } + public var Passport_ScanPassport: String { return self._s[702]! } + public var Watch_Suggestion_Thanks: String { return self._s[703]! } + public var BlockedUsers_AddNew: String { return self._s[704]! } 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[705]!, self._r[705]!, [_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[706]! } + public var SettingsSearch_Synonyms_Privacy_LastSeen: String { return self._s[707]! } + public var Month_GenJuly: String { return self._s[708]! } + public var CreatePoll_QuizInfo: String { return self._s[709]! } + public var UserInfo_StartSecretChatStart: String { return self._s[710]! } + public var SocksProxySetup_ProxySocks5: String { return self._s[711]! } + public var IntentsSettings_SuggestByShare: String { return self._s[713]! } + public var Notification_Exceptions_DeleteAllConfirmation: String { return self._s[714]! } + public var Notification_ChannelInviterSelf: String { return self._s[715]! } + public var CheckoutInfo_ReceiverInfoEmail: String { return self._s[716]! } 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[717]!, self._r[717]!, [_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[718]! } + public var CheckoutInfo_Title: String { return self._s[719]! } + public var Watch_Stickers_RecentPlaceholder: String { return self._s[720]! } public func Map_DistanceAway(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[720]!, self._r[720]!, [_0]) + return formatWithArgumentRanges(self._s[721]!, self._r[721]!, [_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[722]! } + public var TwoStepAuth_ConfirmEmailResendCode: String { return self._s[723]! } + public var Passport_Language_de: String { return self._s[724]! } + public var Update_Title: String { return self._s[725]! } + public var ContactInfo_PhoneLabelWorkFax: String { return self._s[726]! } + public var Channel_AdminLog_BanEmbedLinks: String { return self._s[727]! } + public var Passport_Email_UseTelegramEmailHelp: String { return self._s[728]! } + public var Notifications_ChannelNotificationsPreview: String { return self._s[729]! } + public var NotificationsSound_Telegraph: String { return self._s[730]! } + public var Watch_LastSeen_ALongTimeAgo: String { return self._s[731]! } + public var ChannelMembers_WhoCanAddMembers: String { return self._s[732]! } public func AutoDownloadSettings_UpTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[732]!, self._r[732]!, [_0]) + return formatWithArgumentRanges(self._s[733]!, self._r[733]!, [_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[734]! } + public var Stickers_SuggestAll: String { return self._s[735]! } + public var Conversation_ForwardTitle: String { return self._s[736]! } + public var Appearance_ThemePreview_ChatList_7_Name: String { return self._s[737]! } public func Notification_JoinedChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[737]!, self._r[737]!, [_0]) + return formatWithArgumentRanges(self._s[738]!, self._r[738]!, [_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[739]! } + public var Call_StatusEnded: String { return self._s[740]! } + public var AutoDownloadSettings_DataUsageLow: String { return self._s[741]! } + public var Settings_ProxyConnected: String { return self._s[742]! } + public var Channel_AdminLogFilter_EventsPinned: String { return self._s[743]! } + public var PhotoEditor_QualityVeryLow: String { return self._s[744]! } + public var Channel_AdminLogFilter_EventsDeletedMessages: String { return self._s[745]! } + public var Passport_PasswordPlaceholder: String { return self._s[746]! } + public var Message_PinnedInvoice: String { return self._s[747]! } + public var Passport_Identity_IssueDate: String { return self._s[748]! } + public var Passport_Language_pl: String { return self._s[749]! } public func ChannelInfo_ChannelForbidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[749]!, self._r[749]!, [_0]) + return formatWithArgumentRanges(self._s[750]!, self._r[750]!, [_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[751]! } + public var SocksProxySetup_PasteFromClipboard: String { return self._s[752]! } public func Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[752]!, self._r[752]!, [_0]) + return formatWithArgumentRanges(self._s[753]!, self._r[753]!, [_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[755]! } + public var Common_Edit: String { return self._s[756]! } + public var PrivacySettings_LastSeenNobody: String { return self._s[757]! } public func Notification_LeftChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[757]!, self._r[757]!, [_0]) + return formatWithArgumentRanges(self._s[758]!, self._r[758]!, [_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[759]! } + public var PrivateDataSettings_Title: String { return self._s[760]! } + public var Login_CancelPhoneVerificationStop: String { return self._s[761]! } + public var ChatList_Read: String { return self._s[762]! } + public var Wallet_WordImport_Text: String { return self._s[763]! } + public var Undo_ChatClearedForBothSides: String { return self._s[764]! } + public var ChatListFolder_AddChats: String { return self._s[765]! } + public var GroupPermission_SectionTitle: String { return self._s[766]! } + public var TwoFactorSetup_Intro_Title: String { return self._s[768]! } 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[769]!, self._r[769]!, [_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[770]! } + public var Update_UpdateApp: String { return self._s[772]! } + public var Group_Username_RevokeExistingUsernamesInfo: String { return self._s[773]! } + public var Settings_Appearance: String { return self._s[774]! } + public var SettingsSearch_Synonyms_Stickers_SuggestStickers: String { return self._s[778]! } + public var Watch_Location_Access: String { return self._s[779]! } + public var ShareMenu_CopyShareLink: String { return self._s[781]! } + public var TwoStepAuth_SetupHintTitle: String { return self._s[782]! } + public var Conversation_Theme: String { return self._s[784]! } public func DialogList_SingleRecordingVideoMessageSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[784]!, self._r[784]!, [_0]) + return formatWithArgumentRanges(self._s[785]!, self._r[785]!, [_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[786]! } + public var Weekday_ShortWednesday: String { return self._s[787]! } + public var WallpaperPreview_SwipeColorsBottomText: String { return self._s[788]! } + public var Undo_LeftGroup: String { return self._s[791]! } + public var ChatListFolder_DiscardCancel: String { return self._s[792]! } + public var Wallet_RestoreFailed_Text: String { return self._s[793]! } + public var Conversation_LinkDialogCopy: String { return self._s[794]! } + public var Wallet_TransactionInfo_NoAddress: String { return self._s[796]! } + public var Wallet_Navigation_Back: String { return self._s[797]! } + public var KeyCommand_FocusOnInputField: String { return self._s[798]! } + public var Contacts_SelectAll: String { return self._s[799]! } + public var Preview_SaveToCameraRoll: String { return self._s[800]! } + public var PrivacySettings_PasscodeOff: String { return self._s[801]! } + public var Appearance_ThemePreview_ChatList_6_Name: String { return self._s[802]! } public func PUSH_CHANNEL_MESSAGE_QUIZ(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[802]!, self._r[802]!, [_1]) + return formatWithArgumentRanges(self._s[803]!, self._r[803]!, [_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[804]! } + public var Conversation_FilePhotoOrVideo: String { return self._s[805]! } + public var AccessDenied_Camera: String { return self._s[806]! } + public var Watch_Compose_CurrentLocation: String { return self._s[807]! } + public var PeerInfo_ButtonMessage: String { return self._s[809]! } + public var Channel_DiscussionGroup_MakeHistoryPublicProceed: String { return self._s[810]! } public func SecretImage_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[810]!, self._r[810]!, [_0]) + return formatWithArgumentRanges(self._s[811]!, self._r[811]!, [_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[812]! } + public var Passport_Language_ro: String { return self._s[813]! } + public var EditTheme_UploadNewTheme: String { return self._s[814]! } + public var CheckoutInfo_SaveInfoHelp: String { return self._s[815]! } + public var Wallet_Intro_Terms: String { return self._s[816]! } public func Notification_SecretChatMessageScreenshot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[816]!, self._r[816]!, [_0]) + return formatWithArgumentRanges(self._s[817]!, self._r[817]!, [_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[818]! } + public var State_ConnectingToProxy: String { return self._s[819]! } + public var Calls_RatingTitle: String { return self._s[820]! } + public var Generic_ErrorMoreInfo: String { return self._s[821]! } + public var ChatList_Search_ShowMore: String { return self._s[822]! } + public var Appearance_PreviewReplyText: String { return self._s[823]! } + public var CheckoutInfo_ShippingInfoPostcodePlaceholder: String { return self._s[824]! } public func Wallet_Send_Balance(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[824]!, self._r[824]!, [_0]) + return formatWithArgumentRanges(self._s[825]!, self._r[825]!, [_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[826]! } + public var SharedMedia_CategoryLinks: String { return self._s[827]! } + public var Calls_Missed: String { return self._s[828]! } + public var Cache_Photos: String { return self._s[832]! } + public var GroupPermission_NoAddMembers: String { return self._s[833]! } + public var ScheduledMessages_Title: String { return self._s[834]! } public func Channel_AdminLog_MessageUnpinned(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[834]!, self._r[834]!, [_0]) + return formatWithArgumentRanges(self._s[835]!, self._r[835]!, [_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[836]! } + public var Settings_ProxyDisabled: String { return self._s[837]! } 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[838]!, self._r[838]!, [_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[839]!, self._r[839]!, [_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[841]! } + public var ChatList_Context_RemoveFromRecents: String { return self._s[842]! } + public var Appearance_Title: String { return self._s[843]! } public func Time_MonthOfYear_m2(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[844]!, self._r[844]!, [_0]) + return formatWithArgumentRanges(self._s[845]!, self._r[845]!, [_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[846]! } + public var StickerPacksSettings_ShowStickersButtonHelp: String { return self._s[847]! } + public var OldChannels_NoticeCreateText: String { return self._s[848]! } + public var Channel_EditMessageErrorGeneric: String { return self._s[849]! } + public var Privacy_Calls_IntegrationHelp: String { return self._s[850]! } + public var Preview_DeletePhoto: String { return self._s[851]! } + public var Appearance_AppIconFilledX: String { return self._s[852]! } + public var PrivacySettings_PrivacyTitle: String { return self._s[853]! } public func Conversation_BotInteractiveUrlAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[853]!, self._r[853]!, [_0]) + return formatWithArgumentRanges(self._s[854]!, self._r[854]!, [_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[857]! } + public var MuteFor_Forever: String { return self._s[858]! } + public var Coub_TapForSound: String { return self._s[859]! } + public var Map_LocatingError: String { return self._s[860]! } + public var TwoStepAuth_EmailChangeSuccess: String { return self._s[862]! } + public var Conversation_SendMessage_SendSilently: String { return self._s[863]! } + public var VoiceOver_MessageContextOpenMessageMenu: String { return self._s[864]! } 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[865]!, self._r[865]!, [_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[866]! } + public var GroupInfo_InviteLink_RevokeLink: String { return self._s[867]! } + public var StickerPacksSettings_ArchivedPacks: String { return self._s[868]! } + public var Login_TermsOfServiceSignupDecline: String { return self._s[870]! } + public var Channel_Moderator_AccessLevelRevoke: String { return self._s[871]! } + public var Message_Location: String { return self._s[872]! } + public var Passport_Identity_NamePlaceholder: String { return self._s[873]! } + public var Channel_Management_Title: String { return self._s[874]! } + public var DialogList_SearchSectionDialogs: String { return self._s[876]! } + public var Compose_NewChannel_Members: String { return self._s[877]! } public func DialogList_SingleUploadingFileSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[877]!, self._r[877]!, [_0]) + return formatWithArgumentRanges(self._s[878]!, self._r[878]!, [_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[879]! } + public var Appearance_ThemePreview_ChatList_5_Name: String { return self._s[880]! } + public var ClearCache_Clear: String { return self._s[881]! } + public var InstantPage_FeedbackButtonShort: String { return self._s[882]! } + public var AutoNightTheme_ScheduledFrom: String { return self._s[883]! } + public var PhotoEditor_WarmthTool: String { return self._s[884]! } + public var Passport_Language_tr: String { return self._s[885]! } 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[886]!, self._r[886]!, [_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[887]! } + public var Login_ResetAccountProtected_Reset: String { return self._s[889]! } + public var Watch_PhotoView_Title: String { return self._s[890]! } + public var Passport_Phone_Delete: String { return self._s[891]! } + public var Undo_ChatDeletedForBothSides: String { return self._s[892]! } + public var Conversation_EditingMessageMediaEditCurrentPhoto: String { return self._s[893]! } + public var GroupInfo_Permissions: String { return self._s[894]! } + public var PasscodeSettings_TurnPasscodeOff: String { return self._s[895]! } + public var Profile_ShareContactButton: String { return self._s[896]! } + public var ChatSettings_Other: String { return self._s[897]! } + public var UserInfo_NotificationsDisabled: String { return self._s[898]! } + public var CheckoutInfo_ShippingInfoCity: String { return self._s[899]! } + public var LastSeen_WithinAMonth: String { return self._s[900]! } + public var VoiceOver_Chat_PlayHint: String { return self._s[901]! } + public var Conversation_ReportGroupLocation: String { return self._s[902]! } + public var Conversation_EncryptionCanceled: String { return self._s[903]! } + public var MediaPicker_GroupDescription: String { return self._s[904]! } + public var WebSearch_Images: String { return self._s[905]! } public func Channel_Management_PromotedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[905]!, self._r[905]!, [_0]) + return formatWithArgumentRanges(self._s[906]!, self._r[906]!, [_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[907]! } + public var PasscodeSettings_HelpBottom: String { return self._s[908]! } + public var AutoDownloadSettings_VideosTitle: String { return self._s[909]! } + public var VoiceOver_Media_PlaybackRateChange: String { return self._s[910]! } + public var Passport_Identity_AddDriversLicense: String { return self._s[911]! } + public var TwoStepAuth_EnterPasswordPassword: String { return self._s[912]! } + public var NotificationsSound_Calypso: String { return self._s[913]! } + public var Map_Map: String { return self._s[914]! } public func Conversation_LiveLocationYouAndOther(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[914]!, self._r[914]!, [_0]) + return formatWithArgumentRanges(self._s[915]!, self._r[915]!, [_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[917]! } + public var ChatSettings_TextSizeUnits: String { return self._s[918]! } public func VoiceOver_Chat_FileFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[918]!, self._r[918]!, [_0]) + return formatWithArgumentRanges(self._s[919]!, self._r[919]!, [_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[920]! } + public var Conversation_ForwardContacts: String { return self._s[923]! } + public var IntentsSettings_SuggestByAll: String { return self._s[925]! } public func Call_AnsweringWithAccount(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[925]!, self._r[925]!, [_0]) + return formatWithArgumentRanges(self._s[926]!, self._r[926]!, [_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[927]! } + public var Notifications_MessageNotificationsHelp: String { return self._s[928]! } + public var AutoDownloadSettings_Reset: String { return self._s[929]! } + public var Wallet_TransactionInfo_AddressCopied: String { return self._s[930]! } + public var Paint_ClearConfirm: String { return self._s[931]! } + public var Camera_VideoMode: String { return self._s[932]! } public func Conversation_RestrictedStickersTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[932]!, self._r[932]!, [_0]) + return formatWithArgumentRanges(self._s[933]!, self._r[933]!, [_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[934]! } + public var Conversation_ViewBackground: String { return self._s[935]! } 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[936]!, self._r[936]!, [_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[937]! } + public var PhotoEditor_Original: String { return self._s[938]! } + public var Settings_FAQ_Button: String { return self._s[940]! } + public var Channel_Setup_PublicNoLink: String { return self._s[942]! } + public var Conversation_UnsupportedMedia: String { return self._s[943]! } + public var Conversation_SlideToCancel: String { return self._s[944]! } + public var Appearance_ThemePreview_ChatList_4_Name: String { return self._s[945]! } + public var Passport_Identity_OneOfTypeInternalPassport: String { return self._s[946]! } + public var CheckoutInfo_ShippingInfoPostcode: String { return self._s[947]! } + public var Conversation_ReportSpamChannelConfirmation: String { return self._s[948]! } + public var AutoNightTheme_NotAvailable: String { return self._s[949]! } + public var Conversation_Owner: String { return self._s[950]! } + public var Common_Create: String { return self._s[951]! } + public var Settings_ApplyProxyAlertEnable: String { return self._s[952]! } + public var ContactList_Context_Call: String { return self._s[953]! } + public var Localization_ChooseLanguage: String { return self._s[955]! } + public var ChatList_Context_AddToContacts: String { return self._s[957]! } + public var OldChannels_NoticeTitle: String { return self._s[958]! } + public var Settings_Proxy: String { return self._s[960]! } + public var Privacy_TopPeersHelp: String { return self._s[961]! } + public var CheckoutInfo_ShippingInfoCountryPlaceholder: String { return self._s[962]! } + public var Chat_UnsendMyMessages: String { return self._s[963]! } public func VoiceOver_Chat_Duration(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[963]!, self._r[963]!, [_0]) + return formatWithArgumentRanges(self._s[964]!, self._r[964]!, [_0]) } - public var TwoStepAuth_ConfirmationAbort: String { return self._s[964]! } + public var TwoStepAuth_ConfirmationAbort: String { return self._s[965]! } public func Contacts_AccessDeniedHelpPortrait(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[966]!, self._r[966]!, [_0]) + return formatWithArgumentRanges(self._s[967]!, self._r[967]!, [_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[968]! } + public var Passport_Identity_SurnamePlaceholder: String { return self._s[969]! } + public var Cache_Title: String { return self._s[970]! } public func Login_PhoneBannedEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[970]!, self._r[970]!, [_0]) + return formatWithArgumentRanges(self._s[971]!, self._r[971]!, [_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[972]! } + public var Channel_Moderator_Title: String { return self._s[973]! } + public var InstantPage_AutoNightTheme: String { return self._s[975]! } public func PUSH_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[977]!, self._r[977]!, [_1]) + return formatWithArgumentRanges(self._s[978]!, self._r[978]!, [_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[979]! } + public var Undo_Undo: String { return self._s[981]! } + public var Contacts_AccessDeniedHelpON: String { return self._s[982]! } + public var TwoStepAuth_RemovePassword: String { return self._s[983]! } + public var Common_Delete: String { return self._s[984]! } + public var Contacts_AddPeopleNearby: String { return self._s[986]! } + public var Conversation_ContextMenuDelete: String { return self._s[987]! } + public var SocksProxySetup_Credentials: String { return self._s[988]! } + public var Appearance_EditTheme: String { return self._s[990]! } + public var ClearCache_StorageOtherApps: String { return self._s[991]! } + public var PasscodeSettings_AutoLock_Disabled: String { return self._s[993]! } + public var Wallet_Send_NetworkErrorText: String { return self._s[994]! } + public var AuthSessions_DevicesTitle: String { return self._s[996]! } + public var Passport_Address_OneOfTypeRentalAgreement: String { return self._s[998]! } + public var Conversation_ShareBotContactConfirmationTitle: String { return self._s[999]! } + public var Passport_Language_id: String { return self._s[1001]! } + public var Chat_Gifs_TrendingSectionHeader: String { return self._s[1002]! } + public var WallpaperSearch_ColorTeal: String { return self._s[1003]! } + public var ChannelIntro_Title: String { return self._s[1004]! } public func Channel_AdminLog_MessageToggleSignaturesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1004]!, self._r[1004]!, [_0]) + return formatWithArgumentRanges(self._s[1005]!, self._r[1005]!, [_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[1007]! } + public var VoiceOver_Chat_Reply: String { return self._s[1008]! } + public var ScheduledMessages_BotActionUnavailable: String { return self._s[1009]! } + public var Channel_Info_Description: String { return self._s[1010]! } + public var Stickers_FavoriteStickers: String { return self._s[1011]! } + public var Channel_BanUser_PermissionAddMembers: String { return self._s[1012]! } + public var Notifications_DisplayNamesOnLockScreen: String { return self._s[1013]! } + public var ChatSearch_ResultsTooltip: String { return self._s[1014]! } + public var Wallet_VoiceOver_Editing_ClearText: String { return self._s[1015]! } + public var Calls_NoMissedCallsPlacehoder: String { return self._s[1016]! } + public var Group_PublicLink_Placeholder: String { return self._s[1017]! } + public var Notifications_ExceptionsDefaultSound: String { return self._s[1018]! } public func PUSH_CHANNEL_MESSAGE_POLL(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1018]!, self._r[1018]!, [_1]) + return formatWithArgumentRanges(self._s[1019]!, self._r[1019]!, [_1]) } - public var TextFormat_Underline: String { return self._s[1019]! } + public var TextFormat_Underline: String { return self._s[1020]! } 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[1022]!, self._r[1022]!, [_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[1023]!, self._r[1023]!, [_0]) } - public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1023]! } + public var Appearance_ThemePreview_ChatList_3_Name: String { return self._s[1024]! } 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[1025]!, self._r[1025]!, [_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[1026]! } + public var GroupPermission_Delete: String { return self._s[1027]! } + public var Passport_Language_uk: String { return self._s[1028]! } + public var StickerPack_HideStickers: String { return self._s[1030]! } + public var ChangePhoneNumberNumber_NumberPlaceholder: String { return self._s[1031]! } 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[1032]!, self._r[1032]!, [_1, _2]) } - public var Activity_UploadingVideoMessage: String { return self._s[1032]! } + public var Activity_UploadingVideoMessage: String { return self._s[1033]! } public func GroupPermission_ApplyAlertText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1033]!, self._r[1033]!, [_0]) + return formatWithArgumentRanges(self._s[1034]!, self._r[1034]!, [_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[1035]! } + public var StickerPacksSettings_ArchivedPacks_Info: String { return self._s[1036]! } + public var Settings_CallSettings: String { return self._s[1037]! } + public var Camera_SquareMode: String { return self._s[1038]! } + public var Conversation_SendMessage_ScheduleMessage: String { return self._s[1039]! } + public var GroupInfo_SharedMediaNone: String { return self._s[1040]! } public func PUSH_MESSAGE_VIDEO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1040]!, self._r[1040]!, [_1]) + return formatWithArgumentRanges(self._s[1041]!, self._r[1041]!, [_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[1042]! } + public var Application_Update: String { return self._s[1044]! } + public var Month_ShortJanuary: String { return self._s[1045]! } + public var Contacts_PermissionsKeepDisabled: String { return self._s[1046]! } + public var Channel_AdminLog_BanReadMessages: String { return self._s[1047]! } + public var Settings_AppLanguage_Unofficial: String { return self._s[1048]! } + public var Passport_Address_Street2Placeholder: String { return self._s[1049]! } public func Map_LiveLocationShortHour(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1049]!, self._r[1049]!, [_0]) + return formatWithArgumentRanges(self._s[1050]!, self._r[1050]!, [_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[1051]! } + public var Appearance_PreviewOutgoingText: String { return self._s[1052]! } public func StickerPackActionInfo_RemovedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1052]!, self._r[1052]!, [_0]) + return formatWithArgumentRanges(self._s[1053]!, self._r[1053]!, [_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[1054]! } + public var AutoDownloadSettings_OnForAll: String { return self._s[1056]! } + public var Map_Directions: String { return self._s[1057]! } + public var Passport_FieldIdentityTranslationHelp: String { return self._s[1059]! } + public var Appearance_ThemeDay: String { return self._s[1060]! } + public var LogoutOptions_LogOut: String { return self._s[1061]! } + public var Group_PublicLink_Title: String { return self._s[1063]! } + public var Channel_AddBotErrorNoRights: String { return self._s[1064]! } + public var ChatList_Search_ShowLess: String { return self._s[1065]! } + public var Passport_Identity_AddPassport: String { return self._s[1066]! } + public var LocalGroup_ButtonTitle: String { return self._s[1067]! } + public var Stats_InteractionsTitle: String { return self._s[1068]! } + public var Call_Message: String { return self._s[1069]! } + public var PhotoEditor_ExposureTool: String { return self._s[1070]! } + public var Wallet_Receive_CommentInfo: String { return self._s[1072]! } + public var Passport_FieldOneOf_Delimeter: String { return self._s[1073]! } + public var Channel_AdminLog_CanBanUsers: String { return self._s[1075]! } + public var Appearance_ThemePreview_ChatList_2_Name: String { return self._s[1076]! } + public var Appearance_Preview: String { return self._s[1077]! } + public var Compose_ChannelMembers: String { return self._s[1078]! } + public var Conversation_DeleteManyMessages: String { return self._s[1079]! } + public var ReportPeer_ReasonOther_Title: String { return self._s[1080]! } + public var Checkout_ErrorProviderAccountTimeout: String { return self._s[1081]! } + public var TwoStepAuth_ResetAccountConfirmation: String { return self._s[1082]! } + public var Channel_Stickers_CreateYourOwn: String { return self._s[1085]! } + public var Conversation_UpdateTelegram: String { return self._s[1086]! } + public var EditTheme_Create_TopInfo: String { return self._s[1087]! } public func Notification_PinnedPhotoMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1087]!, self._r[1087]!, [_0]) + return formatWithArgumentRanges(self._s[1088]!, self._r[1088]!, [_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[1089]! } + public var TwoFactorSetup_Hint_Action: String { return self._s[1090]! } + public var IntentsSettings_ResetAll: String { return self._s[1091]! } public func PUSH_PINNED_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1091]!, self._r[1091]!, [_1]) + return formatWithArgumentRanges(self._s[1092]!, self._r[1092]!, [_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[1093]! } + public var GroupInfo_Administrators_Title: String { return self._s[1094]! } + public var Privacy_Forwards_PreviewMessageText: String { return self._s[1095]! } public func PrivacySettings_LastSeenNobodyPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1095]!, self._r[1095]!, [_0]) + return formatWithArgumentRanges(self._s[1096]!, self._r[1096]!, [_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[1097]! } + public var Channel_EditAdmin_PermissionInviteSubscribers: String { return self._s[1098]! } + public var Clipboard_SendPhoto: String { return self._s[1102]! } + public var MediaPicker_Videos: String { return self._s[1103]! } + public var Passport_Email_Title: String { return self._s[1104]! } public func PrivacySettings_LastSeenEverybodyMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1104]!, self._r[1104]!, [_0]) + return formatWithArgumentRanges(self._s[1105]!, self._r[1105]!, [_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[1106]! } + public var Conversation_MessageDialogDelete: String { return self._s[1107]! } + public var Privacy_Calls_CustomHelp: String { return self._s[1109]! } + public var Message_Wallpaper: String { return self._s[1110]! } + public var MemberSearch_BotSection: String { return self._s[1111]! } + public var GroupInfo_SetSound: String { return self._s[1112]! } + public var Wallet_Send_EncryptComment: String { return self._s[1113]! } public func Time_TomorrowAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1113]!, self._r[1113]!, [_0]) + return formatWithArgumentRanges(self._s[1114]!, self._r[1114]!, [_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[1115]! } + public var LiveLocationUpdated_JustNow: String { return self._s[1116]! } + public var Call_StatusFailed: String { return self._s[1117]! } + public var TwoFactorSetup_Email_Placeholder: String { return self._s[1118]! } + public var TwoStepAuth_SetupPasswordDescription: String { return self._s[1119]! } + public var TwoStepAuth_SetPassword: String { return self._s[1120]! } + public var Permissions_PeopleNearbyText_v0: String { return self._s[1121]! } public func SocksProxySetup_ProxyStatusPing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1122]!, self._r[1122]!, [_0]) + return formatWithArgumentRanges(self._s[1123]!, self._r[1123]!, [_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[1124]! } + public var Map_NoPlacesNearby: String { return self._s[1125]! } + public var Profile_Username: String { return self._s[1126]! } + public var Bot_DescriptionTitle: String { return self._s[1127]! } + public var MaskStickerSettings_Title: String { return self._s[1128]! } + public var SharedMedia_CategoryOther: String { return self._s[1129]! } + public var GroupInfo_SetGroupPhoto: String { return self._s[1130]! } + public var Common_NotNow: String { return self._s[1131]! } + public var CallFeedback_IncludeLogsInfo: String { return self._s[1132]! } + public var Conversation_ShareMyPhoneNumber: String { return self._s[1133]! } + public var Map_Location: String { return self._s[1134]! } + public var Invitation_JoinGroup: String { return self._s[1135]! } + public var AutoDownloadSettings_Title: String { return self._s[1137]! } + public var Conversation_DiscardVoiceMessageDescription: String { return self._s[1138]! } + public var Channel_ErrorAddBlocked: String { return self._s[1139]! } + public var ChatList_AddChatsToFolder: String { return self._s[1140]! } + public var Conversation_UnblockUser: String { return self._s[1141]! } + public var EditTheme_Edit_TopInfo: String { return self._s[1142]! } + public var Watch_Bot_Restart: String { return self._s[1143]! } + public var TwoStepAuth_Title: String { return self._s[1144]! } + public var Channel_AdminLog_BanSendMessages: String { return self._s[1145]! } + public var Checkout_ShippingMethod: String { return self._s[1146]! } + public var Passport_Identity_OneOfTypeIdentityCard: String { return self._s[1147]! } 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[1148]!, self._r[1148]!, [_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[1149]! } + public var EditTheme_ChangeColors: String { return self._s[1151]! } public func Chat_UnsendMyMessagesAlertTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1151]!, self._r[1151]!, [_0]) - } - public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1152]!, self._r[1152]!, [_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 func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1173]!, self._r[1173]!, [_1]) + public func Channel_Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1153]!, self._r[1153]!, [_0]) } - 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 Appearance_ThemePreview_ChatList_1_Name: String { return self._s[1154]! } + public var SettingsSearch_Synonyms_Data_AutoplayGifs: String { return self._s[1156]! } + public var AuthSessions_TerminateOtherSessions: String { return self._s[1157]! } + public var Contacts_FailedToSendInvitesMessage: String { return self._s[1158]! } + public var PrivacySettings_TwoStepAuth: String { return self._s[1159]! } + public var Notification_Exceptions_PreviewAlwaysOn: String { return self._s[1160]! } + public var SettingsSearch_Synonyms_Privacy_Passcode: String { return self._s[1161]! } + public var Conversation_EditingMessagePanelMedia: String { return self._s[1162]! } + public var Checkout_PaymentMethod_Title: String { return self._s[1163]! } + public var SocksProxySetup_Connection: String { return self._s[1164]! } + public var Group_MessagePhotoRemoved: String { return self._s[1165]! } + public var PeopleNearby_MakeInvisible: String { return self._s[1167]! } + public var Channel_Stickers_NotFound: String { return self._s[1169]! } + public var Group_About_Help: String { return self._s[1170]! } + public var Notification_PassportValueProofOfIdentity: String { return self._s[1171]! } + public var PeopleNearby_Title: String { return self._s[1173]! } + public func ApplyLanguage_ChangeLanguageOfficialText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1174]!, self._r[1174]!, [_1]) + } + public var Map_Home: String { return self._s[1175]! } + public var Stats_ZoomOut: String { return self._s[1176]! } + public var CheckoutInfo_ShippingInfoStatePlaceholder: String { return self._s[1178]! } + public var Notifications_GroupNotificationsExceptionsHelp: String { return self._s[1179]! } + public var SocksProxySetup_Password: String { return self._s[1180]! } + public var Notifications_PermissionsEnable: String { return self._s[1181]! } + public var TwoStepAuth_ChangeEmail: String { return self._s[1183]! } public func Channel_AdminLog_MessageInvitedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1183]!, self._r[1183]!, [_1]) + return formatWithArgumentRanges(self._s[1184]!, self._r[1184]!, [_1]) } public func Time_MonthOfYear_m10(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1185]!, self._r[1185]!, [_0]) + return formatWithArgumentRanges(self._s[1186]!, self._r[1186]!, [_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[1187]! } + public var ArchivedPacksAlert_Title: String { return self._s[1188]! } + public var Wallet_Receive_InvoiceUrlCopied: String { return self._s[1189]! } + public var Map_PlacesNearby: String { return self._s[1190]! } 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[1191]!, self._r[1191]!, [_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[1192]! } + public var Privacy_Calls_NeverAllow_Placeholder: String { return self._s[1195]! } + public var Conversation_StatusTyping: String { return self._s[1196]! } + public var Widget_ApplicationStartRequired: String { return self._s[1197]! } + public var Broadcast_AdminLog_EmptyText: String { return self._s[1198]! } + public var Notification_PassportValueProofOfAddress: String { return self._s[1199]! } + public var UserInfo_CreateNewContact: String { return self._s[1200]! } + public var Passport_Identity_FrontSide: String { return self._s[1201]! } + public var Login_PhoneNumberAlreadyAuthorizedSwitch: String { return self._s[1202]! } + public var Calls_CallTabTitle: String { return self._s[1203]! } + public var Channel_AdminLog_ChannelEmptyText: String { return self._s[1204]! } public func Login_BannedPhoneBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1205]!, self._r[1205]!, [_0]) + return formatWithArgumentRanges(self._s[1206]!, self._r[1206]!, [_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[1207]! } + public var Group_EditAdmin_RankAdminPlaceholder: String { return self._s[1208]! } + public var SharedMedia_EmptyMusicText: String { return self._s[1209]! } + public var Wallet_Completed_Text: String { return self._s[1210]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1minute: String { return self._s[1211]! } + public var Paint_Stickers: String { return self._s[1212]! } + public var Privacy_GroupsAndChannels: String { return self._s[1213]! } + public var ChatList_Context_Delete: String { return self._s[1215]! } + public var UserInfo_AddContact: String { return self._s[1216]! } public func Conversation_MessageViaUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1216]!, self._r[1216]!, [_0]) + return formatWithArgumentRanges(self._s[1217]!, self._r[1217]!, [_0]) } - public var PhoneNumberHelp_ChangeNumber: String { return self._s[1218]! } + public var PhoneNumberHelp_ChangeNumber: String { return self._s[1219]! } public func ChatList_ClearChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1220]!, self._r[1220]!, [_0]) + return formatWithArgumentRanges(self._s[1221]!, self._r[1221]!, [_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[1222]! } + public var EditProfile_NameAndPhotoHelp: String { return self._s[1223]! } + public var BlockedUsers_BlockUser: String { return self._s[1224]! } + public var Notifications_PermissionsOpenSettings: String { return self._s[1225]! } + public var MediaPicker_UngroupDescription: String { return self._s[1227]! } + public var Watch_NoConnection: String { return self._s[1228]! } + public var Month_GenSeptember: String { return self._s[1229]! } + public var Conversation_ViewGroup: String { return self._s[1231]! } + public var Channel_AdminLogFilter_EventsLeavingSubscribers: String { return self._s[1234]! } + public var Privacy_Forwards_AlwaysLink: String { return self._s[1235]! } + public var Channel_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[1236]! } + public var Passport_FieldOneOf_FinalDelimeter: String { return self._s[1237]! } + public var Wallet_WordCheck_IncorrectHeader: String { return self._s[1238]! } + public var MediaPicker_CameraRoll: String { return self._s[1240]! } + public var Month_GenAugust: String { return self._s[1241]! } + public var Wallet_Configuration_SourceHeader: String { return self._s[1242]! } + public var AccessDenied_VideoMessageMicrophone: String { return self._s[1243]! } + public var SharedMedia_EmptyText: String { return self._s[1244]! } + public var Map_ShareLiveLocation: String { return self._s[1245]! } + public var Calls_All: String { return self._s[1246]! } + public var Map_SendThisPlace: String { return self._s[1248]! } + public var Appearance_ThemeNight: String { return self._s[1250]! } + public var Conversation_HoldForAudio: String { return self._s[1251]! } + public var SettingsSearch_Synonyms_Support: String { return self._s[1254]! } + public var GroupInfo_GroupHistoryHidden: String { return self._s[1255]! } + public var SocksProxySetup_Secret: String { return self._s[1256]! } public func Activity_RemindAboutChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1256]!, self._r[1256]!, [_0]) + return formatWithArgumentRanges(self._s[1257]!, self._r[1257]!, [_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[1259]! } + public var Conversation_Location: String { return self._s[1260]! } 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[1261]!, self._r[1261]!, [_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[1263]! } + public var SettingsSearch_Synonyms_Privacy_Title: String { return self._s[1264]! } + public var Notifications_PermissionsText: String { return self._s[1265]! } + public var SettingsSearch_Synonyms_Data_SaveIncomingPhotos: String { return self._s[1266]! } + public var Call_Flip: String { return self._s[1267]! } + public var Channel_AdminLog_CanDeleteMessagesOfOthers: String { return self._s[1269]! } + public var SocksProxySetup_ProxyStatusConnecting: String { return self._s[1270]! } + public var Wallet_TransactionInfo_StorageFeeInfoUrl: String { return self._s[1271]! } + public var PrivacyPhoneNumberSettings_DiscoveryHeader: String { return self._s[1272]! } + public var Channel_EditAdmin_PermissionPinMessages: String { return self._s[1274]! } + public var TwoStepAuth_ReEnterPasswordDescription: String { return self._s[1276]! } + public var ChatList_EditFolders: String { return self._s[1278]! } + public var Channel_TooMuchBots: String { return self._s[1279]! } + public var Passport_DeletePassportConfirmation: String { return self._s[1280]! } + public var Login_InvalidCodeError: String { return self._s[1281]! } + public var StickerPacksSettings_FeaturedPacks: String { return self._s[1282]! } public func ChatList_DeleteSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1282]!, self._r[1282]!, [_0]) - } - public func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[1283]!, self._r[1283]!, [_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 func GroupInfo_InvitationLinkAcceptChannel(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1284]!, self._r[1284]!, [_0]) + } + public var VoiceOver_Navigation_ProxySettings: String { return self._s[1285]! } + public var Call_CallInProgressTitle: String { return self._s[1286]! } + public var Month_ShortSeptember: String { return self._s[1287]! } + public var Watch_ChannelInfo_Title: String { return self._s[1288]! } + public var ChatList_DeleteSavedMessagesConfirmation: String { return self._s[1291]! } + public var DialogList_PasscodeLockHelp: String { return self._s[1292]! } + public var Chat_MultipleTextMessagesDisabled: String { return self._s[1293]! } + public var Wallet_Receive_Title: String { return self._s[1294]! } + public var Notifications_Badge_IncludePublicGroups: String { return self._s[1295]! } + public var Channel_AdminLogFilter_EventsTitle: String { return self._s[1296]! } + public var PhotoEditor_CropReset: String { return self._s[1297]! } + public var Group_Username_CreatePrivateLinkHelp: String { return self._s[1299]! } + public var Channel_Management_LabelEditor: String { return self._s[1300]! } + public var Passport_Identity_LatinNameHelp: String { return self._s[1302]! } + public var PhotoEditor_HighlightsTool: String { return self._s[1303]! } + public var Wallet_Info_WalletCreated: String { return self._s[1304]! } + public var UserInfo_Title: String { return self._s[1305]! } + public var ChatList_HideAction: String { return self._s[1306]! } + public var AccessDenied_Title: String { return self._s[1307]! } + public var DialogList_SearchLabel: String { return self._s[1308]! } + public var Group_Setup_HistoryHidden: String { return self._s[1309]! } + public var TwoStepAuth_PasswordChangeSuccess: String { return self._s[1310]! } + public var State_Updating: String { return self._s[1312]! } + public var Contacts_TabTitle: String { return self._s[1313]! } + public var Notifications_Badge_CountUnreadMessages: String { return self._s[1315]! } + public var GroupInfo_GroupHistory: String { return self._s[1316]! } + public var Conversation_UnsupportedMediaPlaceholder: String { return self._s[1317]! } + public var Wallpaper_SetColor: String { return self._s[1318]! } + public var CheckoutInfo_ShippingInfoCountry: String { return self._s[1319]! } + public var SettingsSearch_Synonyms_SavedMessages: String { return self._s[1320]! } + public var ChatList_ReorderTabs: String { return self._s[1321]! } + public var ChatListFolder_IncludeChatsTitle: String { return self._s[1322]! } + public var Chat_AttachmentLimitReached: String { return self._s[1323]! } + public var Passport_Identity_OneOfTypeDriversLicense: String { return self._s[1324]! } + public var Contacts_NotRegisteredSection: String { return self._s[1325]! } 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[1326]!, self._r[1326]!, [_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[1327]! } + public var StickerPacksSettings_ArchivedMasks: String { return self._s[1328]! } + public var SocksProxySetup_Connecting: String { return self._s[1329]! } + public var ExplicitContent_AlertChannel: String { return self._s[1330]! } + public var CreatePoll_AllOptionsAdded: String { return self._s[1331]! } + public var Conversation_Contact: String { return self._s[1332]! } + public var Login_CodeExpired: String { return self._s[1333]! } + public var Passport_DiscardMessageAction: String { return self._s[1334]! } + public var ChatList_Context_Unpin: String { return self._s[1335]! } + public var Channel_AdminLog_MessagePreviousDescription: String { return self._s[1336]! } public func VoiceOver_Chat_MusicFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1336]!, self._r[1336]!, [_0]) + return formatWithArgumentRanges(self._s[1337]!, self._r[1337]!, [_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[1338]! } + public var SettingsSearch_Synonyms_Data_NetworkUsage: String { return self._s[1339]! } public func Group_EditAdmin_RankInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1339]!, self._r[1339]!, [_0]) + return formatWithArgumentRanges(self._s[1340]!, self._r[1340]!, [_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[1341]! } + public var AuthSessions_CurrentSession: String { return self._s[1342]! } + public var Chat_AttachmentMultipleFilesDisabled: String { return self._s[1345]! } + public var Wallet_Navigation_Cancel: String { return self._s[1347]! } + public var WallpaperPreview_CropTopText: String { return self._s[1348]! } + public var PrivacySettings_DeleteAccountIfAwayFor: String { return self._s[1349]! } + public var CheckoutInfo_ShippingInfoTitle: String { return self._s[1350]! } 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[1351]!, self._r[1351]!, [_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[1352]! } + public var Channel_Setup_TypePrivate: String { return self._s[1354]! } + public var Forward_ChannelReadOnly: String { return self._s[1357]! } + public var PhotoEditor_CurvesBlue: String { return self._s[1358]! } + public var AddContact_SharedContactException: String { return self._s[1359]! } + public var UserInfo_BotPrivacy: String { return self._s[1361]! } + public var Wallet_CreateInvoice_Title: String { return self._s[1362]! } + public var Notification_PassportValueEmail: String { return self._s[1363]! } + public var EmptyGroupInfo_Subtitle: String { return self._s[1364]! } + public var GroupPermission_NewTitle: String { return self._s[1365]! } + public var CallFeedback_ReasonDropped: String { return self._s[1366]! } + public var GroupInfo_Permissions_AddException: String { return self._s[1367]! } + public var Channel_SignMessages_Help: String { return self._s[1369]! } + public var Undo_ChatDeleted: String { return self._s[1371]! } + public var Conversation_ChatBackground: String { return self._s[1372]! } 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]) - } - 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]) } - 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 func PUSH_CHAT_MESSAGE_QUIZ(_ _1: String, _ _2: String, _ _3: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[1374]!, self._r[1374]!, [_1, _2, _3]) + } + public var ChannelMembers_WhoCanAddMembers_Admins: String { return self._s[1375]! } + public var FastTwoStepSetup_EmailPlaceholder: String { return self._s[1376]! } + public var Passport_Language_pt: String { return self._s[1377]! } + public var VoiceOver_Chat_YourVoiceMessage: String { return self._s[1378]! } + public var NotificationsSound_Popcorn: String { return self._s[1381]! } + public var AutoNightTheme_Disabled: String { return self._s[1382]! } + public var BlockedUsers_LeavePrefix: String { return self._s[1383]! } + public var WallpaperPreview_CustomColorTopText: String { return self._s[1384]! } + public var Contacts_PermissionsSuppressWarningText: String { return self._s[1385]! } + public var WallpaperSearch_ColorBlue: String { return self._s[1386]! } public func CancelResetAccount_TextSMS(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1386]!, self._r[1386]!, [_0]) + return formatWithArgumentRanges(self._s[1387]!, self._r[1387]!, [_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[1388]! } + public var CheckoutInfo_ErrorNameInvalid: String { return self._s[1389]! } + public var SocksProxySetup_UseForCalls: String { return self._s[1390]! } + public var Passport_DeleteDocumentConfirmation: String { return self._s[1392]! } + public var PeerInfo_PaneGroups: String { return self._s[1393]! } public func Conversation_Megabytes(_ _0: Float) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1393]!, self._r[1393]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[1394]!, self._r[1394]!, ["\(_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[1397]! } + public var ChatSettings_AutoDownloadSettings_OffForAll: String { return self._s[1398]! } + public var Compose_NewEncryptedChat: String { return self._s[1399]! } + public var Login_CodeFloodError: String { return self._s[1400]! } + public var Calls_TabTitle: String { return self._s[1401]! } + public var Privacy_ProfilePhoto: String { return self._s[1402]! } + public var Passport_Language_he: String { return self._s[1403]! } public func Conversation_SetReminder_RemindToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1403]!, self._r[1403]!, [_0]) + return formatWithArgumentRanges(self._s[1404]!, self._r[1404]!, [_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[1405]! } + public var GroupPermission_Title: String { return self._s[1406]! } public func Channel_AdminLog_MessageGroupPreHistoryHidden(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1406]!, self._r[1406]!, [_0]) + return formatWithArgumentRanges(self._s[1407]!, self._r[1407]!, [_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[1408]! } + public var GroupPermission_NoChangeInfo: String { return self._s[1409]! } + public var ChatList_DeleteForCurrentUser: String { return self._s[1410]! } + public var Tour_Text1: String { return self._s[1411]! } + public var Channel_EditAdmin_TransferOwnership: String { return self._s[1412]! } + public var Month_ShortFebruary: String { return self._s[1413]! } + public var TwoStepAuth_EmailSkip: String { return self._s[1414]! } 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[1415]!, self._r[1415]!, [_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[1416]! } + public var NotificationsSound_Glass: String { return self._s[1417]! } + public var Appearance_ThemeNightBlue: String { return self._s[1418]! } + public var CheckoutInfo_Pay: String { return self._s[1419]! } + public var PeerInfo_ButtonLeave: String { return self._s[1421]! } + public var Invite_LargeRecipientsCountWarning: String { return self._s[1422]! } + public var Call_CallAgain: String { return self._s[1424]! } + public var AttachmentMenu_SendAsFile: String { return self._s[1425]! } + public var AccessDenied_MicrophoneRestricted: String { return self._s[1426]! } + public var Passport_InvalidPasswordError: String { return self._s[1427]! } + public var Watch_Message_Game: String { return self._s[1428]! } + public var Stickers_Install: String { return self._s[1429]! } + public var VoiceOver_Chat_Message: String { return self._s[1430]! } + public var PrivacyLastSeenSettings_NeverShareWith: String { return self._s[1431]! } + public var Passport_Identity_ResidenceCountry: String { return self._s[1433]! } + public var Notifications_GroupNotificationsHelp: String { return self._s[1434]! } + public var AuthSessions_OtherSessions: String { return self._s[1435]! } + public var Channel_Username_Help: String { return self._s[1436]! } + public var Camera_Title: String { return self._s[1437]! } + public var IntentsSettings_Title: String { return self._s[1438]! } + public var GroupInfo_SetGroupPhotoDelete: String { return self._s[1440]! } + public var Privacy_ProfilePhoto_NeverShareWith_Title: String { return self._s[1441]! } + public var Channel_AdminLog_SendPolls: String { return self._s[1442]! } + public var Channel_AdminLog_TitleAllEvents: String { return self._s[1443]! } + public var Channel_EditAdmin_PermissionInviteMembers: String { return self._s[1444]! } + public var Contacts_MemberSearchSectionTitleGroup: String { return self._s[1445]! } + public var ScheduledMessages_DeleteMany: String { return self._s[1446]! } + public var Conversation_RestrictedStickers: String { return self._s[1447]! } + public var Notifications_ExceptionsResetToDefaults: String { return self._s[1449]! } + public var UserInfo_TelegramCall: String { return self._s[1451]! } + public var TwoStepAuth_SetupResendEmailCode: String { return self._s[1452]! } + public var CreatePoll_OptionsHeader: String { return self._s[1453]! } + public var SettingsSearch_Synonyms_Data_CallsUseLessData: String { return self._s[1454]! } + public var ArchivedChats_IntroTitle1: String { return self._s[1455]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Title: String { return self._s[1456]! } + public var Theme_Colors_Proceed: String { return self._s[1457]! } + public var Passport_Identity_EditPersonalDetails: String { return self._s[1458]! } 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[1459]!, self._r[1459]!, [_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[1460]! } + public var Settings_SaveEditedPhotos: String { return self._s[1461]! } + public var Stats_FollowersBySourceTitle: String { return self._s[1462]! } + public var TwoStepAuth_ConfirmationTitle: String { return self._s[1463]! } + public var Privacy_GroupsAndChannels_NeverAllow_Title: String { return self._s[1464]! } + public var Conversation_MessageDialogRetry: String { return self._s[1465]! } + public var ChatList_Context_MarkAsUnread: String { return self._s[1466]! } + public var MessagePoll_SubmitVote: String { return self._s[1467]! } + public var Conversation_DiscardVoiceMessageAction: String { return self._s[1468]! } + public var Permissions_PeopleNearbyTitle_v0: String { return self._s[1469]! } + public var ChatList_Context_Back: String { return self._s[1470]! } + public var Group_Setup_TypeHeader: String { return self._s[1471]! } + public var Paint_RecentStickers: String { return self._s[1472]! } + public var PhotoEditor_GrainTool: String { return self._s[1473]! } + public var CheckoutInfo_ShippingInfoState: String { return self._s[1474]! } + public var EmptyGroupInfo_Line4: String { return self._s[1475]! } + public var Watch_AuthRequired: String { return self._s[1477]! } public func Passport_Email_UseTelegramEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1477]!, self._r[1477]!, [_0]) + return formatWithArgumentRanges(self._s[1478]!, self._r[1478]!, [_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[1479]! } + public var ChannelIntro_Text: String { return self._s[1480]! } + public var DialogList_DeleteBotConfirmation: String { return self._s[1481]! } + public var GroupPermission_NoSendMedia: String { return self._s[1482]! } + public var Calls_AddTab: String { return self._s[1483]! } + public var Message_ReplyActionButtonShowReceipt: String { return self._s[1484]! } + public var Channel_AdminLog_EmptyFilterText: String { return self._s[1485]! } + public var Conversation_WalletRequiredSetup: String { return self._s[1486]! } + public var Notification_MessageLifetime1d: String { return self._s[1487]! } + public var Notifications_ChannelNotificationsExceptionsHelp: String { return self._s[1488]! } + public var Channel_BanUser_PermissionsHeader: String { return self._s[1489]! } + public var Passport_Identity_GenderFemale: String { return self._s[1490]! } + public var BlockedUsers_BlockTitle: String { return self._s[1491]! } public func PUSH_CHANNEL_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1491]!, self._r[1491]!, [_1]) + return formatWithArgumentRanges(self._s[1492]!, self._r[1492]!, [_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[1493]! } + public var WallpaperSearch_ColorBlack: String { return self._s[1494]! } + public var Settings_Context_Logout: String { return self._s[1495]! } + public var Wallet_Info_UnknownTransaction: String { return self._s[1496]! } + public var ChatList_ArchiveAction: String { return self._s[1497]! } + public var AutoNightTheme_Scheduled: String { return self._s[1498]! } + public var TwoFactorSetup_Email_SkipAction: String { return self._s[1499]! } + public var Settings_Devices: String { return self._s[1500]! } + public var ContactInfo_Note: String { return self._s[1501]! } 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[1502]!, self._r[1502]!, [_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[1503]! } + public var Wallet_Receive_CreateInvoice: String { return self._s[1504]! } + public var PrivacyPolicy_DeclineDeleteNow: String { return self._s[1505]! } + public var Theme_Colors_ColorWallpaperWarningProceed: String { return self._s[1506]! } 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[1507]!, self._r[1507]!, [_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[1508]! } + public var Channel_Members_AddBannedErrorAdmin: String { return self._s[1509]! } 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[1510]!, self._r[1510]!, [_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[1511]! } + public var Checkout_ErrorProviderAccountInvalid: String { return self._s[1512]! } + public var Notifications_InAppNotificationsSounds: String { return self._s[1514]! } public func PUSH_PINNED_GAME_SCORE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1514]!, self._r[1514]!, [_1]) + return formatWithArgumentRanges(self._s[1515]!, self._r[1515]!, [_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[1516]! } + public var Notification_MessageLifetimeRemovedOutgoing: String { return self._s[1517]! } 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[1518]!, self._r[1518]!, [_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[1519]!, self._r[1519]!, [_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[1520]! } + public var ArchivedChats_IntroText3: String { return self._s[1521]! } + public var ChatList_UndoArchiveHiddenText: String { return self._s[1522]! } + public var NetworkUsageSettings_TotalSection: String { return self._s[1523]! } + public var Wallet_Month_GenSeptember: String { return self._s[1524]! } + public var Channel_Setup_TypePrivateHelp: String { return self._s[1525]! } 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[1526]!, self._r[1526]!, [_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[1528]! } + public var FastTwoStepSetup_HintSection: String { return self._s[1529]! } + public var Wallpaper_PhotoLibrary: String { return self._s[1530]! } + public var TwoStepAuth_SetupResendEmailCodeAlert: String { return self._s[1531]! } + public var Gif_NoGifsFound: String { return self._s[1532]! } + public var Watch_LastSeen_WithinAMonth: String { return self._s[1533]! } + public var VoiceOver_MessageContextDelete: String { return self._s[1534]! } + public var EditTheme_Preview: String { return self._s[1535]! } public func ClearCache_StorageTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1535]!, self._r[1535]!, [_0]) + return formatWithArgumentRanges(self._s[1536]!, self._r[1536]!, [_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[1537]! } + public var PasscodeSettings_SimplePasscode: String { return self._s[1538]! } + public var GroupInfo_Permissions_Title: String { return self._s[1539]! } + public var Permissions_ContactsText_v0: String { return self._s[1540]! } + public var PrivacyPhoneNumberSettings_CustomDisabledHelp: String { return self._s[1541]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedPublicGroups: String { return self._s[1542]! } + public var PrivacySettings_DataSettingsHelp: String { return self._s[1545]! } + public var Passport_FieldEmailHelp: String { return self._s[1546]! } public func Activity_RemindAboutUser(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1546]!, self._r[1546]!, [_0]) + return formatWithArgumentRanges(self._s[1547]!, self._r[1547]!, [_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[1548]! } + public var Weekday_ShortSaturday: String { return self._s[1549]! } + public var ContactInfo_PhoneLabelMain: String { return self._s[1550]! } + public var Watch_Conversation_UserInfo: String { return self._s[1551]! } + public var CheckoutInfo_ShippingInfoCityPlaceholder: String { return self._s[1552]! } + public var GroupPermission_PermissionDisabledByDefault: String { return self._s[1553]! } + public var PrivacyLastSeenSettings_Title: String { return self._s[1554]! } + public var Conversation_ShareBotLocationConfirmation: String { return self._s[1556]! } + public var PhotoEditor_VignetteTool: String { return self._s[1557]! } + public var Conversation_ContextMenuDiscuss: String { return self._s[1558]! } + public var Passport_Address_Street1Placeholder: String { return self._s[1559]! } + public var Passport_Language_et: String { return self._s[1560]! } + public var AppUpgrade_Running: String { return self._s[1561]! } + public var Channel_DiscussionGroup_Info: String { return self._s[1563]! } + public var EditTheme_Create_Preview_IncomingReplyName: String { return self._s[1564]! } + public var Passport_Language_bg: String { return self._s[1565]! } + public var Stickers_NoStickersFound: String { return self._s[1567]! } 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[1569]!, self._r[1569]!, [_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[1570]!, self._r[1570]!, [_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[1571]! } + public var Wallet_Receive_AddressHeader: String { return self._s[1572]! } + public var Wallet_Send_AmountText: String { return self._s[1573]! } + public var Settings_About: String { return self._s[1574]! } 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[1575]!, self._r[1575]!, [_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[1577]! } + public var KeyCommand_NewMessage: String { return self._s[1578]! } + public var Group_ErrorAddBlocked: String { return self._s[1579]! } public func Message_PaymentSent(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1579]!, self._r[1579]!, [_0]) + return formatWithArgumentRanges(self._s[1580]!, self._r[1580]!, [_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[1581]! } + public var ReportGroupLocation_Title: String { return self._s[1582]! } + public var CallSettings_UseLessDataLongDescription: String { return self._s[1583]! } + public var Cache_ClearProgress: String { return self._s[1584]! } public func Channel_Management_ErrorNotMember(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1584]!, self._r[1584]!, [_0]) + return formatWithArgumentRanges(self._s[1585]!, self._r[1585]!, [_0]) } - public var GroupRemoved_AddToGroup: String { return self._s[1585]! } + public var GroupRemoved_AddToGroup: String { return self._s[1586]! } public func External_OpenIn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1586]!, self._r[1586]!, [_0]) + return formatWithArgumentRanges(self._s[1587]!, self._r[1587]!, [_0]) } - public var Passport_UpdateRequiredError: String { return self._s[1587]! } - public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1588]! } + public var Passport_UpdateRequiredError: String { return self._s[1588]! } + public var Wallet_SecureStorageNotAvailable_Text: String { return self._s[1589]! } public func PUSH_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1589]!, self._r[1589]!, [_1]) + return formatWithArgumentRanges(self._s[1590]!, self._r[1590]!, [_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[1592]! } + public var Passport_Identity_MainPageHelp: String { return self._s[1593]! } + public var PeerInfo_ButtonSearch: String { return self._s[1594]! } + public var Conversation_StatusKickedFromGroup: String { return self._s[1595]! } + public var Passport_Language_ka: String { return self._s[1596]! } 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[1597]!, self._r[1597]!, [_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[1598]! } + public var SocksProxySetup_ProxyEnabled: String { return self._s[1599]! } + public var TwoFactorSetup_Email_SkipConfirmationText: String { return self._s[1602]! } public func AuthCode_Alert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1602]!, self._r[1602]!, [_0]) + return formatWithArgumentRanges(self._s[1603]!, self._r[1603]!, [_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[1604]! } + public var EditTheme_EditTitle: String { return self._s[1605]! } 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[1606]!, self._r[1606]!, [_1, _2]) } - public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1606]! } + public var Passport_Phone_UseTelegramNumberHelp: String { return self._s[1607]! } public func Wallet_Updated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1608]!, self._r[1608]!, [_0]) + return formatWithArgumentRanges(self._s[1609]!, self._r[1609]!, [_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[1610]! } + public var SettingsSearch_Synonyms_Data_Title: String { return self._s[1611]! } + public var Passport_DeletePassport: String { return self._s[1612]! } + public var Appearance_AppIconFilled: String { return self._s[1613]! } + public var Privacy_Calls_P2PAlways: String { return self._s[1614]! } + public var Month_ShortDecember: String { return self._s[1615]! } + public var Channel_AdminLog_CanEditMessages: String { return self._s[1617]! } public func Contacts_AccessDeniedHelpLandscape(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1617]!, self._r[1617]!, [_0]) + return formatWithArgumentRanges(self._s[1618]!, self._r[1618]!, [_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[1619]! } + public var Conversation_EncryptedDescription1: String { return self._s[1620]! } + public var Conversation_EncryptedDescription2: String { return self._s[1621]! } + public var PasscodeSettings_PasscodeOptions: String { return self._s[1622]! } + public var ChatListFolder_NameUnread: String { return self._s[1624]! } + public var Conversation_EncryptedDescription3: String { return self._s[1625]! } + public var PhotoEditor_SharpenTool: String { return self._s[1626]! } + public var Wallet_Configuration_Title: String { return self._s[1627]! } public func Conversation_AddNameToContacts(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1627]!, self._r[1627]!, [_0]) + return formatWithArgumentRanges(self._s[1628]!, self._r[1628]!, [_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[1630]! } + public var Channel_Members_AddMembers: String { return self._s[1631]! } + public var Wallpaper_Search: String { return self._s[1632]! } public func Message_GenericForwardedPsa(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1633]!, self._r[1633]!, [_0]) + return formatWithArgumentRanges(self._s[1634]!, self._r[1634]!, [_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[1635]! } + public var Privacy_ContactsSync: String { return self._s[1636]! } + public var SettingsSearch_Synonyms_Privacy_Data_ContactsReset: String { return self._s[1637]! } + public var ApplyLanguage_ChangeLanguageAction: String { return self._s[1638]! } public func Channel_Management_RestrictedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1638]!, self._r[1638]!, [_0]) + return formatWithArgumentRanges(self._s[1639]!, self._r[1639]!, [_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[1640]! } + public var GroupInfo_Permissions_Removed: String { return self._s[1641]! } + public var ScheduledMessages_ScheduledOnline: String { return self._s[1642]! } + public var Passport_Identity_GenderMale: String { return self._s[1643]! } public func Call_StatusBar(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1643]!, self._r[1643]!, [_0]) + return formatWithArgumentRanges(self._s[1644]!, self._r[1644]!, [_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[1645]! } + public var Conversation_JumpToDate: String { return self._s[1646]! } + public var Contacts_GlobalSearch: String { return self._s[1647]! } + public var AutoDownloadSettings_ResetHelp: String { return self._s[1648]! } + public var SettingsSearch_Synonyms_FAQ: String { return self._s[1649]! } + public var ChatListFolderSettings_NewFolder: String { return self._s[1650]! } + public var Profile_MessageLifetime1d: String { return self._s[1651]! } 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[1652]!, self._r[1652]!, [_1, _2]) } - public var StickerPack_BuiltinPackName: String { return self._s[1654]! } + public var StickerPack_BuiltinPackName: String { return self._s[1655]! } 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[1656]!, self._r[1656]!, [_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[1657]! } + public var Passport_InfoTitle: String { return self._s[1659]! } + public var Notifications_PermissionsUnreachableText: String { return self._s[1660]! } public func NetworkUsageSettings_CellularUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1663]!, self._r[1663]!, [_0]) + return formatWithArgumentRanges(self._s[1664]!, self._r[1664]!, [_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[1665]!, self._r[1665]!, [_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[1666]! } + public var Profile_BotInfo: String { return self._s[1667]! } + public var Watch_Compose_CreateMessage: String { return self._s[1668]! } + public var AutoDownloadSettings_VoiceMessagesInfo: String { return self._s[1669]! } + public var Month_ShortNovember: String { return self._s[1670]! } + public var Conversation_ScamWarning: String { return self._s[1671]! } + public var Wallpaper_SetCustomBackground: String { return self._s[1672]! } + public var Appearance_TextSize_Title: String { return self._s[1673]! } + public var ChatList_EmptyChatListFilterTitle: String { return self._s[1674]! } + public var Passport_Identity_TranslationsHelp: String { return self._s[1675]! } + public var NotificationsSound_Chime: String { return self._s[1676]! } + public var Passport_Language_ko: String { return self._s[1678]! } + public var InviteText_URL: String { return self._s[1679]! } + public var TextFormat_Monospace: String { return self._s[1680]! } 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[1681]!, self._r[1681]!, [_1, _2, _3]) } - public var EditTheme_Edit_BottomInfo: String { return self._s[1681]! } + public var EditTheme_Edit_BottomInfo: String { return self._s[1682]! } public func Login_WillSendSms(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1682]!, self._r[1682]!, [_0]) + return formatWithArgumentRanges(self._s[1683]!, self._r[1683]!, [_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[1684]!, self._r[1684]!, [_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[1685]! } + public var Wallet_Month_ShortMay: String { return self._s[1686]! } + public var EditTheme_CreateTitle: String { return self._s[1688]! } + public var Passport_InfoLearnMore: String { return self._s[1689]! } + public var TwoStepAuth_EmailPlaceholder: String { return self._s[1690]! } + public var Passport_Identity_AddIdentityCard: String { return self._s[1691]! } + public var Your_card_has_expired: String { return self._s[1692]! } + public var StickerPacksSettings_StickerPacksSection: String { return self._s[1693]! } + public var GroupInfo_InviteLink_Help: String { return self._s[1694]! } + public var TwoFactorSetup_EmailVerification_ResendAction: String { return self._s[1698]! } + public var Conversation_Report: String { return self._s[1700]! } + public var Notifications_MessageNotificationsSound: String { return self._s[1701]! } + public var Notification_MessageLifetime1m: String { return self._s[1702]! } + public var Privacy_ContactsTitle: String { return self._s[1703]! } + public var Conversation_ShareMyContactInfo: String { return self._s[1704]! } + public var Wallet_WordCheck_Title: String { return self._s[1705]! } + public var ChannelMembers_WhoCanAddMembersAdminsHelp: String { return self._s[1706]! } + public var Channel_Members_Title: String { return self._s[1707]! } + public var Map_OpenInWaze: String { return self._s[1708]! } + public var Appearance_RemoveThemeColorConfirmation: String { return self._s[1709]! } + public var Login_PhoneBannedError: String { return self._s[1710]! } + public var PeerInfo_GroupAboutItem: String { return self._s[1711]! } public func LiveLocationUpdated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1711]!, self._r[1711]!, [_0]) + return formatWithArgumentRanges(self._s[1712]!, self._r[1712]!, [_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[1713]! } + public var Group_Management_AddModeratorHelp: String { return self._s[1714]! } + public var AutoDownloadSettings_WifiTitle: String { return self._s[1715]! } + public var Common_OK: String { return self._s[1716]! } + public var Passport_Address_TypeBankStatementUploadScan: String { return self._s[1717]! } + public var Wallet_Words_NotDoneResponse: String { return self._s[1718]! } + public var Cache_Music: String { return self._s[1719]! } + public var Wallet_Configuration_SourceURL: String { return self._s[1720]! } + public var SettingsSearch_Synonyms_EditProfile_PhoneNumber: String { return self._s[1721]! } + public var PasscodeSettings_UnlockWithTouchId: String { return self._s[1724]! } + public var ChatList_EmptyChatListEditFilter: String { return self._s[1725]! } + public var TwoStepAuth_HintPlaceholder: String { return self._s[1726]! } public func PUSH_PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1726]!, self._r[1726]!, [_1]) + return formatWithArgumentRanges(self._s[1727]!, self._r[1727]!, [_1]) } public func Passport_RequestHeader(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1727]!, self._r[1727]!, [_0]) + return formatWithArgumentRanges(self._s[1728]!, self._r[1728]!, [_0]) } - public var TwoFactorSetup_Done_Action: String { return self._s[1728]! } + public var TwoFactorSetup_Done_Action: String { return self._s[1729]! } public func VoiceOver_Chat_ContactOrganization(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1729]!, self._r[1729]!, [_0]) + return formatWithArgumentRanges(self._s[1730]!, self._r[1730]!, [_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 var Wallet_Send_ErrorNotEnoughFundsText: String { return self._s[1731]! } + public var Watch_MessageView_ViewOnPhone: String { return self._s[1733]! } + public var Privacy_Calls_CustomShareHelp: String { return self._s[1734]! } + public var Wallet_Receive_CreateInvoiceInfo: String { return self._s[1736]! } + public var ChangePhoneNumberNumber_Title: String { return self._s[1737]! } + public var State_ConnectingToProxyInfo: String { return self._s[1738]! } + public var Conversation_SwipeToReplyHintTitle: String { return self._s[1739]! } + public var Message_VideoMessage: String { return self._s[1741]! } + public var ChannelInfo_DeleteChannel: String { return self._s[1742]! } + public var ContactInfo_PhoneLabelOther: String { return self._s[1743]! } + public var Channel_EditAdmin_CannotEdit: String { return self._s[1744]! } + public var Passport_DeleteAddressConfirmation: String { return self._s[1745]! } 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]) + return formatWithArgumentRanges(self._s[1746]!, self._r[1746]!, [_1, _2, _3]) } - 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 WallpaperPreview_SwipeBottomText: String { return self._s[1747]! } + public var Activity_RecordingAudio: String { return self._s[1748]! } + public var SettingsSearch_Synonyms_Watch: String { return self._s[1749]! } + public var PasscodeSettings_TryAgainIn1Minute: String { return self._s[1750]! } + public var Wallet_Info_Address: String { return self._s[1751]! } 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[1753]!, self._r[1753]!, [_0, _1]) } public func EmptyGroupInfo_Line1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1756]!, self._r[1756]!, [_0]) + return formatWithArgumentRanges(self._s[1757]!, self._r[1757]!, [_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[1758]! } + public var Conversation_ApplyLocalization: String { return self._s[1759]! } + public var TwoFactorSetup_Intro_Action: String { return self._s[1760]! } + public var UserInfo_AddPhone: String { return self._s[1761]! } + public var Map_ShareLiveLocationHelp: String { return self._s[1762]! } public func Passport_Identity_NativeNameGenericHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1762]!, self._r[1762]!, [_0]) + return formatWithArgumentRanges(self._s[1763]!, self._r[1763]!, [_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[1765]! } + public var Passport_Scans: String { return self._s[1766]! } + public var BlockedUsers_Unblock: String { return self._s[1767]! } public func PUSH_ENCRYPTION_REQUEST(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1767]!, self._r[1767]!, [_1]) + return formatWithArgumentRanges(self._s[1768]!, self._r[1768]!, [_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[1769]! } + public var Conversation_ReportSpamAndLeave: String { return self._s[1770]! } + public var SettingsSearch_Synonyms_EditProfile_Bio: String { return self._s[1771]! } + public var ChatList_UndoArchiveMultipleTitle: String { return self._s[1772]! } + public var Passport_Identity_NativeNameGenericTitle: String { return self._s[1773]! } 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[1774]!, self._r[1774]!, [_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[1775]! } + public var LastSeen_ALongTimeAgo: String { return self._s[1776]! } + public var Channel_AdminLog_CanPinMessages: String { return self._s[1777]! } + public var ChannelIntro_CreateChannel: String { return self._s[1778]! } + public var Conversation_UnreadMessages: String { return self._s[1779]! } + public var SettingsSearch_Synonyms_Stickers_ArchivedPacks: String { return self._s[1780]! } + public var Channel_AdminLog_EmptyText: String { return self._s[1781]! } + public var Theme_Context_Apply: String { return self._s[1782]! } + public var Notification_GroupActivated: String { return self._s[1783]! } + public var NotificationSettings_ContactJoinedInfo: String { return self._s[1784]! } + public var Wallet_Intro_CreateWallet: String { return self._s[1785]! } public func Notification_PinnedContactMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1785]!, self._r[1785]!, [_0]) + return formatWithArgumentRanges(self._s[1786]!, self._r[1786]!, [_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[1787]!, self._r[1787]!, [_0, _1]) } - public var GroupInfo_ConvertToSupergroup: String { return self._s[1788]! } + public var GroupInfo_ConvertToSupergroup: String { return self._s[1789]! } public func PrivacyPolicy_AgeVerificationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1789]!, self._r[1789]!, [_0]) + return formatWithArgumentRanges(self._s[1790]!, self._r[1790]!, [_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[1791]! } + public var CallFeedback_AddComment: String { return self._s[1792]! } public func Conversation_OpenBotLinkAllowMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1792]!, self._r[1792]!, [_0]) + return formatWithArgumentRanges(self._s[1793]!, self._r[1793]!, [_0]) } - public var Document_TargetConfirmationFormat: String { return self._s[1793]! } + public var Document_TargetConfirmationFormat: String { return self._s[1794]! } public func Call_StatusOngoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1794]!, self._r[1794]!, [_0]) + return formatWithArgumentRanges(self._s[1795]!, self._r[1795]!, [_0]) } - public var LogoutOptions_SetPasscodeTitle: String { return self._s[1795]! } + public var LogoutOptions_SetPasscodeTitle: String { return self._s[1796]! } 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[1797]!, self._r[1797]!, [_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[1798]! } + public var Theme_ErrorNotFound: String { return self._s[1799]! } + public var Contacts_SortByName: String { return self._s[1800]! } + public var SettingsSearch_Synonyms_Privacy_Forwards: String { return self._s[1801]! } 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[1803]!, self._r[1803]!, [_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[1804]! } + public var ScheduledMessages_EditTime: String { return self._s[1805]! } + public var Conversation_ClearSelfHistory: String { return self._s[1806]! } + public var Checkout_NewCard_PostcodePlaceholder: String { return self._s[1807]! } + public var PasscodeSettings_DoNotMatch: String { return self._s[1808]! } + public var Stickers_SuggestNone: String { return self._s[1809]! } + public var ChatSettings_Cache: String { return self._s[1810]! } + public var Settings_SaveIncomingPhotos: String { return self._s[1811]! } + public var Media_ShareThisPhoto: String { return self._s[1812]! } + public var Chat_SlowmodeTooltipPending: String { return self._s[1813]! } + public var InfoPlist_NSContactsUsageDescription: String { return self._s[1814]! } + public var Conversation_ContextMenuCopyLink: String { return self._s[1815]! } + public var PrivacyPolicy_AgeVerificationTitle: String { return self._s[1816]! } + public var SettingsSearch_Synonyms_Stickers_Masks: String { return self._s[1817]! } + public var TwoStepAuth_SetupPasswordEnterPasswordNew: String { return self._s[1818]! } + public var Appearance_ThemePreview_Chat_6_Text: String { return self._s[1819]! } public func Wallet_SecureStorageReset_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1819]!, self._r[1819]!, [_0]) + return formatWithArgumentRanges(self._s[1820]!, self._r[1820]!, [_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[1821]! } + public var WallpaperSearch_ColorWhite: String { return self._s[1823]! } + public var Channel_AdminLog_DefaultRestrictionsUpdated: String { return self._s[1824]! } + public var Conversation_ErrorInaccessibleMessage: String { return self._s[1825]! } + public var Map_OpenIn: String { return self._s[1826]! } + public var PeerInfo_ButtonCall: String { return self._s[1827]! } public func PUSH_PHONE_CALL_MISSED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1830]!, self._r[1830]!, [_1]) + return formatWithArgumentRanges(self._s[1831]!, self._r[1831]!, [_1]) } public func ChannelInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1831]!, self._r[1831]!, [_0]) + return formatWithArgumentRanges(self._s[1832]!, self._r[1832]!, [_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[1833]! } + public var MessagePoll_LabelClosed: String { return self._s[1834]! } + public var GroupPermission_PermissionGloballyDisabled: String { return self._s[1836]! } + public var Wallet_Send_SendAnyway: String { return self._s[1837]! } + public var Passport_Identity_MiddleNamePlaceholder: String { return self._s[1838]! } + public var UserInfo_FirstNamePlaceholder: String { return self._s[1839]! } + public var PrivacyLastSeenSettings_WhoCanSeeMyTimestamp: String { return self._s[1840]! } + public var Map_SetThisPlace: String { return self._s[1841]! } + public var Login_SelectCountry_Title: String { return self._s[1842]! } + public var Channel_EditAdmin_PermissionBanUsers: String { return self._s[1843]! } 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[1844]!, self._r[1844]!, [_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[1845]! } + public var Watch_Suggestion_BRB: String { return self._s[1846]! } + public var Passport_Identity_EditIdentityCard: String { return self._s[1847]! } + public var Contacts_PermissionsTitle: String { return self._s[1848]! } + public var Conversation_RestrictedInline: String { return self._s[1849]! } + public var Appearance_RemoveThemeColor: String { return self._s[1851]! } + public var StickerPack_ViewPack: String { return self._s[1852]! } + public var Wallet_UnknownError: String { return self._s[1853]! } public func Update_AppVersion(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1853]!, self._r[1853]!, [_0]) + return formatWithArgumentRanges(self._s[1854]!, self._r[1854]!, [_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[1856]! } + public var ChatSettings_AutoDownloadSettings_TypePhoto: String { return self._s[1860]! } + public var MessagePoll_LabelQuiz: String { return self._s[1862]! } + public var Conversation_ReportSpamGroupConfirmation: String { return self._s[1863]! } + public var Channel_Info_Stickers: String { return self._s[1864]! } + public var AutoNightTheme_PreferredTheme: String { return self._s[1865]! } + public var PrivacyPolicy_AgeVerificationAgree: String { return self._s[1866]! } + public var Passport_DeletePersonalDetails: String { return self._s[1867]! } + public var LogoutOptions_AddAccountTitle: String { return self._s[1868]! } + public var Channel_DiscussionGroupInfo: String { return self._s[1869]! } + public var Group_EditAdmin_RankOwnerPlaceholder: String { return self._s[1870]! } + public var Stats_LoadingText: String { return self._s[1873]! } + public var Conversation_SearchNoResults: String { return self._s[1874]! } + public var ChatList_AddFolder: String { return self._s[1875]! } + public var Wallet_Configuration_ApplyErrorTextURLInvalid: String { return self._s[1876]! } + public var ChatListFolder_NameNonContacts: String { return self._s[1877]! } + public var MessagePoll_LabelAnonymous: String { return self._s[1878]! } + public var Channel_Members_AddAdminErrorNotAMember: String { return self._s[1879]! } + public var Login_Code: String { return self._s[1880]! } + public var EditTheme_Create_BottomInfo: String { return self._s[1881]! } + public var Watch_Suggestion_WhatsUp: String { return self._s[1882]! } + public var Weekday_ShortThursday: String { return self._s[1883]! } + public var Resolve_ErrorNotFound: String { return self._s[1885]! } + public var LastSeen_Offline: String { return self._s[1886]! } + public var PeopleNearby_NoMembers: String { return self._s[1887]! } + public var GroupPermission_AddMembersNotAvailable: String { return self._s[1888]! } + public var Privacy_Calls_AlwaysAllow_Title: String { return self._s[1889]! } + public var Conversation_Dice_u1F3AF: String { return self._s[1891]! } + public var GroupInfo_Title: String { return self._s[1892]! } + public var NotificationsSound_Note: String { return self._s[1893]! } + public var Conversation_EditingMessagePanelTitle: String { return self._s[1894]! } + public var Watch_Message_Poll: String { return self._s[1895]! } + public var Privacy_Calls: String { return self._s[1896]! } 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[1897]!, self._r[1897]!, [_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[1898]! } + public var TwoStepAuth_SetPasswordHelp: String { return self._s[1899]! } + public var Notifications_Reset: String { return self._s[1900]! } + public var Conversation_Pin: String { return self._s[1901]! } + public var Passport_Language_lv: String { return self._s[1902]! } + public var Permissions_PeopleNearbyAllowInSettings_v0: String { return self._s[1903]! } + public var BlockedUsers_Info: String { return self._s[1904]! } + public var SettingsSearch_Synonyms_Data_AutoplayVideos: String { return self._s[1906]! } + public var Watch_Conversation_Unblock: String { return self._s[1908]! } public func Time_MonthOfYear_m9(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1908]!, self._r[1908]!, [_0]) + return formatWithArgumentRanges(self._s[1909]!, self._r[1909]!, [_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[1910]! } + public var GroupInfo_DeleteAndExitConfirmation: String { return self._s[1911]! } public func NetworkUsageSettings_WifiUsageSince(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1911]!, self._r[1911]!, [_0]) + return formatWithArgumentRanges(self._s[1912]!, self._r[1912]!, [_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[1913]! } + public var Watch_Suggestion_OnMyWay: String { return self._s[1914]! } + public var TwoStepAuth_RecoveryEmailTitle: String { return self._s[1915]! } + public var Passport_Address_EditBankStatement: String { return self._s[1916]! } 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[1917]!, self._r[1917]!, [_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[1918]! } + public var ShareMenu_Comment: String { return self._s[1919]! } + public var Permissions_ContactsTitle_v0: String { return self._s[1920]! } + public var Notifications_PermissionsTitle: String { return self._s[1921]! } + public var GroupPermission_NoSendLinks: String { return self._s[1922]! } + public var Privacy_Forwards_NeverAllow_Title: String { return self._s[1923]! } + public var Wallet_SecureStorageChanged_ImportWallet: String { return self._s[1924]! } + public var PeerInfo_PaneLinks: String { return self._s[1925]! } + public var Settings_Support: String { return self._s[1926]! } + public var Notifications_ChannelNotificationsSound: String { return self._s[1927]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadReset: String { return self._s[1928]! } + public var Privacy_Forwards_Preview: String { return self._s[1929]! } + public var GroupPermission_ApplyAlertAction: String { return self._s[1930]! } + public var Watch_Stickers_StickerPacks: String { return self._s[1931]! } + public var Common_Select: String { return self._s[1933]! } + public var CheckoutInfo_ErrorEmailInvalid: String { return self._s[1934]! } + public var WallpaperSearch_ColorGray: String { return self._s[1937]! } + public var TwoFactorSetup_Password_PlaceholderPassword: String { return self._s[1938]! } + public var TwoFactorSetup_Hint_SkipAction: String { return self._s[1939]! } + public var ChatAdmins_AllMembersAreAdminsOffHelp: String { return self._s[1940]! } + public var PollResults_Title: String { return self._s[1941]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5hours: String { return self._s[1942]! } + public var Appearance_PreviewReplyAuthor: String { return self._s[1943]! } + public var TwoStepAuth_RecoveryTitle: String { return self._s[1944]! } + public var Widget_AuthRequired: String { return self._s[1945]! } + public var Camera_FlashOn: String { return self._s[1946]! } + public var Conversation_ContextMenuLookUp: String { return self._s[1947]! } + public var Channel_Stickers_NotFoundHelp: String { return self._s[1948]! } + public var Watch_Suggestion_OK: String { return self._s[1949]! } public func Username_LinkHint(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1950]!, self._r[1950]!, [_0]) + return formatWithArgumentRanges(self._s[1951]!, self._r[1951]!, [_0]) } public func Notification_PinnedLiveLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1952]!, self._r[1952]!, [_0]) + return formatWithArgumentRanges(self._s[1953]!, self._r[1953]!, [_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 var TextFormat_Strikethrough: String { return self._s[1954]! } + public var DialogList_AdLabel: String { return self._s[1955]! } + public var WatchRemote_NotificationText: String { return self._s[1956]! } + public var IntentsSettings_SuggestedChatsSavedMessages: String { return self._s[1957]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsAlert: String { return self._s[1958]! } + public var Conversation_ReportSpam: String { return self._s[1959]! } + public var SettingsSearch_Synonyms_Privacy_Data_TopPeers: String { return self._s[1960]! } + public var Settings_LogoutConfirmationTitle: String { return self._s[1962]! } + public var PhoneLabel_Title: String { return self._s[1963]! } + public var Passport_Address_EditRentalAgreement: String { return self._s[1964]! } + public var Settings_ChangePhoneNumber: String { return self._s[1965]! } + public var Notifications_ExceptionsTitle: String { return self._s[1966]! } + public var Notifications_AlertTones: String { return self._s[1967]! } + public var Call_ReportIncludeLogDescription: String { return self._s[1968]! } + public var SettingsSearch_Synonyms_Notifications_ResetAllNotifications: String { return self._s[1969]! } + public var AutoDownloadSettings_PrivateChats: String { return self._s[1970]! } + public var VoiceOver_Chat_Photo: String { return self._s[1972]! } + public var TwoStepAuth_AddHintTitle: String { return self._s[1973]! } + public var Stats_PostsTitle: String { return self._s[1974]! } + public var ReportPeer_ReasonOther: String { return self._s[1975]! } + public var ChatList_Context_JoinChannel: String { return self._s[1976]! } + public var KeyCommand_ScrollDown: String { return self._s[1978]! } + public var Conversation_ScheduleMessage_Title: String { return self._s[1979]! } public func Login_BannedPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1979]!, self._r[1979]!, [_0]) + return formatWithArgumentRanges(self._s[1980]!, self._r[1980]!, [_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[1982]! } + public var ChannelInfo_DeleteGroupConfirmation: String { return self._s[1983]! } + public var AuthSessions_LogOut: String { return self._s[1984]! } + public var Passport_Identity_TypeInternalPassport: String { return self._s[1985]! } + public var ChatSettings_AutoDownloadVoiceMessages: String { return self._s[1986]! } + public var Passport_Phone_Title: String { return self._s[1987]! } + public var ContactList_Context_StartSecretChat: String { return self._s[1988]! } + public var Settings_PhoneNumber: String { return self._s[1989]! } public func Conversation_ScheduleMessage_SendToday(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[1989]!, self._r[1989]!, [_0]) + return formatWithArgumentRanges(self._s[1990]!, self._r[1990]!, [_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[1992]! } + public var Wallet_SecureStorageChanged_CreateWallet: String { return self._s[1993]! } + public var WebSearch_SearchNoResults: String { return self._s[1994]! } + public var Privacy_ProfilePhoto_AlwaysShareWith_Title: String { return self._s[1996]! } + public var Wallet_Configuration_SourceInfo: String { return self._s[1997]! } + public var LogoutOptions_AlternativeOptionsSection: String { return self._s[1998]! } + public var SettingsSearch_Synonyms_Passport: String { return self._s[1999]! } + public var PhotoEditor_CurvesTool: String { return self._s[2000]! } + public var Checkout_PaymentMethod: String { return self._s[2002]! } 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[2003]!, self._r[2003]!, [_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[2004]! } + public var Camera_PhotoMode: String { return self._s[2007]! } + public var EditTheme_Expand_Preview_IncomingText: String { return self._s[2008]! } + public var Appearance_TextSize_Apply: String { return self._s[2009]! } + public var Passport_Address_AddUtilityBill: String { return self._s[2011]! } + public var ChatListFolderSettings_RecommendedNewFolder: String { return self._s[2012]! } + public var CallSettings_OnMobile: String { return self._s[2013]! } + public var Tour_Text2: String { return self._s[2014]! } 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[2015]!, self._r[2015]!, [_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[2017]! } + public var Permissions_Skip: String { return self._s[2018]! } + public var Wallet_Words_NotDoneOk: String { return self._s[2019]! } + public var SecretImage_Title: String { return self._s[2020]! } + public var Watch_MessageView_Title: String { return self._s[2021]! } + public var Channel_DiscussionGroupAdd: String { return self._s[2022]! } + public var AttachmentMenu_Poll: String { return self._s[2023]! } public func Notification_GroupInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2023]!, self._r[2023]!, [_0]) + return formatWithArgumentRanges(self._s[2024]!, self._r[2024]!, [_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[2025]!, self._r[2025]!, [_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[2026]! } + public var WallpaperPreview_Title: String { return self._s[2027]! } + public var Privacy_PaymentsClear_PaymentInfo: String { return self._s[2028]! } + public var Settings_ProxyConnecting: String { return self._s[2029]! } + public var Settings_CheckPhoneNumberText: String { return self._s[2031]! } + public var VoiceOver_Chat_YourVideo: String { return self._s[2032]! } + public var Wallet_Intro_Title: String { return self._s[2033]! } + public var TwoFactorSetup_Password_Action: String { return self._s[2034]! } + public var Profile_MessageLifetime5s: String { return self._s[2035]! } + public var Username_InvalidCharacters: String { return self._s[2036]! } + public var VoiceOver_Media_PlaybackRateFast: String { return self._s[2037]! } + public var ScheduledMessages_ClearAll: String { return self._s[2038]! } + public var WallpaperPreview_CropBottomText: String { return self._s[2039]! } + public var AutoDownloadSettings_LimitBySize: String { return self._s[2040]! } + public var Settings_AddAccount: String { return self._s[2041]! } + public var Notification_CreatedChannel: String { return self._s[2044]! } 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[2045]!, self._r[2045]!, [_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[2047]! } + public var StickerPacksSettings_AnimatedStickersInfo: String { return self._s[2048]! } + public var VoiceOver_Media_PlaybackStop: String { return self._s[2049]! } + public var Contacts_TopSection: String { return self._s[2050]! } + public var ChatList_DeleteForEveryoneConfirmationAction: String { return self._s[2051]! } 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[2052]!, self._r[2052]!, [_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[2053]! } + public var Wallet_Completed_ViewWallet: String { return self._s[2054]! } public func Time_MonthOfYear_m6(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2054]!, self._r[2054]!, [_0]) + return formatWithArgumentRanges(self._s[2055]!, self._r[2055]!, [_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[2056]! } + public var UserInfo_TapToCall: String { return self._s[2057]! } + public var Conversation_ForwardAuthorHiddenTooltip: String { return self._s[2059]! } + public var AutoDownloadSettings_DataUsageCustom: String { return self._s[2060]! } + public var Common_Search: String { return self._s[2061]! } + public var ScheduledMessages_EmptyPlaceholder: String { return self._s[2062]! } public func Channel_AdminLog_MessageChangedGroupGeoLocation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2062]!, self._r[2062]!, [_0]) + return formatWithArgumentRanges(self._s[2063]!, self._r[2063]!, [_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[2064]! } + public var AuthSessions_IncompleteAttemptsInfo: String { return self._s[2066]! } + public var Message_InvoiceLabel: String { return self._s[2067]! } + public var Conversation_InputTextPlaceholder: String { return self._s[2068]! } + public var NetworkUsageSettings_MediaImageDataSection: String { return self._s[2069]! } public func Passport_Address_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2069]!, self._r[2069]!, [_0]) + return formatWithArgumentRanges(self._s[2070]!, self._r[2070]!, [_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[2071]! } + public var Conversation_Info: String { return self._s[2072]! } + public var Login_InfoDeletePhoto: String { return self._s[2073]! } + public var ChatListFolder_DiscardDiscard: String { return self._s[2075]! } + public var Passport_Language_vi: String { return self._s[2076]! } + public var UserInfo_ScamUserWarning: String { return self._s[2077]! } + public var Conversation_Search: String { return self._s[2078]! } + public var DialogList_DeleteBotConversationConfirmation: String { return self._s[2080]! } + public var ChatListFolder_NameGroups: String { return self._s[2081]! } + public var ReportPeer_ReasonPornography: String { return self._s[2082]! } + public var AutoDownloadSettings_PhotosTitle: String { return self._s[2083]! } + public var Conversation_SendMessageErrorGroupRestricted: String { return self._s[2084]! } + public var Map_LiveLocationGroupDescription: String { return self._s[2085]! } + public var Channel_Setup_TypeHeader: String { return self._s[2086]! } + public var AuthSessions_LoggedIn: String { return self._s[2087]! } + public var Privacy_Forwards_AlwaysAllow_Title: String { return self._s[2088]! } + public var Login_SmsRequestState3: String { return self._s[2089]! } + public var Passport_Address_EditUtilityBill: String { return self._s[2090]! } + public var Appearance_ReduceMotionInfo: String { return self._s[2091]! } + public var Join_ChannelsTooMuch: String { return self._s[2092]! } + public var Channel_Edit_LinkItem: String { return self._s[2093]! } + public var Privacy_Calls_P2PNever: String { return self._s[2094]! } + public var Conversation_AddToReadingList: String { return self._s[2096]! } + public var Share_MultipleMessagesDisabled: String { return self._s[2097]! } + public var Message_Animation: String { return self._s[2098]! } + public var Conversation_DefaultRestrictedMedia: String { return self._s[2099]! } + public var Map_Unknown: String { return self._s[2100]! } + public var AutoDownloadSettings_LastDelimeter: String { return self._s[2101]! } public func PUSH_PINNED_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2101]!, self._r[2101]!, [_1, _2]) - } - public func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2102]!, self._r[2102]!, [_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 func Passport_FieldOneOf_Or(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2103]!, self._r[2103]!, [_1, _2]) + } + public var Call_StatusRequesting: String { return self._s[2104]! } + public var Conversation_SecretChatContextBotAlert: String { return self._s[2105]! } + public var SocksProxySetup_ProxyStatusChecking: String { return self._s[2106]! } 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[2107]!, self._r[2107]!, [_1, _2]) } public func Notification_PinnedLocationMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2107]!, self._r[2107]!, [_0]) + return formatWithArgumentRanges(self._s[2108]!, self._r[2108]!, [_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[2109]! } + public var Group_Username_RemoveExistingUsernamesInfo: String { return self._s[2110]! } + public var BlockedUsers_Title: String { return self._s[2111]! } + public var Weekday_Monday: String { return self._s[2112]! } public func PUSH_CHANNEL_MESSAGE_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2112]!, self._r[2112]!, [_1]) + return formatWithArgumentRanges(self._s[2113]!, self._r[2113]!, [_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[2114]! } + public var NotificationsSound_Bell: String { return self._s[2115]! } + public var Conversation_SendMessageErrorFlood: String { return self._s[2116]! } + public var SettingsSearch_Synonyms_Notifications_DisplayNamesOnLockScreen: String { return self._s[2117]! } + public var ChannelMembers_ChannelAdminsTitle: String { return self._s[2118]! } + public var ChatSettings_Groups: String { return self._s[2119]! } + public var WallpaperPreview_PatternPaternDiscard: String { return self._s[2120]! } + public var ChatList_PeerTypeContact: String { return self._s[2121]! } public func Conversation_SetReminder_RemindTomorrow(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2121]!, self._r[2121]!, [_0]) + return formatWithArgumentRanges(self._s[2122]!, self._r[2122]!, [_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[2123]! } + public var TwoStepAuth_EnterPasswordHelp: String { return self._s[2125]! } + public var Wallet_Month_ShortApril: String { return self._s[2126]! } + public var ChatList_Unmute: String { return self._s[2127]! } + public var AuthSessions_AddDevice_ScanTitle: String { return self._s[2128]! } + public var PhotoEditor_CurvesAll: String { return self._s[2129]! } + public var Weekday_ShortTuesday: String { return self._s[2130]! } + public var DialogList_Read: String { return self._s[2131]! } + public var Appearance_AppIconClassic: String { return self._s[2132]! } + public var Conversation_Dice_u1F3B2: String { return self._s[2133]! } + public var ChannelMembers_WhoCanAddMembers_AllMembers: String { return self._s[2134]! } + public var Passport_Identity_Gender: String { return self._s[2135]! } public func Target_ShareGameConfirmationPrivate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2135]!, self._r[2135]!, [_0]) + return formatWithArgumentRanges(self._s[2136]!, self._r[2136]!, [_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[2137]! } + public var Map_HomeAndWorkInfo: String { return self._s[2139]! } public func DialogList_EncryptedChatStartedIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2139]!, self._r[2139]!, [_0]) + return formatWithArgumentRanges(self._s[2140]!, self._r[2140]!, [_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[2141]! } + public var AutoDownloadSettings_AutodownloadPhotos: String { return self._s[2142]! } + public var Channel_Username_CreatePublicLinkHelp: String { return self._s[2143]! } + public var Login_CancelPhoneVerificationContinue: String { return self._s[2144]! } + public var ScheduledMessages_SendNow: String { return self._s[2145]! } + public var Checkout_NewCard_PaymentCard: String { return self._s[2147]! } + public var Login_InfoHelp: String { return self._s[2148]! } + public var Appearance_BubbleCorners_AdjustAdjacent: String { return self._s[2149]! } + public var Contacts_PermissionsSuppressWarningTitle: String { return self._s[2150]! } + public var SettingsSearch_Synonyms_Stickers_FeaturedPacks: String { return self._s[2151]! } 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[2152]!, self._r[2152]!, [_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[2155]! } + public var CreatePoll_Title: String { return self._s[2156]! } + public var MessagePoll_QuizNoUsers: String { return self._s[2157]! } + public var Conversation_ViewTheme: String { return self._s[2158]! } + public var SettingsSearch_Synonyms_Privacy_Data_SecretChatLinkPreview: String { return self._s[2159]! } + public var PasscodeSettings_SimplePasscodeHelp: String { return self._s[2160]! } + public var TwoFactorSetup_Intro_Text: String { return self._s[2161]! } + public var UserInfo_GroupsInCommon: String { return self._s[2162]! } + public var TelegramWallet_Intro_TermsUrl: String { return self._s[2163]! } + public var Stats_ViewsByHoursTitle: String { return self._s[2164]! } + public var Call_AudioRouteHide: String { return self._s[2165]! } 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[2167]!, self._r[2167]!, [_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[2168]! } + public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2169]! } + public var CreatePoll_QuizOptionsHeader: String { return self._s[2170]! } public func ChatList_LeaveGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2170]!, self._r[2170]!, [_0]) + return formatWithArgumentRanges(self._s[2171]!, self._r[2171]!, [_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[2172]! } + public var CreatePoll_ExplanationInfo: String { return self._s[2173]! } + public var FastTwoStepSetup_EmailSection: String { return self._s[2174]! } + public var StickerPackActionInfo_AddedTitle: String { return self._s[2175]! } + public var Notifications_Title: String { return self._s[2176]! } + public var Group_Username_InvalidTooShort: String { return self._s[2177]! } + public var Channel_ErrorAddTooMuch: String { return self._s[2178]! } public func DialogList_MultipleTypingSuffix(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2178]!, self._r[2178]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2179]!, self._r[2179]!, ["\(_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[2181]! } + public var Stickers_SuggestAdded: String { return self._s[2182]! } + public var Login_CountryCode: String { return self._s[2183]! } + public var ChatSettings_AutoPlayVideos: String { return self._s[2184]! } + public var Map_GetDirections: String { return self._s[2185]! } + public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2186]! } + public var Login_PhoneFloodError: String { return self._s[2187]! } public func Time_MonthOfYear_m3(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2187]!, self._r[2187]!, [_0]) + return formatWithArgumentRanges(self._s[2188]!, self._r[2188]!, [_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[2189]!, self._r[2189]!, [_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[2190]! } + public var Settings_SetUsername: String { return self._s[2192]! } + public var Group_Location_ChangeLocation: String { return self._s[2193]! } + public var Notification_GroupInviterSelf: String { return self._s[2194]! } + public var InstantPage_TapToOpenLink: String { return self._s[2195]! } public func Notification_ChannelInviter(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2195]!, self._r[2195]!, [_0]) + return formatWithArgumentRanges(self._s[2196]!, self._r[2196]!, [_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[2197]! } + public var SecretChat_Title: String { return self._s[2198]! } + public var Group_UpgradeNoticeText1: String { return self._s[2199]! } + public var AuthSessions_Title: String { return self._s[2200]! } public func TextFormat_AddLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2200]!, self._r[2200]!, [_0]) + return formatWithArgumentRanges(self._s[2201]!, self._r[2201]!, [_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[2202]! } + public var Channel_About_Title: String { return self._s[2203]! } + public var Theme_ThemeChanged: String { return self._s[2204]! } + public var FastTwoStepSetup_EmailHelp: String { return self._s[2205]! } public func Conversation_Bytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2206]!, self._r[2206]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2207]!, self._r[2207]!, ["\(_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[2208]! } + public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2210]! } + public var Group_Setup_HistoryVisibleHelp: String { return self._s[2211]! } public func PUSH_MESSAGE_GIF(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2211]!, self._r[2211]!, [_1]) + return formatWithArgumentRanges(self._s[2212]!, self._r[2212]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2213]!, self._r[2213]!, [_0]) - } - public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2214]!, self._r[2214]!, [_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 func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2215]!, self._r[2215]!, [_0]) + } + public var Privacy_PaymentsClearInfoHelp: String { return self._s[2216]! } + public var PeopleNearby_DiscoverDescription: String { return self._s[2218]! } + public var Presence_online: String { return self._s[2220]! } + public var PasscodeSettings_Title: String { return self._s[2221]! } + public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2222]! } + public var Web_OpenExternal: String { return self._s[2223]! } + public var AutoDownloadSettings_AutoDownload: String { return self._s[2225]! } + public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2226]! } + public var LocalGroup_Title: String { return self._s[2227]! } public func AutoNightTheme_AutomaticHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2227]!, self._r[2227]!, [_0]) + return formatWithArgumentRanges(self._s[2228]!, self._r[2228]!, [_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[2229]! } + public var Conversation_StopQuizConfirmation: String { return self._s[2230]! } + public var Map_YouAreHere: String { return self._s[2231]! } public func AuthSessions_Message(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2231]!, self._r[2231]!, [_0]) - } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2232]!, self._r[2232]!, [_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 func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2236]!, self._r[2236]!, [_0]) + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2233]!, self._r[2233]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + public var Theme_Context_ChangeColors: String { return self._s[2234]! } + public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2235]! } + public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2236]! } + public func AuthSessions_AppUnofficial(_ _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 DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2238]!, self._r[2238]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + public var SocksProxySetup_Username: String { return self._s[2239]! } + public var Bot_Start: String { return self._s[2240]! } + public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2241]!, self._r[2241]!, [_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[2242]!, self._r[2242]!, [_0]) + } + public var Contacts_SortByPresence: String { return self._s[2243]! } + public var AccentColor_Title: String { return self._s[2246]! } + public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2247]! } 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[2248]!, self._r[2248]!, [_1, _2]) } public func PrivacySettings_LastSeenContactsMinus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2248]!, self._r[2248]!, [_0]) + return formatWithArgumentRanges(self._s[2249]!, self._r[2249]!, [_0]) } public func Channel_AdminLog_MessageChangedLinkedGroup(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2249]!, self._r[2249]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2250]!, self._r[2250]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[2250]! } - public var Login_InfoAvatarPhoto: String { return self._s[2251]! } + public var Passport_Email_EnterOtherEmail: String { return self._s[2251]! } + public var Login_InfoAvatarPhoto: String { return self._s[2252]! } public func ChatList_RemovedFromFolderTooltip(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2252]!, self._r[2252]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2253]!, self._r[2253]!, [_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 Privacy_PaymentsClear_ShippingInfo: String { return self._s[2254]! } + public var Tour_Title4: String { return self._s[2255]! } + public var Passport_Identity_Translation: String { return self._s[2256]! } + public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2257]! } + public var Login_TermsOfServiceLabel: String { return self._s[2259]! } + public var Passport_Language_it: String { return self._s[2260]! } + public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2261]! } + public var Passport_Identity_SelfieHelp: String { return self._s[2262]! } + public var Conversation_ClearAll: String { return self._s[2264]! } + public var Wallet_Send_UninitializedText: String { return self._s[2266]! } + public var Channel_OwnershipTransfer_Title: String { return self._s[2267]! } + public var TwoStepAuth_FloodError: String { return self._s[2268]! } public func PUSH_CHANNEL_MESSAGE_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2268]!, self._r[2268]!, [_1]) + return formatWithArgumentRanges(self._s[2269]!, self._r[2269]!, [_1]) } - public var Paint_Delete: String { return self._s[2269]! } + public var Paint_Delete: String { return self._s[2270]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2270]!, self._r[2270]!, [_0]) + return formatWithArgumentRanges(self._s[2271]!, self._r[2271]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2271]! } + public var Privacy_AddNewPeer: String { return self._s[2272]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2272]!, self._r[2272]!, [_1]) + return formatWithArgumentRanges(self._s[2273]!, self._r[2273]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2273]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2274]! } 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[2275]!, self._r[2275]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2275]! } + public var Message_PinnedAudioMessage: String { return self._s[2276]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2276]!, self._r[2276]!, [_0]) + return formatWithArgumentRanges(self._s[2277]!, self._r[2277]!, [_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[2278]! } + public var Notifications_GroupNotificationsSound: String { return self._s[2279]! } + public var Wallet_Month_GenNovember: String { return self._s[2280]! } + public var SocksProxySetup_ShareProxyList: String { return self._s[2281]! } + public var Conversation_MessageEditedLabel: String { return self._s[2282]! } 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[2283]!, self._r[2283]!, [_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[2284]! } + public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2285]! } 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[2286]!, self._r[2286]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2286]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2287]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2287]!, self._r[2287]!, [_1]) + return formatWithArgumentRanges(self._s[2288]!, self._r[2288]!, [_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[2289]! } + public var Month_GenOctober: String { return self._s[2290]! } + public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2291]! } + public var EnterPasscode_EnterPasscode: String { return self._s[2292]! } + public var MediaPicker_TimerTooltip: String { return self._s[2294]! } + public var SharedMedia_TitleAll: String { return self._s[2295]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2298]! } + public var Conversation_RestrictedMedia: String { return self._s[2299]! } + public var AccessDenied_PhotosRestricted: String { return self._s[2300]! } + public var Privacy_Forwards_WhoCanForward: String { return self._s[2302]! } + public var ChangePhoneNumberCode_Called: String { return self._s[2303]! } public func Notification_PinnedDocumentMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2303]!, self._r[2303]!, [_0]) + return formatWithArgumentRanges(self._s[2304]!, self._r[2304]!, [_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[2307]! } + public var Your_cards_expiration_month_is_invalid: String { return self._s[2309]! } + public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2310]! } public func Target_ShareGameConfirmationGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2311]!, self._r[2311]!, [_0]) + return formatWithArgumentRanges(self._s[2312]!, self._r[2312]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2312]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2313]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2313]!, self._r[2313]!, [_0]) + return formatWithArgumentRanges(self._s[2314]!, self._r[2314]!, [_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[2315]! } + public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2316]! } 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[2317]!, self._r[2317]!, [_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[2318]! } + public var PhotoEditor_FadeTool: String { return self._s[2319]! } + public var Privacy_ContactsReset: String { return self._s[2320]! } public func Channel_AdminLog_MessageRestrictedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2321]!, self._r[2321]!, [_0]) + return formatWithArgumentRanges(self._s[2322]!, self._r[2322]!, [_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[2323]! } + public var ChatList_Mute: String { return self._s[2324]! } 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[2325]!, self._r[2325]!, [_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[2326]! } + public var Conversation_PinnedQuiz: String { return self._s[2328]! } + public var ShareMenu_SelectChats: String { return self._s[2330]! } + public var ChatList_Context_Unarchive: String { return self._s[2331]! } + public var MusicPlayer_VoiceNote: String { return self._s[2332]! } + public var Conversation_RestrictedText: String { return self._s[2333]! } + public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2334]! } + public var Wallet_Month_GenApril: String { return self._s[2335]! } + public var Wallet_Month_ShortMarch: String { return self._s[2336]! } + public var TwoStepAuth_DisableSuccess: String { return self._s[2337]! } + public var Chat_PsaTooltip_covid: String { return self._s[2338]! } + public var Cache_Videos: String { return self._s[2339]! } + public var PrivacySettings_PhoneNumber: String { return self._s[2340]! } + public var Wallet_Month_GenFebruary: String { return self._s[2341]! } + public var FeatureDisabled_Oops: String { return self._s[2343]! } + public var ChatList_RemoveFolderAction: String { return self._s[2344]! } + public var Passport_Address_PostcodePlaceholder: String { return self._s[2345]! } public func AddContact_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2345]!, self._r[2345]!, [_0]) + return formatWithArgumentRanges(self._s[2346]!, self._r[2346]!, [_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[2348]! } + public var GroupPermission_NoSendPolls: String { return self._s[2349]! } + public var Wallet_Qr_ScanCode: String { return self._s[2350]! } + public var Message_VideoExpired: String { return self._s[2352]! } + public var GroupInfo_GroupHistoryVisible: String { return self._s[2353]! } + public var Notifications_Badge: String { return self._s[2354]! } + public var Wallet_Receive_AddressCopied: String { return self._s[2355]! } + public var CreatePoll_OptionPlaceholder: String { return self._s[2356]! } + public var Username_InvalidTooShort: String { return self._s[2357]! } + public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2358]! } + public var Channel_AdminLog_PinMessages: String { return self._s[2359]! } + public var ArchivedChats_IntroTitle3: String { return self._s[2360]! } public func Notification_MessageLifetimeRemoved(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2360]!, self._r[2360]!, [_1]) + return formatWithArgumentRanges(self._s[2361]!, self._r[2361]!, [_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[2362]! } + public var Conversation_DefaultRestrictedText: String { return self._s[2363]! } + public var SharedMedia_CategoryDocs: String { return self._s[2366]! } public func PUSH_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2366]!, self._r[2366]!, [_1]) + return formatWithArgumentRanges(self._s[2367]!, self._r[2367]!, [_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[2368]! } + public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2369]! } + public var Privacy_Forwards_NeverLink: String { return self._s[2371]! } public func Notification_MessageLifetimeChangedOutgoing(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2371]!, self._r[2371]!, [_1]) + return formatWithArgumentRanges(self._s[2372]!, self._r[2372]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2372]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2373]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2373]!, self._r[2373]!, [_0]) + return formatWithArgumentRanges(self._s[2374]!, self._r[2374]!, [_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[2375]! } + public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2376]! } + public var Conversation_PrivateMessageLinkCopied: String { return self._s[2377]! } + public var Channel_UpdatePhotoItem: String { return self._s[2378]! } + public var GroupInfo_LeftStatus: String { return self._s[2379]! } + public var Watch_MessageView_Forward: String { return self._s[2381]! } + public var ReportPeer_ReasonChildAbuse: String { return self._s[2382]! } + public var Cache_ClearEmpty: String { return self._s[2384]! } + public var Localization_LanguageName: String { return self._s[2385]! } + public var Wallet_AccessDenied_Title: String { return self._s[2386]! } + public var WebSearch_GIFs: String { return self._s[2387]! } + public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2388]! } + public var Wallet_AccessDenied_Settings: String { return self._s[2389]! } + public var Username_InvalidStartsWithNumber: String { return self._s[2390]! } + public var Common_Back: String { return self._s[2391]! } + public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2392]! } + public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2393]! } + public var Wallet_Send_Send: String { return self._s[2394]! } 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[2396]!, self._r[2396]!, [_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[2397]! } + public var ChatList_Tabs_All: String { return self._s[2398]! } + public var Wallet_Month_GenJune: String { return self._s[2399]! } + public var Passport_Email_Help: String { return self._s[2400]! } + public var Watch_Conversation_Reply: String { return self._s[2402]! } + public var Conversation_EditingMessageMediaChange: String { return self._s[2405]! } + public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2406]! } + public var Channel_BanUser_Unban: String { return self._s[2408]! } + public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2409]! } + public var Group_Username_CreatePublicLinkHelp: String { return self._s[2410]! } + public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2412]! } + public var Wallet_Send_AddressHeader: String { return self._s[2413]! } + public var Passport_Identity_Name: String { return self._s[2414]! } public func Channel_DiscussionGroup_HeaderGroupSet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2414]!, self._r[2414]!, [_0]) + return formatWithArgumentRanges(self._s[2415]!, self._r[2415]!, [_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[2416]! } + public var Conversation_BlockUser: String { return self._s[2417]! } + public var Month_GenJanuary: String { return self._s[2418]! } + public var ChatSettings_TextSize: String { return self._s[2419]! } + public var Notification_PassportValuePhone: String { return self._s[2420]! } + public var MediaPlayer_UnknownArtist: String { return self._s[2421]! } + public var Passport_Language_ne: String { return self._s[2422]! } + public var Notification_CallBack: String { return self._s[2423]! } + public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2424]! } + public var TwoStepAuth_EmailHelp: String { return self._s[2425]! } public func Time_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2425]!, self._r[2425]!, [_0]) + return formatWithArgumentRanges(self._s[2426]!, self._r[2426]!, [_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[2427]! } + public var Passport_FieldIdentityUploadHelp: String { return self._s[2428]! } + public var Stickers_FrequentlyUsed: String { return self._s[2430]! } + public var Channel_BanUser_PermissionSendMessages: String { return self._s[2431]! } + public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2433]! } 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[2434]!, self._r[2434]!, [_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[2435]! } + public var Passport_Address_EditResidentialAddress: String { return self._s[2436]! } + public var PrivacyPolicy_DeclineTitle: String { return self._s[2437]! } + public var CreatePoll_TextHeader: String { return self._s[2438]! } public func Checkout_SavePasswordTimeoutAndTouchId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2438]!, self._r[2438]!, [_0]) + return formatWithArgumentRanges(self._s[2439]!, self._r[2439]!, [_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[2440]! } + public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2441]! } + public var Conversation_StatusKickedFromChannel: String { return self._s[2443]! } + public var CheckoutInfo_ReceiverInfoName: String { return self._s[2444]! } + public var Group_ErrorSendRestrictedStickers: String { return self._s[2445]! } public func Conversation_RestrictedInlineTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2445]!, self._r[2445]!, [_0]) + return formatWithArgumentRanges(self._s[2446]!, self._r[2446]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2446]!, self._r[2446]!, [_1]) + return formatWithArgumentRanges(self._s[2447]!, self._r[2447]!, [_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[2448]! } + public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2449]! } + public var Conversation_LinkDialogOpen: String { return self._s[2451]! } + public var TwoFactorSetup_Hint_Title: String { return self._s[2452]! } + public var VoiceOver_Chat_PollNoVotes: String { return self._s[2453]! } + public var Settings_Username: String { return self._s[2455]! } + public var Conversation_Block: String { return self._s[2457]! } + public var Wallpaper_Wallpaper: String { return self._s[2458]! } + public var SocksProxySetup_UseProxy: String { return self._s[2460]! } + public var Wallet_Send_Confirmation: String { return self._s[2461]! } + public var EditTheme_UploadEditedTheme: String { return self._s[2462]! } + public var UserInfo_ShareMyContactInfo: String { return self._s[2463]! } + public var MessageTimer_Forever: String { return self._s[2464]! } + public var Privacy_Calls_WhoCanCallMe: String { return self._s[2465]! } + public var PhotoEditor_DiscardChanges: String { return self._s[2466]! } + public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2467]! } + public var Passport_Language_da: String { return self._s[2468]! } + public var SocksProxySetup_PortPlaceholder: String { return self._s[2470]! } public func SecretGIF_NotViewedYet(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2470]!, self._r[2470]!, [_0]) + return formatWithArgumentRanges(self._s[2471]!, self._r[2471]!, [_0]) } - public var Passport_Address_EditPassportRegistration: String { return self._s[2471]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2472]! } public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2473]!, self._r[2473]!, [_0]) + return formatWithArgumentRanges(self._s[2474]!, self._r[2474]!, [_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[2475]! } + public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2477]! } + public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2478]! } + public var Conversation_SearchByName_Prefix: String { return self._s[2479]! } + public var Conversation_PinnedPoll: String { return self._s[2480]! } + public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2481]! } + public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2482]! } + public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2483]! } public func PUSH_ENCRYPTION_ACCEPT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2483]!, self._r[2483]!, [_1]) + return formatWithArgumentRanges(self._s[2484]!, self._r[2484]!, [_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[2485]! } + public var Cache_ByPeerHeader: String { return self._s[2486]! } public func Conversation_EncryptedPlaceholderTitleIncoming(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2486]!, self._r[2486]!, [_0]) + return formatWithArgumentRanges(self._s[2487]!, self._r[2487]!, [_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[2488]! } + public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2491]! } + public var Wallet_Completed_Title: String { return self._s[2492]! } + public var Notification_PinnedMessage: String { return self._s[2493]! } + public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2494]! } + public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2496]! } + public var Contacts_SortBy: String { return self._s[2497]! } public func PUSH_CHANNEL_MESSAGE_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2497]!, self._r[2497]!, [_1]) + return formatWithArgumentRanges(self._s[2498]!, self._r[2498]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2499]! } + public var Appearance_ColorThemeNight: String { return self._s[2500]! } 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[2501]!, self._r[2501]!, [_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[2502]! } + public var Watch_UserInfo_Service: String { return self._s[2503]! } + public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2505]! } + public var Conversation_Unpin: String { return self._s[2507]! } + public var CancelResetAccount_Title: String { return self._s[2508]! } + public var Map_LiveLocationFor15Minutes: String { return self._s[2509]! } 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[2511]!, self._r[2511]!, [_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[2512]! } + public var Appearance_BubbleCorners_Title: String { return self._s[2513]! } + public var CallSettings_Title: String { return self._s[2514]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2515]! } + public var PasscodeSettings_EncryptDataHelp: String { return self._s[2517]! } + public var AutoDownloadSettings_Contacts: String { return self._s[2518]! } 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[2519]!, self._r[2519]!, [_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[2520]! } + public var Passport_Identity_DocumentDetails: String { return self._s[2521]! } + public var LoginPassword_PasswordHelp: String { return self._s[2522]! } + public var ChatListFolderSettings_Info: String { return self._s[2523]! } + public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2524]! } + public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2525]! } + public var ChatContextMenu_TextSelectionTip: String { return self._s[2526]! } + public var ChatListFolder_CategoryGroups: String { return self._s[2527]! } + public var Checkout_TotalPaidAmount: String { return self._s[2528]! } public func FileSize_KB(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2528]!, self._r[2528]!, [_0]) + return formatWithArgumentRanges(self._s[2529]!, self._r[2529]!, [_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[2530]! } + public var PasscodeSettings_ChangePasscode: String { return self._s[2531]! } + public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2532]! } + public var Conversation_SecretLinkPreviewAlert: String { return self._s[2534]! } + public var Privacy_SecretChatsLinkPreviews: String { return self._s[2535]! } public func PUSH_CHANNEL_MESSAGE_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2535]!, self._r[2535]!, [_1]) + return formatWithArgumentRanges(self._s[2536]!, self._r[2536]!, [_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[2537]! } + public var Contacts_InviteFriends: String { return self._s[2539]! } + public var Map_ChooseLocationTitle: String { return self._s[2540]! } + public var Conversation_StopPoll: String { return self._s[2542]! } public func WebSearch_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2542]!, self._r[2542]!, [_0]) + return formatWithArgumentRanges(self._s[2543]!, self._r[2543]!, [_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[2544]! } + public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2545]! } + public var AppWallet_Intro_Text: String { return self._s[2546]! } + public var Appearance_BubbleCornersSetting: String { return self._s[2547]! } + public var Calls_RatingFeedback: String { return self._s[2548]! } public func Conversation_NoticeInvitedByInGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2549]!, self._r[2549]!, [_0]) + return formatWithArgumentRanges(self._s[2550]!, self._r[2550]!, [_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[2551]! } + public var Wallet_Alert_OK: String { return self._s[2552]! } + public var NotificationsSound_Pulse: String { return self._s[2553]! } + public var Watch_LastSeen_Lately: String { return self._s[2554]! } + public var ReportGroupLocation_Report: String { return self._s[2557]! } + public var Widget_NoUsers: String { return self._s[2558]! } + public var Conversation_UnvotePoll: String { return self._s[2559]! } + public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2561]! } + public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2562]! } + public var NotificationsSound_Circles: String { return self._s[2563]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2566]! } + public var Wallet_Settings_DeleteWallet: String { return self._s[2567]! } + public var ChatListFolder_CategoryBots: String { return self._s[2568]! } + public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2569]! } + public var Proxy_TooltipUnavailable: String { return self._s[2570]! } + public var Passport_Identity_CountryPlaceholder: String { return self._s[2572]! } + public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2574]! } + public var Conversation_FileDropbox: String { return self._s[2575]! } + public var Notifications_ExceptionsUnmuted: String { return self._s[2576]! } + public var Tour_Text3: String { return self._s[2578]! } + public var Login_ResetAccountProtected_Title: String { return self._s[2581]! } + public var ChatListFolder_NamePlaceholder: String { return self._s[2582]! } + public var GroupPermission_NoSendMessages: String { return self._s[2583]! } + public var WallpaperSearch_ColorTitle: String { return self._s[2584]! } + public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2585]! } public func Conversation_LiveLocationYouAnd(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2586]!, self._r[2586]!, [_0]) + return formatWithArgumentRanges(self._s[2587]!, self._r[2587]!, [_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 var GroupInfo_AddParticipantTitle: String { return self._s[2588]! } + public var Checkout_ShippingOption_Title: String { return self._s[2589]! } + public var ChatSettings_AutoDownloadTitle: String { return self._s[2590]! } 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 func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2592]!, self._r[2592]!, [_0]) + } + public var Channel_Management_LabelAdministrator: String { return self._s[2593]! } + public var EditTheme_FileReadError: String { return self._s[2594]! } + public var OwnershipTransfer_ComeBackLater: String { return self._s[2595]! } + public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2596]! } + public var AutoDownloadSettings_Photos: String { return self._s[2598]! } + public var Appearance_PreviewIncomingText: String { return self._s[2599]! } + public var ChatList_Context_MarkAllAsRead: String { return self._s[2600]! } + public var ChannelInfo_ConfirmLeave: String { return self._s[2601]! } + public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2602]! } + public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2603]! } + public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2604]! } + public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2605]! } + public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2606]! } + public var GroupInfo_SetGroupPhotoStop: String { return self._s[2607]! } + public var Notification_SecretChatScreenshot: String { return self._s[2608]! } + public var AccessDenied_Wallpapers: String { return self._s[2609]! } + public var ChatList_Context_Mute: String { return self._s[2611]! } + public var Passport_Address_City: String { return self._s[2612]! } + public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2613]! } + public var Appearance_ThemeCarouselClassic: String { return self._s[2614]! } + public var SocksProxySetup_SecretPlaceholder: String { return self._s[2615]! } + public var AccessDenied_LocationDisabled: String { return self._s[2616]! } + public var Group_Location_Title: String { return self._s[2617]! } + public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2619]! } + public var GroupInfo_Sound: String { return self._s[2620]! } + public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2621]! } + public var ChannelInfo_ScamChannelWarning: String { return self._s[2622]! } + public var Stickers_RemoveFromFavorites: String { return self._s[2623]! } + public var Contacts_Title: String { return self._s[2624]! } + public var EditTheme_ThemeTemplateAlertText: String { return self._s[2625]! } + public var Passport_Language_fr: String { return self._s[2626]! } + public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2627]! } + public var Notifications_ResetAllNotifications: String { return self._s[2628]! } + public var IntentsSettings_SuggestedChats: String { return self._s[2630]! } + public var PrivacySettings_SecurityTitle: String { return self._s[2632]! } + public var Checkout_NewCard_Title: String { return self._s[2633]! } + public var Login_HaveNotReceivedCodeInternal: String { return self._s[2634]! } + public var Conversation_ForwardChats: String { return self._s[2635]! } + public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2637]! } + public var PasscodeSettings_4DigitCode: String { return self._s[2638]! } + public var Settings_FAQ: String { return self._s[2640]! } + public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2641]! } + public var Conversation_ContextMenuForward: String { return self._s[2642]! } + public var VoiceOver_Chat_YourPhoto: String { return self._s[2645]! } + public var PrivacyPolicy_Title: String { return self._s[2648]! } + public var Notifications_TextTone: String { return self._s[2649]! } + public var Profile_CreateNewContact: String { return self._s[2650]! } + public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2651]! } + public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2653]! } + public var Call_Speaker: String { return self._s[2654]! } + public var AutoNightTheme_AutomaticSection: String { return self._s[2655]! } + public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2657]! } + public var Channel_Username_InvalidCharacters: String { return self._s[2658]! } public func Channel_AdminLog_MessageChangedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2658]!, self._r[2658]!, [_0]) + return formatWithArgumentRanges(self._s[2659]!, self._r[2659]!, [_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[2660]! } + public var PrivacySettings_LastSeenTitle: String { return self._s[2661]! } + public var Channel_AdminLog_CanInviteUsers: String { return self._s[2662]! } + public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2663]! } + public var OwnershipTransfer_SecurityCheck: String { return self._s[2664]! } + public var Conversation_MessageDeliveryFailed: String { return self._s[2665]! } + public var Watch_ChatList_NoConversationsText: String { return self._s[2666]! } + public var Bot_Unblock: String { return self._s[2667]! } + public var TextFormat_Italic: String { return self._s[2668]! } + public var WallpaperSearch_ColorPink: String { return self._s[2669]! } + public var Settings_About_Help: String { return self._s[2671]! } + public var SearchImages_Title: String { return self._s[2672]! } + public var Weekday_Wednesday: String { return self._s[2673]! } + public var Conversation_ClousStorageInfo_Description1: String { return self._s[2674]! } + public var ExplicitContent_AlertTitle: String { return self._s[2675]! } 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[2676]!, self._r[2676]!, [_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[2677]! } + public var Weekday_Thursday: String { return self._s[2678]! } + public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2679]! } + public var Channel_Members_AddMembersHelp: String { return self._s[2680]! } public func Checkout_SavePasswordTimeout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2680]!, self._r[2680]!, [_0]) + return formatWithArgumentRanges(self._s[2681]!, self._r[2681]!, [_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[2682]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2683]! } + public var Passport_RequestedInformation: String { return self._s[2684]! } + public var Login_PhoneAndCountryHelp: String { return self._s[2685]! } + public var Conversation_EncryptionProcessing: String { return self._s[2687]! } + public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2688]! } + public var PhotoEditor_EnhanceTool: String { return self._s[2690]! } + public var Channel_Setup_Title: String { return self._s[2691]! } + public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2692]! } + public var Conversation_SearchPlaceholder: String { return self._s[2693]! } + public var OldChannels_GroupEmptyFormat: String { return self._s[2694]! } + public var AccessDenied_LocationAlwaysDenied: String { return self._s[2695]! } + public var Checkout_ErrorGeneric: String { return self._s[2696]! } + public var Passport_Language_hu: String { return self._s[2697]! } + public var GroupPermission_EditingDisabled: String { return self._s[2698]! } + public var Wallet_Month_ShortSeptember: String { return self._s[2700]! } public func Passport_Identity_UploadOneOfScan(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2700]!, self._r[2700]!, [_0]) + return formatWithArgumentRanges(self._s[2701]!, self._r[2701]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2703]!, self._r[2703]!, [_1]) + return formatWithArgumentRanges(self._s[2704]!, self._r[2704]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2704]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2705]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_0]) + return formatWithArgumentRanges(self._s[2706]!, self._r[2706]!, [_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 var Conversation_CloudStorageInfo_Title: String { return self._s[2707]! } + public var Group_Location_Info: String { return self._s[2708]! } + public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2709]! } + public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2710]! } public func Notification_Exceptions_MutedUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2710]!, self._r[2710]!, [_0]) + return formatWithArgumentRanges(self._s[2711]!, self._r[2711]!, [_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 var Conversation_ClearPrivateHistory: String { return self._s[2712]! } + public var ContactInfo_PhoneLabelHome: String { return self._s[2713]! } + public var Appearance_RemoveThemeConfirmation: String { return self._s[2714]! } + public var PrivacySettings_LastSeenContacts: String { return self._s[2715]! } public func ChangePhone_ErrorOccupied(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2715]!, self._r[2715]!, [_0]) - } - public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2716]!, self._r[2716]!, [_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 func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2717]!, self._r[2717]!, [_0]) + } + public var Passport_Language_cs: String { return self._s[2718]! } + public var Message_PinnedAnimationMessage: String { return self._s[2720]! } + public var Passport_Identity_ReverseSideHelp: String { return self._s[2722]! } + public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2723]! } + public var Wallet_Info_TransactionTo: String { return self._s[2725]! } + public var Stats_ViewsBySourceTitle: String { return self._s[2726]! } + public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2727]! } + public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2728]! } + public var Embed_PlayingInPIP: String { return self._s[2729]! } + public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2730]! } + public var AutoNightTheme_ScheduleSection: String { return self._s[2731]! } public func Call_EmojiDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2731]!, self._r[2731]!, [_0]) + return formatWithArgumentRanges(self._s[2732]!, self._r[2732]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2732]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2733]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2733]!, self._r[2733]!, [_1]) + return formatWithArgumentRanges(self._s[2734]!, self._r[2734]!, [_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[2735]! } + public var PhotoEditor_CurvesGreen: String { return self._s[2736]! } + public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2737]! } + public var AutoNightTheme_System: String { return self._s[2738]! } + public var SaveIncomingPhotosSettings_Title: String { return self._s[2739]! } + public var CreatePoll_QuizTitle: String { return self._s[2740]! } + public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2741]! } + public var VoiceOver_Chat_PagePreview: String { return self._s[2742]! } public func PUSH_MESSAGE_SCREENSHOT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2744]!, self._r[2744]!, [_1]) - } - public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2745]!, self._r[2745]!, [_1]) } - public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + public func PUSH_MESSAGE_PHOTO_SECRET(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2746]!, self._r[2746]!, [_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 func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2747]!, self._r[2747]!, [_1]) + } + public var NetworkUsageSettings_CallDataSection: String { return self._s[2749]! } + public var PasscodeSettings_HelpTop: String { return self._s[2750]! } + public var Conversation_WalletRequiredTitle: String { return self._s[2751]! } + public var PeerInfo_AddToContacts: String { return self._s[2752]! } + public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2753]! } + public var Passport_Address_TypeRentalAgreement: String { return self._s[2754]! } + public var FeaturedStickers_OtherSection: String { return self._s[2755]! } + public var EditTheme_ShortLink: String { return self._s[2756]! } + public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2757]! } + public var ProxyServer_VoiceOver_Active: String { return self._s[2758]! } + public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2759]! } + public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2760]! } + public var Call_Accept: String { return self._s[2762]! } + public var GroupRemoved_RemoveInfo: String { return self._s[2763]! } + public var Month_GenMarch: String { return self._s[2765]! } + public var PhotoEditor_ShadowsTool: String { return self._s[2766]! } + public var LoginPassword_Title: String { return self._s[2767]! } + public var Call_End: String { return self._s[2768]! } + public var Watch_Conversation_GroupInfo: String { return self._s[2769]! } + public var VoiceOver_Chat_Contact: String { return self._s[2770]! } + public var EditTheme_Create_Preview_IncomingText: String { return self._s[2771]! } + public var CallSettings_Always: String { return self._s[2772]! } + public var CallFeedback_Success: String { return self._s[2773]! } + public var TwoStepAuth_SetupHint: String { return self._s[2774]! } public func AddContact_ContactWillBeSharedAfterMutual(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2774]!, self._r[2774]!, [_1]) + return formatWithArgumentRanges(self._s[2775]!, self._r[2775]!, [_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[2776]! } + public var PeerInfo_ButtonAddMember: String { return self._s[2777]! } + public var Login_PhoneTitle: String { return self._s[2778]! } + public var Passport_FieldPhoneHelp: String { return self._s[2779]! } + public var Weekday_ShortSunday: String { return self._s[2780]! } + public var Passport_InfoFAQ_URL: String { return self._s[2781]! } + public var ContactInfo_Job: String { return self._s[2783]! } + public var UserInfo_InviteBotToGroup: String { return self._s[2784]! } + public var Appearance_ThemeCarouselNightBlue: String { return self._s[2785]! } + public var CreatePoll_QuizTip: String { return self._s[2786]! } + public var TwoFactorSetup_Email_Text: String { return self._s[2787]! } + public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2788]! } + public var Invite_ChannelsTooMuch: String { return self._s[2789]! } + public var Wallet_Send_ConfirmationConfirm: String { return self._s[2790]! } + public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2791]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2792]! } + public var Wallet_Receive_AmountText: String { return self._s[2793]! } + public var TwoStepAuth_Disable: String { return self._s[2794]! } + public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2795]! } + public var CallFeedback_ReasonNoise: String { return self._s[2796]! } + public var Appearance_AppIconDefault: String { return self._s[2798]! } + public var Passport_Identity_AddInternalPassport: String { return self._s[2799]! } + public var MediaPicker_AddCaption: String { return self._s[2800]! } + public var CallSettings_TabIconDescription: String { return self._s[2801]! } public func VoiceOver_Chat_Caption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2801]!, self._r[2801]!, [_0]) + return formatWithArgumentRanges(self._s[2802]!, self._r[2802]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2802]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2803]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2803]!, self._r[2803]!, [_0]) + return formatWithArgumentRanges(self._s[2804]!, self._r[2804]!, [_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[2806]! } + public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2807]! } + public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2808]! } + public var Passport_Identity_TypePersonalDetails: String { return self._s[2809]! } + public var DialogList_SearchSectionRecent: String { return self._s[2810]! } + public var PrivacyPolicy_DeclineMessage: String { return self._s[2811]! } + public var CreatePoll_Anonymous: String { return self._s[2812]! } + public var LogoutOptions_ClearCacheText: String { return self._s[2815]! } + public var LastSeen_WithinAWeek: String { return self._s[2816]! } + public var ChannelMembers_GroupAdminsTitle: String { return self._s[2817]! } + public var Conversation_CloudStorage_ChatStatus: String { return self._s[2819]! } + public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2820]! } public func AddContact_SharedContactExceptionInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2820]!, self._r[2820]!, [_0]) + return formatWithArgumentRanges(self._s[2821]!, self._r[2821]!, [_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[2822]! } + public var Conversation_StatusLeftGroup: String { return self._s[2823]! } + public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2824]! } + public var OwnershipTransfer_Transfer: String { return self._s[2826]! } + public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2827]! } + public var GroupPermission_AddSuccess: String { return self._s[2828]! } + public var PhotoEditor_BlurToolRadial: String { return self._s[2830]! } + public var Conversation_ContextMenuCopy: String { return self._s[2831]! } + public var AccessDenied_CallMicrophone: String { return self._s[2832]! } 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[2833]!, self._r[2833]!, [_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[2834]! } + public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2835]! } + public var Checkout_PaymentMethod_New: String { return self._s[2836]! } + public var ShareMenu_CopyShareLinkGame: String { return self._s[2837]! } + public var PhotoEditor_QualityTool: String { return self._s[2838]! } + public var Login_SendCodeViaSms: String { return self._s[2839]! } + public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2840]! } + public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2841]! } + public var Wallet_Receive_CopyAddress: String { return self._s[2842]! } + public var Login_EmailNotConfiguredError: String { return self._s[2843]! } + public var SocksProxySetup_Status: String { return self._s[2844]! } + public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2845]! } + public var PrivacyPolicy_Accept: String { return self._s[2846]! } + public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2847]! } + public var Appearance_AppIconClassicX: String { return self._s[2848]! } 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[2849]!, self._r[2849]!, [_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[2850]! } + public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2852]! } + public var AutoNightTheme_Automatic: String { return self._s[2853]! } + public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2854]! } + public var Privacy_ContactsSyncHelp: String { return self._s[2855]! } + public var Cache_Help: String { return self._s[2856]! } + public var Group_ErrorAccessDenied: String { return self._s[2857]! } + public var Passport_Language_fa: String { return self._s[2858]! } + public var Wallet_Intro_Text: String { return self._s[2859]! } + public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2860]! } + public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2861]! } + public var PrivacySettings_LastSeen: String { return self._s[2862]! } 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[2863]!, self._r[2863]!, [_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[2867]! } + public var Preview_SaveGif: String { return self._s[2868]! } + public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2869]! } + public var Profile_About: String { return self._s[2870]! } + public var Channel_About_Placeholder: String { return self._s[2871]! } + public var Login_InfoTitle: String { return self._s[2872]! } public func TwoStepAuth_SetupPendingEmail(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2872]!, self._r[2872]!, [_0]) + return formatWithArgumentRanges(self._s[2873]!, self._r[2873]!, [_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[2874]! } + public var Watch_Suggestion_CantTalk: String { return self._s[2876]! } + public var ContactInfo_Title: String { return self._s[2877]! } + public var Media_ShareThisVideo: String { return self._s[2878]! } + public var Chat_GenericPsaTooltip: String { return self._s[2879]! } + public var Weekday_ShortFriday: String { return self._s[2880]! } + public var AccessDenied_Contacts: String { return self._s[2882]! } + public var Notification_CallIncomingShort: String { return self._s[2883]! } + public var Group_Setup_TypePublic: String { return self._s[2884]! } + public var Notifications_MessageNotificationsExceptions: String { return self._s[2885]! } + public var Notifications_Badge_IncludeChannels: String { return self._s[2886]! } + public var Notifications_MessageNotificationsPreview: String { return self._s[2889]! } + public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2890]! } + public var Group_ErrorAddTooMuchBots: String { return self._s[2891]! } + public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2892]! } + public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2893]! } public func Wallet_SecureStorageChanged_BiometryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2893]!, self._r[2893]!, [_0]) + return formatWithArgumentRanges(self._s[2894]!, self._r[2894]!, [_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[2895]! } + public var CallFeedback_IncludeLogs: String { return self._s[2897]! } + public var Checkout_Phone: String { return self._s[2899]! } + public var Login_InfoFirstNamePlaceholder: String { return self._s[2902]! } + public var Privacy_Calls_Integration: String { return self._s[2903]! } + public var Notifications_PermissionsAllow: String { return self._s[2904]! } + public var TwoStepAuth_AddHintDescription: String { return self._s[2910]! } + public var Settings_ChatSettings: String { return self._s[2911]! } + public var Conversation_SendingOptionsTooltip: String { return self._s[2912]! } public func UserInfo_StartSecretChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2913]!, self._r[2913]!, [_0]) + return formatWithArgumentRanges(self._s[2914]!, self._r[2914]!, [_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[2915]!, self._r[2915]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2916]! } + public var GroupRemoved_DeleteUser: String { return self._s[2917]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2917]!, self._r[2917]!, [_0]) + return formatWithArgumentRanges(self._s[2918]!, self._r[2918]!, [_0]) } - public var ChatListFolder_CategoryMuted: String { return self._s[2918]! } + public var ChatListFolder_CategoryMuted: String { return self._s[2919]! } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2919]!, self._r[2919]!, [_1]) + return formatWithArgumentRanges(self._s[2920]!, self._r[2920]!, [_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[2921]! } + public var Watch_Message_ForwardedFrom: String { return self._s[2922]! } + public var TwoStepAuth_EnterEmailCode: String { return self._s[2924]! } + public var Conversation_Unblock: String { return self._s[2925]! } + public var PrivacySettings_DataSettings: String { return self._s[2926]! } + public var WallpaperPreview_PatternPaternApply: String { return self._s[2927]! } + public var Group_PublicLink_Info: String { return self._s[2928]! } 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[2929]!, self._r[2929]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2929]! } + public var Notifications_InAppNotificationsVibrate: String { return self._s[2930]! } 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[2931]!, self._r[2931]!, [_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[2932]! } + public var OldChannels_ChannelsHeader: String { return self._s[2934]! } + public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2935]! } + public var PrivacySettings_Passcode: String { return self._s[2937]! } + public var Call_Mute: String { return self._s[2938]! } + public var Wallet_Weekday_Yesterday: String { return self._s[2939]! } + public var Passport_Language_dz: String { return self._s[2940]! } + public var Wallet_Receive_AmountHeader: String { return self._s[2941]! } + public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2942]! } + public var Passport_Language_tk: String { return self._s[2943]! } public func Login_EmailCodeSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2943]!, self._r[2943]!, [_0]) + return formatWithArgumentRanges(self._s[2944]!, self._r[2944]!, [_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[2945]! } + public var Wallet_Month_ShortFebruary: String { return self._s[2946]! } + public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2947]! } + public var Wallet_Configuration_SourceJSON: String { return self._s[2948]! } + public var Conversation_ContextMenuReply: String { return self._s[2949]! } + public var WallpaperSearch_ColorBrown: String { return self._s[2950]! } + public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2951]! } + public var Tour_Title1: String { return self._s[2952]! } + public var Wallet_Alert_Cancel: String { return self._s[2953]! } + public var Stats_Total: String { return self._s[2955]! } + public var Conversation_ClearGroupHistory: String { return self._s[2956]! } + public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2957]! } + public var WallpaperPreview_Motion: String { return self._s[2958]! } public func Checkout_PasswordEntry_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2958]!, self._r[2958]!, [_0]) + return formatWithArgumentRanges(self._s[2959]!, self._r[2959]!, [_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[2960]! } + public var Call_RateCall: String { return self._s[2961]! } + public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2962]! } + public var Passport_PasswordCompleteSetup: String { return self._s[2963]! } + public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2964]! } + public var UserInfo_LastNamePlaceholder: String { return self._s[2966]! } public func Login_WillCallYou(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2967]!, self._r[2967]!, [_0]) + return formatWithArgumentRanges(self._s[2968]!, self._r[2968]!, [_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[2969]! } + public var Contacts_InviteToTelegram: String { return self._s[2970]! } + public var GroupInfo_Notifications: String { return self._s[2971]! } + public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2973]! } + public var Message_PinnedLiveLocationMessage: String { return self._s[2974]! } + public var Month_GenApril: String { return self._s[2975]! } + public var Appearance_AutoNightTheme: String { return self._s[2976]! } + public var ChatSettings_AutomaticAudioDownload: String { return self._s[2978]! } + public var Login_CodeSentSms: String { return self._s[2980]! } public func UserInfo_UnblockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2980]!, self._r[2980]!, [_0]) + return formatWithArgumentRanges(self._s[2981]!, self._r[2981]!, [_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 var EmptyGroupInfo_Line3: String { return self._s[2982]! } + public var LogoutOptions_ContactSupportText: String { return self._s[2983]! } + public var Passport_Language_hr: String { return self._s[2984]! } + public var Common_ActionNotAllowedError: String { return self._s[2985]! } public func Channel_AdminLog_MessageRestrictedNewSetting(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_0]) + return formatWithArgumentRanges(self._s[2986]!, self._r[2986]!, [_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 GroupInfo_InviteLink_CopyLink: String { return self._s[2987]! } + public var Wallet_Info_TransactionFrom: String { return self._s[2988]! } + public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2989]! } + public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2990]! } + public var Privacy_SecretChatsTitle: String { return self._s[2991]! } + public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2993]! } + public var GroupInfo_AddUserLeftError: String { return self._s[2994]! } + public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2995]! } + public var ChatListFolder_NameSectionHeader: String { return self._s[2996]! } + public var LogoutOptions_ContactSupportTitle: String { return self._s[2997]! } + public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2998]! } + public var Channel_AddBotErrorHaveRights: String { return self._s[2999]! } + public var Preview_DeleteGif: String { return self._s[3000]! } + public var GroupInfo_Permissions_Exceptions: String { return self._s[3001]! } + public var Group_ErrorNotMutualContact: String { return self._s[3002]! } + public var Notification_MessageLifetime5s: String { return self._s[3003]! } + public var Wallet_Send_OwnAddressAlertText: String { return self._s[3004]! } + public var OldChannels_ChannelFormat: String { return self._s[3005]! } public func Watch_LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3005]!, self._r[3005]!, [_0]) + return formatWithArgumentRanges(self._s[3006]!, self._r[3006]!, [_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[3007]! } + public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3009]! } + public var ReportSpam_DeleteThisChat: String { return self._s[3010]! } + public var Passport_Address_AddBankStatement: String { return self._s[3011]! } + public var Notification_CallIncoming: String { return self._s[3012]! } + public var Wallet_Words_NotDoneTitle: String { return self._s[3013]! } + public var Compose_NewGroupTitle: String { return self._s[3014]! } + public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3016]! } + public var Passport_Address_Postcode: String { return self._s[3018]! } public func LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3018]!, self._r[3018]!, [_0]) + return formatWithArgumentRanges(self._s[3019]!, self._r[3019]!, [_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[3020]! } + public var Wallet_Month_ShortOctober: String { return self._s[3021]! } + public var VoiceOver_Chat_YourMusic: String { return self._s[3022]! } + public var WallpaperColors_Title: String { return self._s[3023]! } + public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3024]! } + public var VoiceOver_MessageContextForward: String { return self._s[3025]! } + public var GroupPermission_Duration: String { return self._s[3026]! } public func Cache_Clear(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3026]!, self._r[3026]!, [_0]) + return formatWithArgumentRanges(self._s[3027]!, self._r[3027]!, [_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[3028]! } + public var Username_Placeholder: String { return self._s[3029]! } + public var CallFeedback_WhatWentWrong: String { return self._s[3030]! } + public var Passport_FieldAddressUploadHelp: String { return self._s[3031]! } + public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3032]! } 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[3034]!, self._r[3034]!, [_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[3035]! } + public var Channel_MessagePhotoUpdated: String { return self._s[3036]! } + public var MediaPicker_TapToUngroupDescription: String { return self._s[3037]! } + public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3038]! } + public var AttachmentMenu_PhotoOrVideo: String { return self._s[3039]! } + public var Conversation_ContextMenuMore: String { return self._s[3040]! } + public var Privacy_PaymentsClearInfo: String { return self._s[3041]! } + public var CallSettings_TabIcon: String { return self._s[3042]! } + public var KeyCommand_Find: String { return self._s[3043]! } + public var ClearCache_FreeSpaceDescription: String { return self._s[3044]! } + public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3045]! } + public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3046]! } public func Conversation_NoticeInvitedByInChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3046]!, self._r[3046]!, [_0]) + return formatWithArgumentRanges(self._s[3047]!, self._r[3047]!, [_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[3048]! } + public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3049]! } + public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3051]! } + public var Login_CallRequestState2: String { return self._s[3053]! } + public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3055]! } public func VoiceOver_Chat_PhotoFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3055]!, self._r[3055]!, [_0]) + return formatWithArgumentRanges(self._s[3056]!, self._r[3056]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3057]!, self._r[3057]!, [_0]) + return formatWithArgumentRanges(self._s[3058]!, self._r[3058]!, [_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 var AuthSessions_AddDevice: String { return self._s[3059]! } + public var WallpaperPreview_Blurred: String { return self._s[3060]! } + public var Conversation_InstantPagePreview: String { return self._s[3061]! } + public var PeerInfo_ButtonUnmute: String { return self._s[3062]! } public func DialogList_SingleUploadingVideoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_0]) + return formatWithArgumentRanges(self._s[3063]!, self._r[3063]!, [_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 ChatList_PeerTypeChannel: String { return self._s[3064]! } + public var SecretTimer_VideoDescription: String { return self._s[3067]! } + public var WallpaperSearch_ColorRed: String { return self._s[3068]! } + public var GroupPermission_NoPinMessages: String { return self._s[3069]! } + public var Passport_Language_es: String { return self._s[3070]! } + public var Permissions_ContactsAllow_v0: String { return self._s[3072]! } + public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3073]! } 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[3074]!, self._r[3074]!, [_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[3075]! } + public var WebPreview_GettingLinkInfo: String { return self._s[3077]! } + public var Watch_UserInfo_Unmute: String { return self._s[3078]! } + public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3079]! } + public var AccessDenied_CameraRestricted: String { return self._s[3081]! } public func Conversation_Kilobytes(_ _0: Int) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3081]!, self._r[3081]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[3082]!, self._r[3082]!, ["\(_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[3084]! } + public var Settings_CopyUsername: String { return self._s[3085]! } + public var Contacts_SearchLabel: String { return self._s[3086]! } + public var Map_OpenInYandexNavigator: String { return self._s[3088]! } + public var PasscodeSettings_EncryptData: String { return self._s[3089]! } + public var Settings_Wallet: String { return self._s[3090]! } + public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3091]! } + public var ChatList_PeerTypeBot: String { return self._s[3092]! } + public var WallpaperSearch_ColorPrefix: String { return self._s[3093]! } + public var Notifications_GroupNotificationsPreview: String { return self._s[3094]! } + public var DialogList_AdNoticeAlert: String { return self._s[3095]! } + public var Wallet_Month_GenMay: String { return self._s[3097]! } + public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3098]! } + public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3099]! } + public var Localization_LanguageCustom: String { return self._s[3100]! } + public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3101]! } + public var CallFeedback_Title: String { return self._s[3102]! } + public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3105]! } + public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3106]! } + public var Wallet_Intro_CreateErrorTitle: String { return self._s[3107]! } + public var Conversation_InfoGroup: String { return self._s[3108]! } + public var Compose_NewMessage: String { return self._s[3109]! } + public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3110]! } + public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3111]! } + public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3112]! } + public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3113]! } public func Passport_Scans_ScanIndex(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3113]!, self._r[3113]!, [_0]) + return formatWithArgumentRanges(self._s[3114]!, self._r[3114]!, [_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[3115]! } + public var Login_CancelSignUpConfirmation: String { return self._s[3116]! } + public var ChangePhoneNumberCode_Help: String { return self._s[3117]! } + public var PrivacySettings_DeleteAccountHelp: String { return self._s[3118]! } + public var ChatList_Context_RemoveFromFolder: String { return self._s[3119]! } + public var Channel_BlackList_Title: String { return self._s[3120]! } + public var UserInfo_PhoneCall: String { return self._s[3121]! } + public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3123]! } + public var Wallet_Month_ShortJanuary: String { return self._s[3124]! } + public var State_connecting: String { return self._s[3125]! } + public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3126]! } + public var Wallet_Month_GenMarch: String { return self._s[3127]! } + public var EditTheme_Expand_BottomInfo: String { return self._s[3128]! } + public var AuthSessions_AddedDeviceTerminate: String { return self._s[3129]! } public func LastSeen_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3129]!, self._r[3129]!, [_0]) - } - public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3130]!, self._r[3130]!, [_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 func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3148]!, self._r[3148]!, [_1]) + public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3131]!, self._r[3131]!, [_0]) } - 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 Notifications_GroupNotifications: String { return self._s[3132]! } + public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3133]! } + public var Passport_Identity_EditPassport: String { return self._s[3134]! } + public var EnterPasscode_RepeatNewPasscode: String { return self._s[3136]! } + public var Localization_EnglishLanguageName: String { return self._s[3137]! } + public var Share_AuthDescription: String { return self._s[3138]! } + public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3139]! } + public var Passport_Identity_Surname: String { return self._s[3140]! } + public var Compose_TokenListPlaceholder: String { return self._s[3141]! } + public var Wallet_AccessDenied_Camera: String { return self._s[3142]! } + public var Passport_Identity_OneOfTypePassport: String { return self._s[3143]! } + public var Settings_AboutEmpty: String { return self._s[3144]! } + public var Conversation_Unmute: String { return self._s[3145]! } + public var CreateGroup_ChannelsTooMuch: String { return self._s[3147]! } + public var Wallet_Sending_Text: String { return self._s[3148]! } + public func PUSH_CONTACT_JOINED(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3149]!, self._r[3149]!, [_1]) + } + public var Login_CodeSentCall: String { return self._s[3150]! } + public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3152]! } + public var ChatSettings_Appearance: String { return self._s[3153]! } + public var ClearCache_StorageUsage: String { return self._s[3154]! } + public var ChatListFolder_NameContacts: String { return self._s[3155]! } + public var Appearance_PickAccentColor: String { return self._s[3156]! } 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[3157]!, self._r[3157]!, [_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[3158]!, self._r[3158]!, [_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[3159]! } + public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3160]! } + public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3161]! } + public var Wallet_Month_GenOctober: String { return self._s[3163]! } + public var ChatAdmins_AdminLabel: String { return self._s[3164]! } + public var KeyCommand_JumpToNextChat: String { return self._s[3165]! } + public var Conversation_StopPollConfirmationTitle: String { return self._s[3167]! } + public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3168]! } + public var Month_GenJune: String { return self._s[3169]! } + public var IntentsSettings_MainAccountInfo: String { return self._s[3170]! } + public var Watch_Location_Current: String { return self._s[3171]! } + public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3172]! } + public var Conversation_TitleMute: String { return self._s[3173]! } + public var Map_PlacesInThisArea: String { return self._s[3174]! } public func PUSH_CHANNEL_MESSAGE_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3174]!, self._r[3174]!, [_1]) + return formatWithArgumentRanges(self._s[3175]!, self._r[3175]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3175]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3176]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3176]!, self._r[3176]!, [_0]) + return formatWithArgumentRanges(self._s[3177]!, self._r[3177]!, [_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 var Call_ReportPlaceholder: String { return self._s[3178]! } + public var Chat_SlowmodeSendError: String { return self._s[3179]! } + public var MaskStickerSettings_Info: String { return self._s[3180]! } + public var EditTheme_Expand_TopInfo: String { return self._s[3181]! } public func GroupInfo_AddParticipantConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3181]!, self._r[3181]!, [_0]) + return formatWithArgumentRanges(self._s[3182]!, self._r[3182]!, [_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 var Checkout_NewCard_PostcodeTitle: String { return self._s[3183]! } + public var Passport_Address_RegionPlaceholder: String { return self._s[3185]! } + public var Contacts_ShareTelegram: String { return self._s[3186]! } + public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3187]! } + public var Map_AddressOnMap: String { return self._s[3188]! } + public var Channel_ErrorAccessDenied: String { return self._s[3189]! } + public var UserInfo_ScamBotWarning: String { return self._s[3191]! } + public var Stickers_GroupChooseStickerPack: String { return self._s[3192]! } + public var Call_ConnectionErrorTitle: String { return self._s[3193]! } + public var UserInfo_NotificationsEnable: String { return self._s[3194]! } + public var ArchivedChats_IntroText1: String { return self._s[3195]! } + public var Tour_Text4: String { return self._s[3198]! } + public var WallpaperSearch_Recent: String { return self._s[3199]! } + public var GroupInfo_ScamGroupWarning: String { return self._s[3200]! } + public var PeopleNearby_MakeVisibleTitle: String { return self._s[3201]! } + public var Profile_MessageLifetime2s: String { return self._s[3203]! } + public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3204]! } + public var Notification_MessageLifetime2s: String { return self._s[3205]! } 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]) + return formatWithArgumentRanges(self._s[3206]!, self._r[3206]!, [_1, _2, _3]) } - 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 Cache_ClearCache: String { return self._s[3207]! } + public var AutoNightTheme_UpdateLocation: String { return self._s[3208]! } + public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3209]! } public func Channel_AdminLog_MessageChangedGroupUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3212]!, self._r[3212]!, [_0]) + return formatWithArgumentRanges(self._s[3213]!, self._r[3213]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3214]!, self._r[3214]!, [_0]) + return formatWithArgumentRanges(self._s[3215]!, self._r[3215]!, [_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[3216]! } + public var PeerInfo_PaneMembers: String { return self._s[3217]! } + public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3218]! } + public var SocksProxySetup_TypeSocks: String { return self._s[3219]! } + public var ChatList_UnarchiveAction: String { return self._s[3220]! } + public var AutoNightTheme_Title: String { return self._s[3221]! } + public var InstantPage_FeedbackButton: String { return self._s[3222]! } + public var Passport_FieldAddress: String { return self._s[3223]! } 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[3224]!, self._r[3224]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3224]! } + public var Month_ShortMarch: String { return self._s[3225]! } 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[3226]!, self._r[3226]!, [_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[3227]! } + public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3228]! } + public var Passport_FloodError: String { return self._s[3229]! } + public var SecretGif_Title: String { return self._s[3230]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3231]! } + public var ChatList_Context_UnhideArchive: String { return self._s[3232]! } + public var Passport_Language_th: String { return self._s[3234]! } + public var Passport_Address_Address: String { return self._s[3235]! } + public var Login_InvalidLastNameError: String { return self._s[3236]! } + public var Notifications_InAppNotificationsPreview: String { return self._s[3237]! } + public var Notifications_PermissionsUnreachableTitle: String { return self._s[3238]! } + public var ChatList_Context_Archive: String { return self._s[3239]! } + public var SettingsSearch_FAQ: String { return self._s[3240]! } + public var ShareMenu_Send: String { return self._s[3241]! } + public var ChatState_Connecting: String { return self._s[3242]! } + public var WallpaperSearch_ColorYellow: String { return self._s[3244]! } + public var Month_GenNovember: String { return self._s[3246]! } + public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3248]! } 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[3249]!, self._r[3249]!, [_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[3250]! } + public var Conversation_SwipeToReplyHintText: String { return self._s[3251]! } + public var Checkout_Email: String { return self._s[3252]! } + public var NotificationsSound_Tritone: String { return self._s[3253]! } + public var StickerPacksSettings_ManagingHelp: String { return self._s[3255]! } + public var Wallet_ContextMenuCopy: String { return self._s[3257]! } 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[3259]!, self._r[3259]!, [_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[3260]! } + public var Stickers_Installed: String { return self._s[3262]! } public func PUSH_PINNED_ROUND(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3262]!, self._r[3262]!, [_1]) + return formatWithArgumentRanges(self._s[3263]!, self._r[3263]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3263]!, self._r[3263]!, [_0]) + return formatWithArgumentRanges(self._s[3264]!, self._r[3264]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3264]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3265]! } 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[3266]!, self._r[3266]!, [_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[3267]! } + public var Notification_Exceptions_Add: String { return self._s[3268]! } + public var DialogList_You: String { return self._s[3269]! } + public var ChatList_PsaLabel_covid: String { return self._s[3271]! } + public var MediaPicker_Send: String { return self._s[3273]! } + public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3274]! } + public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3275]! } + public var Call_AudioRouteSpeaker: String { return self._s[3276]! } + public var Watch_UserInfo_Title: String { return self._s[3277]! } + public var VoiceOver_Chat_PollFinalResults: String { return self._s[3278]! } + public var Appearance_AccentColor: String { return self._s[3280]! } public func Login_EmailPhoneSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3280]!, self._r[3280]!, [_0]) + return formatWithArgumentRanges(self._s[3281]!, self._r[3281]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3281]! } + public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3282]! } 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[3283]!, self._r[3283]!, [_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[3284]! } + public var WebSearch_RecentClearConfirmation: String { return self._s[3285]! } + public var Notification_CallOutgoing: String { return self._s[3286]! } + public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3287]! } + public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3288]! } + public var Call_RecordingDisabledMessage: String { return self._s[3289]! } + public var Message_Game: String { return self._s[3290]! } + public var Conversation_PressVolumeButtonForSound: String { return self._s[3291]! } + public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3292]! } + public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3293]! } + public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3294]! } + public var Date_DialogDateFormat: String { return self._s[3296]! } + public var WallpaperColors_SetCustomColor: String { return self._s[3297]! } + public var Notifications_InAppNotifications: String { return self._s[3298]! } public func Channel_Management_RemovedBy(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3298]!, self._r[3298]!, [_0]) + return formatWithArgumentRanges(self._s[3299]!, self._r[3299]!, [_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[3300]!, self._r[3300]!, [_1, _2]) } - public var NewContact_Title: String { return self._s[3300]! } + public var NewContact_Title: String { return self._s[3301]! } public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3301]!, self._r[3301]!, [_0]) + return formatWithArgumentRanges(self._s[3302]!, self._r[3302]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3302]! } + public var Conversation_ViewContactDetails: String { return self._s[3303]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3304]!, self._r[3304]!, [_1]) + return formatWithArgumentRanges(self._s[3305]!, self._r[3305]!, [_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[3306]! } + public var Passport_Identity_ExpiryDateNone: String { return self._s[3307]! } + public var PrivacySettings_Title: String { return self._s[3308]! } + public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3311]! } + public var GroupRemoved_UsersSectionTitle: String { return self._s[3312]! } + public var VoiceOver_Chat_ContactEmail: String { return self._s[3313]! } + public var Contacts_PhoneNumber: String { return self._s[3314]! } + public var PeerInfo_ButtonMute: String { return self._s[3315]! } + public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3317]! } + public var Map_ShowPlaces: String { return self._s[3318]! } + public var ChatAdmins_Title: String { return self._s[3319]! } + public var InstantPage_Reference: String { return self._s[3321]! } + public var Wallet_Info_Updating: String { return self._s[3322]! } + public var ReportGroupLocation_Text: String { return self._s[3323]! } 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[3324]!, self._r[3324]!, [_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[3325]! } + public var Watch_UserInfo_Block: String { return self._s[3326]! } + public var ChatSettings_Stickers: String { return self._s[3327]! } + public var ChatSettings_DownloadInBackground: String { return self._s[3328]! } + public var Appearance_ThemeCarouselTintedNight: String { return self._s[3329]! } public func UserInfo_BlockConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3329]!, self._r[3329]!, [_0]) + return formatWithArgumentRanges(self._s[3330]!, self._r[3330]!, [_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[3331]! } + public var Login_CheckOtherSessionMessages: String { return self._s[3332]! } + public var AutoDownloadSettings_Cellular: String { return self._s[3333]! } + public var Wallet_Created_ExportErrorTitle: String { return self._s[3334]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3335]! } + public var VoiceOver_MessageContextShare: String { return self._s[3336]! } public func Target_InviteToGroupConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3337]!, self._r[3337]!, [_0]) + return formatWithArgumentRanges(self._s[3338]!, self._r[3338]!, [_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[3339]! } + public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3340]! } public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3340]!, self._r[3340]!, [_0]) + return formatWithArgumentRanges(self._s[3341]!, self._r[3341]!, [_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[3342]! } + public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3343]! } + public var DialogList_SavedMessages: String { return self._s[3344]! } + public var GroupInfo_UpgradeButton: String { return self._s[3345]! } + public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3347]! } + public var DialogList_Pin: String { return self._s[3348]! } public func ForwardedAuthors2(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3348]!, self._r[3348]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3349]!, self._r[3349]!, [_0, _1]) } public func Login_PhoneGenericEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3349]!, self._r[3349]!, [_0]) + return formatWithArgumentRanges(self._s[3350]!, self._r[3350]!, [_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[3351]! } + public var UserInfo_NotificationsDisable: String { return self._s[3352]! } + public var Conversation_ContextMenuCancelEditing: String { return self._s[3353]! } + public var Paint_Outlined: String { return self._s[3354]! } + public var Activity_PlayingGame: String { return self._s[3355]! } + public var SearchImages_NoImagesFound: String { return self._s[3356]! } + public var SocksProxySetup_ProxyType: String { return self._s[3357]! } + public var AppleWatch_ReplyPresetsHelp: String { return self._s[3359]! } + public var Conversation_ContextMenuCancelSending: String { return self._s[3360]! } + public var Settings_AppLanguage: String { return self._s[3361]! } + public var TwoStepAuth_ResetAccountHelp: String { return self._s[3362]! } + public var Common_ChoosePhoto: String { return self._s[3363]! } + public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3364]! } + public var CallFeedback_ReasonEcho: String { return self._s[3365]! } public func PUSH_PINNED_AUDIO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3365]!, self._r[3365]!, [_1]) + return formatWithArgumentRanges(self._s[3366]!, self._r[3366]!, [_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[3367]! } + public var PollResults_Collapse: String { return self._s[3368]! } + public var Activity_UploadingVideo: String { return self._s[3369]! } + public var Conversation_WalletRequiredNotNow: String { return self._s[3370]! } + public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3371]! } + public var NetworkUsageSettings_Wifi: String { return self._s[3372]! } + public var VoiceOver_Editing_ClearText: String { return self._s[3373]! } + public var PUSH_SENDER_YOU: String { return self._s[3374]! } + public var Channel_BanUser_PermissionReadMessages: String { return self._s[3375]! } + public var Checkout_PayWithTouchId: String { return self._s[3376]! } + public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3377]! } public func PUSH_LOCKED_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3378]!, self._r[3378]!, [_1]) + return formatWithArgumentRanges(self._s[3379]!, self._r[3379]!, [_1]) } - public var Notifications_ExceptionsNone: String { return self._s[3379]! } + public var Notifications_ExceptionsNone: String { return self._s[3380]! } public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3380]!, self._r[3380]!, [_0]) + return formatWithArgumentRanges(self._s[3381]!, self._r[3381]!, [_0]) } public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3381]!, self._r[3381]!, [_1]) + return formatWithArgumentRanges(self._s[3382]!, self._r[3382]!, [_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[3384]! } + public var Passport_Address_Region: String { return self._s[3387]! } + public var ChatList_DeleteChat: String { return self._s[3388]! } + public var LogoutOptions_ClearCacheTitle: String { return self._s[3389]! } + public var PhotoEditor_TiltShift: String { return self._s[3390]! } + public var Settings_FAQ_URL: String { return self._s[3391]! } + public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3392]! } + public var Passport_Language_sl: String { return self._s[3394]! } + public var Settings_PrivacySettings: String { return self._s[3396]! } + public var SharedMedia_TitleLink: String { return self._s[3397]! } + public var Passport_Identity_TypePassportUploadScan: String { return self._s[3398]! } + public var Settings_SetProfilePhoto: String { return self._s[3399]! } + public var Channel_About_Help: String { return self._s[3400]! } + public var Contacts_PermissionsEnable: String { return self._s[3401]! } + public var Wallet_Sending_Title: String { return self._s[3402]! } + public var PeerInfo_PaneMedia: String { return self._s[3403]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3404]! } + public var AttachmentMenu_SendAsFiles: String { return self._s[3405]! } + public var CallFeedback_ReasonInterruption: String { return self._s[3407]! } + public var Passport_Address_AddTemporaryRegistration: String { return self._s[3408]! } + public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3409]! } + public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3410]! } + public var OldChannels_Title: String { return self._s[3411]! } + public var PrivacySettings_DeleteAccountTitle: String { return self._s[3412]! } + public var AccessDenied_VideoMessageCamera: String { return self._s[3414]! } + public var Map_OpenInYandexMaps: String { return self._s[3416]! } + public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3417]! } + public var VoiceOver_MessageContextReply: String { return self._s[3418]! } + public var ChatListFolder_DiscardConfirmation: String { return self._s[3420]! } + public var PhotoEditor_SaturationTool: String { return self._s[3421]! } 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[3422]!, self._r[3422]!, [_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[3423]! } + public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3424]! } + public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3425]! } 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[3426]!, self._r[3426]!, [_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[3427]! } + public var Channel_Username_InvalidTooShort: String { return self._s[3429]! } + public var SettingsSearch_Synonyms_Wallet: String { return self._s[3430]! } 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[3431]!, self._r[3431]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3431]! } + public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3432]! } 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[3433]!, self._r[3433]!, [_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[3434]! } + public var GroupInfo_PublicLinkAdd: String { return self._s[3435]! } + public var Passport_PassportInformation: String { return self._s[3438]! } + public var Theme_Unsupported: String { return self._s[3439]! } + public var WatchRemote_AlertTitle: String { return self._s[3440]! } + public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3441]! } + public var ConvertToSupergroup_HelpText: String { return self._s[3443]! } public func Time_MonthOfYear_m7(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3443]!, self._r[3443]!, [_0]) + return formatWithArgumentRanges(self._s[3444]!, self._r[3444]!, [_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[3445]!, self._r[3445]!, [_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[3446]! } + public var Wallet_Navigation_Done: String { return self._s[3448]! } + public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3449]! } + public var AccessDenied_CameraDisabled: String { return self._s[3450]! } public func Channel_Username_UsernameIsAvailable(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3450]!, self._r[3450]!, [_0]) + return formatWithArgumentRanges(self._s[3451]!, self._r[3451]!, [_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[3452]! } + public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3453]! } + public var CreatePoll_Quiz: String { return self._s[3454]! } + public var PhotoEditor_ContrastTool: String { return self._s[3457]! } public func PUSH_PINNED_DOC(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3457]!, self._r[3457]!, [_1]) + return formatWithArgumentRanges(self._s[3458]!, self._r[3458]!, [_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[3459]! } + public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3460]! } public func PeopleNearby_VisibleUntil(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3460]!, self._r[3460]!, [_0]) + return formatWithArgumentRanges(self._s[3461]!, self._r[3461]!, [_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[3462]! } + public var Privacy_TopPeersDelete: String { return self._s[3464]! } + public var LoginPassword_PasswordPlaceholder: String { return self._s[3465]! } + public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3466]! } + public var WebSearch_RecentSectionClear: String { return self._s[3467]! } + public var EditTheme_ErrorInvalidCharacters: String { return self._s[3468]! } + public var Watch_ChatList_NoConversationsTitle: String { return self._s[3470]! } + public var PeerInfo_ButtonMore: String { return self._s[3472]! } + public var Common_Done: String { return self._s[3473]! } + public var Shortcut_SwitchAccount: String { return self._s[3474]! } + public var AuthSessions_EmptyText: String { return self._s[3475]! } + public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3476]! } + public var Conversation_ShareBotContactConfirmation: String { return self._s[3477]! } + public var Tour_Title5: String { return self._s[3479]! } + public var Wallet_Settings_Title: String { return self._s[3480]! } public func Map_DirectionsDriveEta(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3479]!, self._r[3479]!, [_0]) + return formatWithArgumentRanges(self._s[3481]!, self._r[3481]!, [_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[3482]! } + public var Conversation_LinkDialogSave: String { return self._s[3483]! } + public var GroupInfo_ActionRestrict: String { return self._s[3484]! } + public var Checkout_Title: String { return self._s[3485]! } + public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3487]! } + public var Channel_AdminLog_CanChangeInfo: String { return self._s[3489]! } + public var Notification_RenamedGroup: String { return self._s[3490]! } + public var PeopleNearby_Groups: String { return self._s[3491]! } + public var Checkout_PayWithFaceId: String { return self._s[3492]! } + public var Channel_BanList_BlockedTitle: String { return self._s[3493]! } + public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3495]! } + public var Checkout_WebConfirmation_Title: String { return self._s[3496]! } + public var Notifications_MessageNotificationsAlert: String { return self._s[3497]! } public func Activity_RemindAboutGroup(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3496]!, self._r[3496]!, [_0]) + return formatWithArgumentRanges(self._s[3498]!, self._r[3498]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3498]! } + public var Profile_AddToExisting: String { return self._s[3500]! } 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[3501]!, self._r[3501]!, [_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[3503]! } + public var Permissions_PrivacyPolicy: String { return self._s[3504]! } + public var SocksProxySetup_ConnectAndSave: String { return self._s[3505]! } + public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3506]! } + public var AutoDownloadSettings_TypeContacts: String { return self._s[3508]! } + public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3510]! } + public var Calls_NoCallsPlaceholder: String { return self._s[3511]! } public func Wallet_Receive_ShareInvoiceUrlInfo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3510]!, self._r[3510]!, [_0]) + return formatWithArgumentRanges(self._s[3512]!, self._r[3512]!, [_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[3513]! } + public var VoiceOver_AttachMedia: String { return self._s[3516]! } + public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3517]! } 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[3518]!, self._r[3518]!, [_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[3519]! } + public var Conversation_SetReminder_Title: String { return self._s[3520]! } + public var Passport_FieldAddressHelp: String { return self._s[3521]! } + public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3522]! } + public var PUSH_REMINDER_TITLE: String { return self._s[3523]! } public func Login_TermsOfService_ProceedBot(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3522]!, self._r[3522]!, [_0]) + return formatWithArgumentRanges(self._s[3524]!, self._r[3524]!, [_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[3525]! } + public var Privacy_Calls_NeverAllow_Title: String { return self._s[3526]! } + public var Login_UnknownError: String { return self._s[3527]! } + public var Group_UpgradeNoticeText2: String { return self._s[3530]! } + public var Watch_Compose_AddContact: String { return self._s[3531]! } + public var ClearCache_StorageServiceFiles: String { return self._s[3532]! } + public var Web_Error: String { return self._s[3533]! } + public var Gif_Search: String { return self._s[3534]! } + public var Profile_MessageLifetime1h: String { return self._s[3535]! } + public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3536]! } + public var Channel_Username_CheckingUsername: String { return self._s[3537]! } + public var CallFeedback_ReasonSilentRemote: String { return self._s[3538]! } + public var AutoDownloadSettings_TypeChannels: String { return self._s[3539]! } + public var Channel_AboutItem: String { return self._s[3540]! } + public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3543]! } + public var VoiceOver_Chat_VoiceMessage: String { return self._s[3544]! } + public var GroupInfo_SharedMedia: String { return self._s[3545]! } public func Channel_AdminLog_MessagePromotedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3543]!, self._r[3543]!, [_1]) + return formatWithArgumentRanges(self._s[3546]!, self._r[3546]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3544]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3547]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3545]!, self._r[3545]!, [_1]) + return formatWithArgumentRanges(self._s[3548]!, self._r[3548]!, [_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[3549]! } + public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3550]! } + public var Conversation_SearchByName_Placeholder: String { return self._s[3551]! } + public var CreatePoll_AddOption: String { return self._s[3552]! } + public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3553]! } + public var Group_UpgradeNoticeHeader: String { return self._s[3554]! } + public var Channel_Management_AddModerator: String { return self._s[3555]! } + public var AutoDownloadSettings_MaxFileSize: String { return self._s[3556]! } + public var StickerPacksSettings_ShowStickersButton: String { return self._s[3557]! } + public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3558]! } + public var Theme_Colors_Background: String { return self._s[3559]! } + public var NotificationsSound_Hello: String { return self._s[3562]! } + public var SocksProxySetup_SavedProxies: String { return self._s[3564]! } + public var Channel_Stickers_Placeholder: String { return self._s[3566]! } public func Login_EmailCodeBody(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3564]!, self._r[3564]!, [_0]) + return formatWithArgumentRanges(self._s[3567]!, self._r[3567]!, [_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[3568]! } + public var Channel_Management_AddModeratorHelp: String { return self._s[3569]! } + public var ContactInfo_BirthdayLabel: String { return self._s[3570]! } + public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3571]! } + public var AutoDownloadSettings_Channels: String { return self._s[3572]! } + public var Passport_Language_mn: String { return self._s[3573]! } + public var Settings_ChatFolders: String { return self._s[3574]! } 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[3575]!, self._r[3575]!, [_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[3578]! } + public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3579]! } + public var Passport_Language_ja: String { return self._s[3581]! } + public var Settings_About_Title: String { return self._s[3582]! } + public var Settings_NotificationsAndSounds: String { return self._s[3583]! } + public var ChannelInfo_DeleteGroup: String { return self._s[3584]! } + public var Settings_BlockedUsers: String { return self._s[3585]! } public func Time_MonthOfYear_m4(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3583]!, self._r[3583]!, [_0]) + return formatWithArgumentRanges(self._s[3586]!, self._r[3586]!, [_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[3587]! } + public var Wallet_Weekday_Today: String { return self._s[3588]! } + public var ChatListFolderSettings_AddRecommended: String { return self._s[3589]! } + public var AutoDownloadSettings_PreloadVideo: String { return self._s[3590]! } + public var Widget_ApplicationLocked: String { return self._s[3591]! } + public var Passport_Address_AddResidentialAddress: String { return self._s[3592]! } + public var Channel_Username_Title: String { return self._s[3593]! } public func Notification_RemovedGroupPhoto(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3591]!, self._r[3591]!, [_0]) + return formatWithArgumentRanges(self._s[3594]!, self._r[3594]!, [_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[3596]! } + public var AppleWatch_Title: String { return self._s[3597]! } + public var Activity_RecordingVideoMessage: String { return self._s[3598]! } 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[3599]!, self._r[3599]!, [_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[3600]! } + public var Weekday_Saturday: String { return self._s[3601]! } + public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3602]! } + public var Conversation_Timer_Send: String { return self._s[3603]! } + public var Profile_CreateEncryptedChatError: String { return self._s[3604]! } + public var Common_Next: String { return self._s[3606]! } + public var Channel_Stickers_YourStickers: String { return self._s[3608]! } + public var Message_Theme: String { return self._s[3609]! } + public var Call_AudioRouteHeadphones: String { return self._s[3610]! } + public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3612]! } + public var Watch_Contacts_NoResults: String { return self._s[3614]! } + public var PhotoEditor_TintTool: String { return self._s[3617]! } + public var LoginPassword_ResetAccount: String { return self._s[3619]! } + public var Settings_SavedMessages: String { return self._s[3620]! } + public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3621]! } + public var Bot_GenericSupportStatus: String { return self._s[3622]! } + public var StickerPack_Add: String { return self._s[3623]! } + public var Checkout_TotalAmount: String { return self._s[3624]! } + public var Your_cards_number_is_invalid: String { return self._s[3625]! } + public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3626]! } + public var VoiceOver_Chat_VideoMessage: String { return self._s[3627]! } public func ChangePhoneNumberCode_CallTimer(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3625]!, self._r[3625]!, [_0]) + return formatWithArgumentRanges(self._s[3628]!, self._r[3628]!, [_0]) } public func GroupPermission_AddedInfo(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3626]!, self._r[3626]!, [_1, _2]) - } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3627]! } - public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3629]!, self._r[3629]!, [_1, _2]) } + public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3630]! } + public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3632]!, self._r[3632]!, [_1, _2]) + } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3630]!, self._r[3630]!, [_0]) + return formatWithArgumentRanges(self._s[3633]!, self._r[3633]!, [_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[3634]! } + public var StickerPack_Share: String { return self._s[3635]! } + public var Passport_DeleteAddress: String { return self._s[3636]! } + public var Settings_Passport: String { return self._s[3637]! } + public var SharedMedia_EmptyFilesText: String { return self._s[3638]! } + public var Conversation_DeleteMessagesForMe: String { return self._s[3639]! } + public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3640]! } + public var Contacts_PermissionsText: String { return self._s[3641]! } + public var Group_Setup_HistoryVisible: String { return self._s[3642]! } + public var Wallet_Month_ShortDecember: String { return self._s[3644]! } + public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3645]! } + public var Passport_Address_AddRentalAgreement: String { return self._s[3646]! } + public var SocksProxySetup_Title: String { return self._s[3647]! } + public var Notification_Mute1h: String { return self._s[3648]! } public func Passport_Email_CodeHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3646]!, self._r[3646]!, [_0]) + return formatWithArgumentRanges(self._s[3649]!, self._r[3649]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3647]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3650]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3648]!, self._r[3648]!, [_1]) + return formatWithArgumentRanges(self._s[3651]!, self._r[3651]!, [_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[3652]! } + public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3655]! } + public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3657]! } + public var DialogList_NoMessagesText: String { return self._s[3658]! } + public var Privacy_ContactsResetConfirmation: String { return self._s[3659]! } + public var Privacy_Calls_P2PHelp: String { return self._s[3660]! } + public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3662]! } + public var Your_cards_expiration_year_is_invalid: String { return self._s[3663]! } + public var Common_TakePhotoOrVideo: String { return self._s[3664]! } + public var Wallet_Words_Text: String { return self._s[3665]! } + public var Call_StatusBusy: String { return self._s[3666]! } + public var Conversation_PinnedMessage: String { return self._s[3667]! } + public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3668]! } + public var ChatList_EmptyChatListNewMessage: String { return self._s[3669]! } + public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3670]! } + public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3671]! } + public var Undo_ChatCleared: String { return self._s[3672]! } + public var CreatePoll_Explanation: String { return self._s[3673]! } + public var AppleWatch_ReplyPresets: String { return self._s[3674]! } + public var Passport_DiscardMessageDescription: String { return self._s[3676]! } + public var Login_NetworkError: String { return self._s[3677]! } public func Notification_PinnedRoundMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3675]!, self._r[3675]!, [_0]) + return formatWithArgumentRanges(self._s[3678]!, self._r[3678]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3676]!, self._r[3676]!, [_0]) + return formatWithArgumentRanges(self._s[3679]!, self._r[3679]!, [_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[3680]! } + public var Wallet_WordCheck_ViewWords: String { return self._s[3682]! } + public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3683]! } public func Watch_LastSeen_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3682]!, self._r[3682]!, [_0]) + return formatWithArgumentRanges(self._s[3685]!, self._r[3685]!, [_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[3686]! } + public var VoiceOver_Chat_Music: String { return self._s[3687]! } + public var ChatListFolder_CategoryContacts: String { return self._s[3688]! } + public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3689]! } + public var Compose_GroupTokenListPlaceholder: String { return self._s[3691]! } + public var ConversationMedia_Title: String { return self._s[3692]! } + public var EncryptionKey_Title: String { return self._s[3694]! } + public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3695]! } + public var Notification_Exceptions_AddException: String { return self._s[3696]! } + public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3697]! } + public var Profile_MessageLifetime1m: String { return self._s[3698]! } public func Channel_AdminLog_MessageUnkickedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3696]!, self._r[3696]!, [_1]) + return formatWithArgumentRanges(self._s[3699]!, self._r[3699]!, [_1]) } - public var Month_GenMay: String { return self._s[3697]! } + public var Month_GenMay: String { return self._s[3700]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3698]!, self._r[3698]!, [_0]) + return formatWithArgumentRanges(self._s[3701]!, self._r[3701]!, [_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[3702]! } + public var Wallet_Send_AddressInfo: String { return self._s[3703]! } + public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3704]! } + public var AutoDownloadSettings_ResetSettings: String { return self._s[3705]! } public func Wallet_Updated_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3704]!, self._r[3704]!, [_0]) + return formatWithArgumentRanges(self._s[3707]!, self._r[3707]!, [_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[3708]! } + public var Conversation_EmptyPlaceholder: String { return self._s[3709]! } + public var Passport_Address_AddPassportRegistration: String { return self._s[3710]! } + public var Notifications_ChannelNotificationsAlert: String { return self._s[3711]! } + public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3712]! } + public var Camera_TapAndHoldForVideo: String { return self._s[3713]! } + public var Channel_JoinChannel: String { return self._s[3715]! } + public var Appearance_Animations: String { return self._s[3718]! } 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[3719]!, self._r[3719]!, [_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[3721]! } + public var Appearance_ShareTheme: String { return self._s[3722]! } + public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3723]! } + public var ConvertToSupergroup_HelpTitle: String { return self._s[3725]! } + public var StickerPackActionInfo_RemovedTitle: String { return self._s[3726]! } + public var Passport_Address_Street: String { return self._s[3727]! } + public var Conversation_AddContact: String { return self._s[3728]! } + public var Login_PhonePlaceholder: String { return self._s[3729]! } + public var Channel_Members_InviteLink: String { return self._s[3731]! } + public var Bot_Stop: String { return self._s[3732]! } + public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3734]! } + public var Notification_PassportValueAddress: String { return self._s[3735]! } + public var Month_ShortJuly: String { return self._s[3736]! } + public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3737]! } + public var Channel_AdminLog_BanSendMedia: String { return self._s[3738]! } + public var Passport_Identity_ReverseSide: String { return self._s[3739]! } + public var Watch_Stickers_Recents: String { return self._s[3742]! } + public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3744]! } + public var Map_SendThisLocation: String { return self._s[3745]! } public func Time_MonthOfYear_m1(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3743]!, self._r[3743]!, [_0]) + return formatWithArgumentRanges(self._s[3746]!, self._r[3746]!, [_0]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3744]!, self._r[3744]!, [_0]) - } - public var ConvertToSupergroup_Note: String { return self._s[3745]! } - public var Wallet_Intro_NotNow: String { return self._s[3746]! } - public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3747]!, self._r[3747]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3748]! } + public var ConvertToSupergroup_Note: String { return self._s[3748]! } + public var Wallet_Intro_NotNow: String { return self._s[3749]! } + public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3750]!, self._r[3750]!, [_0]) + } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3751]! } 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[3752]!, self._r[3752]!, [_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[3754]! } + public var Wallpaper_SearchShort: String { return self._s[3755]! } + public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3757]! } + public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3758]! } + public var Channel_BotDoesntSupportGroups: String { return self._s[3759]! } 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[3760]!, self._r[3760]!, [_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[3761]! } + public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3763]! } + public var Notifications_GroupNotificationsExceptions: String { return self._s[3766]! } public func FileSize_B(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3764]!, self._r[3764]!, [_0]) - } - public var Passport_CorrectErrors: String { return self._s[3765]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3766]! } - public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3767]!, self._r[3767]!, [_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 Passport_CorrectErrors: String { return self._s[3768]! } + public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3769]! } + public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3770]!, self._r[3770]!, [_0]) + } + public var Map_SendMyCurrentLocation: String { return self._s[3771]! } + public var Channel_DiscussionGroup: String { return self._s[3772]! } + public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3773]! } 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[3774]!, self._r[3774]!, [_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[3775]! } + public var Permissions_NotificationsText_v0: String { return self._s[3776]! } + public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3777]! } + public var Appearance_AppIcon: String { return self._s[3778]! } + public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3779]! } + public var LoginPassword_FloodError: String { return self._s[3780]! } + public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3782]! } + public var Group_Setup_HistoryHiddenHelp: String { return self._s[3783]! } public func TwoStepAuth_PendingEmailHelp(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3781]!, self._r[3781]!, [_0]) + return formatWithArgumentRanges(self._s[3784]!, self._r[3784]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3782]! } + public var Passport_Language_bn: String { return self._s[3785]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3783]!, self._r[3783]!, [_0]) - } - public var ChatList_Context_Pin: String { return self._s[3784]! } - public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3785]!, self._r[3785]!, [_0]) - } - public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3786]!, self._r[3786]!, [_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 ChatList_Context_Pin: String { return self._s[3787]! } + public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3788]!, self._r[3788]!, [_0]) + } + public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3789]!, self._r[3789]!, [_0]) + } + public var Wallet_Navigation_Close: String { return self._s[3790]! } + public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3794]! } + public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3796]! } + public var Wallet_Month_GenDecember: String { return self._s[3797]! } + public var Contacts_PermissionsAllow: String { return self._s[3798]! } + public var ReportPeer_ReasonCopyright: String { return self._s[3799]! } + public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3800]! } + public var WallpaperPreview_Pattern: String { return self._s[3801]! } + public var Paint_Duplicate: String { return self._s[3802]! } + public var Passport_Address_Country: String { return self._s[3803]! } + public var Notification_RenamedChannel: String { return self._s[3805]! } + public var DialogList_UnknownPinLimitError: String { return self._s[3806]! } + public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3807]! } + public var ChatList_Context_Unmute: String { return self._s[3808]! } + public var Group_MessagePhotoUpdated: String { return self._s[3809]! } + public var Channel_BanUser_PermissionSendMedia: String { return self._s[3810]! } + public var Conversation_ContextMenuBan: String { return self._s[3811]! } + public var TwoStepAuth_EmailSent: String { return self._s[3812]! } + public var MessagePoll_NoVotes: String { return self._s[3813]! } + public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3814]! } + public var Passport_Language_is: String { return self._s[3816]! } + public var PeopleNearby_UsersEmpty: String { return self._s[3818]! } + public var Tour_Text5: String { return self._s[3819]! } 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[3822]!, self._r[3822]!, [_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[3823]! } + public var SocksProxySetup_ShareQRCode: String { return self._s[3824]! } public func VoiceOver_Chat_Size(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3822]!, self._r[3822]!, [_0]) + return formatWithArgumentRanges(self._s[3825]!, self._r[3825]!, [_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[3826]! } + public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3827]! } + public var Paint_Edit: String { return self._s[3829]! } + public var ScheduledMessages_ReminderNotification: String { return self._s[3831]! } + public var Undo_DeletedGroup: String { return self._s[3833]! } + public var LoginPassword_ForgotPassword: String { return self._s[3834]! } + public var Wallet_WordImport_IncorrectTitle: String { return self._s[3835]! } + public var GroupInfo_GroupNamePlaceholder: String { return self._s[3836]! } 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[3837]!, self._r[3837]!, [_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[3838]! } + public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3839]! } + public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3840]! } + public var Passport_Language_uz: String { return self._s[3841]! } + public var Conversation_PinMessageAlertGroup: String { return self._s[3842]! } + public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3843]! } + public var Map_StopLiveLocation: String { return self._s[3845]! } + public var VoiceOver_MessageContextSend: String { return self._s[3847]! } + public var PasscodeSettings_Help: String { return self._s[3848]! } + public var NotificationsSound_Input: String { return self._s[3849]! } + public var Share_Title: String { return self._s[3852]! } + public var LogoutOptions_Title: String { return self._s[3853]! } + public var Wallet_Send_AddressText: String { return self._s[3854]! } + public var Login_TermsOfServiceAgree: String { return self._s[3855]! } + public var Compose_NewEncryptedChatTitle: String { return self._s[3856]! } + public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3857]! } + public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3858]! } + public var EnterPasscode_EnterTitle: String { return self._s[3859]! } public func Call_PrivacyErrorMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3857]!, self._r[3857]!, [_0]) - } - public var Settings_CopyPhoneNumber: String { return self._s[3858]! } - public var Conversation_AddToContacts: String { return self._s[3859]! } - public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3860]!, self._r[3860]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3861]! } + public var Settings_CopyPhoneNumber: String { return self._s[3861]! } + public var Conversation_AddToContacts: String { return self._s[3862]! } + public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3863]!, self._r[3863]!, [_0]) + } + public var NotificationsSound_Keys: String { return self._s[3864]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3862]!, self._r[3862]!, [_0]) + return formatWithArgumentRanges(self._s[3865]!, self._r[3865]!, [_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 var Notification_MessageLifetime1w: String { return self._s[3866]! } + public var Message_Video: String { return self._s[3867]! } + public var AutoDownloadSettings_CellularTitle: String { return self._s[3868]! } public func PUSH_CHANNEL_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3866]!, self._r[3866]!, [_1]) + return formatWithArgumentRanges(self._s[3869]!, self._r[3869]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3869]! } - public var Stats_Overview: String { return self._s[3870]! } + public var Wallet_Receive_AmountInfo: String { return self._s[3872]! } + public var Stats_Overview: String { return self._s[3873]! } public func Notification_JoinedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3871]!, self._r[3871]!, [_0]) + return formatWithArgumentRanges(self._s[3874]!, self._r[3874]!, [_0]) } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3872]!, self._r[3872]!, [_0]) + return formatWithArgumentRanges(self._s[3875]!, self._r[3875]!, [_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[3876]! } + public var Passport_Language_mk: String { return self._s[3877]! } + public var ChatListFolder_CategoryNonContacts: String { return self._s[3878]! } 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[3879]!, self._r[3879]!, [_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[3880]! } + public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3881]! } + public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3883]! } + public var PrivacyPolicy_Decline: String { return self._s[3884]! } + public var Passport_Identity_DoesNotExpire: String { return self._s[3885]! } + public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3886]! } + public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3887]! } + public var Permissions_SiriAllow_v0: String { return self._s[3889]! } + public var Wallet_Month_ShortAugust: String { return self._s[3890]! } + public var Appearance_ThemeCarouselNight: String { return self._s[3891]! } 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[3892]!, self._r[3892]!, [_1, "\(_2)"]) } public func Notification_RenamedChat(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3890]!, self._r[3890]!, [_0]) + return formatWithArgumentRanges(self._s[3893]!, self._r[3893]!, [_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[3894]! } + public var ChatSettings_AutoDownloadReset: String { return self._s[3895]! } + public var SocksProxySetup_ShareLink: String { return self._s[3896]! } + public var Wallet_Qr_Title: String { return self._s[3897]! } + public var BlockedUsers_SelectUserTitle: String { return self._s[3898]! } + public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3900]! } + public var Wallet_Settings_Configuration: String { return self._s[3901]! } + public var GroupInfo_InviteByLink: String { return self._s[3902]! } + public var MessageTimer_Custom: String { return self._s[3903]! } + public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3904]! } + public var Conversation_StopQuizConfirmationTitle: String { return self._s[3905]! } + public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3907]! } + public var Conversation_SendMessage_SetReminder: String { return self._s[3908]! } + public var VoiceOver_Chat_Selected: String { return self._s[3909]! } + public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3910]! } + public var Channel_Username_InvalidTaken: String { return self._s[3911]! } + public var Conversation_ClousStorageInfo_Description3: String { return self._s[3912]! } + public var Wallet_WordCheck_TryAgain: String { return self._s[3913]! } + public var Wallet_Info_TransactionPendingHeader: String { return self._s[3914]! } + public var Settings_ChatBackground: String { return self._s[3915]! } + public var Channel_Subscribers_Title: String { return self._s[3916]! } + public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3917]! } + public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3918]! } + public var Watch_ConnectionDescription: String { return self._s[3919]! } + public var OldChannels_NoticeText: String { return self._s[3922]! } + public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3923]! } + public var IntentsSettings_SuggestBy: String { return self._s[3925]! } + public var Theme_ThemeChangedText: String { return self._s[3926]! } + public var ChatList_ArchivedChatsTitle: String { return self._s[3927]! } + public var Wallpaper_ResetWallpapers: String { return self._s[3928]! } + public var Wallet_Send_TransactionInProgress: String { return self._s[3929]! } + public var Conversation_SendDice: String { return self._s[3930]! } + public var EditProfile_Title: String { return self._s[3931]! } + public var NotificationsSound_Bamboo: String { return self._s[3933]! } + public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3935]! } + public var Login_SmsRequestState2: String { return self._s[3936]! } + public var Passport_Language_ar: String { return self._s[3937]! } public func Message_AuthorPinnedGame(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3935]!, self._r[3935]!, [_0]) + return formatWithArgumentRanges(self._s[3938]!, self._r[3938]!, [_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[3939]! } + public var Wallet_Created_Text: String { return self._s[3940]! } + public var Conversation_MessageDialogEdit: String { return self._s[3942]! } + public var Wallet_Created_Proceed: String { return self._s[3943]! } + public var Wallet_Words_Done: String { return self._s[3944]! } + public var VoiceOver_Media_PlaybackPause: String { return self._s[3945]! } + public var ChatListFolder_NameChannels: String { return self._s[3946]! } public func PUSH_AUTH_UNKNOWN(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3944]!, self._r[3944]!, [_1]) + return formatWithArgumentRanges(self._s[3947]!, self._r[3947]!, [_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[3948]! } + public var GroupInfo_PublicLink: String { return self._s[3949]! } + public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3950]! } + public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3951]! } public func Channel_AdminLog_MessageToggleInvitesOff(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3952]!, self._r[3952]!, [_0]) + return formatWithArgumentRanges(self._s[3955]!, self._r[3955]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3953]! } + public var UserInfo_About_Placeholder: String { return self._s[3956]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3954]!, self._r[3954]!, [_0]) + return formatWithArgumentRanges(self._s[3957]!, self._r[3957]!, [_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[3958]! } + public var Channel_Info_Banned: String { return self._s[3960]! } public func Time_MonthOfYear_m11(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3958]!, self._r[3958]!, [_0]) + return formatWithArgumentRanges(self._s[3961]!, self._r[3961]!, [_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[3962]! } + public var Passport_Language_my: String { return self._s[3963]! } + public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3964]! } 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[3965]!, self._r[3965]!, [_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[3966]! } + public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3967]! } + public var Preview_CopyAddress: String { return self._s[3968]! } public func DialogList_SinglePlayingGameSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3966]!, self._r[3966]!, [_0]) + return formatWithArgumentRanges(self._s[3969]!, self._r[3969]!, [_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[3970]! } + public var UserInfo_BotSettings: String { return self._s[3971]! } + public var LiveLocation_MenuStopAll: String { return self._s[3973]! } + public var Passport_PasswordCreate: String { return self._s[3974]! } + public var StickerSettings_MaskContextInfo: String { return self._s[3975]! } + public var Message_PinnedLocationMessage: String { return self._s[3976]! } + public var Map_Satellite: String { return self._s[3977]! } + public var Watch_Message_Unsupported: String { return self._s[3978]! } + public var Username_TooManyPublicUsernamesError: String { return self._s[3979]! } + public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3980]! } 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[3981]!, self._r[3981]!, [_0, _1]) } public func Conversation_OpenBotLinkText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3979]!, self._r[3979]!, [_0]) + return formatWithArgumentRanges(self._s[3982]!, self._r[3982]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3980]! } + public var Wallet_WordImport_Continue: String { return self._s[3983]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3981]!, self._r[3981]!, [_0]) + return formatWithArgumentRanges(self._s[3984]!, self._r[3984]!, [_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[3985]! } + public var Privacy_Calls_P2PContacts: String { return self._s[3986]! } + public var NotificationsSound_None: String { return self._s[3987]! } + public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3988]! } + public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3990]! } + public var AccessDenied_VoiceMicrophone: String { return self._s[3991]! } public func ApplyLanguage_ChangeLanguageAlreadyActive(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3989]!, self._r[3989]!, [_1]) + return formatWithArgumentRanges(self._s[3992]!, self._r[3992]!, [_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[3993]! } + public var DialogList_RecentTitlePeople: String { return self._s[3995]! } + public var DialogList_EncryptionRejected: String { return self._s[3996]! } + public var GroupInfo_Administrators: String { return self._s[3997]! } + public var Passport_ScanPassportHelp: String { return self._s[3998]! } + public var Application_Name: String { return self._s[3999]! } + public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[4000]! } + public var Conversation_Timer_Title: String { return self._s[4001]! } + public var ChatList_PeerTypeGroup: String { return self._s[4002]! } + public var PeopleNearby_MakeVisible: String { return self._s[4004]! } + public var Appearance_ThemeCarouselDay: String { return self._s[4005]! } + public var Stats_GrowthTitle: String { return self._s[4006]! } + public var Passport_Identity_TranslationHelp: String { return self._s[4007]! } public func VoiceOver_Chat_VideoMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4005]!, self._r[4005]!, [_0]) + return formatWithArgumentRanges(self._s[4008]!, self._r[4008]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4006]!, self._r[4006]!, [_0]) + return formatWithArgumentRanges(self._s[4009]!, self._r[4009]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4007]!, self._r[4007]!, [_0]) + return formatWithArgumentRanges(self._s[4010]!, self._r[4010]!, [_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[4011]! } + public var Privacy_ChatsTitle: String { return self._s[4012]! } + public var DialogList_ClearHistoryConfirmation: String { return self._s[4013]! } + public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4014]! } + public var Watch_Suggestion_HoldOn: String { return self._s[4015]! } + public var Group_EditAdmin_TransferOwnership: String { return self._s[4016]! } + public var WebBrowser_Title: String { return self._s[4017]! } + public var Group_LinkedChannel: String { return self._s[4018]! } + public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4019]! } + public var SocksProxySetup_RequiredCredentials: String { return self._s[4020]! } + public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4021]! } + public var Appearance_TextSize_UseSystem: String { return self._s[4022]! } + public var TwoStepAuth_EmailSkipAlert: String { return self._s[4023]! } + public var ScheduledMessages_RemindersTitle: String { return self._s[4025]! } + public var Channel_Setup_TypePublic: String { return self._s[4027]! } public func Channel_AdminLog_MessageToggleInvitesOn(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4025]!, self._r[4025]!, [_0]) + return formatWithArgumentRanges(self._s[4028]!, self._r[4028]!, [_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[4030]! } + public var MessagePoll_ViewResults: String { return self._s[4031]! } + public var Map_OpenInMaps: String { return self._s[4033]! } public func PUSH_PINNED_NOTEXT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4031]!, self._r[4031]!, [_1]) + return formatWithArgumentRanges(self._s[4034]!, self._r[4034]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[4033]! } + public var NotificationsSound_Tremolo: String { return self._s[4036]! } 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[4037]!, self._r[4037]!, [_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[4038]! } + public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4039]! } + public var Passport_PasswordHelp: String { return self._s[4041]! } + public var Login_CodeExpiredError: String { return self._s[4042]! } + public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4043]! } + public var Conversation_TitleUnmute: String { return self._s[4044]! } + public var Passport_Identity_ScansHelp: String { return self._s[4045]! } + public var Passport_Language_lo: String { return self._s[4046]! } + public var Camera_FlashAuto: String { return self._s[4047]! } + public var Conversation_OpenBotLinkOpen: String { return self._s[4048]! } + public var Common_Cancel: String { return self._s[4049]! } + public var DialogList_SavedMessagesTooltip: String { return self._s[4050]! } + public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4051]! } + public var Appearance_TintAllColors: String { return self._s[4052]! } public func PUSH_MESSAGE_FWD(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4050]!, self._r[4050]!, [_1]) + return formatWithArgumentRanges(self._s[4053]!, self._r[4053]!, [_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[4054]! } + public var ChatSettings_Title: String { return self._s[4056]! } + public var Passport_PasswordReset: String { return self._s[4057]! } + public var SocksProxySetup_TypeNone: String { return self._s[4058]! } + public var EditTheme_Title: String { return self._s[4061]! } + public var PhoneNumberHelp_Help: String { return self._s[4062]! } + public var Checkout_EnterPassword: String { return self._s[4063]! } + public var Activity_UploadingDocument: String { return self._s[4065]! } + public var Share_AuthTitle: String { return self._s[4066]! } + public var State_Connecting: String { return self._s[4067]! } + public var Profile_MessageLifetime1w: String { return self._s[4068]! } + public var Conversation_ContextMenuReport: String { return self._s[4069]! } + public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4070]! } + public var AutoNightTheme_ScheduledTo: String { return self._s[4071]! } public func VoiceOver_Chat_AnonymousPollFrom(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4069]!, self._r[4069]!, [_0]) + return formatWithArgumentRanges(self._s[4072]!, self._r[4072]!, [_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[4073]! } + public var Wallet_WordImport_CanNotRemember: String { return self._s[4074]! } + public var PeerInfo_PaneAudio: String { return self._s[4075]! } public func Message_ForwardedPsa_covid(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4073]!, self._r[4073]!, [_0]) + return formatWithArgumentRanges(self._s[4076]!, self._r[4076]!, [_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[4078]! } + public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4079]! } + public var PhotoEditor_Set: String { return self._s[4080]! } + public var EmptyGroupInfo_Title: String { return self._s[4081]! } + public var Login_PadPhoneHelp: String { return self._s[4083]! } + public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4085]! } + public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4087]! } + public var NotificationsSound_Complete: String { return self._s[4088]! } + public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4089]! } + public var Group_Info_AdminLog: String { return self._s[4090]! } + public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4091]! } 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[4092]!, self._r[4092]!, [_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[4093]! } + public var Group_Location_CreateInThisPlace: String { return self._s[4095]! } + public var Conversation_Admin: String { return self._s[4096]! } + public var Conversation_GifTooltip: String { return self._s[4097]! } + public var Passport_NotLoggedInMessage: String { return self._s[4098]! } public func AutoDownloadSettings_OnFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4097]!, self._r[4097]!, [_0]) + return formatWithArgumentRanges(self._s[4100]!, self._r[4100]!, [_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[4101]! } + public var SharedMedia_EmptyTitle: String { return self._s[4103]! } + public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4105]! } + public var Username_Help: String { return self._s[4106]! } + public var DialogList_LanguageTooltip: String { return self._s[4108]! } + public var Map_LoadError: String { return self._s[4109]! } + public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4110]! } + public var Channel_AdminLog_AddMembers: String { return self._s[4111]! } + public var ArchivedChats_IntroTitle2: String { return self._s[4112]! } + public var Notification_Exceptions_NewException: String { return self._s[4113]! } + public var TwoStepAuth_EmailTitle: String { return self._s[4114]! } + public var WatchRemote_AlertText: String { return self._s[4115]! } 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[4116]!, self._r[4116]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[4117]! } + public var ChatSettings_ConnectionType_Title: String { return self._s[4120]! } 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[4121]!, self._r[4121]!, [_1, _2]) } public func Settings_CheckPhoneNumberTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4119]!, self._r[4119]!, [_0]) + return formatWithArgumentRanges(self._s[4122]!, self._r[4122]!, [_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[4123]! } + public var WebBrowser_DefaultBrowser: String { return self._s[4124]! } + public var Passport_Address_CountryPlaceholder: String { return self._s[4125]! } public func DialogList_AwaitingEncryption(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4123]!, self._r[4123]!, [_0]) + return formatWithArgumentRanges(self._s[4126]!, self._r[4126]!, [_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[4127]!, self._r[4127]!, [_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[4128]! } + public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4129]! } + public var Conversation_PrivateChannelTooltip: String { return self._s[4131]! } + public var Wallet_Created_ExportErrorText: String { return self._s[4132]! } + public var ChatList_UndoArchiveText1: String { return self._s[4133]! } + public var ChatListFolder_IncludedSectionHeader: String { return self._s[4134]! } + public var AccessDenied_VideoMicrophone: String { return self._s[4135]! } + public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4136]! } + public var Cache_ClearNone: String { return self._s[4137]! } + public var SocksProxySetup_FailedToConnect: String { return self._s[4138]! } + public var Permissions_NotificationsTitle_v0: String { return self._s[4139]! } public func Channel_AdminLog_MessageEdited(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4137]!, self._r[4137]!, [_0]) - } - public var Passport_Identity_Country: String { return self._s[4138]! } - public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4139]!, self._r[4139]!, [_0]) - } - public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4140]!, self._r[4140]!, [_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 func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4161]!, self._r[4161]!, [_0]) + public var Passport_Identity_Country: String { return self._s[4141]! } + public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4142]!, self._r[4142]!, [_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 func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4143]!, self._r[4143]!, [_0]) + } + public var Exceptions_AddToExceptions: String { return self._s[4144]! } + public var AccessDenied_Settings: String { return self._s[4145]! } + public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4146]! } + public var Month_ShortMay: String { return self._s[4148]! } + public var Compose_NewGroup: String { return self._s[4150]! } + public var Group_Setup_TypePrivate: String { return self._s[4152]! } + public var Login_PadPhoneHelpTitle: String { return self._s[4154]! } + public var Appearance_ThemeDayClassic: String { return self._s[4155]! } + public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4156]! } + public var AutoDownloadSettings_OffForAll: String { return self._s[4157]! } + public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4158]! } + public var Conversation_typing: String { return self._s[4160]! } + public var Undo_ScheduledMessagesCleared: String { return self._s[4161]! } + public var Paint_Masks: String { return self._s[4162]! } + public var Contacts_DeselectAll: String { return self._s[4163]! } + public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4164]!, self._r[4164]!, [_0]) + } + public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4165]! } + public var Username_InvalidTaken: String { return self._s[4166]! } + public var Call_StatusNoAnswer: String { return self._s[4167]! } + public var TwoStepAuth_EmailAddSuccess: String { return self._s[4168]! } + public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4169]! } + public var Passport_Identity_Selfie: String { return self._s[4170]! } + public var Login_InfoLastNamePlaceholder: String { return self._s[4171]! } + public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4172]! } + public var Conversation_ClearSecretHistory: String { return self._s[4173]! } + public var PeopleNearby_Description: String { return self._s[4175]! } + public var NetworkUsageSettings_Title: String { return self._s[4176]! } + public var Your_cards_security_code_is_invalid: String { return self._s[4178]! } + public var Stats_EnabledNotifications: String { return self._s[4179]! } public func Notification_LeftChannel(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4178]!, self._r[4178]!, [_0]) + return formatWithArgumentRanges(self._s[4181]!, self._r[4181]!, [_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[4182]!, self._r[4182]!, [_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[4184]! } + public var VoiceOver_Navigation_Search: String { return self._s[4185]! } + public var Map_LiveLocationTitle: String { return self._s[4186]! } + public var Login_InfoAvatarAdd: String { return self._s[4187]! } + public var Passport_Identity_FilesView: String { return self._s[4188]! } + public var ChatListFolderSettings_Title: String { return self._s[4189]! } + public var UserInfo_GenericPhoneLabel: String { return self._s[4190]! } + public var Privacy_Calls_NeverAllow: String { return self._s[4191]! } + public var VoiceOver_Chat_File: String { return self._s[4192]! } + public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4193]! } public func Contacts_AddPhoneNumber(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4191]!, self._r[4191]!, [_0]) + return formatWithArgumentRanges(self._s[4194]!, self._r[4194]!, [_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[4196]! } + public var ContactInfo_PhoneNumberHidden: String { return self._s[4197]! } + public var TwoStepAuth_ConfirmationText: String { return self._s[4198]! } + public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4199]! } 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[4200]!, self._r[4200]!, [_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[4201]! } + public var Wallet_Intro_CreateErrorText: String { return self._s[4202]! } + public var Tour_Title2: String { return self._s[4203]! } + public var Wallet_Sent_ViewWallet: String { return self._s[4204]! } + public var Conversation_FileOpenIn: String { return self._s[4205]! } + public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4206]! } + public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4207]! } + public var Wallpaper_Set: String { return self._s[4208]! } + public var Passport_Identity_Translations: String { return self._s[4210]! } public func Channel_AdminLog_MessageChangedChannelAbout(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4207]!, self._r[4207]!, [_0]) + return formatWithArgumentRanges(self._s[4211]!, self._r[4211]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4208]! } + public var Channel_LeaveChannel: String { return self._s[4212]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4209]!, self._r[4209]!, [_1]) + return formatWithArgumentRanges(self._s[4213]!, self._r[4213]!, [_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[4215]! } + public var PhotoEditor_HighlightsTint: String { return self._s[4216]! } + public var MessagePoll_LabelPoll: String { return self._s[4217]! } + public var Passport_Email_Delete: String { return self._s[4218]! } + public var Conversation_Mute: String { return self._s[4220]! } + public var Channel_AddBotAsAdmin: String { return self._s[4221]! } + public var Channel_AdminLog_CanSendMessages: String { return self._s[4223]! } + public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4224]! } + public var ChatSettings_IntentsSettings: String { return self._s[4226]! } + public var Channel_Management_LabelOwner: String { return self._s[4227]! } 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[4228]!, self._r[4228]!, [_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[4229]! } + public var Passport_Identity_NativeNameHelp: String { return self._s[4230]! } + public var Common_No: String { return self._s[4231]! } + public var Weekday_Sunday: String { return self._s[4232]! } + public var Notification_Reply: String { return self._s[4233]! } + public var Conversation_ViewMessage: String { return self._s[4234]! } public func Checkout_SavePasswordTimeoutAndFaceId(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4231]!, self._r[4231]!, [_0]) + return formatWithArgumentRanges(self._s[4235]!, self._r[4235]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4232]!, self._r[4232]!, [_0]) + return formatWithArgumentRanges(self._s[4236]!, self._r[4236]!, [_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[4237]!, self._r[4237]!, [_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[4238]! } + public var Wallet_Send_Title: String { return self._s[4239]! } + public var Message_PinnedDocumentMessage: String { return self._s[4240]! } + public var Wallet_Info_RefreshErrorText: String { return self._s[4241]! } + public var DialogList_TabTitle: String { return self._s[4243]! } + public var ChatSettings_AutoPlayTitle: String { return self._s[4244]! } + public var Passport_FieldEmail: String { return self._s[4245]! } + public var Conversation_UnpinMessageAlert: String { return self._s[4246]! } + public var Passport_Address_TypeBankStatement: String { return self._s[4247]! } + public var Wallet_SecureStorageReset_Title: String { return self._s[4248]! } + public var Passport_Identity_ExpiryDate: String { return self._s[4249]! } + public var Privacy_Calls_P2P: String { return self._s[4250]! } public func CancelResetAccount_Success(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4248]!, self._r[4248]!, [_0]) + return formatWithArgumentRanges(self._s[4252]!, self._r[4252]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4249]! } + public var SocksProxySetup_UseForCallsHelp: String { return self._s[4253]! } 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[4254]!, self._r[4254]!, [_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[4255]! } + public var EnterPasscode_ChangeTitle: String { return self._s[4256]! } + public var TwoFactorSetup_Email_Title: String { return self._s[4257]! } + public var Passport_InfoText: String { return self._s[4258]! } + public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4259]! } public func Login_InvalidPhoneEmailSubject(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4256]!, self._r[4256]!, [_0]) + return formatWithArgumentRanges(self._s[4260]!, self._r[4260]!, [_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[4261]!, self._r[4261]!, [_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[4262]! } + public var ScheduledMessages_PollUnavailable: String { return self._s[4263]! } + public var VoiceOver_Navigation_Compose: String { return self._s[4264]! } + public var Passport_Identity_EditDriversLicense: String { return self._s[4265]! } + public var Conversation_TapAndHoldToRecord: String { return self._s[4267]! } + public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4268]! } 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[4269]!, self._r[4269]!, [_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[4272]! } + public var ChatSettings_OpenLinksIn: String { return self._s[4273]! } + public var Map_HomeAndWorkTitle: String { return self._s[4274]! } public func Generic_OpenHiddenLinkAlert(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4272]!, self._r[4272]!, [_0]) + return formatWithArgumentRanges(self._s[4276]!, self._r[4276]!, [_0]) } - public var DialogList_Unread: String { return self._s[4273]! } + public var DialogList_Unread: String { return self._s[4277]! } 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[4278]!, self._r[4278]!, [_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[4279]! } + public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4280]! } + public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4281]! } public func Watch_Time_ShortYesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4278]!, self._r[4278]!, [_0]) + return formatWithArgumentRanges(self._s[4282]!, self._r[4282]!, [_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[4283]! } + public var SharedMedia_CategoryMedia: String { return self._s[4284]! } + public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4285]! } + public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4286]! } + public var Watch_ChatList_Compose: String { return self._s[4287]! } + public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4288]! } + public var AutoDownloadSettings_Delimeter: String { return self._s[4289]! } + public var Watch_Microphone_Access: String { return self._s[4290]! } + public var Group_Setup_HistoryHeader: String { return self._s[4291]! } + public var Map_SetThisLocation: String { return self._s[4292]! } + public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4293]! } + public var Activity_UploadingPhoto: String { return self._s[4294]! } + public var Conversation_Edit: String { return self._s[4296]! } + public var Group_ErrorSendRestrictedMedia: String { return self._s[4297]! } + public var Login_TermsOfServiceDecline: String { return self._s[4298]! } + public var Message_PinnedContactMessage: String { return self._s[4299]! } 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[4300]!, self._r[4300]!, [_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[4301]!, self._r[4301]!, [_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[4302]! } + public var TwoStepAuth_AdditionalPassword: String { return self._s[4304]! } + public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4305]! } 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[4306]!, self._r[4306]!, [_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[4307]! } + public var Message_PinnedPhotoMessage: String { return self._s[4308]! } + public var Passport_FieldPhone: String { return self._s[4309]! } + public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4310]! } + public var Stats_NotificationsTitle: String { return self._s[4311]! } + public var ChatSettings_AutoPlayGifs: String { return self._s[4312]! } + public var InfoPlist_NSCameraUsageDescription: String { return self._s[4314]! } + public var Conversation_Call: String { return self._s[4315]! } + public var Common_TakePhoto: String { return self._s[4317]! } + public var Group_EditAdmin_RankTitle: String { return self._s[4318]! } + public var Wallet_Receive_CommentHeader: String { return self._s[4319]! } + public var Channel_NotificationLoading: String { return self._s[4320]! } public func Notification_Exceptions_Sound(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4317]!, self._r[4317]!, [_0]) - } - public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4318]!, self._r[4318]!, [_0]) - } - public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4319]!, self._r[4319]!, [_1]) - } - public var Permissions_SiriTitle_v0: String { return self._s[4320]! } - public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4321]!, self._r[4321]!, [_0]) } - public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4322]!, self._r[4322]!, [_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 func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4323]!, self._r[4323]!, [_1]) + } + public var Permissions_SiriTitle_v0: String { return self._s[4324]! } + public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4325]!, self._r[4325]!, [_0]) + } + public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4326]!, self._r[4326]!, [_0]) + } + public var Channel_MessagePhotoRemoved: String { return self._s[4327]! } + public var Wallet_Info_ReceiveGrams: String { return self._s[4328]! } + public var ClearCache_FreeSpace: String { return self._s[4329]! } + public var Appearance_BubbleCorners_Apply: String { return self._s[4330]! } + public var Common_edit: String { return self._s[4331]! } + public var PrivacySettings_AuthSessions: String { return self._s[4332]! } + public var Month_ShortJune: String { return self._s[4333]! } + public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4334]! } + public var Call_ReportSend: String { return self._s[4335]! } + public var Watch_LastSeen_JustNow: String { return self._s[4336]! } + public var Notifications_MessageNotifications: String { return self._s[4337]! } + public var WallpaperSearch_ColorGreen: String { return self._s[4338]! } + public var BroadcastListInfo_AddRecipient: String { return self._s[4340]! } + public var Group_Status: String { return self._s[4341]! } 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[4342]!, self._r[4342]!, [_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[4343]! } + public var ShareMenu_ShareTo: String { return self._s[4344]! } + public var Conversation_Moderate_Ban: String { return self._s[4345]! } public func Conversation_DeleteMessagesFor(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4342]!, self._r[4342]!, [_0]) + return formatWithArgumentRanges(self._s[4346]!, self._r[4346]!, [_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[4347]! } + public var Map_LiveLocationFor8Hours: String { return self._s[4348]! } public func PUSH_PINNED_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4345]!, self._r[4345]!, [_1]) + return formatWithArgumentRanges(self._s[4349]!, self._r[4349]!, [_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[4350]!, self._r[4350]!, [_1, _2]) } public func Map_AccurateTo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4348]!, self._r[4348]!, [_0]) + return formatWithArgumentRanges(self._s[4352]!, self._r[4352]!, [_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[4353]! } + public var Appearance_ReduceMotion: String { return self._s[4354]! } public func PUSH_MESSAGE_TEXT(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4351]!, self._r[4351]!, [_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 { - 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) - } - 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[12 * 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[13 * 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[14 * 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[15 * 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[16 * 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[17 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Hours(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[19 * 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[20 * 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[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) + return formatWithArgumentRanges(self._s[4355]!, self._r[4355]!, [_1, _2]) } + public var Channel_Setup_TypePublicHelp: String { return self._s[4356]! } + public var Passport_Identity_EditInternalPassport: String { return self._s[4357]! } + public var PhotoEditor_Skip: String { return self._s[4358]! } 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) - } - 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) - } - public func LastSeen_HoursAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_ShortSeconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[70 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Media_ShareItem(_ 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 MuteFor_Hours(_ 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 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 Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[74 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Wallet_Updated_HoursAgo(_ 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 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) - } - 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) + return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } public func MessageTimer_Seconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + public func AttachmentMenu_SendGif(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[2 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_Leave(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[3 * 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[4 * 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[5 * 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[6 * 6 + Int(form.rawValue)]!, _0, _1) } public func ServiceMessage_GameScoreSimple(_ 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) + return String(format: self._ps[7 * 6 + Int(form.rawValue)]!, stringValue) } - public func CreatePoll_AddMoreOptions(_ value: Int32) -> String { + 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[81 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSimple(_ 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[82 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[9 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func Conversation_StatusOnline(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[83 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Years(_ value: Int32) -> String { + public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Invitation_Members(_ 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 { - 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) + return String(format: self._ps[11 * 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[115 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[12 * 6 + Int(form.rawValue)]!, stringValue) } - public func Passport_Scans(_ value: Int32) -> String { + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[13 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_ShortHours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[14 * 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[15 * 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[16 * 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[17 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func OldChannels_GroupFormat(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Notifications_ExceptionMuteExpires_Days(_ 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 AttachmentMenu_SendPhoto(_ 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 StickerPack_RemoveMaskCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[21 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PrivacyLastSeenSettings_AddUsers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[22 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_InactiveWeek(_ 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 Forward_ConfirmMultipleFiles(_ 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 OldChannels_InactiveYear(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[25 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedGifs(_ 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 PasscodeSettings_FailedAttempts(_ 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 Notifications_ExceptionMuteExpires_Minutes(_ 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 Notification_GameScoreExtended(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[29 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Link(_ 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 Notification_GameScoreSelfSimple(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[31 * 6 + Int(form.rawValue)]!, stringValue) + } + public func SharedMedia_Generic(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LiveLocation_MenuChatsCount(_ 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 Media_ShareItem(_ 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 Stats_MessageForwards(_ 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 PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func AttachmentMenu_SendItem(_ 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 UserCount(_ 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 ForwardedLocations(_ 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 Contacts_ImportersCount(_ 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 StickerPack_StickerCount(_ 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_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[42 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func PUSH_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[43 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func SharedMedia_Video(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[44 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ForwardedStickers(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[45 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Invitation_Members(_ 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_DeleteConfirmation(_ 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 MessageTimer_ShortSeconds(_ 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 PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + 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[50 * 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) + return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LastSeen_MinutesAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[52 * 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[53 * 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[54 * 6 + Int(form.rawValue)]!, stringValue) + } + 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[55 * 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[56 * 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[57 * 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[58 * 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[59 * 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[60 * 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) + return String(format: self._ps[61 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHANNEL_MESSAGE_PHOTOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + public func MessageTimer_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[62 * 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[63 * 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[64 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Years(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[65 * 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[66 * 6 + Int(form.rawValue)]!, stringValue) + } + public func ChatList_MessagePhotos(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[67 * 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[68 * 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[119 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[69 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func Conversation_SelectedMessages(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[70 * 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[71 * 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[72 * 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[73 * 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[74 * 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[75 * 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[76 * 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[77 * 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[78 * 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[79 * 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[80 * 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[81 * 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[82 * 6 + Int(form.rawValue)]!, stringValue) + } + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[83 * 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[84 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[85 * 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[86 * 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[87 * 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[88 * 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[89 * 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[90 * 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[91 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MuteFor_Days(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[92 * 6 + Int(form.rawValue)]!, stringValue) + } + public func VoiceOver_Chat_ContactEmailCount(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[93 * 6 + Int(form.rawValue)]!, stringValue) + } + public func LastSeen_HoursAgo(_ 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 Media_ShareVideo(_ 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 PeopleNearby_ShowMorePeople(_ 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 ForwardedVideos(_ 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 Map_ETAMinutes(_ 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 Conversation_LiveLocationMembersCount(_ 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 InstantPage_Views(_ 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 ServiceMessage_GameScoreSelfExtended(_ 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 PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func GroupInfo_ParticipantCount(_ 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 Passport_Scans(_ 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 PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, _1, _2) + } + public func MuteExpires_Minutes(_ 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 QuickSend_Photos(_ 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 PUSH_CHAT_MESSAGES(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[109 * 6 + Int(form.rawValue)]!, _2, _1, _3) + } + public func ServiceMessage_GameScoreSelfSimple(_ 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 MessageTimer_Weeks(_ 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 VoiceOver_Chat_PollVotes(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[112 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Days(_ 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 Media_SharePhoto(_ 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 Call_Minutes(_ 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 MuteFor_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[116 * 6 + Int(form.rawValue)]!, stringValue) + } + public func InviteText_ContactsCountText(_ 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_StatusSubscribers(_ 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 Map_ETAHours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[119 * 6 + Int(form.rawValue)]!, stringValue) + } + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { + let form = getPluralizationForm(self.lc, selector) + return String(format: self._ps[120 * 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[121 * 6 + Int(form.rawValue)]!, stringValue) } - public func DialogList_LiveLocationChatsCount(_ value: Int32) -> String { + public func MessagePoll_VotedCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[122 * 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 Wallet_Updated_MinutesAgo(_ 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 Map_ETAMinutes(_ value: Int32) -> String { + public func ChatList_SelectedChats(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[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) + 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[125 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func MessagePoll_QuizCount(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[126 * 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 Notifications_ExceptionMuteExpires_Hours(_ 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 Conversation_StatusMembers(_ value: Int32) -> String { + 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[128 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_StatusOnline(_ value: Int32) -> String { + public func ForwardedFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[129 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_DeleteItemsConfirmation(_ 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[130 * 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[131 * 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[132 * 6 + Int(form.rawValue)]!, _1, _2) + } public init(primaryComponent: PresentationStringsComponent, secondaryComponent: PresentationStringsComponent?, groupingSeparator: String) { self.primaryComponent = primaryComponent diff --git a/submodules/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Resources/PresentationStrings.mapping index 0873e9119c0c0bbd67a55f67cc26553576c3072b..7704fb8448a842976e13aa24199429b6318970bd 100644 GIT binary patch delta 45718 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%0AWo0Xgnwh-BvaP7Q#JO5HeTPSD-dxOgnKdi0yvQ zdr^i7vSKXwt!jP!H_r&aU_xC1n@D}?Jl08|$Vrtu0)VJ=Cj=ITu+KGgU7dwZrn~E` zd@9)N3Ov!#xdTdQ&YwYa?N@&VrH&VAIC%kqS7N$_JDVE=?x+yjxT(J7xkgIof zNT{UsYJ|Tfq)wLMP>GKW0v+^UB1iEy>bJnm*Me+O z@0TDqH+Z&SK*~W{M=KZPBB1-kf_%OKOdh$T(k}~=`9_pnqA~@RW%j~Yz6r&2+GtIo z%7rne+fj-}bBWdPBYPqWE-VDJ+rBUxvECyKGnl}4xl``~tAxj4)EiX#>E3ps;2`!% zU2Isj$xgOX#iC5MjTSBPBBqP!(alzRaz{HdzG@PM%a}>jeaxgQ@cg0-ejoZ)4xAC; z*b?+=O=xiL2T4j#$m$BoN3d>YO@sRE2SAmwTMAT8bO;Jd;i+5_g~0ImB@RHqMN91P0&ZTC0oZq7Nfuz=H~4#> z(!`xwHSv?wXK5F{A3b6_9Boak3^q1Zg`fNsYI6jp-$I9%rm&~!)1^K@zbi{^a0A+| zHS_1dU{~rXCKSh&WA;2vzt#i5cjL7_?WJ~N;}~p1uUwl5!1vL$?!L`v@_(GG5Rb)b zOb>%1UDYjCG$N=H&come`8;0+Jy*UXjart%UZI+0PWGx2)g8-Xwb$CwiUW3fXPKVA z0Y-exa%)^ApnikDrb!Cko7C<)uXd!JI8zBlR&rg6`7Q7%`$uW))~)Al3SO7R-vQAY z(ocJ@OJMI(^L1`^jK01u1HM50ax43Qe9N6FAAwCulX9QQU-&!XW176&2NZY1@{IIP z!JuG8$jA!mRmt=@y}aC`ebG+&g4XwmiD@H!NyZgEc9OcTZ~(@QU*Xfvw4;q*r_!>^ zdfL7smVHG}tjI(p_`?-m?b~*Ar7{)KJw2tbOwztoN1Oh&(9xATc9uR_Y17WNgM}N~hiZ}%bu(ocCE`LmG4e~6++L<=$USZd+ywH4 zFSZjK3R!YIET~#FVVCe}J{3DyyUNUdrUzGffWeNe@&bdMUsb667Fs0TlbIC=tnzv< z5ZHq2^MSzbzdnooMekgn$^S+lUS;mLZyXSq>0eOWG&;B-l=AWqK!TO}-JpXHZ|DsU z_8-;UkfU8`C-z=~Wf_hPb2@Ybd|Z)0w8a{W6uUgkNuC>%nMU1j^s#m{{YIA-87U*K z(F+uiiK6>%^zi6N>B>$OqD#gkx_C=8{BeKY;^3L6OQGY}o2ckkJwhZs zZuJ4R`ET{`9M!MXgI=0?p9|wwxI3u$`rp&ZrYdNap$+*Gom;jdl3uGXnt*dS#jogsYcM^Cc ziW^fiFM#BxdBKK;;Gz;GD%XIN0#Ye}9pHb%!kVgpj8TP5MERJ>kz(z)kiBCYVvu8VFu-Eiwni&Z>tSWilG2NOyp1-5f`7vAnWW!j0VK@W6up{#}>b9oqazy0FO7CP)pDV*cYW zyf)tMW{tETznkde+r8R?NaZf31WEv;bC3&=u7s>?F-;|_wj{Je5%S}!N>FlaYMipn2DjyX=v|3t>s*ZP;Vc*<@fJA$e=Q`wyb+UiJY z#hJz|3XX0H)R!!1Ql7V4@SIHPN)gY_f(d&3POjY=+3KpH%Xh|VYa+vLT`Rv0+*VPv z;A*etTGXY7f^4ym>vSP}zAjQ2e`V&_QGt2Ea3<;o+Pyi0ZvuB39ly;)XE(@&)q4KU6wiSy$iHsk|(XzV?fPJg)a`PQvQSJ>39l0xk--n`!iU%g^ie-*T z#Ql*WSkeCO6!rjR-|dm^ySsDj4}nkFB*3Lg@*B%x7|c-H=fjx)7tPUKW&1}UX+JSL zy?=KaqPl1AF4UfgRAIuRdyMeomE4m9C|7$=CZJsLElJd4Pdq(+PkTVRH}CNR(w)1< z$DhQbvc#?FS_bvL*MOMqkb7Ivp{d9!fEQ4N<)79D^##G6F$9hTeA`AUAa|8 zdLKf~n{;%miyfhhTZ`D+PWjuD;bJS@p3gp}`P*}mzqfU}3;BD8wx`3D_WAZaxYD9`6!0(6 zB$*Nin5cY*j-8rnaRHgQ;OL1A$IO-cItu00y};1dad1=0|55yPA5MH2CLj~W2N&BTdo|B3%B2w zqg{+_ar3t6nM;vW+{Ywhma`a9carJ&&uCt#eD06lmjdk7e4mN`hPrTAgMXklE1be(0wAluzcc?Eb(u28K}YUS0Ob1Y{$fC`m={-!iE1bFwm5T69E>24`<--J0JFzq@jhB z*4Au_R=h8LLDKahz1Pa|Hw6CtlGbbjnMoygOL3+flg4M_BQDLx#la4UP?bNT=XTIt zD))>UA4#-0!_SesVc5AB9&=>HJz~{7tzQ`>;uf$ZuuGfq!Xq-OnfPc&r0j*B*Sc|I zk8LUq)`mVW6I7=(f?`Vnlbb?`WLdP~(IP;t=0_cHkez-s7Z5AA;gF_8D1ntTIYN$!uj*zuOJaM!Q`AZBOscbB+X`l%Q7Gf7l|VwWMA$v!ku<*kJok$xa8L>15=7< zIFUehJedmi`uG%ZBvbub6V2PJ<5N*eA$CVHZ9r)nN)nV*YXZBOSm=9 zxrR>e>i{QP;*(x&F5jH5!5{Ht46CKdPiC-rbp4ZAS{Pi()PHIQ?^i!T60?a4`E!+54s+zU~ctJ21)ceb83?2iMW+PdEZKy`S(1D>)o z`_q7>{@L%)u2mnYn;nqjv!|3X`RAuN0!aCahi~~NjqtE0cUGCp!()cEDr-^O7v8@+9YtU}zVxJ$H zwBlJaBbxne77j*idRE3k_dILSHgmDD9wL90C#_ufydp3ecOdgA#`099w6FXj)SjaB&_@?MD79_AsVZ{;NeZCR`n$NRBJ?a`2y zrQIV8bkhq-z*Kj?;Dk@?g%@%Gr@no`qwVIxd9DQq7rbcF_HePRGqW4i9PY&$i$%a#n;uIO%_|v4h&17V3m&rK173K@#vRCnhiv(QEdCri z$_eG>_k2C3Z7Y9Xy>&VrT#r2F1A6`f_-qO+IbSjYU=_dQ;s;RYqm{RNXz5D^{t`+~ zX$!@vF%26-2Wj6+PJRe9WQJ!Z<+f!fG^0+r(^Q&=JmXc@bTvpjOs0cQ{xY~iYEW%h zQovrJX$KvEV=E5Y0LQi-%;9f<2`}5uG;V~$@ONVG{eRCdsa9f+R0ruW#c55F(oU@rVdgvgzYCfX)!&d$=+NFz2 z1DV;-9~P%_{Cq+q54(Z?nhs|J|7|<$0{&}0?BQR4*8$_ydexToB_+IU0Se5;?~^q6 zWgi@IbuZ^>r@7eM2|LWaXX2DfI)k?M%^$J!Sb5eUoJ8^!oqM^H?Q4+a5>=U3Dh@cT zVkl1J$d~*d^?Ak0zM*SgDF9$x^NJgQan~!w?0Y)(N+G;;39l9dCzibG0#2-Y)vcZ5 z;zAeZrbk~*V(00lR~?9lo&fbCU3s+-33P?8dHB!rRYJM9b+5$(4PN(J9{&}UX`xKD zCEMcIZ*=UnEdDzx)gBR7SutXSe4js2Q`91+>HIGgt>VkOV3A#w&Gt7ff8B-S89QDt z0z7>0^>lUC@k*m@iTJiEBjIMjb4ZqxuH*$a&-+sf# zBLSW*qI?hblDIcxI7bnB_+{ozhJmYM6D?{b3Z&9drq+r#U9gXLzL^Wp_q%UOJbCd= z503={qUFt&&dSbe^DxM;g|vBElB1Oh9*t;rLpVh`9tFVK_6Cis6pT2O0?3{w>xXL5bq3?%jck{-bP?Giu%s7 z7{&~oFh-82JBoH@C!0z`@d_DBlC>UmXi_t77`7nfsP#rkp+$<#I|hKvx$nr-xpnWP zX_-+iY5UQlxd_8~{GCXijrNwXCW_Lx1i^FY-*=pVm9}@CSciSywF5~`dDjXgx%6Ex zkmUAvJ2;EbQf_sn%Ac-69B}T>YB^(5Oqbrx(>g>6wt^)kNIei#p)|CJ=tw0;(~)F1 z`DiBZjBem){2Ry8jwWkeqJ+!Ml5_(q` zp#BRGTB>V1#oCkDSIJa!%&hfN0~|BgFJGWH+F7W%uhkJcde{f$7Nvz?XjN@Z=*R^Q zcO1)vD^P#D6Dy@Y@V^eA3CFFjf#8?lE)9_}vjcFNslQsn*@L3gX{P-5VfP$59*gs{ z?;J0LGw|QzE<|tb@A>#}bl{ezTwDIv2vns~`2!(eSQ$!YaWM!f+w-0Q`16JL+`ykF z-m_~Xqm=VE>3tI)rMf}vgND2x$48@-uDmC8@5cdlvad`C+@&GaF7%hl&_RCuIIxAI zg%{sX(k4WS_mC_=_74mIp<&Lbj*@c{jsL)n!yQXM$Uq!-#|PO+scY$~lVq5to`~bG zfDbbNQElPV$^M}QCuw_p=tCse|6v-=Ze07JLkmQSQ^S}{@`jTJK>{PUW1|yanH1?eMboNew4@Of@GB{!CU4J zog1u0jWhyPCRoT{+25~h?s*u(tq$c%ufyl#h)=?>1@mAwv}B|NY2?RFtv)Jr1bO|( zaeO{Hv&j4m{h*SO^4lAt=**)gT3M=(#~G?nUb?JrqzfN=txaH8aq;lEqoL*FDu$M- zwBAKj_=!(j93?{#6#PUFB)jC3PKfsI{=~+YpNg{ox1US%mU zp`%OJqoSkAc&`1_XT2f(BrLv}h+r4M8fj52H`4A;ecDY?V%21vqWa?u2L8WKb@2E_ ze`eQKM}^##Jw8i7e%`Rpvb0;H#Jngta@T*R=WEcbOYF=5s(<>k1nsscc`}JkerD3v zMybs1xX<+((2TS#iaw9BYyiI;>!EcEYnlSee>-;62ss`bY2@b)wu$EB_wBUlbFZDi zE1lLMzts2|88fM?9z9Qayzih7KKBBf{`ooFd|*r#`{J+&3crZvcgZ5T;H@kFLJxd8 z;R_eP2X*1V-FJHvw0kjQG6Vj_FOt|6I`)MV?!Aj&bmZH>mL@Zgso$46WZ(_`vKxN@ zbxAVbnS%WfM>S~YmmRc+qGaA-v4XBlPDw{%B~nL-}-4(<|$doIpyHbpk$S)nyFb>NcF+G z#(-pc7S(N`&$0!LHC3|uIaJ%}(c&eU9MPb`v>yxJvki)m(YqO|7hwZ|MrTS8o zI`>cAPsby|JLI$vDSg4ycKG|&pLQXoZ|~_0{xW)T%hQ3$6%Diebu~*BT9oSi6;M3l z=&#Jv0{&j3j%TufJ13vX;%|cL6vYcMz+29k;0fFZ(p&WT86W(C?5liu0t>%#AXBg6 zD=$9==1{V2e5;rLIO?p@6iY&$LS3*)>SXzy@1Y(^$tR%XPJd+tn7s5=2LC`l4Gx2} zgitzy6j{mqA(ejZ<{yD-lOtgm@5gz2N%$Bek&iI%OJCcy&!WT`2j27I*Cy=*7V^O~ za{P}2I%fPY572SP2gx++e2QFO#-d_RuA~O=35Cr zAN$q``1$s?PJRhI>Xd_tBEM^oKyd1J8GxU?zw>FoVz*C60@vE_5`jIpeV5_=9n5m0 z3~iDUyU556(%(W*Y^X=9PN-$A{~EMZ59=Evx4D}QzX6oLpJB&0eX8Cf>hREU{PX4B=T{({%AzELw>Zw z<2ma`yQYtBi;(R4F&2pRg&!S20-yibmB*onbY;xu{uB#OXt$rTSOWQfDg^%A^pg)> z&*y$}ApZO5Pd13x@2D}6?W_ai)BCIs-qGr_g*+8~IHgz4p_c)B`Eh1yKAVrXI)Anp z`rCP~lV*vQey!Lp>c$JnVvQE3Cn8w>;5j3=sUCV4GpkWTmauW@kng69DEjZ5UUNpP zYyro4hvo{6+UWCE7$x=Rlkw3vpO=|>51w}+^83d5VxEo0Ub!)g{E-+3`vn8fK~*Zv z|JjsKS{rN(<;CQoE+>qy4K(k9$(xTF8D9(^S(G~gT%dK;C3Q;{g&Z6O(V@lh(uFiY z&rdF7v7*~AcC{6wp)|OphK0{`%G0e5xwZZB?s$GUtY4aKJ?EeEAIz-dpc8}tjxy&C|%{zn)Y)X8$|Pdc4~v8 ziQSBdBG&37Kc~5efKS5Ou>6Lv1_|HMA|EuAzWzB2P_p@~mx_MTBN?#AFWGzqn%U^x z4sFMZ%V^y%K7hxkekrt%1XZdb34|JPbjV)~*>2H#a9aMFiGv#1zuNd1Fd~0?yIE{l z!Z^+TH5CYQ<*(U%90=)hLdC!TGQIlZ@pSyx4weZZNY7YkLvP7P(&Cgr0t5Uj5al&g4JL3!|Mya^7U zlBs`wOXq%+9K!M1*BD1GMsYw>C2*=l0D>{aY!s&`9b9 zwGXu9EEGt86)GcUgDOMHEm=%bdnkom6WwyCr!Jd=cm#QFb4s_M1PAe6cE?!RS!RU-8-!Sc0LTOSG}1 zdR|RkW9xS>#Vna=?q4zdTC_n5ArA4jL7io^^RIk(SC9SG6*tC2|6RmZP`AIW+Dhm? z!n5lCjzt3Eb$@5`>(RQ!LllQwWRCuw$8HQMPWwMbWFHp(W0NuHe=OSSXmRm7=#z`( zdhM3z))OW2vy+i%`0+m;z6QNH)m%@z$v~EW4LCsJ``3q~BW3@Zwe`_7eSn!({A&c> z-1x7T-wyU%k^dAd;8Xv`!uxsl-)w#dDl_EKAvg89Y;fO+qFfhpN--x$NxJF?@MaJZ zUXxc=EW2z&PT@V5v-n-8ObZ=hJ$YFI(eE$YE%%@@WNau;=pZ<7XIIpr--vt3^^ zhRH`fK;A2v{6X-*jVaGTY@ZXKG}@2YdU%IaGWk$6?Jduvy;p47!_lE*BG5Sc(e-`> zcORikSGuvs?#yAiuE)`p@@C1iZR#;?2`*27=9Q51&NVER?Yi?mmZ9yAMy%4_CLeq5 zyu>_wFF2jFY=qf3AkbLVP@@h<%lF+UN*EiYJsGXe6^I8IGipykxgz0Ayv>-NJuNrX7PJF)}Fm4^pVV=y$(U$fn3l&k;rv>6Q63L9oA^QOvR92cSMSJNB$PtrisO6 zxM4!pzJnr8DDF=czeEBhy({85%V9^6kia_dV<0-^QB|v0%UKLNF7D#Y#otGDip;2x z@yv*b55$+8S^0;kO-II~*)R}!It`NYiEu<=pgsjfouT)NyjtX`ekN+8n3sJaHbt=< z{w1int!Jst-A|ybwizfb?4Y63?-g}r!5Oe4Wv?f}@P8s69c1k(tTH6ejj9-1uDqLP zL|HV;aeW15B{G4Ac{PoVa1i6TK=|O**Px{+yF~1XW>NP4p{(|zKvhGaY3Mwey40$9 zz7ZcpGdKShJn6LQmvkNQvV87$!m49-_Pyw-!#DjPrt4T|{v){3=#VQk#y`pD$S7c& zB%T!~bS#gZ69zp5>Vhahu9|icUS5?hCnliXel!k4?ruZa?+vCOAM>(rLeMQ#Z?aceAAie5Yx%WOOb z?K8!}i7Zuo9m`UAEXu9-iwI{NGuY!$bydbxn_n#+1f231mn^2lF_V^{lPMWFVrv{e z-Y9m(F&B>9AB$rJIFRsP9F~kJ^!j4!O?Z6Ic$T0g>(mOZjb|p7B38w-T)fDxc)Xuk z9F51qN)tcHl10QOV9KmIxj%|>+{VLfVr&8?(=L`IV1S(Bt_0SVxy11V$c0<{mcTMK zk50`7E|N&#Uc79cn7;*_IK7a>G7y1dxtb5rBRFYe+JY#V;yojtm?eHTLX%_*XCl5M zN4}d`OiDz{T!F(2K9(o$Ok@t0FP=^Wdx7{^@)e0c6Im837OwUzn{^Pw+heJA#G^gx zM5mt5v&n&E~__IAa>?YEam{aSn3n`n* zB#cQ9F)xV~@Sf-L)>?1T2>&*I!ZYE~4 z^aE2oUZ=%dj<99eO(R`PNqWACyF>T)Wdh=xo1%nR7f_Qv zRVV73S!PVz;h|~bxS8Qxj9_W3i2Kn)8rE2f7?H*dyb49Dn07xptWRU{tXix{!@dwu z&*?W5DV5KsVT+n6-brH}*{sd!th+W_2S;>+*&utEVZ79*@IlP^Ix?pBP_8U$G??gN!wE8eoQ9P2VLsdQ903y>ux zPq+6+4yl~Z>jZ8j%;3wxVWXpa)2@zKtq{{}Sl26|Y5=gs4jX{PD)E>N%kg^gp$%_z zgZRUSP4_0@wnN?AEXtuh*lH29V`<$Y*4mlRek*#GTa#R&g9A+iY8paUjVO6tBaYkA z+il`+G}P8A)oM^TR;)ua6;X%|r3kJUeh1dsMj;%KuTA1v2gc=gaa#U^8!??2vpYnA zlll0aXqgTOm@Mj?ES7B+*FxuMLMJXAW45Sb`O$ZY7oAYpcY_lLU?M|D6Qx4GNBrYN z_xB15B64ht=-~p}R@EWKru8K0cCj1;wnJ=jv21=H=w9I(C{^5 zVZ!K!5`REA-B3jjiC%72%pMkXZdS-15!>8&|HlLZd%4yp&_vD>4v{qmaL}+ISl42- z?Go`GXt3R)$iq6=_JC1J+W5c>Ko~CsyESAA3?f;bC2D`@@{_s8y{} z6Kyj2l(^!706h(sB9TxCc^`~ickP+b#)8x8p>z4qij7_@pXbD5UX0B1;w>*G`~~rw z7gF;g+Gfglp6HPQZGJ$MXRr?JC9x_4#DgF@#k65sdV6`Li8PMY`PxIM53idaGgxeT zGs+Us!EGqd$%Y``VN_-)CxV#!FpCj|NOof{i{40y2b7%UgY3O7*7%rJdqbx@P#bT@ zFr2^u6p*RSf34PI3f0CGf&z{5M`__lt|ik4Ca(Li@QVEX`#zuHtmcql>d)QGjXq2 z-CX(IUy1S@h~L*@Q4Xa2e`0eEcBpT}fgFtPx8hU|p7EW)x-Qbb*9m(^po*Nwp>%)H ziS6&Ol+9Ndk5|W!|he`3>5y|>cepF{U#wntEF<`b? zuPj%wxEKSSE>;&aCztn^rHhNdu#{MNeKFkSvb9wl1rcEJLNRc#U9WC$6umpJWX+)$ zEAM3~@vWJKPV^846ze)**jz$%z<9XDOC8XKN1W`yQZ=t$opg@t2>qBLY#jkXGet>9 zd{&n5cZ4d>MlZ@T7CSn^G|myvNuE6MWk=|jd=Oh4A(6t-2~Q~y*`1)5i^Skgur-Up zU?a!QG-OLR*5H~{`4Jt&#!e9Sj$%(IEVE7mfx=AISzPG^P|`&{PJDJhbE)I}p(_Zw z>ea##b35ZLyNPQ%W2fmZc67$%^bp57vwW?mK6J(1in7GkGwyvvZWp|2Us2HopVLnS zyFgk>#NA!ctW><&1!FNlobQ5rHwTK0t_%s4c(zK37xi6%$Onr>U7;z4=!HK3TrThG zjfFQ5S18Dj7^;^#Pkh@I+w3sWt{dcKxbStulgh-PZg|0RF}EA@*(%Ygf+T)Vr%>};F~ZmbgE&bzd%(7y42o6WEoL@e zbwXnbYHeaquGZ#sohsJ#fJUDNN+>f!KWsrLonX3ns|TRr3{cGQ*`>e-7!HI4L|ji+ ztj)yKNSDNfoXl8lzBeRbk+`!r-gYq>Bg0RobDT>Mr+WjqE|LAoq(@UL zAXzG6`#{%UE3*1P7M6+OeW13Ni$$`uLfq2_0=5dRGE`s_XC1}4KA4E>#pOO&NH>6D z6I=DTo2=Dma3kt6CAX;V3+KvBVnttw?9JlAzF5Ai#p``B47Z3s`(kWv6}EmT-6ksf zLC38XEBZk{t`m>+V|m*8@X}a$$%v>gZc37hXM&v3qP6$MKK0Loep{)sjR^ zDf~%0MQSMq2!O}X#D^3vUZDp16gJW&h8PH z1^}n;4QcX((B&a59`${aF;9Ckq%u|wgv!{j+8R2_Z+r?5NugEWB*m1JmJX~`nNd%R za|4;r`3y*EM3wgFzeFYlwb}O1;>y&*JTYw$F!pnzb`TWdi+UL&69)&u$UGp93}P<+ z68cD2_X%IU)g2UxgW+Ll7DETaJUc9w4rb~6Ww2V5K8Pu=Xi3s~RU8=1GVHH`CTCtH z1GZc}+j6bj>*C5_=-M}gX9!042&5~VnHnYL48dOfwpcy{yTUtS%Mh@=E1HL3%RZ); z$A?0fsT~*5Ls=*Gp6E4{WqaOl{p_o}c&!WL15k?*_O%PAP1A|KI}miN+#AV05{HLk z&3!D+4TW>%6ZDQ7D)u_`Mqn*@ZHJuKPtg|VS$Z&2OewZzrCvXSR3X7aURtb+9S~^3 z9XhK1bFpa{{J>x6aR<9fifJ|Nz7!{ivEJGVy&v523p8-v(X>}_DuFWbK-e11cSK`OvfQMfrCGd?@;T*x*YyZ=Wy*4=WhK>Mm z{ua$VqAxCl7T1k{XX!g}`v{B8=kAHyYQzn?B2hC$su5eTSQJdR@|?mOF1^U z-^I9c?4f^%o61?S?N2aClPT=7Q-}8oLZ1J>aOaCIO`I(UF8EvgUJhM)8Qkf#{N2>6 zE-?R3^sWF1y%I)2b1QInG=q;ePnzalx_dwf$!n-WRvnzp?^dv6-VQ~T+%GOyuox}M zpw6F3D=6WrC|R`VUkOpu8RR|sVr3<^PQBPv35aYE2Pz?pvEpd8y2qT{5P-ncw%8@MA(jH~}*OoS~)^RebT;jdO%%uze?;KLZ@sY4j zQ$di2u+=@%iC2d&%%Ftg)1u!fj8d8yHi{K$7JQ6M%Gon6L2Mlb=a3bAHgzj*L7%WaSX$#E8%R9A|S6E7%ORO4=Rqqy0j)stU!08apjqt*p z9}N@9yLk+R+lOSzIE$Dx2AU*O1jb;8$PydmKiT5>F&McVabgSvE>{@FvL0HVf%-00 zYskj)(IHS|_>Ob21DAmV7w#Dg7+nYwQqG>o^`qfii;6`2ICN7idXB?R*-=a#hwZJC zSRw!EEOv}zU3eGuf@kJ2OI&H28>_29Y;44uNE?s%M>kP89(!JQF=0GBvpo%>PA(Um zyGV8RLTf3YYB?&8a_dRq-XP%y5-UO!UyaA+-ADX49v|3OWK96L>L)5E!0av&b0$Ew z_cw@5i!niaCtzzSMZ-)g`_d~;PGAPz02DoVgqY4?&JRK9F9XxR& zhIgo#I}s~%m{>Ovo5FBI%k@@9AjeY^v5l9D#7WGTR*7cPsBGP8!%2E0Mdc(`pp7!L zCh3Z8lduBD8d?JYacqJ(ItfZ?qBu7R&zd9>uEE}V4SFn=*~xY>_8LHnDWd)wtl+8P z2Ps`Jx;}tAsvGd!h-s*Ih*OKO{6D(}*G2kK&Xh+IbFhdbB4(iIR=2&0qRB8ostlq3 zQHM0{YbQhLSBsUCfqDYqQ=gBEtaNSgW~S;LLShoXOvWh9Lb*%G8J9l=d(mt~S5mol z5$;(pmFGm{b8E0TG}u|Ir(kmCh@Dg5Wu7aJO<^gHTC|aSluQ8#JK2Ud`El2yY&Xv! z?~V|TsR$wkMHVg^1d1FymDwEg!_8V;#^VFkb*=YLHyG6aRU&k%q7j_wo1Fo$Q8>eGc ztrRa!XWf7@f1i%Ub%RLrK1Xr4`1M| z1{J=ay+DrM8eyM-c-vaMhDCX)<3|VTacytd=wB!5XQ1Uqv2_N*E}OuWFY0eby0yFs z>UMD+ZQ&zKtHQoo`e2V3ISVhfS1gzXZM_eTvs%uto8V=9XBIT&esOLVT0AAvW@F=i8a%}USC)1{ z23bVJGnnb@WU+QO436i;me~-67sR32%*$T{qg%Xvgt=p}WaOh?LXB6seF|zIo(ECH zacU$Bh)Fe2GKUOw>X56b6^k{4o`Pnr+3G4QKAh06X5lb6a%ggnQ+!$j-{jLrX5$YaqMn(#sjjCU{+JoC9HfLp(PJTlSjbcCG zd>qVhLWPp%28Ql&c~87B7f*a&Y^eW#ZG8uLRK@o;cVv^0ts%Ylgc3qWIzfs8QWU|0 zQiLE#NCF|!tD+*^1zxIPp-C@_Akq|3Is!^ZKtOr`1qFfsd*<#g;rD&d6Q1QxyLV>J zIdkSzBiw0vE3iq4gKV2B=0KSA8#SH7b_Hl1b>l-Um+1&a^^xy}IW+##OLCaiA_SA_ zrrFuu-qi7#3%hn@#0werSJsERmv)Q5q#UE9@f)V*7}YFC^}bnH#!I*FmZ$*G;joZh7KzvG+U#E~;N*_$|e7J*EFVmZg*A|;@O zPhj!~TIL$HD1H1OmuJQWEY2mDc`?xaXl*QdjWTQ+mj3k7omlFtTjd!kDVI5t%(hsd zg-nn4i_GQ}W-YzBIg`MP%!ap_tT{wi!>6$4^0QSBmqu_oY_2q}9EwFv;0Uv_9Ix%EAVz z?)A%4?81%+*7>o-yz4(-zzy?9!Xz4CRGR7MkbvfzbCHh|&86m?LJo zw=61$ghC!E3?f&^t92+|EaV+L3plrk>;a9HV1!T^|;bD~YnYD}5C1 zcp^1TG}^vHhBSsf%uoVWn(LXX7;BZdBiiaD7(c#4J~0l5-ysJVZ^fxB200JzPa$Q3 z)g4qW!pr;V=za88?{6epk~n6X$-0tBh_IyaxtuprEdxnd-CMVYVt)sZXJY(WfDsU0hL7BBqN9lDyytIO^d7+Jmcyh0#H8|AIe^#p4D1;|nN|hsW3OXG z4x|VxQx9oI>ok)XR79(Rq_9<45#_Z!EEQXgj~)e+j#4NFO^jV4n_Jx~MsX4r7sm%0 z&Zrt}YTDtMP7qo)Aq}5K$w5X+Oij;FriG$Fl8-9aLgPWa8q~JBNBU*hy#|qW*&$L4 zv+(U8N(}1ZCnlyK&wG9lC)fa%!NjL5qz@+jcm_=e^Hgbsw+0if8e=l+EKS%y!@Z?{ zsus&zn(~q9;1-3uuf5_A`w(i}nz4vZ{A{6v_%=uDAx2G03;o_nFEJ8lo_XVb9?OQ1 zqP1j2InZV|8pcr4?N(NdD9Kw%ouQ-?t?~R&N@!kSn+W&5$)-4{EyfQe*Vi5khw{5# z#(|++;#b%tPW(#(sYEb?V0T2qFgECf=EKOybheth{Sm_`f_xJ*hVhEk)hedI_A@Q{k{{j=RYwva-$DD4M9TgcGLr1mKsJidcMB#XvV{%eqr6VD@?Mq0V4NLE z^RXesB8tWmM)CeKlne8?*P z71QEXmX2fa@4H4^=)#gulkiN__CQ9NiIn$w#LYsp_qlI#kn=uI z*H5tEeIp}!uBVreCGn|k=HVK9Sw3R}GnER;eZa6CU!dU!#Mb%f_yLcd1y*s;z`PIW zxV;byKH&Xyk-2R>^wn)KZb`E*t=egC3q2!)>Cok2MTFol;qb9k(#81f?U!Qkhoth$ z@Y#nvVwPjyht&12fMpC1>s2T_hQh+t=rV@q&KmYj)wvcr-LhcO7#?wJt#lj<#ojU8 zldo8vh%Y}d5`0;xzDCeT1om~v`iNJQZ_x82V)lBrOTgw@46QVvEAJ9wT_?-70joda z@${{gUQ0<<(^hRG+s3=UX&mo$viS~~V~v#LO)M8q+O%Z$*;+U3Cr)oN&&^gd6vV70tL@jI&8pk922R=rk*I<68eA0Hb7{{Ib5&7eYtUqD$ zIC2>~rH$@F&6r8^cj44H(v#hIIF5k7M-L*dUdS5H<8&_?e#}!;l#YQuhoybUAI~xO zWAb=jkq%%Ze=NVSrv%oZHN$wr7IBb|{PP@8T8AWaJA|YO+^WN9J%KO%6?qf5Ilr-C zyt{Kugwssn;yuoeV9NxfhB{{TUecY#<7FR5<%tC86L@tZVc;Z2OyqW*!itGTGcu9? zO5yLqL8M#GaQsNo$w&C4p=Z&XyajdG<0lbU{=lM16#TMt{O3BM#3Age@r8xB3b0*q+1+PBmr7#K$(6fBTLYry{iU_+pG)|`zh1*_Afp% z=qxR^Hh#=2&fh#OBQtguAkKVhgg9FCWXeZLj4NPbL;h4=5bPK? zmF*o^HkF&@!k(!F`yjrTr;=Rn0;lm*DvhXV+{0j0pGNEtL9c1##X@b8X)PwOZ#Lry zb3m@0^GgA0$w8zK`f!||#+gQPv|#PHjRf$^UIImit-ojE9m~>8 z9o=UejD+|&J_;B-aV_%kG!%YJC-0V|`|$oK@j}s_4*pbS=S}C_Q}o=ibUMvcQn6t= zMe1ob+&s_RaWg41tpv;@*{_TZGkM#p%1V>L zFPh1Nv>G27m&Z;|%*RT~>Zmk});~3Df;kK|?&aH_#_(C(xtf?ai*&J;P4Z@j;nXZ6 zG`2R!5lNGe^64zD4fRdF4qUT&>#2)|vnd&a(kvacuK!vRhf$ zKbr)oA?{1-XOKRJj8h{Ug-luQy|qhO8p{{!y;?elu-F9O%pr(3#qV=Sbe?6Uj&m$w znnD{q$49vkKEC>jTFs~SZsw_eLQVJ>qgtTg6N35knE44g(Uw>*Kdo@&6K-f5n>WXR z#U}Egrd>2ZzJU0-{b+ewmfw?&s@7!8Ok)X?cZ@HJ{KiMOt2EnGW_8jQn{#=sHLj6Wr&_(;{P*h9-(*F+HYUWV zPboz0ifNyc_wL5xSaBo`bJ87I;vBW>nUv5L9-`vKBL9T+nD>Akw_8hR{6=nxzC8oy*VB�HTD#DC7Y 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 D6Sj@0 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/ChatController.swift b/submodules/TelegramUI/Sources/ChatController.swift index 26dc36ef2f..90cfb23653 100644 --- a/submodules/TelegramUI/Sources/ChatController.swift +++ b/submodules/TelegramUI/Sources/ChatController.swift @@ -3680,6 +3680,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 { 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/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/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift index f1de6e484f..71320476f4 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/WalletUI/Resources/WalletStrings.mapping b/submodules/WalletUI/Resources/WalletStrings.mapping index d38b0e0300080115b02bd8f6670183d9196a04fa..1246758922535bca4d24a763b4150cc1ff0b4957 100644 GIT binary patch delta 17 ZcmaFn_{?#`Duv0X6{Hy%Cofk}002q>2HpSw delta 17 ZcmaFn_{?#`Duu}>6=WG1Cofl!0{}_;2HXGu diff --git a/submodules/WalletUI/Sources/WalletStrings.swift b/submodules/WalletUI/Sources/WalletStrings.swift index 759572d1b4..b25bf2d505 100644 --- a/submodules/WalletUI/Sources/WalletStrings.swift +++ b/submodules/WalletUI/Sources/WalletStrings.swift @@ -449,12 +449,12 @@ public final class WalletStrings: Equatable { public var Wallet_SecureStorageReset_Title: String { return self._s[219]! } public var Wallet_Receive_CommentHeader: String { return self._s[220]! } public var Wallet_Info_ReceiveGrams: String { return self._s[221]! } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) 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 { From 20a381c5954d5f6effccc08e03148c7e628c1b80 Mon Sep 17 00:00:00 2001 From: Ilya Laktyushin Date: Fri, 5 Jun 2020 17:52:43 +0300 Subject: [PATCH 2/9] Drawing improvements and fixes --- .../Telegram-iOS/en.lproj/Localizable.strings | 5 + .../Contents.json | 2 +- .../BrushArrow.imageset/ic_menu_brush4.pdf | Bin 0 -> 4138 bytes .../Editor/BrushMarker.imageset/Contents.json | 12 + .../BrushMarker.imageset/ic_menu_brush2.pdf | Bin 0 -> 4262 bytes .../Editor/BrushNeon.imageset/Contents.json | 12 + .../BrushNeon.imageset/ic_menu_brush3.pdf | Bin 0 -> 4346 bytes .../Editor/BrushPen.imageset/Contents.json | 12 + .../BrushPen.imageset/ic_menu_brush1.pdf | Bin 0 -> 4162 bytes .../BrushSelectedArrow.imageset/Contents.json | 12 + .../ic_editor_brush4.pdf | Bin 0 -> 4127 bytes .../Contents.json | 12 + .../ic_editor_brush2.pdf} | Bin 4331 -> 4251 bytes .../BrushSelectedNeon.imageset/Contents.json | 12 + .../ic_editor_brush3.pdf | Bin 0 -> 4345 bytes .../BrushSelectedPen.imageset/Contents.json | 12 + .../ic_editor_brush1.pdf | Bin 0 -> 4155 bytes .../Editor/TextFramed.imageset/Contents.json | 12 + .../TextFramed.imageset/ic_menu_font3.pdf | Bin 0 -> 4171 bytes .../TextOutlined.imageset/Contents.json | 12 + .../TextOutlined.imageset/ic_menu_font2.pdf | Bin 0 -> 4412 bytes .../Editor/TextRegular.imageset/Contents.json | 12 + .../TextRegular.imageset/ic_menu_font1.pdf | Bin 0 -> 4027 bytes .../TextSelectedFramed.imageset/Contents.json | 12 + .../ic_editor_font3.pdf | Bin 0 -> 4139 bytes .../Contents.json | 12 + .../ic_editor_font2.pdf | Bin 0 -> 4393 bytes .../Contents.json | 12 + .../ic_editor_font1.pdf | Bin 0 -> 4036 bytes .../LegacyComponents/TGCameraCapturedVideo.h | 7 +- .../TGMediaPickerGalleryVideoItem.h | 2 +- .../TGMediaSelectionContext.h | 2 +- .../LegacyComponents/TGPhotoPaintEntityView.h | 8 +- .../LegacyComponents/TGPhotoPaintTextEntity.h | 6 +- .../LegacyComponents/Sources/PGPhotoEditor.m | 22 +- .../LegacyComponents/Sources/PGVideoMovie.h | 1 + .../LegacyComponents/Sources/PGVideoMovie.m | 5 + .../Sources/TGAttachmentCarouselItemView.m | 10 +- .../Sources/TGCameraCapturedVideo.m | 112 +++++++-- .../Sources/TGCameraController.m | 14 +- .../Sources/TGCameraPhotoPreviewController.m | 2 +- .../Sources/TGClipboardGalleryPhotoItem.m | 2 +- .../LegacyComponents/Sources/TGGifConverter.m | 23 +- .../Sources/TGMediaAssetsPickerController.m | 2 +- .../TGMediaPickerGalleryInterfaceView.m | 9 + .../Sources/TGMediaPickerGalleryModel.m | 2 +- .../TGMediaPickerGalleryPhotoItemView.m | 11 +- .../TGMediaPickerGallerySelectedItemsModel.m | 2 - .../Sources/TGMediaPickerGalleryVideoItem.m | 11 +- .../TGMediaPickerGalleryVideoItemView.m | 30 ++- .../Sources/TGMediaPickerModernGalleryMixin.m | 7 +- .../Sources/TGMediaPickerPhotoCounterButton.m | 8 +- .../Sources/TGPaintArrowBrush.h | 5 + .../Sources/TGPaintArrowBrush.m | 90 +++++++ .../LegacyComponents/Sources/TGPaintBrush.h | 4 +- .../LegacyComponents/Sources/TGPaintBrush.m | 5 + .../Sources/TGPaintBrushPreview.m | 3 +- .../LegacyComponents/Sources/TGPaintInput.m | 32 ++- .../LegacyComponents/Sources/TGPaintPath.h | 1 + .../Sources/TGPaintRadialBrush.m | 5 + .../LegacyComponents/Sources/TGPaintRender.m | 39 +-- .../LegacyComponents/Sources/TGPaintSwatch.h | 2 +- .../LegacyComponents/Sources/TGPaintSwatch.m | 4 +- .../Sources/TGPhotoBrushSettingsView.m | 175 ++++++-------- .../Sources/TGPhotoEditorController.m | 2 +- .../Sources/TGPhotoEntitiesContainerView.h | 2 + .../Sources/TGPhotoEntitiesContainerView.m | 40 ++- .../Sources/TGPhotoPaintColorPicker.m | 2 +- .../Sources/TGPhotoPaintController.m | 217 +++++++++++++++-- .../Sources/TGPhotoPaintEntityView.m | 24 ++ .../Sources/TGPhotoPaintEyedropperView.h | 13 + .../Sources/TGPhotoPaintEyedropperView.m | 157 ++++++++++++ .../Sources/TGPhotoPaintSettingsView.h | 11 +- .../Sources/TGPhotoPaintSettingsView.m | 57 +++-- .../Sources/TGPhotoQualityController.m | 6 +- .../Sources/TGPhotoStickerEntityView.m | 6 +- .../Sources/TGPhotoTextEntityView.m | 12 +- .../Sources/TGPhotoTextSettingsView.h | 3 - .../Sources/TGPhotoTextSettingsView.m | 227 +++++++----------- .../Sources/TGPhotoVideoEditor.m | 1 + .../Sources/TGVideoEditAdjustments.m | 2 +- 81 files changed, 1215 insertions(+), 393 deletions(-) rename submodules/LegacyComponents/LegacyImages.xcassets/Editor/{Font.imageset => BrushArrow.imageset}/Contents.json (75%) create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushArrow.imageset/ic_menu_brush4.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushMarker.imageset/ic_menu_brush2.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushNeon.imageset/ic_menu_brush3.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushPen.imageset/ic_menu_brush1.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedArrow.imageset/ic_editor_brush4.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedMarker.imageset/Contents.json rename submodules/LegacyComponents/LegacyImages.xcassets/Editor/{Font.imageset/ic_editor_font.pdf => BrushSelectedMarker.imageset/ic_editor_brush2.pdf} (75%) create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedNeon.imageset/ic_editor_brush3.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/BrushSelectedPen.imageset/ic_editor_brush1.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextFramed.imageset/ic_menu_font3.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextOutlined.imageset/ic_menu_font2.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextRegular.imageset/ic_menu_font1.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedFramed.imageset/ic_editor_font3.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedOutlined.imageset/ic_editor_font2.pdf create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/Contents.json create mode 100644 submodules/LegacyComponents/LegacyImages.xcassets/Editor/TextSelectedRegular.imageset/ic_editor_font1.pdf create mode 100644 submodules/LegacyComponents/Sources/TGPaintArrowBrush.h create mode 100644 submodules/LegacyComponents/Sources/TGPaintArrowBrush.m create mode 100644 submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.h create mode 100644 submodules/LegacyComponents/Sources/TGPhotoPaintEyedropperView.m diff --git a/Telegram/Telegram-iOS/en.lproj/Localizable.strings b/Telegram/Telegram-iOS/en.lproj/Localizable.strings index e527eb3a4b..8dbe3a95da 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -5521,3 +5521,8 @@ 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"; 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 0000000000000000000000000000000000000000..d09005a3e7c220db67f210d636b9f1ac694d6d66 GIT binary patch literal 4138 zcmai%c{r5q+s7?a7(yj`+{uz`GiHg(z6?>;WM`PMGn%o>n&rVrwg!bHA!|{IkZg$z z*`kna*|TJqcc$fidY4pzkNdig?{!}1aoyMX{o`|r=&Nf=L8W0}k*3L&$+`U1 zyIoB!U^oB)aCR=>^XCB>U95+rmlJ@XNQQunrn8$D7Ec-7&|X+|tUV5c1r!y*1TQ=m z?GE;%wK7t~aSTqc}1lKMI zHmMrw;8d5IOzz~hM9xQ-K@2-3n&MazW?PT<#tvx>dCSd!2VaKQhbH44Jr1`X$G26b zX06>iAm>o%Ys@_oxXRo;$j0%gfcNbjRHv9^;L=nO+a!Iy>LezD;d+>k>kuND`23u? z75AfCoS6db4%QmPDo&DTK0{h%`awpQ?((59V^TE@7vZt2>3vmSss2V{Cw;AGn4;03 za95V8>6})tu(D8742nJpbo_+n_Sa>>qk8^_?yY#wUOxtI<69Me>)$sYeE=!qEcCgg zq3~T2hw{J>TL#yXS1ORO{Y@u^yOT#iPuqHK!JuI>KRa>LPV2`-dHj{XMaO zj6T}&#}|+F@B&~ztzn2I;JoqnSOS3jDX8H*yeR7gfNCd0s!e|7qptt9mp&e6Z-n&% zEGS9UH32I?Mh)kN!y9>`?XdvWe`*9MaOPKnKXSi&|<$pxUT%sIEMuloq4~jZ5)@ zljE?s3C8#(Eh<{bUW0@Adbr&H(+azOOM`*B#^f;3m1(I2u{x5m*J?I8IQ?v3&~Yhf zpqfU1HyrfJ%ak@0o@2_fIM-l#6jMHaf^}F;NV$|S)rq0OlgvTfoF}|l6T6Y@q6Gn5etgZwtH}RAkBI5 z%WH@2%!)@k5|;CUZ$yZKd3x8R;;%K(5xJwsT{ep zDiGynoz(Q1MT|Lae%_5ho9!ws@#V};b~x@$eU$u0di&yz$+-tyN?|9pkHN4SlMnJA z=%{yeu&|QIn7s}5{qdLb&TrcqCGTXvjT7;r>L-&hDY zQjCEoIMbEG$=ik|C{kX(N}J&|PJu@4B)zbQQUG1hoCP}+{JQRiQ%PbOAwf3a`}DRT zvt_Kun68SD(bPIi0tPQ~Pm(8hG{UWc?#N9Bue)G)m^6e=()JL4D9n?71fYos)ncc= zMK7&I=d28RtfKgy2CM>oPwR8t#gnEtET9W?DIDo}&=Pdz*tHs=8Pg36M5-s39ef?pMn!du?NiW`N zMyu=FcNw|>_`yBepoqh1bUo-p?`fWf4wj$eXGFbf|D^7B><$Ch%MW80syG!{pS|K5 znNj&QBYn4~DI?#qy6R0+VcNqdToZ-v(-mrD++@Aa_dH%J@#+Nq!RQ=x z8aHPP&v>*Mam>yH-EVgR(wAnRW}?eAg>+ztg>8lB+4VhoU@BIur0-`{GP#8+?KK)h*HoqwgF;I=v?EWG0|ne7pF%!mcrQ@2w&~4 zou~tc@P`PDCJ46Fi``^02f2o`owx-Ey9pb!^D<5|?nNAa1vdyQ(DM?CV)t*dv=e`H z9$sF2I!d!;J;^~!P#@a4IR-y``wI`C>&SFq_ZZlW*{9xCwYHGP;?ooTLDs~&VANCuS*BdwCg+e(s)5?xd0 zNP!}HDFY;5l8tn>n9Yfh3*R5?R?!(WC^r~|<(8Y|XpU9BQi#;n$henk_m^FUU5wrJ z&xmFNkrzo}Nzabx6)Mk^zZ1zj!K>Pn=l`y%@?z!LA?y(3IO@#(ou1^G<~6}DwQEdR z5v;}JsY(7x-pPtLh6i6kY&T(sJbA=qVhu526+ZQxJWl?AEOWNre<7Z_b=u?fwN#;0 zhg90sgonD9aeW+pnGf9`>h(fgL|xD>gDyLL(nay)e6nvAInxHdKd~DrwRqF4 V-puWR%U&g9Bmx<#HVu50hdbIOLGtD~1 zI}df{GP7`f zBf+M_mWYaLP03H5<|Q**|3xahl6a-;S<;5xlFL%Q;#tKQ#dyV|bv|`PK{A`@J-R)g z?cvpduhZKDJ9;2FP%+aN@O_Xb$b>gl!wS0#-#SNBZdUfFilAf5C9GfyVzn}j@LY&m z^&98D#mh(UDR(F8o+6kz)TG_`uKP`kD12Mwx*2nY%i|G86gK;fLC4{#wTX-gkM`qj zt8F{M2nU3(w_}~p_o&?l#G)%}No0Si<%j2&e61R)$G+9gCAb6bT7zHPHQVE{e4`$* zBfSQ94a)0mohp{5T2!B_8jRISby~2xHM<>iTNrkzC~^5f60+|8X4n2X_OqVI$E3MY zv!E+m!yW4p3$=Occ{{$Jd>DN{4$oAtnx@;CSr2xVezGc=>{z+C@~q~{e4Po};;Jp1 za{?xzQnui6?S(QIRA2t={n;?ygp8@$*}!KDnM17~2I@!MLwacA>6;l81vvO$guLF+ zcP&wIZ$^I{D{dsu-J7khcMP!!QD4wnP9&ouQF*Pe61@A)^$wgVIFo{W6`$1dX#8p` zZtv4KwZNlAGy1UH=bIq86Y|TSTQ>!lvRKX!`o{)6oDtj0UVqwU9&4V{|FJ*j>3yVg zpl;ykOlVK$@y_E?O1Jl~tr6GLGb-LV>W~vVkKMT~pY0pGqS_L<92dhCefEl%Vs+)j zyUfz^(vkKsQknJgb9~{4+MV6Yq$0;sd8>0lnL)J+QG4AJvu>yHXEK_h$J425jgN*w`mdro`y z^W*o#z{y~eb=;wS3vFg3anvAXkr`I$2 zmHiF8RDPvu6v)+9Q&U9~uo!>}u!exu?+_|P|7PO98JhseT*P9W(W*E@tG2Zr+ zPVbaE+Fs8HFu~#p&NvSM3Xz5)q!EDSDOGQ0Hw*xk*Mvf#mg0bcHyZC108kkI2lo4U ziBr&>(iD18cBxZ19DGXstSm$p0zpC$P$&e3kTr)u#3(N%?jjCD4FUfDkiQSHC+{!^ShrTYKe3xiXO^Dhkn|KrSFc(k({7XPCGH*yZZQvMf^F~s30C8w5^ z(uiw&IN&Jt|2bEuIN-cJ3=WZ%lS3ozph&1Z5{-q(Lu8Q{4ALHkmB&EQis1hq^3y>C VFG?+cTr}(q5(*X((a_Tb{|}k99ku`f literal 0 HcmV?d00001 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 0000000000000000000000000000000000000000..326fa4893152aaa2740fd8706019e5651fb875c8 GIT binary patch literal 4262 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 literal 0 HcmV?d00001 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 0000000000000000000000000000000000000000..ab17d8361f0d4077343a0360233491534eed9fbf GIT binary patch literal 4346 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 b|9_W1GRVV|9Lt{vjX+8w!4Qb5jvDx%nB9Ue literal 0 HcmV?d00001 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 0000000000000000000000000000000000000000..7e189831a4d7cb8cd36c7b5c2a28da5386c4e498 GIT binary patch literal 4162 zcmai%cT`i$7RD)2AXJs2h;ZamM3E#Up-AsW(9k7RlMp&Y6S^WriZtm`6cCVJ1(YTr zN)h1^kR~c1Vn8|wmn!mtz#GhnOWcL*=x@1?~mUW)z{QM3zLF_MO&#~sB`(N z4|-eM!3Y2f5OGdmMMVIjM{u)ucL0zy$q;~OJG!_NNVL%f>rT)l;EA>bKv@|~b|(?A zu3&F^E2FLm0T|oUjmw_}ZsSl-1gCGbWPG7#$1+w0621u;uGb!~?9R%q6iF^p%v{sX z6uI!$JLNS~IQjOI`dGhZ9_=olB#^WAW4T4)$wm2&rl5qfc=o3sARqYa6lB9ErRp5s z>!E$cVP(+6nBlIN!uhQ(Wn zl?@ic%M1tzW%f=R+GV(M>ve{fw!f=n#DRPvmo&3{v*PN&U=rooY+Ft)OSQ4!TZ=MG z??DMfYNgiZBSQ^v=VRUDt96O|#+E4rRz3D799KGg}_jWF~hz*`nzE@_uZm^k)QNk78Fm3Fl#B2}C zZtF&;f9s9OL}#s{Tz503SFG-yI5#wX%d)DZ#FUZxk>;a`dIt#UlPI19f1F^j3I$c^dR90WI*PJph0wV zr>&ELeVZBX+vjJ#{q=H;PXP9PsX>MTvOg32 zmP78h96zlq|2+zFiFP1}+P;0=Xx;@NngmZrJi$;${r|f<{jQg>(FkuCrBSxA_pmS^ zy2kIz0=!l@&jT_DM+N9Jga(UwY97$$J|tmkYy6B}CrlWx#m#yv2sg~~g-gG^#XwVw zIvVB7vQ&y(9ZTEoz>JSf*9?!?FZm7E)9HT=0zG#(qYpr2nQ<@9wOAfL($%`baFmOl z!;JpfgqH^vBXf zCvu`dS(YiHAMA5(FcBJ!QE7D4jZ^*ooA>qTpxmi8-P2-OF5%Kz+{YHfzcA1-C$`Ez zC2>S<$vb4wdFR=GiU5V9aCwJ@Qyi(EU)pW2R2gmIU}q9vT%5S=tw&j_X1fFB3n(Yv z)uI>0xTZS9EtCo@EMSJF9JZQA#szO0?JB+W-7#4ao2O)`MP*>dUFJ(5jl6X0BIfr_ zR5c};&{ex0RHaUopqBu;F9+zV$L_BRhPqhCw|-<3XN{bncOlbfI!m4TEW48#M10j8 zD!-B1wYX!dkjJMI_y>vyPSB#}<>%>Yc6YOJBvWj6H@NmDpUFG^qw|I2{mf^4D_PfgfpYMm{{mL!@jc`Ro<*rkQxa4eJi z127^`3d$gPgBj;cnS++Oc(T=sVtF5Orm7Ed9XDt8(NNQu<7RBr z2#@88SKaCrD>!=kR#BFQzS7zs?)>%4R=2hvF!ch6gS+&8!G}^9`myY9=$-_OR452A z>pbuJpy|zXpNa3;yNL_6yviIk&-o^fFVjhe*gQ{QR(;9L*r#pAe0)VyJ=RQw{?JM1 zIN^s3g<5H`91oAzMW2tm_KEReSQa+rC~y0*$uLaR1kMyYgu4J8Ou?s^>hVp<*m1!F zw}NtUgOBpe#7k5>S!52~i$2?GdL`zHMMd%>#y8k`1p$tZXU9GYT)kO))Kc0FSq7@% z9FA%Tn0vuKA-3ZE^z<0_QV?egc^P-(WE0q5z+Z4YMyS16JeI{A*H&Mw zKKGXJ7J5QQ_Tf%{!c5zm(C5ZA7J?|jf_jQ7K;@@ay)r!b9C~FFZg?y=Dj}*NDrOZi zRY#emypt(+wBCCvk+gN%?evW#;Uv2x`lOg5Jrm*}_h5RFYY}LlibbsBNn8I&rH zrsPw+GAQXbh`mo=!)7b$!+mSFo&J0=t2CRypT^(Be~jORKN-=EJeKB`)|p04n?`h0 zJD9UR2ANaMrypBGlTsJEjqOCMBIUD6%NFv__9;IcEmkVU7gU+q=Ul4lIbszrWg)9p zV_9S5rH=Ol$N5|{&KuGO;@+b`a>ra4>T{W?OO zCh=80d81R0OAF7Adp0llDWq9djPf>IYM`uhtPAgm?ZB9n!o0&8IX2$7d!A|t_8UAj z_j#hWXC-QqN&LF_qkdHWcsiy>qKCaFhn0`2T{nC7RjTHj7CzZ`eDye57Fx8$^x zuY689Tsd0#NRww%u^(g;yUVcaxjni%yga=)$j~aWI?i7@obZiN=YJ0#O8f!O}uY!%#Ms0f33y>&;XfRM zt2e9r)kU!p6=$sAO5%->7l<6FM*ShwjdXsIZ8u@$}Hd2UGlPO zsh{|>X)eYUa6Lb=+@;+WO*lU87BMzp@W7y=>54Q%Ek-jPCA46vkzwj`D4O{Y1$N%3StreY3s4jlbr?`IR_|PKZu! z$MYDEL4|=~*#g-_ndi~*?T;p}br5$y{HbyMNb!t5Jg06GBzIDNG4}UfJtX;(B=Q z-;>Yuy7@)DJ!B;^oGQArJ%PPvox&o8Styk(uh3^`7zM3Q#+n32(Dfp%P zH7$L6XPyJqwOL_SbW5rD>>w&vjJNUJZxS4tMCORoITE*)I z%hxa7Vy<>m;~T-NJO9bg`xN>enq^?pzkqk2U-vZ{u5`+!Sg<%)3W^r$gutJzh~6I zx?^34_CN5Q{FB@N!gAPe8)#T=>w%|rfTvusc(f5K=|R zwg60C8wQ10N&p5PSdzOhKx6pt*zfHwK|^<1v*=FSrAgy(@F~r6(oktAR0fKK!Ju$B z(i{pEr@geei$vS~5a54@{B=lg62T4(1z<2R^j{AkgG9oSfF1BtgUd+Met!P}+$-wQ{;|05q9Df`=* z-APzS7Xs;fV{YW=OQ8KP05K#IX(it;E3H9Cx!DnE_5U%~q&Yy*RtABG$wO`B}B2h@PstC|nEyhO|ztPR-}7 zJ??952TKAlzy)IuzHk8$*TFg466^pZC1e1ItK%IBI5*1I5lz6U;;=5(I6y%G>`rjQ zp`F0qwC09N_WW>`x=mq%#U1QOylDDb@Wa)>u-Ha^w(0#cNcX5bi@RMle^NK()oIee z>8A$$gQ>4slO8%+i!nSqLWY@aWLfj~wiG$r#$}rf;m^LE6+|gE>VC{7_9#`PLA2X* z2zjOXayB{{G^*9?+Ml2vkMnI`n0*~= zyyMH0OSla?i7H^bzRtQxpf}_$YCAK{A}xv%dVZPzfhR4W3W9EM@Eo+lrBSiZby*G9 z1e5cXf)lQUoljaHd)Uow@1{LF_(M)6zu^Yvoa5s(+5RGjz;OPOI zSTZdfBnBO7gf7xwp9rnK>mg9q^okUF^<$1Rmw{m^*sG*|a`dgB|3=?|nuw)dLSv<4 z>ej~$ZKAY-H)HWMy~$bkMHy*@j+)UrUD?g0mYHeOn30$;{kzTvGB22f0yM=HZ0`^c zwMYb6wU-EOEP#76jh2{qS7Q8`oL@_m>PJ&Hjzw%Mne|t*L%>`?SBLJq9q^jzGIUug$ z;^^XL=!(YT0IKO!+~I)quLOVOkohCWFJH?3P>Elm{E)a3)tk-~V*=u;I8QtlXP}|{ zzb%_~&+Dq;2xmB%Bu(l&!UsUsd3>0F*K(T2K>86{fqHadAy7}%1L_>?Lf5RXHqvT@ z^I_FEm~RJThM88`^xB*BRn?|Oi4IK5#mKd>)V&VW_{dD<@QCfQ-*63$-uGZoGr^cP zP%^`qV`;w0?8wpX)=j$OY_x}sX&WbOY(N@Ys&s?jN%AQvPc+-hHO8Kwx1(G5n7mB_Tl^ZsV|*2J1gae+ZecT zV$0=;JKj3v^$M1|Fs{H-mwRfo5R_AjUEE?Z@8Tlr&9vQi!^rq4f5ScbPM=+)73c!_ zkrMF{YTR+5NSwq;v%zoj;ADAyk`YaX(?P|li6Y%)fM)doO~u&5wNqh^7V)j0SOl1( z78V@cY119Vguh7drU$#cYzULxOzB?Qy(X8-bus9y)-eQ5Z7Me}S6j8GhvjfG*?Mo2 zZGW;+7XPZNMdV?6BiBmk7bE>IiA*68cD11wf{bIutid4xLlXhVr34tb{nH#c>^v-K z{6b~*sS^HgFEZ%?26+`-D4zt{+ii2&1@FwJfWk+XE?pV z5@YQK$rRzv8V_-7qB|1HKzIz63=)IUiC7)t4Me!oj{!6xftqae_vpnm>F|o6XG#ih zX~0VGx3r$O?OkaGgM9ixSAwNn51N6lHy(0jW(m|#1cx z2*fg(fE@a@i5LX?uD>7OX>$b(IxPOvE6Jn!w5aS`&Ow=ix+w&fkP{d zpUZ$>D5WCks+K*UIaD4>I+M_K-de-$I7-n%w}d|(u!OM2U(`z!gmUO!;#E@~xgvY1 zTJfghO_dyjLrO5XVqj zfm4C*Aj}?WkG3DN-yISwj3(!iy&jR%EG73pe-EE4tBLTb+OhxEGABQmz>~^T&%@1Q z#FH%9j^s{tPVGvaN}ZAHsIW6(ehxC3GMRa90ZU3*>bYtIDUXuPC@xvd6YW>X9xaqF z#y%-Gw#~Xy-h0$MUd&WlsnV>{&`ViYTijUOvQ&RLLqR{iI6b>Tqro)bWn&-k&MHdj zLDQ3r$czT`BXrgT_H031VgI=-lPtM*8SIN2kt+(5rqHs8G_828=&s9#ZwJS&TGfy% z$Se-ic2LPeWNk-g*#{J=Nd3)Y*_I2Px3X?N*cN7%k1~!*;~eF*6j>B86rC42jS@l~ zFm|e#E8A&#*P7~Jj`iyZv!BG4_vVgHKQGP~9rtWl^pi_9FB|2oy;4iwIK08P3*Ch? z$cKA}lMZjbC3p(fhWHJ!&wrVy>RlmDG6?tzJRQ)=8&5;^3iTf9&0=QZ`pPvZdfcu5 z#zYmbTb!7+7}3((HDl1|ebS`K{7%p1;piF9R;Sj{xAG%Y!^33d|BrM-F&^TAFB^YJ*RUzqaHz8|0)@{;uK~dVvYaVt#DL{kWKjWD#`X zW|fh*zqc1i6r-l9(psw-)A_nnBPyCxo6}3ZOQTI~NaM1auUfL2cCxVus{FG$(S!)( z%5$DRam<(B(=C7V^{96E|Xi8JGbXk`Q7A_Sj#5VjdQ0?oIW|uwjXh{ zIe$v0WZkmbYYH@+P#eA*KhrKe6TM=-h5H@{N)CAz(yyA_Y94{rD$zQoHA$zd^!%g8 zGt1SW&-sb5iCIF3{Qmq`_>hXNiUDN^IZgzx$WYH%%h{1ITR@bGiMqF`b+&D_UZM{sh^#@Pj;0!q<$77C*qc-Km_V1JVEc(A;x<5sJ(uI78pC3p0UEdz<*$7!AdifE{g^`<)eg(4vd+8f5`b;8CGTwZ66Y(Nj3h%4qJ3bpYkan{7r0B&5 z`?uDK8!4&fFKxBSalOYLK9EiK@?TYM4_%3h;0ix~ouE)t@%eRHNm>C-0XtxmTppd^hK{*Oy5_%p-wi_exczS|hySsGg5}m8SW0^*=!C}V8UojFZti#& zX8;ZpgCoU|fSI7O2j0;dfXk}GVQ@1cK;HxHM(_bB4F3cBy$M1Tbf;<|CjvzliqGP8!!xj!@;nBJ%AJvi9iB2 zz^@nrDMRUEs1M-$I|f4{C^!Dk7(x5buMdoEH!`aB-oOoLW{&_pRk@<3g$b&$%ka z0T(bh3``PZEp3BHk-FF(+#T#Om zEnIbA{ujUbN8FN@mM>QK)Rmi>s(k%uxWxQ9)+$`r3-XW4E?H`NdP{ckCBB^vto4lP zr%E>q%a)&TeJp=@vRy~*)s@ASLZ3wrzWx)DUb-wUWydz=2~z^=S8GNVia%4xJL>A( zu!MQV1~c_SeVdXG`y^ct9sf1u@Xr}vL&JW}>icv4#YCBhZ-u_LaIag%lrO%C%TZ_c zOnLLh;_xR)t3opqaz#`2&iE3@?%T_?WO_njhResLvzMRCUhlf6`1Ed$4#xS5YG%*5$$t9;ivx4qBlpbEd2aR6TV*%+hAgl>8J6a&Y#sgC<;X5SrrP8ax@)V_BwLR< zge)mA?qxpl;FdLK@|6ef$JP`moZaeO#Ar6_yv9qT3zAooo=o7f+-bk;zG-`D*NTIY z7rbYLn233a3I(^imV30m6||fgxQn%_?^$uibstup-}XzN$JttQmrFPz~M$~>8u^Z9H-$HTX`>@R&|%r4ftzNFak zwZYz%DH;|}PAqmT?vY%RCcQr0VCoaOk2}B2`Cnu7d(WL&{-wv_&T|@HJ`-5-Myc%` zKda}Sj!2cC9$#)Y&93hIeLnw7d)CV@v+MRa?KKe5U-kLF)l2IFi#yjo-I-m=w*B=Z zuIe{Ge*baY|KhLyUjEm4T&Z~}#U(|liMb$Feo_{fse*w5m^Lxre4j~@N5E7eM#HHz zGbcsC(9+G&z;H4LlMnH$2AP={qstkXn_y9oMV*DA0lHpeQ=`di`Q;}^2$;ktrkGeHrx{u%8yQ%p znI|QuB&VdAry8dM)flIwq@>w#*$`Bs5UXHk$5mXCSX5F`l$yq6Y+-J~rK;-c@5TiH DI!$B7 delta 941 zcmbQO_*!v7Kz-^I-@Ir;o|f-+t$G1d|1Y^_>lkL+(5S>ZhpF*Bf60pU{Sq9TJU+O} zOgwz?w@m)yVvh4VlT9t22ThZacTO?ty#8R87h`p6_Zara|v?k(AWV_!1CEjV=L4hAw!Vra_|8cszjq{rPYlrxb0|(>kuYI!>lNFP3D5}-^bNG9UI_Fk?8^LIe zhu#}E`8EBF(~fFfDeo@2cwhATx3kJ>t+{KLB*Z3sY@YLc_pk3i%rlPtu&(>J>+_C# z>~H7)F8%XD?t_znhmF{eABG~DER+5{Gub&e<;$b0-wFDy@gHjcNap`%wBEowpDQ&l zrMRRhHF0tklOVI1k;UddCP^NCV}%$Er_#)v6a_;|7jv`8+xc`jO$|&9%ni+r%qPF$ zlS1P0^IM8q8YmcmfI^-E7nosSU~V$`CBOXS8h+_?b0ZTBX$vD`bTMNyZ0alxG1VDh zm}hKmVleq1zg@hsnVD%)szpkgiE&D*d5Wc_sd1XIk)@fLVVbF>Nur4zmkmKB3b6`y bc3j0JiA5z9MX70A#+IfgT&k+B{%%|Vtr>m8 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 0000000000000000000000000000000000000000..0eaaefca86b8b863cbba9676e39e14d4a312552d GIT binary patch literal 4345 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 BFR}mt literal 0 HcmV?d00001 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 0000000000000000000000000000000000000000..d09aa5b91fa79e6afd92c6188e2ed24aab8a2172 GIT binary patch literal 4412 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 literal 0 HcmV?d00001 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 0000000000000000000000000000000000000000..3df88ff7e298b9efbe7490582acc9c03b3f627fc GIT binary patch literal 4027 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 W6e_Eh-wzt8s-gseLJdp}A^!&-vM5vl literal 0 HcmV?d00001 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 0000000000000000000000000000000000000000..c233e9021110a9866d501918c706fe5534c8b5e0 GIT binary patch literal 4393 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 literal 0 HcmV?d00001 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 0000000000000000000000000000000000000000..12ea2bf065a1846bce1b97f5db9c997e2a3dd861 GIT binary patch literal 4036 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 W@**?5{Bh9;1r!<#foK_OgZ~fyFy(Ln literal 0 HcmV?d00001 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..c7e6094709 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" @@ -571,7 +572,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; } }]]; 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..37a4cea68e 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; @@ -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..5779b83a20 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,26 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; - (void)layoutSubviews { + CGFloat inset = 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(inset, ceil((self.frame.size.height - colorPickerHeight) / 2.0f), self.frame.size.width - inset - inset, 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), inset, colorPickerHeight, self.frame.size.height - inset - inset); + _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..bf44bcb018 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; @@ -646,8 +646,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 +688,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]; From c2ab9b9cafe48c829ed92e58fe451981ea26db27 Mon Sep 17 00:00:00 2001 From: Ilya Laktyushin Date: Fri, 5 Jun 2020 18:43:07 +0300 Subject: [PATCH 3/9] Update gif provider attribution --- .../Media Grid/Tenor.imageset/Contents.json | 22 ++++++++++++ .../Media Grid/Tenor.imageset/tenor@2x.png | Bin 0 -> 13648 bytes .../Media Grid/Tenor.imageset/tenor@3x.png | Bin 0 -> 21695 bytes .../Sources/WebSearchController.swift | 32 ++++++++++++++++-- .../Sources/WebSearchControllerNode.swift | 29 ++++++++++++++-- .../Sources/WebSearchInterfaceState.swift | 15 +++++--- 6 files changed, 88 insertions(+), 10 deletions(-) create mode 100644 submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/Contents.json create mode 100644 submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@2x.png create mode 100644 submodules/TelegramUI/Images.xcassets/Media Grid/Tenor.imageset/tenor@3x.png 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 0000000000000000000000000000000000000000..2cda9ab0e992fcd7c7e35bc1aededffefffcba95 GIT binary patch literal 13648 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 VoZuo6^g95a58nV3kKj;Dx|NLeoXn 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 SI*q0P0000 } } +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? @@ -165,9 +177,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 } @@ -179,6 +201,9 @@ public final class WebSearchController: ViewController { if current.presentationData !== presentationData { updated = updated.withUpdatedPresentationData(presentationData) } + if current.gifProvider != gifProvider { + updated = updated.withUpdatedGifProvider(gifProvider) + } return updated } }) @@ -310,13 +335,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 e68aa0ddf3..d503def187 100644 --- a/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift +++ b/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift @@ -348,8 +348,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 +404,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 +474,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 +482,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) } 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) } } From 899ed547a204b5561acf01b66233a3d6de238152 Mon Sep 17 00:00:00 2001 From: Ilya Laktyushin Date: Fri, 5 Jun 2020 18:43:35 +0300 Subject: [PATCH 4/9] Improve media sending options tooltip --- .../Sources/TGMediaPickerGalleryInterfaceView.m | 9 ++++++--- .../LegacyComponents/Sources/TGPhotoPaintSettingsView.m | 9 +++++---- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m index c7e6094709..638486cb1a 100644 --- a/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m +++ b/submodules/LegacyComponents/Sources/TGMediaPickerGalleryInterfaceView.m @@ -151,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)]; @@ -920,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 @@ -928,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]; @@ -943,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/TGPhotoPaintSettingsView.m b/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.m index 5779b83a20..6a9489a2ed 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintSettingsView.m @@ -61,7 +61,7 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.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]; +// [self addSubview:_eyedropperButton]; _settingsButton = [[TGModernButton alloc] initWithFrame:CGRectMake(0, 0, 44.0f, 44.0f)]; _settingsButton.exclusiveTouch = true; @@ -211,7 +211,8 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; - (void)layoutSubviews { - CGFloat inset = 66.0f; + CGFloat leftInset = 23.0f; + CGFloat rightInset = 66.0f; CGFloat colorPickerHeight = 10.0f; if (self.frame.size.width > self.frame.size.height) { @@ -222,14 +223,14 @@ const CGFloat TGPhotoPaintSettingsPadPickerWidth = 360.0f; } else { - _colorPicker.frame = CGRectMake(inset, ceil((self.frame.size.height - colorPickerHeight) / 2.0f), self.frame.size.width - inset - inset, colorPickerHeight); + _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 - colorPickerHeight) / 2.0f), inset, colorPickerHeight, self.frame.size.height - inset - inset); + _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); } From 4d6dfa5204c2f77a95a5edf747be323371bed6f7 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 5 Jun 2020 19:55:52 +0400 Subject: [PATCH 5/9] Fix UI --- .../Sources/Node/ChatListItem.swift | 7 ++- .../Sources/PhotoResources.swift | 49 ++++++++++++------- .../Sources/AccountStateManagementUtils.swift | 4 +- .../Sources/ApplyUpdateMessage.swift | 8 ++- .../Panes/PeerInfoVisualMediaPaneNode.swift | 4 +- 5 files changed, 46 insertions(+), 26 deletions(-) diff --git a/submodules/ChatListUI/Sources/Node/ChatListItem.swift b/submodules/ChatListUI/Sources/Node/ChatListItem.swift index ccc27058aa..089974b675 100644 --- a/submodules/ChatListUI/Sources/Node/ChatListItem.swift +++ b/submodules/ChatListUI/Sources/Node/ChatListItem.swift @@ -361,7 +361,7 @@ private final class ChatListMediaPreviewNode: ASDisplayNode { 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), synchronousLoad: synchronousLoads) + 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) } } @@ -370,7 +370,7 @@ private final class ChatListMediaPreviewNode: ASDisplayNode { 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) + 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) } } @@ -986,6 +986,9 @@ class ChatListItemNode: ItemListRevealOptionsItemNode { } 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 diff --git a/submodules/PhotoResources/Sources/PhotoResources.swift b/submodules/PhotoResources/Sources/PhotoResources.swift index 476eb07610..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) 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/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift index 71320476f4..a779b60417 100644 --- a/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift +++ b/submodules/TelegramUI/Sources/PeerInfo/Panes/PeerInfoVisualMediaPaneNode.swift @@ -450,7 +450,7 @@ private final class VisualMediaItemNode: ASDisplayNode { } self.displayLink?.isPaused = !self.hasVisibility || self.isHidden - if isVisible { + /*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)) @@ -473,7 +473,7 @@ private final class VisualMediaItemNode: ASDisplayNode { self.frameSequenceThumbnailNode = nil frameSequenceThumbnailNode.removeFromSupernode() } - } + }*/ self.frameSequenceThumbnailNode?.updateIsPlaying(isVisible) } From f529ec07930ae59b352a8ea7e462fbc58efe8f2a Mon Sep 17 00:00:00 2001 From: Ali <> Date: Fri, 5 Jun 2020 21:50:50 +0400 Subject: [PATCH 6/9] Link preview update --- Telegram/NotificationService/Serialization.m | 2 +- .../Telegram-iOS/en.lproj/Localizable.strings | 4 + .../Sources/AccountContext.swift | 14 +- .../Sources/ChatController.swift | 2 +- .../Sources/ThemedTextAlertController.swift | 6 +- .../Sources/ContactContextMenus.swift | 6 +- .../Display/Source/TextAlertController.swift | 16 +- .../Sources/InstantPageControllerNode.swift | 4 +- .../Sources/JoinLinkPreviewController.swift | 11 +- .../Sources/PeersNearbyController.swift | 2 +- .../Sources/AlertTheme.swift | 4 +- .../SettingsUI/Sources/DebugController.swift | 2 +- .../Sources/StatsController.swift | 2 +- submodules/TelegramApi/Sources/Api0.swift | 1 + submodules/TelegramApi/Sources/Api1.swift | 26 + .../TelegramCore/Sources/JoinLink.swift | 14 +- .../TelegramCore/Sources/Serialization.swift | 2 +- .../Sources/PresentationStrings.swift | 4591 +++++++++-------- .../Resources/PresentationStrings.mapping | Bin 150552 -> 150730 bytes .../AuthorizationSequenceController.swift | 2 +- .../TelegramUI/Sources/ChatBotInfoItem.swift | 2 +- .../Sources/ChatButtonKeyboardInputNode.swift | 2 +- .../TelegramUI/Sources/ChatController.swift | 85 +- .../ChatMessageAnimatedStickerItemNode.swift | 4 +- .../Sources/ChatMessageBubbleItemNode.swift | 6 +- .../ChatMessageInstantVideoItemNode.swift | 4 +- .../Sources/ChatMessageStickerItemNode.swift | 4 +- .../ChatRecentActionsControllerNode.swift | 8 +- .../Sources/NavigateToChatController.swift | 2 +- .../TelegramUI/Sources/OpenResolvedUrl.swift | 10 +- submodules/TelegramUI/Sources/OpenUrl.swift | 4 +- .../Sources/PeerInfo/PeerInfoScreen.swift | 4 +- .../PeerMediaCollectionController.swift | 4 +- .../TelegramUI/Sources/TextLinkHandling.swift | 8 +- .../UrlHandling/Sources/UrlHandling.swift | 10 +- .../WalletUI/Resources/WalletStrings.mapping | Bin 8422 -> 8422 bytes .../WalletUI/Sources/WalletStrings.swift | 4 +- 37 files changed, 2500 insertions(+), 2372 deletions(-) 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 21deeeba1e..63a6c83733 100644 --- a/Telegram/Telegram-iOS/en.lproj/Localizable.strings +++ b/Telegram/Telegram-iOS/en.lproj/Localizable.strings @@ -5534,3 +5534,7 @@ Any member of this group will be able to see messages in the channel."; "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/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/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/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/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/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/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/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/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 4a6f80bdc7..c8202c96e7 100644 --- a/submodules/TelegramPresentationData/Sources/PresentationStrings.swift +++ b/submodules/TelegramPresentationData/Sources/PresentationStrings.swift @@ -2508,2728 +2508,2734 @@ public final class PresentationStrings: Equatable { 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 Call_AudioRouteHide: String { return self._s[2166]! } + 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[2168]!, self._r[2168]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2169]!, self._r[2169]!, [_1, _2]) } - public var ContactInfo_PhoneLabelMobile: String { return self._s[2169]! } - public var IntentsSettings_SuggestedChatsInfo: String { return self._s[2170]! } - public var CreatePoll_QuizOptionsHeader: String { return self._s[2171]! } + 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[2172]!, self._r[2172]!, [_0]) + return formatWithArgumentRanges(self._s[2173]!, self._r[2173]!, [_0]) } - public var TextFormat_Bold: String { return self._s[2173]! } - public var CreatePoll_ExplanationInfo: String { return self._s[2174]! } - public var FastTwoStepSetup_EmailSection: String { return self._s[2175]! } - public var StickerPackActionInfo_AddedTitle: String { return self._s[2176]! } - public var Notifications_Title: String { return self._s[2177]! } - public var Group_Username_InvalidTooShort: String { return self._s[2178]! } - public var Channel_ErrorAddTooMuch: String { return self._s[2179]! } + 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[2180]!, self._r[2180]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2181]!, self._r[2181]!, ["\(_0)"]) } - public var VoiceOver_DiscardPreparedContent: String { return self._s[2182]! } - public var Stickers_SuggestAdded: String { return self._s[2183]! } - public var Login_CountryCode: String { return self._s[2184]! } - public var ChatSettings_AutoPlayVideos: String { return self._s[2185]! } - public var Map_GetDirections: String { return self._s[2186]! } - public var Wallet_Receive_ShareInvoiceUrl: String { return self._s[2187]! } - public var Login_PhoneFloodError: String { return self._s[2188]! } + 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[2189]!, self._r[2189]!, [_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[2190]!, self._r[2190]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2191]!, self._r[2191]!, [_1, _2, _3]) } - public var IntentsSettings_SuggestedChatsPrivateChats: String { return self._s[2191]! } - public var Settings_SetUsername: String { return self._s[2193]! } - public var Group_Location_ChangeLocation: String { return self._s[2194]! } - public var Notification_GroupInviterSelf: String { return self._s[2195]! } - public var InstantPage_TapToOpenLink: String { return self._s[2196]! } + 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[2197]!, self._r[2197]!, [_0]) + return formatWithArgumentRanges(self._s[2198]!, self._r[2198]!, [_0]) } - public var Watch_Suggestion_TalkLater: String { return self._s[2198]! } - public var SecretChat_Title: String { return self._s[2199]! } - public var Group_UpgradeNoticeText1: String { return self._s[2200]! } - public var AuthSessions_Title: String { return self._s[2201]! } + 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[2202]!, self._r[2202]!, [_0]) + return formatWithArgumentRanges(self._s[2203]!, self._r[2203]!, [_0]) } - public var PhotoEditor_CropAuto: String { return self._s[2203]! } - public var Channel_About_Title: String { return self._s[2204]! } - public var Theme_ThemeChanged: String { return self._s[2205]! } - public var FastTwoStepSetup_EmailHelp: String { return self._s[2206]! } + 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[2208]!, self._r[2208]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[2209]!, self._r[2209]!, ["\(_0)"]) } - public var VoiceOver_MessageContextReport: String { return self._s[2209]! } - public var Conversation_PinMessageAlert_OnlyPin: String { return self._s[2211]! } - public var Group_Setup_HistoryVisibleHelp: String { return self._s[2212]! } + 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[2213]!, self._r[2213]!, [_1]) + return formatWithArgumentRanges(self._s[2214]!, self._r[2214]!, [_1]) } public func SharedMedia_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2215]!, self._r[2215]!, [_0]) - } - public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2216]!, self._r[2216]!, [_0]) } - public var Privacy_PaymentsClearInfoHelp: String { return self._s[2217]! } - public var PeopleNearby_DiscoverDescription: String { return self._s[2219]! } - public var Presence_online: String { return self._s[2221]! } - public var PasscodeSettings_Title: String { return self._s[2222]! } - public var Passport_Identity_ExpiryDatePlaceholder: String { return self._s[2223]! } - public var Web_OpenExternal: String { return self._s[2224]! } - public var AutoDownloadSettings_AutoDownload: String { return self._s[2226]! } - public var Channel_OwnershipTransfer_EnterPasswordText: String { return self._s[2227]! } - public var LocalGroup_Title: String { return self._s[2228]! } + public func TwoStepAuth_RecoveryEmailUnavailable(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2217]!, self._r[2217]!, [_0]) + } + 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[2229]!, self._r[2229]!, [_0]) + return formatWithArgumentRanges(self._s[2230]!, self._r[2230]!, [_0]) } - public var FastTwoStepSetup_PasswordConfirmationPlaceholder: String { return self._s[2230]! } - public var Conversation_StopQuizConfirmation: String { return self._s[2231]! } - public var Map_YouAreHere: String { return self._s[2232]! } + 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[2233]!, self._r[2233]!, [_0]) - } - public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2234]!, self._r[2234]!, [_0]) } - public var Theme_Context_ChangeColors: String { return self._s[2235]! } - public var PrivacyLastSeenSettings_AlwaysShareWith: String { return self._s[2236]! } - public var Target_InviteToGroupErrorAlreadyInvited: String { return self._s[2237]! } - public func AuthSessions_AppUnofficial(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2238]!, self._r[2238]!, [_0]) + public func ChatList_DeleteChatConfirmation(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2235]!, self._r[2235]!, [_0]) } - public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + 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[2239]!, self._r[2239]!, [_0]) } - public var SocksProxySetup_Username: String { return self._s[2240]! } - public var Bot_Start: String { return self._s[2241]! } - public func Channel_AdminLog_EmptyFilterQueryText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2242]!, self._r[2242]!, [_0]) + public func DialogList_LiveLocationSharingTo(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2240]!, self._r[2240]!, [_0]) } - public func Channel_AdminLog_MessagePinned(_ _0: String) -> (String, [(Int, NSRange)]) { + 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[2244]! } - public var AccentColor_Title: String { return self._s[2247]! } - public var Conversation_DiscardVoiceMessageTitle: String { return self._s[2248]! } + 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[2249]!, self._r[2249]!, [_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[2250]!, self._r[2250]!, [_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[2251]!, self._r[2251]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2252]!, self._r[2252]!, [_1, _2]) } - public var Passport_Email_EnterOtherEmail: String { return self._s[2252]! } - public var Login_InfoAvatarPhoto: String { return self._s[2253]! } + 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[2254]!, self._r[2254]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2255]!, self._r[2255]!, [_1, _2]) } - public var Privacy_PaymentsClear_ShippingInfo: String { return self._s[2255]! } - public var Tour_Title4: String { return self._s[2256]! } - public var Passport_Identity_Translation: String { return self._s[2257]! } - public var SettingsSearch_Synonyms_Notifications_ContactJoined: String { return self._s[2258]! } - public var Login_TermsOfServiceLabel: String { return self._s[2260]! } - public var Passport_Language_it: String { return self._s[2261]! } - public var KeyCommand_JumpToNextUnreadChat: String { return self._s[2262]! } - public var Passport_Identity_SelfieHelp: String { return self._s[2263]! } - public var Conversation_ClearAll: String { return self._s[2265]! } - public var Wallet_Send_UninitializedText: String { return self._s[2267]! } - public var Channel_OwnershipTransfer_Title: String { return self._s[2268]! } - public var TwoStepAuth_FloodError: String { return self._s[2269]! } + 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[2270]!, self._r[2270]!, [_1]) + return formatWithArgumentRanges(self._s[2271]!, self._r[2271]!, [_1]) } - public var Paint_Delete: String { return self._s[2271]! } + public var Paint_Delete: String { return self._s[2272]! } public func Wallet_Sent_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2272]!, self._r[2272]!, [_0]) + return formatWithArgumentRanges(self._s[2273]!, self._r[2273]!, [_0]) } - public var Privacy_AddNewPeer: String { return self._s[2273]! } + public var Privacy_AddNewPeer: String { return self._s[2274]! } public func Channel_AdminLog_MessageRank(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2274]!, self._r[2274]!, [_1]) + return formatWithArgumentRanges(self._s[2275]!, self._r[2275]!, [_1]) } - public var LogoutOptions_SetPasscodeText: String { return self._s[2275]! } + public var LogoutOptions_SetPasscodeText: String { return self._s[2276]! } public func Passport_AcceptHelp(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2276]!, self._r[2276]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2277]!, self._r[2277]!, [_1, _2]) } - public var Message_PinnedAudioMessage: String { return self._s[2277]! } + public var Message_PinnedAudioMessage: String { return self._s[2278]! } public func Watch_Time_ShortTodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2278]!, self._r[2278]!, [_0]) + return formatWithArgumentRanges(self._s[2279]!, self._r[2279]!, [_0]) } - public var Notification_Mute1hMin: String { return self._s[2279]! } - public var Notifications_GroupNotificationsSound: String { return self._s[2280]! } - public var Wallet_Month_GenNovember: String { return self._s[2281]! } - public var SocksProxySetup_ShareProxyList: String { return self._s[2282]! } - public var Conversation_MessageEditedLabel: String { return self._s[2283]! } + 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[2284]!, self._r[2284]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2285]!, self._r[2285]!, [_0, _1]) } - public var Notification_Exceptions_AlwaysOff: String { return self._s[2285]! } - public var Notification_Exceptions_NewException_MessagePreviewHeader: String { return self._s[2286]! } + 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[2287]!, self._r[2287]!, [_0, _1, _2]) + return formatWithArgumentRanges(self._s[2288]!, self._r[2288]!, [_0, _1, _2]) } - public var NetworkUsageSettings_ResetStats: String { return self._s[2288]! } + public var NetworkUsageSettings_ResetStats: String { return self._s[2289]! } public func PUSH_MESSAGE_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2289]!, self._r[2289]!, [_1]) + return formatWithArgumentRanges(self._s[2290]!, self._r[2290]!, [_1]) } - public var AccessDenied_LocationTracking: String { return self._s[2290]! } - public var Month_GenOctober: String { return self._s[2291]! } - public var GroupInfo_InviteLink_RevokeAlert_Revoke: String { return self._s[2292]! } - public var EnterPasscode_EnterPasscode: String { return self._s[2293]! } - public var MediaPicker_TimerTooltip: String { return self._s[2295]! } - public var SharedMedia_TitleAll: String { return self._s[2296]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsExceptions: String { return self._s[2299]! } - public var Conversation_RestrictedMedia: String { return self._s[2300]! } - public var AccessDenied_PhotosRestricted: String { return self._s[2301]! } - public var Privacy_Forwards_WhoCanForward: String { return self._s[2303]! } - public var ChangePhoneNumberCode_Called: String { return self._s[2304]! } + 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[2305]!, self._r[2305]!, [_0]) + return formatWithArgumentRanges(self._s[2306]!, self._r[2306]!, [_0]) } - public var Conversation_SavedMessages: String { return self._s[2308]! } - public var Your_cards_expiration_month_is_invalid: String { return self._s[2310]! } - public var FastTwoStepSetup_PasswordPlaceholder: String { return self._s[2311]! } + 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[2313]!, self._r[2313]!, [_0]) + return formatWithArgumentRanges(self._s[2314]!, self._r[2314]!, [_0]) } - public var VoiceOver_Chat_YourMessage: String { return self._s[2314]! } + public var VoiceOver_Chat_YourMessage: String { return self._s[2315]! } public func VoiceOver_Chat_Title(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2315]!, self._r[2315]!, [_0]) + return formatWithArgumentRanges(self._s[2316]!, self._r[2316]!, [_0]) } - public var ReportPeer_AlertSuccess: String { return self._s[2316]! } - public var PhotoEditor_CropAspectRatioOriginal: String { return self._s[2317]! } + 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[2318]!, self._r[2318]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2319]!, self._r[2319]!, [_1, _2]) } - public var Checkout_PasswordEntry_Title: String { return self._s[2319]! } - public var PhotoEditor_FadeTool: String { return self._s[2320]! } - public var Privacy_ContactsReset: String { return self._s[2321]! } + 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[2323]!, self._r[2323]!, [_0]) + return formatWithArgumentRanges(self._s[2325]!, self._r[2325]!, [_0]) } - public var Message_PinnedVideoMessage: String { return self._s[2324]! } - public var ChatList_Mute: String { return self._s[2325]! } + 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[2326]!, self._r[2326]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2328]!, self._r[2328]!, [_1, _2, _3]) } - public var Permissions_CellularDataText_v0: String { return self._s[2327]! } - public var Conversation_PinnedQuiz: String { return self._s[2329]! } - public var ShareMenu_SelectChats: String { return self._s[2331]! } - public var ChatList_Context_Unarchive: String { return self._s[2332]! } - public var MusicPlayer_VoiceNote: String { return self._s[2333]! } - public var Conversation_RestrictedText: String { return self._s[2334]! } - public var SettingsSearch_Synonyms_Privacy_Data_DeleteDrafts: String { return self._s[2335]! } - public var Wallet_Month_GenApril: String { return self._s[2336]! } - public var Wallet_Month_ShortMarch: String { return self._s[2337]! } - public var TwoStepAuth_DisableSuccess: String { return self._s[2338]! } - public var Chat_PsaTooltip_covid: String { return self._s[2339]! } - public var Cache_Videos: String { return self._s[2340]! } - public var PrivacySettings_PhoneNumber: String { return self._s[2341]! } - public var Wallet_Month_GenFebruary: String { return self._s[2342]! } - public var FeatureDisabled_Oops: String { return self._s[2344]! } - public var ChatList_RemoveFolderAction: String { return self._s[2345]! } - public var Passport_Address_PostcodePlaceholder: String { return self._s[2346]! } + 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[2347]!, self._r[2347]!, [_0]) + return formatWithArgumentRanges(self._s[2349]!, self._r[2349]!, [_0]) } - public var Stickers_GroupStickersHelp: String { return self._s[2349]! } - public var GroupPermission_NoSendPolls: String { return self._s[2350]! } - public var Wallet_Qr_ScanCode: String { return self._s[2351]! } - public var Message_VideoExpired: String { return self._s[2353]! } - public var GroupInfo_GroupHistoryVisible: String { return self._s[2354]! } - public var Notifications_Badge: String { return self._s[2355]! } - public var Wallet_Receive_AddressCopied: String { return self._s[2356]! } - public var CreatePoll_OptionPlaceholder: String { return self._s[2357]! } - public var Username_InvalidTooShort: String { return self._s[2358]! } - public var EnterPasscode_EnterNewPasscodeChange: String { return self._s[2359]! } - public var Channel_AdminLog_PinMessages: String { return self._s[2360]! } - public var ArchivedChats_IntroTitle3: String { return self._s[2361]! } + 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[2362]!, self._r[2362]!, [_1]) + return formatWithArgumentRanges(self._s[2364]!, self._r[2364]!, [_1]) } - public var Permissions_SiriAllowInSettings_v0: String { return self._s[2363]! } - public var Conversation_DefaultRestrictedText: String { return self._s[2364]! } - public var SharedMedia_CategoryDocs: String { return self._s[2367]! } + 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[2368]!, self._r[2368]!, [_1]) + return formatWithArgumentRanges(self._s[2370]!, self._r[2370]!, [_1]) } - public var Wallet_Send_UninitializedTitle: String { return self._s[2369]! } - public var StickerPackActionInfo_ArchivedTitle: String { return self._s[2370]! } - public var Privacy_Forwards_NeverLink: String { return self._s[2372]! } + 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[2373]!, self._r[2373]!, [_1]) + return formatWithArgumentRanges(self._s[2375]!, self._r[2375]!, [_1]) } - public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2374]! } + public var CheckoutInfo_ErrorShippingNotAvailable: String { return self._s[2376]! } public func Time_MonthOfYear_m12(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2375]!, self._r[2375]!, [_0]) + return formatWithArgumentRanges(self._s[2377]!, self._r[2377]!, [_0]) } - public var ChatSettings_PrivateChats: String { return self._s[2376]! } - public var SettingsSearch_Synonyms_EditProfile_Logout: String { return self._s[2377]! } - public var Conversation_PrivateMessageLinkCopied: String { return self._s[2378]! } - public var Channel_UpdatePhotoItem: String { return self._s[2379]! } - public var GroupInfo_LeftStatus: String { return self._s[2380]! } - public var Watch_MessageView_Forward: String { return self._s[2382]! } - public var ReportPeer_ReasonChildAbuse: String { return self._s[2383]! } - public var Cache_ClearEmpty: String { return self._s[2385]! } - public var Localization_LanguageName: String { return self._s[2386]! } - public var Wallet_AccessDenied_Title: String { return self._s[2387]! } - public var WebSearch_GIFs: String { return self._s[2388]! } - public var Notifications_DisplayNamesOnLockScreenInfoWithLink: String { return self._s[2389]! } - public var Wallet_AccessDenied_Settings: String { return self._s[2390]! } - public var Username_InvalidStartsWithNumber: String { return self._s[2391]! } - public var Common_Back: String { return self._s[2392]! } - public var GroupInfo_Permissions_EditingDisabled: String { return self._s[2393]! } - public var Passport_Identity_DateOfBirthPlaceholder: String { return self._s[2394]! } - public var Wallet_Send_Send: String { return self._s[2395]! } + 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[2397]!, self._r[2397]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2399]!, self._r[2399]!, [_1, _2]) } - public var Wallet_Info_RefreshErrorTitle: String { return self._s[2398]! } - public var ChatList_Tabs_All: String { return self._s[2399]! } - public var Wallet_Month_GenJune: String { return self._s[2400]! } - public var Passport_Email_Help: String { return self._s[2401]! } - public var Watch_Conversation_Reply: String { return self._s[2403]! } - public var Conversation_EditingMessageMediaChange: String { return self._s[2406]! } - public var Passport_Identity_IssueDatePlaceholder: String { return self._s[2407]! } - public var Channel_BanUser_Unban: String { return self._s[2409]! } - public var Channel_EditAdmin_PermissionPostMessages: String { return self._s[2410]! } - public var Group_Username_CreatePublicLinkHelp: String { return self._s[2411]! } - public var TwoStepAuth_ConfirmEmailCodePlaceholder: String { return self._s[2413]! } - public var Wallet_Send_AddressHeader: String { return self._s[2414]! } - public var Passport_Identity_Name: String { return self._s[2415]! } + 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[2416]!, self._r[2416]!, [_0]) + return formatWithArgumentRanges(self._s[2418]!, self._r[2418]!, [_0]) } - public var GroupRemoved_ViewUserInfo: String { return self._s[2417]! } - public var Conversation_BlockUser: String { return self._s[2418]! } - public var Month_GenJanuary: String { return self._s[2419]! } - public var ChatSettings_TextSize: String { return self._s[2420]! } - public var Notification_PassportValuePhone: String { return self._s[2421]! } - public var MediaPlayer_UnknownArtist: String { return self._s[2422]! } - public var Passport_Language_ne: String { return self._s[2423]! } - public var Notification_CallBack: String { return self._s[2424]! } - public var Wallet_SecureStorageReset_BiometryTouchId: String { return self._s[2425]! } - public var TwoStepAuth_EmailHelp: String { return self._s[2426]! } + 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[2427]!, self._r[2427]!, [_0]) + return formatWithArgumentRanges(self._s[2429]!, self._r[2429]!, [_0]) } - public var Channel_Info_Management: String { return self._s[2428]! } - public var Passport_FieldIdentityUploadHelp: String { return self._s[2429]! } - public var Stickers_FrequentlyUsed: String { return self._s[2431]! } - public var Channel_BanUser_PermissionSendMessages: String { return self._s[2432]! } - public var Passport_Address_OneOfTypeUtilityBill: String { return self._s[2434]! } + 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[2435]!, self._r[2435]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[2437]!, self._r[2437]!, [_1, "\(_2)"]) } - public var TwoFactorSetup_Password_Title: String { return self._s[2436]! } - public var Passport_Address_EditResidentialAddress: String { return self._s[2437]! } - public var PrivacyPolicy_DeclineTitle: String { return self._s[2438]! } - public var CreatePoll_TextHeader: String { return self._s[2439]! } + 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[2440]!, self._r[2440]!, [_0]) + return formatWithArgumentRanges(self._s[2442]!, self._r[2442]!, [_0]) } - public var PhotoEditor_QualityMedium: String { return self._s[2441]! } - public var InfoPlist_NSMicrophoneUsageDescription: String { return self._s[2442]! } - public var Conversation_StatusKickedFromChannel: String { return self._s[2444]! } - public var CheckoutInfo_ReceiverInfoName: String { return self._s[2445]! } - public var Group_ErrorSendRestrictedStickers: String { return self._s[2446]! } + 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[2447]!, self._r[2447]!, [_0]) + return formatWithArgumentRanges(self._s[2449]!, self._r[2449]!, [_0]) } public func Channel_AdminLog_MessageTransferedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2448]!, self._r[2448]!, [_1]) + return formatWithArgumentRanges(self._s[2450]!, self._r[2450]!, [_1]) } - public var LogoutOptions_LogOutWalletInfo: String { return self._s[2449]! } - public var TwoFactorSetup_Email_SkipConfirmationTitle: String { return self._s[2450]! } - public var Conversation_LinkDialogOpen: String { return self._s[2452]! } - public var TwoFactorSetup_Hint_Title: String { return self._s[2453]! } - public var VoiceOver_Chat_PollNoVotes: String { return self._s[2454]! } - public var Settings_Username: String { return self._s[2456]! } - public var Conversation_Block: String { return self._s[2458]! } - public var Wallpaper_Wallpaper: String { return self._s[2459]! } - public var SocksProxySetup_UseProxy: String { return self._s[2461]! } - public var Wallet_Send_Confirmation: String { return self._s[2462]! } - public var EditTheme_UploadEditedTheme: String { return self._s[2463]! } - public var UserInfo_ShareMyContactInfo: String { return self._s[2464]! } - public var MessageTimer_Forever: String { return self._s[2465]! } - public var Privacy_Calls_WhoCanCallMe: String { return self._s[2466]! } - public var PhotoEditor_DiscardChanges: String { return self._s[2467]! } - public var AuthSessions_TerminateOtherSessionsHelp: String { return self._s[2468]! } - public var Passport_Language_da: String { return self._s[2469]! } - public var SocksProxySetup_PortPlaceholder: String { return self._s[2471]! } + 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[2472]!, self._r[2472]!, [_0]) - } - public var Passport_Address_EditPassportRegistration: String { return self._s[2473]! } - public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[2475]!, self._r[2475]!, [_0]) } - public var Settings_AddDevice: String { return self._s[2476]! } - public var Passport_Identity_ResidenceCountryPlaceholder: String { return self._s[2478]! } - public var AuthSessions_AddDeviceIntro_Text1: String { return self._s[2479]! } - public var Conversation_SearchByName_Prefix: String { return self._s[2480]! } - public var Conversation_PinnedPoll: String { return self._s[2481]! } - public var AuthSessions_AddDeviceIntro_Text2: String { return self._s[2482]! } - public var Conversation_EmptyGifPanelPlaceholder: String { return self._s[2483]! } - public var AuthSessions_AddDeviceIntro_Text3: String { return self._s[2484]! } + public var Passport_Address_EditPassportRegistration: String { return self._s[2476]! } + public func Channel_AdminLog_MessageChangedGroupAbout(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[2478]!, self._r[2478]!, [_0]) + } + 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[2485]!, self._r[2485]!, [_1]) + return formatWithArgumentRanges(self._s[2488]!, self._r[2488]!, [_1]) } - public var WallpaperSearch_ColorPurple: String { return self._s[2486]! } - public var Cache_ByPeerHeader: String { return self._s[2487]! } + 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[2488]!, self._r[2488]!, [_0]) + return formatWithArgumentRanges(self._s[2491]!, self._r[2491]!, [_0]) } - public var ChatSettings_AutoDownloadDocuments: String { return self._s[2489]! } - public var Appearance_ThemePreview_Chat_3_Text: String { return self._s[2492]! } - public var Wallet_Completed_Title: String { return self._s[2493]! } - public var Notification_PinnedMessage: String { return self._s[2494]! } - public var TwoFactorSetup_EmailVerification_Placeholder: String { return self._s[2495]! } - public var VoiceOver_Chat_RecordModeVideoMessage: String { return self._s[2497]! } - public var Contacts_SortBy: String { return self._s[2498]! } + 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[2499]!, self._r[2499]!, [_1]) + return formatWithArgumentRanges(self._s[2502]!, self._r[2502]!, [_1]) } - public var Appearance_ColorThemeNight: String { return self._s[2501]! } + 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[2502]!, self._r[2502]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2505]!, self._r[2505]!, [_1, _2]) } - public var Call_EncryptionKey_Title: String { return self._s[2503]! } - public var Watch_UserInfo_Service: String { return self._s[2504]! } - public var SettingsSearch_Synonyms_Data_SaveEditedPhotos: String { return self._s[2506]! } - public var Conversation_Unpin: String { return self._s[2508]! } - public var CancelResetAccount_Title: String { return self._s[2509]! } - public var Map_LiveLocationFor15Minutes: String { return self._s[2510]! } + 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[2512]!, self._r[2512]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2515]!, self._r[2515]!, [_1, _2, _3]) } - public var Group_Members_AddMemberBotErrorNotAllowed: String { return self._s[2513]! } - public var Appearance_BubbleCorners_Title: String { return self._s[2514]! } - public var CallSettings_Title: String { return self._s[2515]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground: String { return self._s[2516]! } - public var PasscodeSettings_EncryptDataHelp: String { return self._s[2518]! } - public var AutoDownloadSettings_Contacts: String { return self._s[2519]! } + 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[2520]!, self._r[2520]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2523]!, self._r[2523]!, [_1, _2]) } - public var ChatList_Tabs_AllChats: String { return self._s[2521]! } - public var Passport_Identity_DocumentDetails: String { return self._s[2522]! } - public var LoginPassword_PasswordHelp: String { return self._s[2523]! } - public var ChatListFolderSettings_Info: String { return self._s[2524]! } - public var SettingsSearch_Synonyms_Data_AutoDownloadUsingWifi: String { return self._s[2525]! } - public var PrivacyLastSeenSettings_CustomShareSettings_Delete: String { return self._s[2526]! } - public var ChatContextMenu_TextSelectionTip: String { return self._s[2527]! } - public var ChatListFolder_CategoryGroups: String { return self._s[2528]! } - public var Checkout_TotalPaidAmount: String { return self._s[2529]! } + 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[2530]!, self._r[2530]!, [_0]) + return formatWithArgumentRanges(self._s[2533]!, self._r[2533]!, [_0]) } - public var ChatState_Updating: String { return self._s[2531]! } - public var PasscodeSettings_ChangePasscode: String { return self._s[2532]! } - public var ChatListFolder_ExcludedSectionHeader: String { return self._s[2533]! } - public var Conversation_SecretLinkPreviewAlert: String { return self._s[2535]! } - public var Privacy_SecretChatsLinkPreviews: String { return self._s[2536]! } + 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[2537]!, self._r[2537]!, [_1]) + return formatWithArgumentRanges(self._s[2540]!, self._r[2540]!, [_1]) } - public var VoiceOver_Chat_ReplyToYourMessage: String { return self._s[2538]! } - public var Contacts_InviteFriends: String { return self._s[2540]! } - public var Map_ChooseLocationTitle: String { return self._s[2541]! } - public var Conversation_StopPoll: String { return self._s[2543]! } + 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[2544]!, self._r[2544]!, [_0]) + return formatWithArgumentRanges(self._s[2547]!, self._r[2547]!, [_0]) } - public var Call_Camera: String { return self._s[2545]! } - public var LogoutOptions_ChangePhoneNumberTitle: String { return self._s[2546]! } - public var AppWallet_Intro_Text: String { return self._s[2547]! } - public var Appearance_BubbleCornersSetting: String { return self._s[2548]! } - public var Calls_RatingFeedback: String { return self._s[2549]! } + 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[2551]!, self._r[2551]!, [_0]) + return formatWithArgumentRanges(self._s[2554]!, self._r[2554]!, [_0]) } - public var GroupInfo_BroadcastListNamePlaceholder: String { return self._s[2552]! } - public var Wallet_Alert_OK: String { return self._s[2553]! } - public var NotificationsSound_Pulse: String { return self._s[2554]! } - public var Watch_LastSeen_Lately: String { return self._s[2555]! } - public var ReportGroupLocation_Report: String { return self._s[2558]! } - public var Widget_NoUsers: String { return self._s[2559]! } - public var Conversation_UnvotePoll: String { return self._s[2560]! } - public var SettingsSearch_Synonyms_Privacy_ProfilePhoto: String { return self._s[2562]! } - public var Privacy_ProfilePhoto_WhoCanSeeMyPhoto: String { return self._s[2563]! } - public var NotificationsSound_Circles: String { return self._s[2564]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Title: String { return self._s[2567]! } - public var Wallet_Settings_DeleteWallet: String { return self._s[2568]! } - public var ChatListFolder_CategoryBots: String { return self._s[2569]! } - public var TwoStepAuth_RecoveryCodeExpired: String { return self._s[2570]! } - public var Proxy_TooltipUnavailable: String { return self._s[2571]! } - public var Passport_Identity_CountryPlaceholder: String { return self._s[2573]! } - public var GroupInfo_Permissions_SlowmodeInfo: String { return self._s[2575]! } - public var Conversation_FileDropbox: String { return self._s[2576]! } - public var Notifications_ExceptionsUnmuted: String { return self._s[2577]! } - public var Tour_Text3: String { return self._s[2579]! } - public var Login_ResetAccountProtected_Title: String { return self._s[2582]! } - public var ChatListFolder_NamePlaceholder: String { return self._s[2583]! } - public var GroupPermission_NoSendMessages: String { return self._s[2584]! } - public var WallpaperSearch_ColorTitle: String { return self._s[2585]! } - public var ChatAdmins_AllMembersAreAdminsOnHelp: String { return self._s[2586]! } + 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[2588]!, self._r[2588]!, [_0]) + return formatWithArgumentRanges(self._s[2591]!, self._r[2591]!, [_0]) } - public var GroupInfo_AddParticipantTitle: String { return self._s[2589]! } - public var Checkout_ShippingOption_Title: String { return self._s[2590]! } - public var ChatSettings_AutoDownloadTitle: String { return self._s[2591]! } + 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[2592]!, self._r[2592]!, [_0]) + return formatWithArgumentRanges(self._s[2595]!, self._r[2595]!, [_0]) } public func ChatSettings_AutoDownloadSettings_TypeVideo(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2593]!, self._r[2593]!, [_0]) + return formatWithArgumentRanges(self._s[2596]!, self._r[2596]!, [_0]) } - public var Channel_Management_LabelAdministrator: String { return self._s[2594]! } - public var EditTheme_FileReadError: String { return self._s[2595]! } - public var OwnershipTransfer_ComeBackLater: String { return self._s[2596]! } - public var PrivacyLastSeenSettings_NeverShareWith_Placeholder: String { return self._s[2597]! } - public var AutoDownloadSettings_Photos: String { return self._s[2599]! } - public var Appearance_PreviewIncomingText: String { return self._s[2600]! } - public var ChatList_Context_MarkAllAsRead: String { return self._s[2601]! } - public var ChannelInfo_ConfirmLeave: String { return self._s[2602]! } - public var ChatListFolder_ExcludeSectionInfo: String { return self._s[2603]! } - public var MediaPicker_MomentsDateRangeSameMonthYearFormat: String { return self._s[2604]! } - public var Passport_Identity_DocumentNumberPlaceholder: String { return self._s[2605]! } - public var Channel_AdminLogFilter_EventsNewMembers: String { return self._s[2606]! } - public var PasscodeSettings_AutoLock_IfAwayFor_5minutes: String { return self._s[2607]! } - public var GroupInfo_SetGroupPhotoStop: String { return self._s[2608]! } - public var Notification_SecretChatScreenshot: String { return self._s[2609]! } - public var AccessDenied_Wallpapers: String { return self._s[2610]! } - public var ChatList_Context_Mute: String { return self._s[2612]! } - public var Passport_Address_City: String { return self._s[2613]! } - public var InfoPlist_NSPhotoLibraryAddUsageDescription: String { return self._s[2614]! } - public var Appearance_ThemeCarouselClassic: String { return self._s[2615]! } - public var SocksProxySetup_SecretPlaceholder: String { return self._s[2616]! } - public var AccessDenied_LocationDisabled: String { return self._s[2617]! } - public var Group_Location_Title: String { return self._s[2618]! } - public var SocksProxySetup_HostnamePlaceholder: String { return self._s[2620]! } - public var GroupInfo_Sound: String { return self._s[2621]! } - public var SettingsSearch_Synonyms_ChatSettings_OpenLinksIn: String { return self._s[2622]! } - public var ChannelInfo_ScamChannelWarning: String { return self._s[2623]! } - public var Stickers_RemoveFromFavorites: String { return self._s[2624]! } - public var Contacts_Title: String { return self._s[2625]! } - public var EditTheme_ThemeTemplateAlertText: String { return self._s[2626]! } - public var Passport_Language_fr: String { return self._s[2627]! } - public var TwoFactorSetup_EmailVerification_Action: String { return self._s[2628]! } - public var Notifications_ResetAllNotifications: String { return self._s[2629]! } - public var IntentsSettings_SuggestedChats: String { return self._s[2631]! } - public var PrivacySettings_SecurityTitle: String { return self._s[2633]! } - public var Checkout_NewCard_Title: String { return self._s[2634]! } - public var Login_HaveNotReceivedCodeInternal: String { return self._s[2635]! } - public var Conversation_ForwardChats: String { return self._s[2636]! } - public var Wallet_SecureStorageReset_PasscodeText: String { return self._s[2638]! } - public var PasscodeSettings_4DigitCode: String { return self._s[2639]! } - public var Settings_FAQ: String { return self._s[2641]! } - public var AutoDownloadSettings_DocumentsTitle: String { return self._s[2642]! } - public var Conversation_ContextMenuForward: String { return self._s[2643]! } - public var VoiceOver_Chat_YourPhoto: String { return self._s[2646]! } - public var PrivacyPolicy_Title: String { return self._s[2649]! } - public var Notifications_TextTone: String { return self._s[2650]! } - public var Profile_CreateNewContact: String { return self._s[2651]! } - public var PrivacyPhoneNumberSettings_WhoCanSeeMyPhoneNumber: String { return self._s[2652]! } - public var TwoFactorSetup_EmailVerification_Title: String { return self._s[2654]! } - public var Call_Speaker: String { return self._s[2655]! } - public var AutoNightTheme_AutomaticSection: String { return self._s[2656]! } - public var Channel_OwnershipTransfer_EnterPassword: String { return self._s[2658]! } - public var Channel_Username_InvalidCharacters: String { return self._s[2659]! } + 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[2660]!, self._r[2660]!, [_0]) + return formatWithArgumentRanges(self._s[2663]!, self._r[2663]!, [_0]) } - public var AutoDownloadSettings_AutodownloadFiles: String { return self._s[2661]! } - public var PrivacySettings_LastSeenTitle: String { return self._s[2662]! } - public var Channel_AdminLog_CanInviteUsers: String { return self._s[2663]! } - public var SettingsSearch_Synonyms_Privacy_Data_ClearPaymentsInfo: String { return self._s[2664]! } - public var OwnershipTransfer_SecurityCheck: String { return self._s[2665]! } - public var Conversation_MessageDeliveryFailed: String { return self._s[2666]! } - public var Watch_ChatList_NoConversationsText: String { return self._s[2667]! } - public var Bot_Unblock: String { return self._s[2668]! } - public var TextFormat_Italic: String { return self._s[2669]! } - public var WallpaperSearch_ColorPink: String { return self._s[2670]! } - public var Settings_About_Help: String { return self._s[2672]! } - public var SearchImages_Title: String { return self._s[2673]! } - public var Weekday_Wednesday: String { return self._s[2674]! } - public var Conversation_ClousStorageInfo_Description1: String { return self._s[2675]! } - public var ExplicitContent_AlertTitle: String { return self._s[2676]! } + 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[2677]!, self._r[2677]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2680]!, self._r[2680]!, [_1, _2, _3]) } - public var Channel_DiscussionGroup_Create: String { return self._s[2678]! } - public var Weekday_Thursday: String { return self._s[2679]! } - public var Channel_BanUser_PermissionChangeGroupInfo: String { return self._s[2680]! } - public var Channel_Members_AddMembersHelp: String { return self._s[2681]! } + 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[2682]!, self._r[2682]!, [_0]) + return formatWithArgumentRanges(self._s[2685]!, self._r[2685]!, [_0]) } - public var Channel_DiscussionGroup_LinkGroup: String { return self._s[2683]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsVibrate: String { return self._s[2684]! } - public var Passport_RequestedInformation: String { return self._s[2685]! } - public var Login_PhoneAndCountryHelp: String { return self._s[2686]! } - public var Conversation_EncryptionProcessing: String { return self._s[2688]! } - public var Notifications_PermissionsSuppressWarningTitle: String { return self._s[2689]! } - public var PhotoEditor_EnhanceTool: String { return self._s[2691]! } - public var Channel_Setup_Title: String { return self._s[2692]! } - public var PeerInfo_PaneVoiceAndVideo: String { return self._s[2693]! } - public var Conversation_SearchPlaceholder: String { return self._s[2694]! } - public var OldChannels_GroupEmptyFormat: String { return self._s[2695]! } - public var AccessDenied_LocationAlwaysDenied: String { return self._s[2696]! } - public var Checkout_ErrorGeneric: String { return self._s[2697]! } - public var Passport_Language_hu: String { return self._s[2698]! } - public var GroupPermission_EditingDisabled: String { return self._s[2699]! } - public var Wallet_Month_ShortSeptember: String { return self._s[2701]! } + 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[2702]!, self._r[2702]!, [_0]) + return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_0]) } public func PUSH_MESSAGE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2705]!, self._r[2705]!, [_1]) + return formatWithArgumentRanges(self._s[2708]!, self._r[2708]!, [_1]) } - public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2706]! } + public var ChatList_DeleteSavedMessagesConfirmationTitle: String { return self._s[2709]! } public func UserInfo_BlockConfirmationTitle(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2707]!, self._r[2707]!, [_0]) + return formatWithArgumentRanges(self._s[2710]!, self._r[2710]!, [_0]) } - public var Conversation_CloudStorageInfo_Title: String { return self._s[2708]! } - public var Group_Location_Info: String { return self._s[2709]! } - public var PhotoEditor_CropAspectRatioSquare: String { return self._s[2710]! } - public var Permissions_PeopleNearbyAllow_v0: String { return self._s[2711]! } + 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[2712]!, self._r[2712]!, [_0]) + return formatWithArgumentRanges(self._s[2715]!, self._r[2715]!, [_0]) } - public var Conversation_ClearPrivateHistory: String { return self._s[2713]! } - public var ContactInfo_PhoneLabelHome: String { return self._s[2714]! } - public var Appearance_RemoveThemeConfirmation: String { return self._s[2715]! } - public var PrivacySettings_LastSeenContacts: String { return self._s[2716]! } + 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[2717]!, self._r[2717]!, [_0]) + return formatWithArgumentRanges(self._s[2720]!, self._r[2720]!, [_0]) } public func Notification_PinnedQuizMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2718]!, self._r[2718]!, [_0]) + return formatWithArgumentRanges(self._s[2721]!, self._r[2721]!, [_0]) } - public var Passport_Language_cs: String { return self._s[2719]! } - public var Message_PinnedAnimationMessage: String { return self._s[2721]! } - public var Passport_Identity_ReverseSideHelp: String { return self._s[2723]! } - public var SettingsSearch_Synonyms_Data_Storage_Title: String { return self._s[2724]! } - public var Wallet_Info_TransactionTo: String { return self._s[2726]! } - public var Stats_ViewsBySourceTitle: String { return self._s[2727]! } - public var ChatList_DeleteForEveryoneConfirmationText: String { return self._s[2728]! } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndTouchId: String { return self._s[2729]! } - public var Embed_PlayingInPIP: String { return self._s[2730]! } - public var Appearance_ThemePreview_Chat_3_TextWithLink: String { return self._s[2731]! } - public var AutoNightTheme_ScheduleSection: String { return self._s[2732]! } + 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[2733]!, self._r[2733]!, [_0]) + return formatWithArgumentRanges(self._s[2736]!, self._r[2736]!, [_0]) } - public var MediaPicker_LivePhotoDescription: String { return self._s[2734]! } + public var MediaPicker_LivePhotoDescription: String { return self._s[2737]! } public func Channel_AdminLog_MessageRestrictedName(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2735]!, self._r[2735]!, [_1]) + return formatWithArgumentRanges(self._s[2738]!, self._r[2738]!, [_1]) } - public var Notification_PaymentSent: String { return self._s[2736]! } - public var PhotoEditor_CurvesGreen: String { return self._s[2737]! } - public var Notification_Exceptions_PreviewAlwaysOff: String { return self._s[2738]! } - public var AutoNightTheme_System: String { return self._s[2739]! } - public var SaveIncomingPhotosSettings_Title: String { return self._s[2740]! } - public var CreatePoll_QuizTitle: String { return self._s[2741]! } - public var NotificationSettings_ShowNotificationsAllAccounts: String { return self._s[2742]! } - public var VoiceOver_Chat_PagePreview: String { return self._s[2743]! } + 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[2746]!, self._r[2746]!, [_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[2747]!, self._r[2747]!, [_1]) + return formatWithArgumentRanges(self._s[2750]!, self._r[2750]!, [_1]) } public func ApplyLanguage_UnsufficientDataText(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2748]!, self._r[2748]!, [_1]) + return formatWithArgumentRanges(self._s[2751]!, self._r[2751]!, [_1]) } - public var NetworkUsageSettings_CallDataSection: String { return self._s[2750]! } - public var PasscodeSettings_HelpTop: String { return self._s[2751]! } - public var Conversation_WalletRequiredTitle: String { return self._s[2752]! } - public var PeerInfo_AddToContacts: String { return self._s[2753]! } - public var Group_OwnershipTransfer_ErrorAdminsTooMuch: String { return self._s[2754]! } - public var Passport_Address_TypeRentalAgreement: String { return self._s[2755]! } - public var FeaturedStickers_OtherSection: String { return self._s[2756]! } - public var EditTheme_ShortLink: String { return self._s[2757]! } - public var Theme_Colors_ColorWallpaperWarning: String { return self._s[2758]! } - public var ProxyServer_VoiceOver_Active: String { return self._s[2759]! } - public var ReportPeer_ReasonOther_Placeholder: String { return self._s[2760]! } - public var CheckoutInfo_ErrorPhoneInvalid: String { return self._s[2761]! } - public var Call_Accept: String { return self._s[2763]! } - public var GroupRemoved_RemoveInfo: String { return self._s[2764]! } - public var Month_GenMarch: String { return self._s[2766]! } - public var PhotoEditor_ShadowsTool: String { return self._s[2767]! } - public var LoginPassword_Title: String { return self._s[2768]! } - public var Call_End: String { return self._s[2769]! } - public var Watch_Conversation_GroupInfo: String { return self._s[2770]! } - public var VoiceOver_Chat_Contact: String { return self._s[2771]! } - public var EditTheme_Create_Preview_IncomingText: String { return self._s[2772]! } - public var CallSettings_Always: String { return self._s[2773]! } - public var CallFeedback_Success: String { return self._s[2774]! } - public var TwoStepAuth_SetupHint: String { return self._s[2775]! } + 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[2776]!, self._r[2776]!, [_1]) + return formatWithArgumentRanges(self._s[2779]!, self._r[2779]!, [_1]) } - public var ConversationProfile_UsersTooMuchError: String { return self._s[2777]! } - public var PeerInfo_ButtonAddMember: String { return self._s[2778]! } - public var Login_PhoneTitle: String { return self._s[2779]! } - public var Passport_FieldPhoneHelp: String { return self._s[2780]! } - public var Weekday_ShortSunday: String { return self._s[2781]! } - public var Passport_InfoFAQ_URL: String { return self._s[2782]! } - public var ContactInfo_Job: String { return self._s[2784]! } - public var UserInfo_InviteBotToGroup: String { return self._s[2785]! } - public var Appearance_ThemeCarouselNightBlue: String { return self._s[2786]! } - public var CreatePoll_QuizTip: String { return self._s[2787]! } - public var TwoFactorSetup_Email_Text: String { return self._s[2788]! } - public var TwoStepAuth_PasswordRemovePassportConfirmation: String { return self._s[2789]! } - public var Invite_ChannelsTooMuch: String { return self._s[2790]! } - public var Wallet_Send_ConfirmationConfirm: String { return self._s[2791]! } - public var Wallet_TransactionInfo_OtherFeeInfo: String { return self._s[2792]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsPreview: String { return self._s[2793]! } - public var Wallet_Receive_AmountText: String { return self._s[2794]! } - public var TwoStepAuth_Disable: String { return self._s[2795]! } - public var Passport_DeletePersonalDetailsConfirmation: String { return self._s[2796]! } - public var CallFeedback_ReasonNoise: String { return self._s[2797]! } - public var Appearance_AppIconDefault: String { return self._s[2799]! } - public var Passport_Identity_AddInternalPassport: String { return self._s[2800]! } - public var MediaPicker_AddCaption: String { return self._s[2801]! } - public var CallSettings_TabIconDescription: String { return self._s[2802]! } + 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[2803]!, self._r[2803]!, [_0]) + return formatWithArgumentRanges(self._s[2806]!, self._r[2806]!, [_0]) } - public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2804]! } + public var IntentsSettings_SuggestedChatsGroups: String { return self._s[2807]! } public func Map_SearchNoResultsDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2805]!, self._r[2805]!, [_0]) + return formatWithArgumentRanges(self._s[2808]!, self._r[2808]!, [_0]) } - public var CreatePoll_ExplanationHeader: String { return self._s[2807]! } - public var ChatList_UndoArchiveHiddenTitle: String { return self._s[2808]! } - public var Privacy_GroupsAndChannels_AlwaysAllow: String { return self._s[2809]! } - public var Passport_Identity_TypePersonalDetails: String { return self._s[2810]! } - public var DialogList_SearchSectionRecent: String { return self._s[2811]! } - public var PrivacyPolicy_DeclineMessage: String { return self._s[2812]! } - public var CreatePoll_Anonymous: String { return self._s[2813]! } - public var LogoutOptions_ClearCacheText: String { return self._s[2816]! } - public var LastSeen_WithinAWeek: String { return self._s[2817]! } - public var ChannelMembers_GroupAdminsTitle: String { return self._s[2818]! } - public var Conversation_CloudStorage_ChatStatus: String { return self._s[2820]! } - public var VoiceOver_Media_PlaybackRateNormal: String { return self._s[2821]! } + 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[2822]!, self._r[2822]!, [_0]) + return formatWithArgumentRanges(self._s[2825]!, self._r[2825]!, [_0]) } - public var Passport_Address_TypeResidentialAddress: String { return self._s[2823]! } - public var Conversation_StatusLeftGroup: String { return self._s[2824]! } - public var SocksProxySetup_ProxyDetailsTitle: String { return self._s[2825]! } - public var OwnershipTransfer_Transfer: String { return self._s[2827]! } - public var SettingsSearch_Synonyms_Calls_Title: String { return self._s[2828]! } - public var GroupPermission_AddSuccess: String { return self._s[2829]! } - public var PhotoEditor_BlurToolRadial: String { return self._s[2831]! } - public var Conversation_ContextMenuCopy: String { return self._s[2832]! } - public var AccessDenied_CallMicrophone: String { return self._s[2833]! } + 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[2834]!, self._r[2834]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2837]!, self._r[2837]!, [_1, _2, _3]) } - public var Login_InvalidFirstNameError: String { return self._s[2835]! } - public var Notifications_Badge_CountUnreadMessages_InfoOn: String { return self._s[2836]! } - public var Checkout_PaymentMethod_New: String { return self._s[2837]! } - public var ShareMenu_CopyShareLinkGame: String { return self._s[2838]! } - public var PhotoEditor_QualityTool: String { return self._s[2839]! } - public var Login_SendCodeViaSms: String { return self._s[2840]! } - public var SettingsSearch_Synonyms_Privacy_DeleteAccountIfAwayFor: String { return self._s[2841]! } - public var Chat_SlowmodeAttachmentLimitReached: String { return self._s[2842]! } - public var Wallet_Receive_CopyAddress: String { return self._s[2843]! } - public var Login_EmailNotConfiguredError: String { return self._s[2844]! } - public var SocksProxySetup_Status: String { return self._s[2845]! } - public var Conversation_ScheduleMessage_SendWhenOnline: String { return self._s[2846]! } - public var PrivacyPolicy_Accept: String { return self._s[2847]! } - public var Notifications_ExceptionsMessagePlaceholder: String { return self._s[2848]! } - public var Appearance_AppIconClassicX: String { return self._s[2849]! } + 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[2850]!, self._r[2850]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2853]!, self._r[2853]!, [_1, _2, _3]) } - public var OwnershipTransfer_SecurityRequirements: String { return self._s[2851]! } - public var InfoPlist_NSLocationAlwaysUsageDescription: String { return self._s[2853]! } - public var AutoNightTheme_Automatic: String { return self._s[2854]! } - public var Channel_Username_InvalidStartsWithNumber: String { return self._s[2855]! } - public var Privacy_ContactsSyncHelp: String { return self._s[2856]! } - public var Cache_Help: String { return self._s[2857]! } - public var Group_ErrorAccessDenied: String { return self._s[2858]! } - public var Passport_Language_fa: String { return self._s[2859]! } - public var Wallet_Intro_Text: String { return self._s[2860]! } - public var Login_ResetAccountProtected_TimerTitle: String { return self._s[2861]! } - public var VoiceOver_Chat_YourVideoMessage: String { return self._s[2862]! } - public var PrivacySettings_LastSeen: String { return self._s[2863]! } + 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[2864]!, self._r[2864]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2867]!, self._r[2867]!, [_0, _1]) } - public var Wallet_Configuration_Apply: String { return self._s[2868]! } - public var Preview_SaveGif: String { return self._s[2869]! } - public var SettingsSearch_Synonyms_Privacy_TwoStepAuth: String { return self._s[2870]! } - public var Profile_About: String { return self._s[2871]! } - public var Channel_About_Placeholder: String { return self._s[2872]! } - public var Login_InfoTitle: String { return self._s[2873]! } + 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[2874]!, self._r[2874]!, [_0]) + return formatWithArgumentRanges(self._s[2877]!, self._r[2877]!, [_0]) } - public var EditTheme_Expand_Preview_IncomingReplyText: String { return self._s[2875]! } - public var Watch_Suggestion_CantTalk: String { return self._s[2877]! } - public var ContactInfo_Title: String { return self._s[2878]! } - public var Media_ShareThisVideo: String { return self._s[2879]! } - public var Chat_GenericPsaTooltip: String { return self._s[2880]! } - public var Weekday_ShortFriday: String { return self._s[2881]! } - public var AccessDenied_Contacts: String { return self._s[2883]! } - public var Notification_CallIncomingShort: String { return self._s[2884]! } - public var Group_Setup_TypePublic: String { return self._s[2885]! } - public var Notifications_MessageNotificationsExceptions: String { return self._s[2886]! } - public var Notifications_Badge_IncludeChannels: String { return self._s[2887]! } - public var Notifications_MessageNotificationsPreview: String { return self._s[2890]! } - public var ConversationProfile_ErrorCreatingConversation: String { return self._s[2891]! } - public var Group_ErrorAddTooMuchBots: String { return self._s[2892]! } - public var Privacy_GroupsAndChannels_CustomShareHelp: String { return self._s[2893]! } - public var Permissions_CellularDataAllowInSettings_v0: String { return self._s[2894]! } + 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[2895]!, self._r[2895]!, [_0]) + return formatWithArgumentRanges(self._s[2898]!, self._r[2898]!, [_0]) } - public var DialogList_Typing: String { return self._s[2896]! } - public var CallFeedback_IncludeLogs: String { return self._s[2898]! } - public var Checkout_Phone: String { return self._s[2900]! } - public var Login_InfoFirstNamePlaceholder: String { return self._s[2903]! } - public var Privacy_Calls_Integration: String { return self._s[2904]! } - public var Notifications_PermissionsAllow: String { return self._s[2905]! } - public var TwoStepAuth_AddHintDescription: String { return self._s[2911]! } - public var Settings_ChatSettings: String { return self._s[2912]! } - public var Conversation_SendingOptionsTooltip: String { return self._s[2913]! } + 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[2915]!, self._r[2915]!, [_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[2916]!, self._r[2916]!, [_1, _2]) + return formatWithArgumentRanges(self._s[2919]!, self._r[2919]!, [_1, _2]) } - public var GroupRemoved_DeleteUser: String { return self._s[2918]! } + public var GroupRemoved_DeleteUser: String { return self._s[2921]! } public func Channel_AdminLog_PollStopped(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2919]!, self._r[2919]!, [_0]) + return formatWithArgumentRanges(self._s[2922]!, self._r[2922]!, [_0]) } - public var ChatListFolder_CategoryMuted: String { return self._s[2920]! } + public var ChatListFolder_CategoryMuted: String { return self._s[2923]! } public func PUSH_MESSAGE_PHOTO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[2921]!, self._r[2921]!, [_1]) + return formatWithArgumentRanges(self._s[2924]!, self._r[2924]!, [_1]) } - public var Login_ContinueWithLocalization: String { return self._s[2922]! } - public var Watch_Message_ForwardedFrom: String { return self._s[2923]! } - public var TwoStepAuth_EnterEmailCode: String { return self._s[2925]! } - public var Conversation_Unblock: String { return self._s[2926]! } - public var PrivacySettings_DataSettings: String { return self._s[2927]! } - public var WallpaperPreview_PatternPaternApply: String { return self._s[2928]! } - public var Group_PublicLink_Info: String { return self._s[2929]! } + 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[2930]!, self._r[2930]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[2933]!, self._r[2933]!, [_1, _2, _3]) } - public var Notifications_InAppNotificationsVibrate: String { return self._s[2931]! } + 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[2932]!, self._r[2932]!, [_0, _1]) + return formatWithArgumentRanges(self._s[2935]!, self._r[2935]!, [_0, _1]) } - public var ChatList_FolderAllChats: String { return self._s[2933]! } - public var OldChannels_ChannelsHeader: String { return self._s[2935]! } - public var Wallet_RestoreFailed_CreateWallet: String { return self._s[2936]! } - public var PrivacySettings_Passcode: String { return self._s[2938]! } - public var Call_Mute: String { return self._s[2939]! } - public var Wallet_Weekday_Yesterday: String { return self._s[2940]! } - public var Passport_Language_dz: String { return self._s[2941]! } - public var Wallet_Receive_AmountHeader: String { return self._s[2942]! } - public var Wallet_TransactionInfo_OtherFeeInfoUrl: String { return self._s[2943]! } - public var Passport_Language_tk: String { return self._s[2944]! } + 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[2945]!, self._r[2945]!, [_0]) + return formatWithArgumentRanges(self._s[2948]!, self._r[2948]!, [_0]) } - public var Settings_Search: String { return self._s[2946]! } - public var Wallet_Month_ShortFebruary: String { return self._s[2947]! } - public var InfoPlist_NSPhotoLibraryUsageDescription: String { return self._s[2948]! } - public var Wallet_Configuration_SourceJSON: String { return self._s[2949]! } - public var Conversation_ContextMenuReply: String { return self._s[2950]! } - public var WallpaperSearch_ColorBrown: String { return self._s[2951]! } - public var Chat_AttachmentMultipleForwardDisabled: String { return self._s[2952]! } - public var Tour_Title1: String { return self._s[2953]! } - public var Wallet_Alert_Cancel: String { return self._s[2954]! } - public var Stats_Total: String { return self._s[2956]! } - public var Conversation_ClearGroupHistory: String { return self._s[2957]! } - public var Wallet_TransactionInfo_RecipientHeader: String { return self._s[2958]! } - public var WallpaperPreview_Motion: String { return self._s[2959]! } + 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[2960]!, self._r[2960]!, [_0]) + return formatWithArgumentRanges(self._s[2963]!, self._r[2963]!, [_0]) } - public var Wallet_Configuration_ApplyErrorTextJSONInvalidData: String { return self._s[2961]! } - public var Call_RateCall: String { return self._s[2962]! } - public var Channel_AdminLog_BanSendStickersAndGifs: String { return self._s[2963]! } - public var Passport_PasswordCompleteSetup: String { return self._s[2964]! } - public var Conversation_InputTextSilentBroadcastPlaceholder: String { return self._s[2965]! } - public var UserInfo_LastNamePlaceholder: String { return self._s[2967]! } + 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[2969]!, self._r[2969]!, [_0]) + return formatWithArgumentRanges(self._s[2972]!, self._r[2972]!, [_0]) } - public var Compose_Create: String { return self._s[2970]! } - public var Contacts_InviteToTelegram: String { return self._s[2971]! } - public var GroupInfo_Notifications: String { return self._s[2972]! } - public var ChatList_DeleteSavedMessagesConfirmationAction: String { return self._s[2974]! } - public var Message_PinnedLiveLocationMessage: String { return self._s[2975]! } - public var Month_GenApril: String { return self._s[2976]! } - public var Appearance_AutoNightTheme: String { return self._s[2977]! } - public var ChatSettings_AutomaticAudioDownload: String { return self._s[2979]! } - public var Login_CodeSentSms: String { return self._s[2981]! } + 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[2982]!, self._r[2982]!, [_0]) + return formatWithArgumentRanges(self._s[2985]!, self._r[2985]!, [_0]) } - public var EmptyGroupInfo_Line3: String { return self._s[2983]! } - public var LogoutOptions_ContactSupportText: String { return self._s[2984]! } - public var Passport_Language_hr: String { return self._s[2985]! } - public var Common_ActionNotAllowedError: String { return self._s[2986]! } + 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[2987]!, self._r[2987]!, [_0]) + return formatWithArgumentRanges(self._s[2990]!, self._r[2990]!, [_0]) } - public var GroupInfo_InviteLink_CopyLink: String { return self._s[2988]! } - public var Wallet_Info_TransactionFrom: String { return self._s[2989]! } - public var Wallet_Send_ErrorDecryptionFailed: String { return self._s[2990]! } - public var Conversation_InputTextBroadcastPlaceholder: String { return self._s[2991]! } - public var Privacy_SecretChatsTitle: String { return self._s[2992]! } - public var Notification_SecretChatMessageScreenshotSelf: String { return self._s[2994]! } - public var GroupInfo_AddUserLeftError: String { return self._s[2995]! } - public var AutoDownloadSettings_TypePrivateChats: String { return self._s[2996]! } - public var ChatListFolder_NameSectionHeader: String { return self._s[2997]! } - public var LogoutOptions_ContactSupportTitle: String { return self._s[2998]! } - public var Appearance_ThemePreview_Chat_7_Text: String { return self._s[2999]! } - public var Channel_AddBotErrorHaveRights: String { return self._s[3000]! } - public var Preview_DeleteGif: String { return self._s[3001]! } - public var GroupInfo_Permissions_Exceptions: String { return self._s[3002]! } - public var Group_ErrorNotMutualContact: String { return self._s[3003]! } - public var Notification_MessageLifetime5s: String { return self._s[3004]! } - public var Wallet_Send_OwnAddressAlertText: String { return self._s[3005]! } - public var OldChannels_ChannelFormat: String { return self._s[3006]! } + 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[3007]!, self._r[3007]!, [_0]) + return formatWithArgumentRanges(self._s[3010]!, self._r[3010]!, [_0]) } - public var VoiceOver_Chat_Video: String { return self._s[3008]! } - public var Channel_OwnershipTransfer_ErrorPublicChannelsTooMuch: String { return self._s[3010]! } - public var ReportSpam_DeleteThisChat: String { return self._s[3011]! } - public var Passport_Address_AddBankStatement: String { return self._s[3012]! } - public var Notification_CallIncoming: String { return self._s[3013]! } - public var Wallet_Words_NotDoneTitle: String { return self._s[3014]! } - public var Compose_NewGroupTitle: String { return self._s[3015]! } - public var TwoStepAuth_RecoveryCodeHelp: String { return self._s[3017]! } - public var Passport_Address_Postcode: String { return self._s[3019]! } + 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[3020]!, self._r[3020]!, [_0]) + return formatWithArgumentRanges(self._s[3023]!, self._r[3023]!, [_0]) } - public var Checkout_NewCard_SaveInfoHelp: String { return self._s[3021]! } - public var Wallet_Month_ShortOctober: String { return self._s[3022]! } - public var VoiceOver_Chat_YourMusic: String { return self._s[3023]! } - public var WallpaperColors_Title: String { return self._s[3024]! } - public var SocksProxySetup_ShareQRCodeInfo: String { return self._s[3025]! } - public var VoiceOver_MessageContextForward: String { return self._s[3026]! } - public var GroupPermission_Duration: String { return self._s[3027]! } + 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[3028]!, self._r[3028]!, [_0]) + return formatWithArgumentRanges(self._s[3031]!, self._r[3031]!, [_0]) } - public var Bot_GroupStatusDoesNotReadHistory: String { return self._s[3029]! } - public var Username_Placeholder: String { return self._s[3030]! } - public var CallFeedback_WhatWentWrong: String { return self._s[3031]! } - public var Passport_FieldAddressUploadHelp: String { return self._s[3032]! } - public var Permissions_NotificationsAllowInSettings_v0: String { return self._s[3033]! } + 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[3035]!, self._r[3035]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3038]!, self._r[3038]!, [_1, _2]) } - public var Passport_PasswordDescription: String { return self._s[3036]! } - public var Channel_MessagePhotoUpdated: String { return self._s[3037]! } - public var MediaPicker_TapToUngroupDescription: String { return self._s[3038]! } - public var SettingsSearch_Synonyms_Notifications_BadgeCountUnreadMessages: String { return self._s[3039]! } - public var AttachmentMenu_PhotoOrVideo: String { return self._s[3040]! } - public var Conversation_ContextMenuMore: String { return self._s[3041]! } - public var Privacy_PaymentsClearInfo: String { return self._s[3042]! } - public var CallSettings_TabIcon: String { return self._s[3043]! } - public var KeyCommand_Find: String { return self._s[3044]! } - public var ClearCache_FreeSpaceDescription: String { return self._s[3045]! } - public var Appearance_ThemePreview_ChatList_7_Text: String { return self._s[3046]! } - public var EditTheme_Edit_Preview_IncomingText: String { return self._s[3047]! } + 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[3048]!, self._r[3048]!, [_0]) + return formatWithArgumentRanges(self._s[3051]!, self._r[3051]!, [_0]) } - public var Message_PinnedGame: String { return self._s[3049]! } - public var VoiceOver_Chat_ForwardedFromYou: String { return self._s[3050]! } - public var Notifications_Badge_CountUnreadMessages_InfoOff: String { return self._s[3052]! } - public var Login_CallRequestState2: String { return self._s[3054]! } - public var CheckoutInfo_ReceiverInfoNamePlaceholder: String { return self._s[3056]! } + 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[3057]!, self._r[3057]!, [_0]) + return formatWithArgumentRanges(self._s[3060]!, self._r[3060]!, [_0]) } public func Checkout_PayPrice(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3059]!, self._r[3059]!, [_0]) + return formatWithArgumentRanges(self._s[3062]!, self._r[3062]!, [_0]) } - public var AuthSessions_AddDevice: String { return self._s[3060]! } - public var WallpaperPreview_Blurred: String { return self._s[3061]! } - public var Conversation_InstantPagePreview: String { return self._s[3062]! } - public var PeerInfo_ButtonUnmute: String { return self._s[3063]! } + 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[3064]!, self._r[3064]!, [_0]) + return formatWithArgumentRanges(self._s[3067]!, self._r[3067]!, [_0]) } - public var ChatList_PeerTypeChannel: String { return self._s[3065]! } - public var SecretTimer_VideoDescription: String { return self._s[3068]! } - public var WallpaperSearch_ColorRed: String { return self._s[3069]! } - public var GroupPermission_NoPinMessages: String { return self._s[3070]! } - public var Passport_Language_es: String { return self._s[3071]! } - public var Permissions_ContactsAllow_v0: String { return self._s[3073]! } - public var Conversation_EditingMessageMediaEditCurrentVideo: String { return self._s[3074]! } + 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[3075]!, self._r[3075]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3078]!, self._r[3078]!, [_1, _2]) } - public var Privacy_Forwards_CustomHelp: String { return self._s[3076]! } - public var WebPreview_GettingLinkInfo: String { return self._s[3078]! } - public var Watch_UserInfo_Unmute: String { return self._s[3079]! } - public var GroupInfo_ChannelListNamePlaceholder: String { return self._s[3080]! } - public var AccessDenied_CameraRestricted: String { return self._s[3082]! } + 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[3083]!, self._r[3083]!, ["\(_0)"]) + return formatWithArgumentRanges(self._s[3086]!, self._r[3086]!, ["\(_0)"]) } - public var ChatList_ReadAll: String { return self._s[3085]! } - public var Settings_CopyUsername: String { return self._s[3086]! } - public var Contacts_SearchLabel: String { return self._s[3087]! } - public var Map_OpenInYandexNavigator: String { return self._s[3089]! } - public var PasscodeSettings_EncryptData: String { return self._s[3090]! } - public var Settings_Wallet: String { return self._s[3091]! } - public var Group_ErrorSupergroupConversionNotPossible: String { return self._s[3092]! } - public var ChatList_PeerTypeBot: String { return self._s[3093]! } - public var WallpaperSearch_ColorPrefix: String { return self._s[3094]! } - public var Notifications_GroupNotificationsPreview: String { return self._s[3095]! } - public var DialogList_AdNoticeAlert: String { return self._s[3096]! } - public var Wallet_Month_GenMay: String { return self._s[3098]! } - public var CheckoutInfo_ShippingInfoAddress1: String { return self._s[3099]! } - public var CheckoutInfo_ShippingInfoAddress2: String { return self._s[3100]! } - public var Localization_LanguageCustom: String { return self._s[3101]! } - public var Passport_Identity_TypeDriversLicenseUploadScan: String { return self._s[3102]! } - public var CallFeedback_Title: String { return self._s[3103]! } - public var VoiceOver_Chat_RecordPreviewVoiceMessage: String { return self._s[3106]! } - public var Passport_Address_OneOfTypePassportRegistration: String { return self._s[3107]! } - public var Wallet_Intro_CreateErrorTitle: String { return self._s[3108]! } - public var Conversation_InfoGroup: String { return self._s[3109]! } - public var Compose_NewMessage: String { return self._s[3110]! } - public var FastTwoStepSetup_HintPlaceholder: String { return self._s[3111]! } - public var ChatSettings_AutoDownloadVideoMessages: String { return self._s[3112]! } - public var Wallet_SecureStorageReset_BiometryFaceId: String { return self._s[3113]! } - public var Channel_DiscussionGroup_UnlinkChannel: String { return self._s[3114]! } + 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[3115]!, self._r[3115]!, [_0]) + return formatWithArgumentRanges(self._s[3118]!, self._r[3118]!, [_0]) } - public var Channel_AdminLog_CanDeleteMessages: String { return self._s[3116]! } - public var Login_CancelSignUpConfirmation: String { return self._s[3117]! } - public var ChangePhoneNumberCode_Help: String { return self._s[3118]! } - public var PrivacySettings_DeleteAccountHelp: String { return self._s[3119]! } - public var ChatList_Context_RemoveFromFolder: String { return self._s[3120]! } - public var Channel_BlackList_Title: String { return self._s[3121]! } - public var UserInfo_PhoneCall: String { return self._s[3122]! } - public var Passport_Address_OneOfTypeBankStatement: String { return self._s[3124]! } - public var Wallet_Month_ShortJanuary: String { return self._s[3125]! } - public var State_connecting: String { return self._s[3126]! } - public var Appearance_ThemePreview_ChatList_6_Text: String { return self._s[3127]! } - public var Wallet_Month_GenMarch: String { return self._s[3128]! } - public var EditTheme_Expand_BottomInfo: String { return self._s[3129]! } - public var AuthSessions_AddedDeviceTerminate: String { return self._s[3130]! } + 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[3131]!, self._r[3131]!, [_0]) + return formatWithArgumentRanges(self._s[3134]!, self._r[3134]!, [_0]) } public func DialogList_SingleRecordingAudioSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3132]!, self._r[3132]!, [_0]) + return formatWithArgumentRanges(self._s[3135]!, self._r[3135]!, [_0]) } - public var Notifications_GroupNotifications: String { return self._s[3133]! } - public var Conversation_SendMessageErrorTooMuchScheduled: String { return self._s[3134]! } - public var Passport_Identity_EditPassport: String { return self._s[3135]! } - public var EnterPasscode_RepeatNewPasscode: String { return self._s[3137]! } - public var Localization_EnglishLanguageName: String { return self._s[3138]! } - public var Share_AuthDescription: String { return self._s[3139]! } - public var SettingsSearch_Synonyms_Notifications_ChannelNotificationsAlert: String { return self._s[3140]! } - public var Passport_Identity_Surname: String { return self._s[3141]! } - public var Compose_TokenListPlaceholder: String { return self._s[3142]! } - public var Wallet_AccessDenied_Camera: String { return self._s[3143]! } - public var Passport_Identity_OneOfTypePassport: String { return self._s[3144]! } - public var Settings_AboutEmpty: String { return self._s[3145]! } - public var Conversation_Unmute: String { return self._s[3146]! } - public var CreateGroup_ChannelsTooMuch: String { return self._s[3148]! } - public var Wallet_Sending_Text: String { return self._s[3149]! } + 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[3150]!, self._r[3150]!, [_1]) + return formatWithArgumentRanges(self._s[3153]!, self._r[3153]!, [_1]) } - public var Login_CodeSentCall: String { return self._s[3151]! } - public var ContactInfo_PhoneLabelHomeFax: String { return self._s[3153]! } - public var ChatSettings_Appearance: String { return self._s[3154]! } - public var ClearCache_StorageUsage: String { return self._s[3155]! } - public var ChatListFolder_NameContacts: String { return self._s[3156]! } - public var Appearance_PickAccentColor: String { return self._s[3157]! } + 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[3158]!, self._r[3158]!, [_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[3159]!, self._r[3159]!, [_1]) + return formatWithArgumentRanges(self._s[3162]!, self._r[3162]!, [_1]) } - public var Notification_CallMissed: String { return self._s[3160]! } - public var SettingsSearch_Synonyms_Appearance_ChatBackground_Custom: String { return self._s[3161]! } - public var Channel_AdminLogFilter_EventsInfo: String { return self._s[3162]! } - public var Wallet_Month_GenOctober: String { return self._s[3164]! } - public var ChatAdmins_AdminLabel: String { return self._s[3165]! } - public var KeyCommand_JumpToNextChat: String { return self._s[3166]! } - public var Conversation_StopPollConfirmationTitle: String { return self._s[3168]! } - public var ChangePhoneNumberCode_CodePlaceholder: String { return self._s[3169]! } - public var Month_GenJune: String { return self._s[3170]! } - public var IntentsSettings_MainAccountInfo: String { return self._s[3171]! } - public var Watch_Location_Current: String { return self._s[3172]! } - public var Wallet_Receive_CopyInvoiceUrl: String { return self._s[3173]! } - public var Conversation_TitleMute: String { return self._s[3174]! } - public var Map_PlacesInThisArea: String { return self._s[3175]! } + 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[3176]!, self._r[3176]!, [_1]) + return formatWithArgumentRanges(self._s[3179]!, self._r[3179]!, [_1]) } - public var GroupInfo_DeleteAndExit: String { return self._s[3177]! } + public var GroupInfo_DeleteAndExit: String { return self._s[3180]! } public func Conversation_Moderate_DeleteAllMessages(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3178]!, self._r[3178]!, [_0]) + return formatWithArgumentRanges(self._s[3181]!, self._r[3181]!, [_0]) } - public var Call_ReportPlaceholder: String { return self._s[3179]! } - public var Chat_SlowmodeSendError: String { return self._s[3180]! } - public var MaskStickerSettings_Info: String { return self._s[3181]! } - public var EditTheme_Expand_TopInfo: String { return self._s[3182]! } + 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[3183]!, self._r[3183]!, [_0]) + return formatWithArgumentRanges(self._s[3186]!, self._r[3186]!, [_0]) } - public var Checkout_NewCard_PostcodeTitle: String { return self._s[3184]! } - public var Passport_Address_RegionPlaceholder: String { return self._s[3186]! } - public var Contacts_ShareTelegram: String { return self._s[3187]! } - public var EnterPasscode_EnterNewPasscodeNew: String { return self._s[3188]! } - public var Map_AddressOnMap: String { return self._s[3189]! } - public var Channel_ErrorAccessDenied: String { return self._s[3190]! } - public var UserInfo_ScamBotWarning: String { return self._s[3192]! } - public var Stickers_GroupChooseStickerPack: String { return self._s[3193]! } - public var Call_ConnectionErrorTitle: String { return self._s[3194]! } - public var UserInfo_NotificationsEnable: String { return self._s[3195]! } - public var ArchivedChats_IntroText1: String { return self._s[3196]! } - public var Tour_Text4: String { return self._s[3199]! } - public var WallpaperSearch_Recent: String { return self._s[3200]! } - public var GroupInfo_ScamGroupWarning: String { return self._s[3201]! } - public var PeopleNearby_MakeVisibleTitle: String { return self._s[3202]! } - public var Profile_MessageLifetime2s: String { return self._s[3204]! } - public var Appearance_ThemePreview_ChatList_5_Text: String { return self._s[3205]! } - public var Notification_MessageLifetime2s: String { return self._s[3206]! } + 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[3207]!, self._r[3207]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3210]!, self._r[3210]!, [_1, _2, _3]) } - public var Cache_ClearCache: String { return self._s[3208]! } - public var AutoNightTheme_UpdateLocation: String { return self._s[3209]! } - public var Permissions_NotificationsUnreachableText_v0: String { return self._s[3210]! } + 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[3214]!, self._r[3214]!, [_0]) + return formatWithArgumentRanges(self._s[3217]!, self._r[3217]!, [_0]) } public func Conversation_ShareMyPhoneNumber_StatusSuccess(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3216]!, self._r[3216]!, [_0]) + return formatWithArgumentRanges(self._s[3219]!, self._r[3219]!, [_0]) } - public var LocalGroup_Text: String { return self._s[3217]! } - public var PeerInfo_PaneMembers: String { return self._s[3218]! } - public var Channel_AdminLog_EmptyFilterTitle: String { return self._s[3219]! } - public var SocksProxySetup_TypeSocks: String { return self._s[3220]! } - public var ChatList_UnarchiveAction: String { return self._s[3221]! } - public var AutoNightTheme_Title: String { return self._s[3222]! } - public var InstantPage_FeedbackButton: String { return self._s[3223]! } - public var Passport_FieldAddress: String { return self._s[3224]! } + 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[3225]!, self._r[3225]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3228]!, self._r[3228]!, [_1, _2]) } - public var Month_ShortMarch: String { return self._s[3226]! } + 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[3227]!, self._r[3227]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3230]!, self._r[3230]!, [_1, _2]) } - public var SocksProxySetup_UsernamePlaceholder: String { return self._s[3228]! } - public var Conversation_ShareInlineBotLocationConfirmation: String { return self._s[3229]! } - public var Passport_FloodError: String { return self._s[3230]! } - public var SecretGif_Title: String { return self._s[3231]! } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOn: String { return self._s[3232]! } - public var ChatList_Context_UnhideArchive: String { return self._s[3233]! } - public var Passport_Language_th: String { return self._s[3235]! } - public var Passport_Address_Address: String { return self._s[3236]! } - public var Login_InvalidLastNameError: String { return self._s[3237]! } - public var Notifications_InAppNotificationsPreview: String { return self._s[3238]! } - public var Notifications_PermissionsUnreachableTitle: String { return self._s[3239]! } - public var ChatList_Context_Archive: String { return self._s[3240]! } - public var SettingsSearch_FAQ: String { return self._s[3241]! } - public var ShareMenu_Send: String { return self._s[3242]! } - public var ChatState_Connecting: String { return self._s[3243]! } - public var WallpaperSearch_ColorYellow: String { return self._s[3245]! } - public var Month_GenNovember: String { return self._s[3247]! } - public var SettingsSearch_Synonyms_Appearance_LargeEmoji: String { return self._s[3249]! } + 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[3250]!, self._r[3250]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3253]!, self._r[3253]!, [_1, _2]) } - public var ChatListFolder_CategoryChannels: String { return self._s[3251]! } - public var Conversation_SwipeToReplyHintText: String { return self._s[3252]! } - public var Checkout_Email: String { return self._s[3253]! } - public var NotificationsSound_Tritone: String { return self._s[3254]! } - public var Paint_Marker: String { return self._s[3255]! } - public var StickerPacksSettings_ManagingHelp: String { return self._s[3257]! } - public var Wallet_ContextMenuCopy: String { return self._s[3259]! } + 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[3261]!, self._r[3261]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3264]!, self._r[3264]!, [_1, _2, _3]) } - public var Appearance_TextSize_Automatic: String { return self._s[3262]! } - public var Stickers_Installed: String { return self._s[3264]! } + 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[3265]!, self._r[3265]!, [_1]) + return formatWithArgumentRanges(self._s[3268]!, self._r[3268]!, [_1]) } public func StickerPackActionInfo_AddedText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3266]!, self._r[3266]!, [_0]) + return formatWithArgumentRanges(self._s[3269]!, self._r[3269]!, [_0]) } - public var ChangePhoneNumberNumber_Help: String { return self._s[3267]! } + public var ChangePhoneNumberNumber_Help: String { return self._s[3270]! } public func Checkout_LiabilityAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3268]!, self._r[3268]!, [_1, _1, _1, _2]) + return formatWithArgumentRanges(self._s[3271]!, self._r[3271]!, [_1, _1, _1, _2]) } - public var ChatList_UndoArchiveTitle: String { return self._s[3269]! } - public var Notification_Exceptions_Add: String { return self._s[3270]! } - public var DialogList_You: String { return self._s[3271]! } - public var ChatList_PsaLabel_covid: String { return self._s[3273]! } - public var MediaPicker_Send: String { return self._s[3275]! } - public var SettingsSearch_Synonyms_Stickers_Title: String { return self._s[3276]! } - public var Appearance_ThemePreview_ChatList_4_Text: String { return self._s[3277]! } - public var Call_AudioRouteSpeaker: String { return self._s[3278]! } - public var Watch_UserInfo_Title: String { return self._s[3279]! } - public var VoiceOver_Chat_PollFinalResults: String { return self._s[3280]! } - public var Appearance_AccentColor: String { return self._s[3282]! } + 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[3283]!, self._r[3283]!, [_0]) + return formatWithArgumentRanges(self._s[3286]!, self._r[3286]!, [_0]) } - public var Permissions_ContactsAllowInSettings_v0: String { return self._s[3284]! } + 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[3285]!, self._r[3285]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3288]!, self._r[3288]!, [_1, _2]) } - public var Conversation_ClousStorageInfo_Description2: String { return self._s[3286]! } - public var WebSearch_RecentClearConfirmation: String { return self._s[3287]! } - public var Notification_CallOutgoing: String { return self._s[3288]! } - public var PrivacySettings_PasscodeAndFaceId: String { return self._s[3289]! } - public var Channel_DiscussionGroup_MakeHistoryPublic: String { return self._s[3290]! } - public var Call_RecordingDisabledMessage: String { return self._s[3291]! } - public var Message_Game: String { return self._s[3292]! } - public var Conversation_PressVolumeButtonForSound: String { return self._s[3293]! } - public var PrivacyLastSeenSettings_CustomHelp: String { return self._s[3294]! } - public var Channel_DiscussionGroup_PrivateGroup: String { return self._s[3295]! } - public var Channel_EditAdmin_PermissionAddAdmins: String { return self._s[3296]! } - public var Date_DialogDateFormat: String { return self._s[3298]! } - public var WallpaperColors_SetCustomColor: String { return self._s[3299]! } - public var Notifications_InAppNotifications: String { return self._s[3300]! } + 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[3301]!, self._r[3301]!, [_0]) - } - public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3302]!, self._r[3302]!, [_1, _2]) - } - public var NewContact_Title: String { return self._s[3303]! } - public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3304]!, self._r[3304]!, [_0]) } - public var Conversation_ViewContactDetails: String { return self._s[3305]! } + public func Settings_ApplyProxyAlert(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3305]!, self._r[3305]!, [_1, _2]) + } + public var NewContact_Title: String { return self._s[3306]! } + public func AutoDownloadSettings_UpToForAll(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3307]!, self._r[3307]!, [_0]) + } + public var Conversation_ViewContactDetails: String { return self._s[3308]! } public func PUSH_CHANNEL_MESSAGE_CONTACT(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3307]!, self._r[3307]!, [_1]) + return formatWithArgumentRanges(self._s[3310]!, self._r[3310]!, [_1]) } - public var Checkout_NewCard_CardholderNameTitle: String { return self._s[3308]! } - public var Passport_Identity_ExpiryDateNone: String { return self._s[3309]! } - public var PrivacySettings_Title: String { return self._s[3310]! } - public var Conversation_SilentBroadcastTooltipOff: String { return self._s[3313]! } - public var GroupRemoved_UsersSectionTitle: String { return self._s[3314]! } - public var VoiceOver_Chat_ContactEmail: String { return self._s[3315]! } - public var Contacts_PhoneNumber: String { return self._s[3316]! } - public var PeerInfo_ButtonMute: String { return self._s[3317]! } - public var TwoFactorSetup_Password_PlaceholderConfirmPassword: String { return self._s[3319]! } - public var Map_ShowPlaces: String { return self._s[3320]! } - public var ChatAdmins_Title: String { return self._s[3321]! } - public var InstantPage_Reference: String { return self._s[3323]! } - public var Wallet_Info_Updating: String { return self._s[3324]! } - public var ReportGroupLocation_Text: String { return self._s[3325]! } + 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[3326]!, self._r[3326]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3329]!, self._r[3329]!, [_1, _2]) } - public var Camera_FlashOff: String { return self._s[3327]! } - public var Watch_UserInfo_Block: String { return self._s[3328]! } - public var ChatSettings_Stickers: String { return self._s[3329]! } - public var ChatSettings_DownloadInBackground: String { return self._s[3330]! } - public var Appearance_ThemeCarouselTintedNight: String { return self._s[3331]! } + 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[3332]!, self._r[3332]!, [_0]) + return formatWithArgumentRanges(self._s[3335]!, self._r[3335]!, [_0]) } - public var Settings_ViewPhoto: String { return self._s[3333]! } - public var Login_CheckOtherSessionMessages: String { return self._s[3334]! } - public var AutoDownloadSettings_Cellular: String { return self._s[3335]! } - public var Wallet_Created_ExportErrorTitle: String { return self._s[3336]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsExceptions: String { return self._s[3337]! } - public var VoiceOver_MessageContextShare: String { return self._s[3338]! } + 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[3340]!, self._r[3340]!, [_0]) - } - public var Privacy_DeleteDrafts: String { return self._s[3341]! } - public var Wallpaper_SetCustomBackgroundInfo: String { return self._s[3342]! } - public func LastSeen_AtDate(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3343]!, self._r[3343]!, [_0]) } - public var DialogList_SavedMessagesHelp: String { return self._s[3344]! } - public var Wallet_SecureStorageNotAvailable_Title: String { return self._s[3345]! } - public var DialogList_SavedMessages: String { return self._s[3346]! } - public var GroupInfo_UpgradeButton: String { return self._s[3347]! } - public var Appearance_ThemePreview_ChatList_3_Text: String { return self._s[3349]! } - public var DialogList_Pin: String { return self._s[3350]! } + 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[3346]!, self._r[3346]!, [_0]) + } + 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[3351]!, self._r[3351]!, [_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[3352]!, self._r[3352]!, [_0]) + return formatWithArgumentRanges(self._s[3355]!, self._r[3355]!, [_0]) } - public var Notification_Exceptions_AlwaysOn: String { return self._s[3353]! } - public var UserInfo_NotificationsDisable: String { return self._s[3354]! } - public var Conversation_ContextMenuCancelEditing: String { return self._s[3355]! } - public var Paint_Outlined: String { return self._s[3356]! } - public var Activity_PlayingGame: String { return self._s[3357]! } - public var SearchImages_NoImagesFound: String { return self._s[3358]! } - public var SocksProxySetup_ProxyType: String { return self._s[3359]! } - public var AppleWatch_ReplyPresetsHelp: String { return self._s[3361]! } - public var Conversation_ContextMenuCancelSending: String { return self._s[3362]! } - public var Settings_AppLanguage: String { return self._s[3363]! } - public var TwoStepAuth_ResetAccountHelp: String { return self._s[3364]! } - public var Common_ChoosePhoto: String { return self._s[3365]! } - public var AuthSessions_AddDevice_InvalidQRCode: String { return self._s[3366]! } - public var CallFeedback_ReasonEcho: String { return self._s[3367]! } + 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[3368]!, self._r[3368]!, [_1]) + return formatWithArgumentRanges(self._s[3371]!, self._r[3371]!, [_1]) } - public var Privacy_Calls_AlwaysAllow: String { return self._s[3369]! } - public var PollResults_Collapse: String { return self._s[3370]! } - public var Activity_UploadingVideo: String { return self._s[3371]! } - public var Conversation_WalletRequiredNotNow: String { return self._s[3372]! } - public var ChannelInfo_DeleteChannelConfirmation: String { return self._s[3373]! } - public var NetworkUsageSettings_Wifi: String { return self._s[3374]! } - public var VoiceOver_Editing_ClearText: String { return self._s[3375]! } - public var PUSH_SENDER_YOU: String { return self._s[3376]! } - public var Channel_BanUser_PermissionReadMessages: String { return self._s[3377]! } - public var Checkout_PayWithTouchId: String { return self._s[3378]! } - public var Wallpaper_ResetWallpapersConfirmation: String { return self._s[3379]! } + 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[3381]!, self._r[3381]!, [_1]) - } - public var Notifications_ExceptionsNone: String { return self._s[3382]! } - public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3383]!, self._r[3383]!, [_0]) - } - public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3384]!, self._r[3384]!, [_1]) } - public var AuthSessions_IncompleteAttempts: String { return self._s[3386]! } - public var Passport_Address_Region: String { return self._s[3389]! } - public var ChatList_DeleteChat: String { return self._s[3390]! } - public var LogoutOptions_ClearCacheTitle: String { return self._s[3391]! } - public var PhotoEditor_TiltShift: String { return self._s[3392]! } - public var Settings_FAQ_URL: String { return self._s[3393]! } - public var TwoFactorSetup_EmailVerification_ChangeAction: String { return self._s[3394]! } - public var Passport_Language_sl: String { return self._s[3396]! } - public var Settings_PrivacySettings: String { return self._s[3398]! } - public var SharedMedia_TitleLink: String { return self._s[3399]! } - public var Passport_Identity_TypePassportUploadScan: String { return self._s[3400]! } - public var Settings_SetProfilePhoto: String { return self._s[3401]! } - public var Channel_About_Help: String { return self._s[3402]! } - public var Contacts_PermissionsEnable: String { return self._s[3403]! } - public var Wallet_Sending_Title: String { return self._s[3404]! } - public var PeerInfo_PaneMedia: String { return self._s[3405]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsAlert: String { return self._s[3406]! } - public var AttachmentMenu_SendAsFiles: String { return self._s[3407]! } - public var CallFeedback_ReasonInterruption: String { return self._s[3409]! } - public var Passport_Address_AddTemporaryRegistration: String { return self._s[3410]! } - public var AutoDownloadSettings_AutodownloadVideos: String { return self._s[3411]! } - public var ChatSettings_AutoDownloadSettings_Delimeter: String { return self._s[3412]! } - public var OldChannels_Title: String { return self._s[3413]! } - public var PrivacySettings_DeleteAccountTitle: String { return self._s[3414]! } - public var AccessDenied_VideoMessageCamera: String { return self._s[3416]! } - public var Map_OpenInYandexMaps: String { return self._s[3418]! } - public var CreateGroup_ErrorLocatedGroupsTooMuch: String { return self._s[3419]! } - public var VoiceOver_MessageContextReply: String { return self._s[3420]! } - public var ChatListFolder_DiscardConfirmation: String { return self._s[3422]! } - public var PhotoEditor_SaturationTool: String { return self._s[3423]! } + public var Notifications_ExceptionsNone: String { return self._s[3385]! } + public func Message_ForwardedMessageShort(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3386]!, self._r[3386]!, [_0]) + } + public func PUSH_PINNED_GEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3387]!, self._r[3387]!, [_1]) + } + 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[3424]!, self._r[3424]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3427]!, self._r[3427]!, [_1, _2]) } - public var PrivacyPhoneNumberSettings_CustomHelp: String { return self._s[3425]! } - public var Notification_Exceptions_NewException_NotificationHeader: String { return self._s[3426]! } - public var Group_OwnershipTransfer_ErrorLocatedGroupsTooMuch: String { return self._s[3427]! } + 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[3428]!, self._r[3428]!, [_1, "\(_2)"]) + return formatWithArgumentRanges(self._s[3431]!, self._r[3431]!, [_1, "\(_2)"]) } - public var Appearance_ThemePreview_ChatList_2_Text: String { return self._s[3429]! } - public var Channel_Username_InvalidTooShort: String { return self._s[3431]! } - public var SettingsSearch_Synonyms_Wallet: String { return self._s[3432]! } + 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[3433]!, self._r[3433]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3436]!, self._r[3436]!, [_1, _2]) } - public var Forward_ErrorPublicPollDisabledInChannels: String { return self._s[3434]! } + 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[3435]!, self._r[3435]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3438]!, self._r[3438]!, [_1, _2, _3]) } - public var WallpaperPreview_PatternTitle: String { return self._s[3436]! } - public var GroupInfo_PublicLinkAdd: String { return self._s[3437]! } - public var Passport_PassportInformation: String { return self._s[3440]! } - public var Theme_Unsupported: String { return self._s[3441]! } - public var WatchRemote_AlertTitle: String { return self._s[3442]! } - public var Privacy_GroupsAndChannels_NeverAllow: String { return self._s[3443]! } - public var ConvertToSupergroup_HelpText: String { return self._s[3445]! } + 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[3446]!, self._r[3446]!, [_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[3447]!, self._r[3447]!, [_1]) + return formatWithArgumentRanges(self._s[3450]!, self._r[3450]!, [_1]) } - public var Privacy_GroupsAndChannels_CustomHelp: String { return self._s[3448]! } - public var Wallet_Navigation_Done: String { return self._s[3450]! } - public var TwoStepAuth_RecoveryCodeInvalid: String { return self._s[3451]! } - public var AccessDenied_CameraDisabled: String { return self._s[3452]! } + 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[3453]!, self._r[3453]!, [_0]) + return formatWithArgumentRanges(self._s[3456]!, self._r[3456]!, [_0]) } - public var ClearCache_Forever: String { return self._s[3454]! } - public var AuthSessions_AddDeviceIntro_Title: String { return self._s[3455]! } - public var CreatePoll_Quiz: String { return self._s[3456]! } - public var PhotoEditor_ContrastTool: String { return self._s[3459]! } + 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[3460]!, self._r[3460]!, [_1]) + return formatWithArgumentRanges(self._s[3463]!, self._r[3463]!, [_1]) } - public var DialogList_Draft: String { return self._s[3461]! } - public var Wallet_Configuration_BlockchainIdInfo: String { return self._s[3462]! } + 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[3463]!, self._r[3463]!, [_0]) + return formatWithArgumentRanges(self._s[3466]!, self._r[3466]!, [_0]) } - public var ChatList_PsaAlert_covid: String { return self._s[3464]! } - public var Privacy_TopPeersDelete: String { return self._s[3466]! } - public var LoginPassword_PasswordPlaceholder: String { return self._s[3467]! } - public var Passport_Identity_TypeIdentityCardUploadScan: String { return self._s[3468]! } - public var WebSearch_RecentSectionClear: String { return self._s[3469]! } - public var EditTheme_ErrorInvalidCharacters: String { return self._s[3470]! } - public var Watch_ChatList_NoConversationsTitle: String { return self._s[3472]! } - public var PeerInfo_ButtonMore: String { return self._s[3474]! } - public var Common_Done: String { return self._s[3475]! } - public var Shortcut_SwitchAccount: String { return self._s[3476]! } - public var AuthSessions_EmptyText: String { return self._s[3477]! } - public var Wallet_Configuration_BlockchainNameChangedTitle: String { return self._s[3478]! } - public var Conversation_ShareBotContactConfirmation: String { return self._s[3479]! } - public var Tour_Title5: String { return self._s[3481]! } - public var Wallet_Settings_Title: String { return self._s[3482]! } + 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[3483]!, self._r[3483]!, [_0]) + return formatWithArgumentRanges(self._s[3486]!, self._r[3486]!, [_0]) } - public var ApplyLanguage_UnsufficientDataTitle: String { return self._s[3484]! } - public var Conversation_LinkDialogSave: String { return self._s[3485]! } - public var GroupInfo_ActionRestrict: String { return self._s[3486]! } - public var Checkout_Title: String { return self._s[3487]! } - public var Channel_DiscussionGroup_HeaderLabel: String { return self._s[3489]! } - public var Channel_AdminLog_CanChangeInfo: String { return self._s[3491]! } - public var Notification_RenamedGroup: String { return self._s[3492]! } - public var PeopleNearby_Groups: String { return self._s[3493]! } - public var Checkout_PayWithFaceId: String { return self._s[3494]! } - public var Channel_BanList_BlockedTitle: String { return self._s[3495]! } - public var SettingsSearch_Synonyms_Notifications_InAppNotificationsSound: String { return self._s[3497]! } - public var Checkout_WebConfirmation_Title: String { return self._s[3498]! } - public var Notifications_MessageNotificationsAlert: String { return self._s[3499]! } + 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[3500]!, self._r[3500]!, [_0]) + return formatWithArgumentRanges(self._s[3503]!, self._r[3503]!, [_0]) } - public var Profile_AddToExisting: String { return self._s[3502]! } + public var Profile_AddToExisting: String { return self._s[3505]! } public func Profile_CreateEncryptedChatOutdatedError(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3503]!, self._r[3503]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3506]!, self._r[3506]!, [_0, _1]) } - public var Cache_Files: String { return self._s[3505]! } - public var Permissions_PrivacyPolicy: String { return self._s[3506]! } - public var SocksProxySetup_ConnectAndSave: String { return self._s[3507]! } - public var UserInfo_NotificationsDefaultDisabled: String { return self._s[3508]! } - public var AutoDownloadSettings_TypeContacts: String { return self._s[3510]! } - public var Appearance_ThemePreview_ChatList_1_Text: String { return self._s[3512]! } - public var Calls_NoCallsPlaceholder: String { return self._s[3513]! } + 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[3514]!, self._r[3514]!, [_0]) + return formatWithArgumentRanges(self._s[3517]!, self._r[3517]!, [_0]) } - public var Channel_Username_RevokeExistingUsernamesInfo: String { return self._s[3515]! } - public var VoiceOver_AttachMedia: String { return self._s[3518]! } - public var Notifications_ExceptionsGroupPlaceholder: String { return self._s[3519]! } + 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[3520]!, self._r[3520]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3523]!, self._r[3523]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsSound: String { return self._s[3521]! } - public var Conversation_SetReminder_Title: String { return self._s[3522]! } - public var Passport_FieldAddressHelp: String { return self._s[3523]! } - public var Privacy_GroupsAndChannels_InviteToChannelMultipleError: String { return self._s[3524]! } - public var PUSH_REMINDER_TITLE: String { return self._s[3525]! } + 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[3526]!, self._r[3526]!, [_0]) + return formatWithArgumentRanges(self._s[3529]!, self._r[3529]!, [_0]) } - public var Channel_AdminLog_EmptyTitle: String { return self._s[3527]! } - public var Privacy_Calls_NeverAllow_Title: String { return self._s[3528]! } - public var Login_UnknownError: String { return self._s[3529]! } - public var Group_UpgradeNoticeText2: String { return self._s[3532]! } - public var Watch_Compose_AddContact: String { return self._s[3533]! } - public var ClearCache_StorageServiceFiles: String { return self._s[3534]! } - public var Web_Error: String { return self._s[3535]! } - public var Paint_Neon: String { return self._s[3536]! } - public var Gif_Search: String { return self._s[3537]! } - public var Profile_MessageLifetime1h: String { return self._s[3538]! } - public var CheckoutInfo_ReceiverInfoEmailPlaceholder: String { return self._s[3539]! } - public var Channel_Username_CheckingUsername: String { return self._s[3540]! } - public var CallFeedback_ReasonSilentRemote: String { return self._s[3541]! } - public var AutoDownloadSettings_TypeChannels: String { return self._s[3542]! } - public var Channel_AboutItem: String { return self._s[3543]! } - public var Privacy_GroupsAndChannels_AlwaysAllow_Placeholder: String { return self._s[3546]! } - public var VoiceOver_Chat_VoiceMessage: String { return self._s[3547]! } - public var GroupInfo_SharedMedia: String { return self._s[3548]! } + 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[3549]!, self._r[3549]!, [_1]) + return formatWithArgumentRanges(self._s[3552]!, self._r[3552]!, [_1]) } - public var Call_PhoneCallInProgressMessage: String { return self._s[3550]! } + public var Call_PhoneCallInProgressMessage: String { return self._s[3553]! } public func PUSH_CHANNEL_ALBUM(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3551]!, self._r[3551]!, [_1]) + return formatWithArgumentRanges(self._s[3554]!, self._r[3554]!, [_1]) } - public var ChatList_UndoArchiveRevealedText: String { return self._s[3552]! } - public var GroupInfo_InviteLink_RevokeAlert_Text: String { return self._s[3553]! } - public var Conversation_SearchByName_Placeholder: String { return self._s[3554]! } - public var CreatePoll_AddOption: String { return self._s[3555]! } - public var GroupInfo_Permissions_SearchPlaceholder: String { return self._s[3556]! } - public var Group_UpgradeNoticeHeader: String { return self._s[3557]! } - public var Channel_Management_AddModerator: String { return self._s[3558]! } - public var AutoDownloadSettings_MaxFileSize: String { return self._s[3559]! } - public var StickerPacksSettings_ShowStickersButton: String { return self._s[3560]! } - public var Wallet_Info_RefreshErrorNetworkText: String { return self._s[3561]! } - public var Theme_Colors_Background: String { return self._s[3562]! } - public var NotificationsSound_Hello: String { return self._s[3565]! } - public var SocksProxySetup_SavedProxies: String { return self._s[3567]! } - public var Channel_Stickers_Placeholder: String { return self._s[3569]! } + 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[3570]!, self._r[3570]!, [_0]) + return formatWithArgumentRanges(self._s[3573]!, self._r[3573]!, [_0]) } - public var PrivacyPolicy_DeclineDeclineAndDelete: String { return self._s[3571]! } - public var Channel_Management_AddModeratorHelp: String { return self._s[3572]! } - public var ContactInfo_BirthdayLabel: String { return self._s[3573]! } - public var ChangePhoneNumberCode_RequestingACall: String { return self._s[3574]! } - public var AutoDownloadSettings_Channels: String { return self._s[3575]! } - public var Passport_Language_mn: String { return self._s[3576]! } - public var Settings_ChatFolders: String { return self._s[3577]! } + 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[3578]!, self._r[3578]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3581]!, self._r[3581]!, [_1, _2]) } - public var Notifications_ResetAllNotificationsHelp: String { return self._s[3581]! } - public var GroupInfo_Permissions_SlowmodeValue_Off: String { return self._s[3582]! } - public var Passport_Language_ja: String { return self._s[3584]! } - public var Settings_About_Title: String { return self._s[3585]! } - public var Settings_NotificationsAndSounds: String { return self._s[3586]! } - public var ChannelInfo_DeleteGroup: String { return self._s[3587]! } - public var Settings_BlockedUsers: String { return self._s[3588]! } + 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[3589]!, self._r[3589]!, [_0]) + return formatWithArgumentRanges(self._s[3592]!, self._r[3592]!, [_0]) } - public var EditTheme_Create_Preview_OutgoingText: String { return self._s[3590]! } - public var Wallet_Weekday_Today: String { return self._s[3591]! } - public var ChatListFolderSettings_AddRecommended: String { return self._s[3592]! } - public var AutoDownloadSettings_PreloadVideo: String { return self._s[3593]! } - public var Widget_ApplicationLocked: String { return self._s[3594]! } - public var Passport_Address_AddResidentialAddress: String { return self._s[3595]! } - public var Channel_Username_Title: String { return self._s[3596]! } + 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[3597]!, self._r[3597]!, [_0]) + return formatWithArgumentRanges(self._s[3600]!, self._r[3600]!, [_0]) } - public var AttachmentMenu_File: String { return self._s[3599]! } - public var AppleWatch_Title: String { return self._s[3600]! } - public var Activity_RecordingVideoMessage: String { return self._s[3601]! } + 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[3602]!, self._r[3602]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3605]!, self._r[3605]!, [_1, _2]) } - public var Theme_Colors_Messages: String { return self._s[3603]! } - public var Weekday_Saturday: String { return self._s[3604]! } - public var WallpaperPreview_SwipeColorsTopText: String { return self._s[3605]! } - public var Conversation_Timer_Send: String { return self._s[3606]! } - public var Profile_CreateEncryptedChatError: String { return self._s[3607]! } - public var Common_Next: String { return self._s[3609]! } - public var Channel_Stickers_YourStickers: String { return self._s[3611]! } - public var Message_Theme: String { return self._s[3612]! } - public var Call_AudioRouteHeadphones: String { return self._s[3613]! } - public var TwoStepAuth_EnterPasswordForgot: String { return self._s[3615]! } - public var Watch_Contacts_NoResults: String { return self._s[3617]! } - public var PhotoEditor_TintTool: String { return self._s[3620]! } - public var LoginPassword_ResetAccount: String { return self._s[3622]! } - public var Settings_SavedMessages: String { return self._s[3623]! } - public var SettingsSearch_Synonyms_Appearance_Animations: String { return self._s[3624]! } - public var Bot_GenericSupportStatus: String { return self._s[3625]! } - public var StickerPack_Add: String { return self._s[3626]! } - public var Checkout_TotalAmount: String { return self._s[3627]! } - public var Your_cards_number_is_invalid: String { return self._s[3628]! } - public var SettingsSearch_Synonyms_Appearance_AutoNightTheme: String { return self._s[3629]! } - public var VoiceOver_Chat_VideoMessage: String { return self._s[3630]! } + 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[3631]!, self._r[3631]!, [_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[3632]!, self._r[3632]!, [_1, _2]) - } - public var ChatSettings_ConnectionType_UseSocks5: String { return self._s[3633]! } - public func PUSH_CHAT_PHOTO_EDITED(_ _1: String, _ _2: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3635]!, self._r[3635]!, [_1, _2]) } + 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[3638]!, self._r[3638]!, [_1, _2]) + } public func Conversation_RestrictedTextTimed(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3636]!, self._r[3636]!, [_0]) + return formatWithArgumentRanges(self._s[3639]!, self._r[3639]!, [_0]) } - public var GroupInfo_InviteLink_ShareLink: String { return self._s[3637]! } - public var StickerPack_Share: String { return self._s[3638]! } - public var Passport_DeleteAddress: String { return self._s[3639]! } - public var Settings_Passport: String { return self._s[3640]! } - public var SharedMedia_EmptyFilesText: String { return self._s[3641]! } - public var Conversation_DeleteMessagesForMe: String { return self._s[3642]! } - public var PasscodeSettings_AutoLock_IfAwayFor_1hour: String { return self._s[3643]! } - public var Contacts_PermissionsText: String { return self._s[3644]! } - public var Group_Setup_HistoryVisible: String { return self._s[3645]! } - public var Wallet_Month_ShortDecember: String { return self._s[3647]! } - public var Channel_EditAdmin_PermissionEnabledByDefault: String { return self._s[3648]! } - public var Passport_Address_AddRentalAgreement: String { return self._s[3649]! } - public var SocksProxySetup_Title: String { return self._s[3650]! } - public var Notification_Mute1h: String { return self._s[3651]! } + 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[3652]!, self._r[3652]!, [_0]) + return formatWithArgumentRanges(self._s[3655]!, self._r[3655]!, [_0]) } - public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3653]! } + public var NotificationSettings_ShowNotificationsAllAccountsInfoOff: String { return self._s[3656]! } public func PUSH_PINNED_GEOLIVE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3654]!, self._r[3654]!, [_1]) + return formatWithArgumentRanges(self._s[3657]!, self._r[3657]!, [_1]) } - public var FastTwoStepSetup_PasswordSection: String { return self._s[3655]! } - public var NetworkUsageSettings_ResetStatsConfirmation: String { return self._s[3658]! } - public var InfoPlist_NSFaceIDUsageDescription: String { return self._s[3660]! } - public var DialogList_NoMessagesText: String { return self._s[3661]! } - public var Privacy_ContactsResetConfirmation: String { return self._s[3662]! } - public var Privacy_Calls_P2PHelp: String { return self._s[3663]! } - public var Channel_DiscussionGroup_SearchPlaceholder: String { return self._s[3665]! } - public var Your_cards_expiration_year_is_invalid: String { return self._s[3666]! } - public var Common_TakePhotoOrVideo: String { return self._s[3667]! } - public var Wallet_Words_Text: String { return self._s[3668]! } - public var Call_StatusBusy: String { return self._s[3669]! } - public var Conversation_PinnedMessage: String { return self._s[3670]! } - public var AutoDownloadSettings_VoiceMessagesTitle: String { return self._s[3671]! } - public var ChatList_EmptyChatListNewMessage: String { return self._s[3672]! } - public var Wallet_Configuration_BlockchainNameChangedProceed: String { return self._s[3673]! } - public var TwoStepAuth_SetupPasswordConfirmFailed: String { return self._s[3674]! } - public var Undo_ChatCleared: String { return self._s[3675]! } - public var CreatePoll_Explanation: String { return self._s[3676]! } - public var AppleWatch_ReplyPresets: String { return self._s[3677]! } - public var Passport_DiscardMessageDescription: String { return self._s[3679]! } - public var Login_NetworkError: String { return self._s[3680]! } + 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[3681]!, self._r[3681]!, [_0]) + return formatWithArgumentRanges(self._s[3684]!, self._r[3684]!, [_0]) } public func Channel_AdminLog_MessageRemovedChannelUsername(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3682]!, self._r[3682]!, [_0]) + return formatWithArgumentRanges(self._s[3685]!, self._r[3685]!, [_0]) } - public var SocksProxySetup_PasswordPlaceholder: String { return self._s[3683]! } - public var Wallet_WordCheck_ViewWords: String { return self._s[3685]! } - public var Login_ResetAccountProtected_LimitExceeded: String { return self._s[3686]! } + 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[3688]!, self._r[3688]!, [_0]) + return formatWithArgumentRanges(self._s[3691]!, self._r[3691]!, [_0]) } - public var Call_ConnectionErrorMessage: String { return self._s[3689]! } - public var VoiceOver_Chat_Music: String { return self._s[3690]! } - public var ChatListFolder_CategoryContacts: String { return self._s[3691]! } - public var SettingsSearch_Synonyms_Notifications_MessageNotificationsSound: String { return self._s[3692]! } - public var Compose_GroupTokenListPlaceholder: String { return self._s[3694]! } - public var ConversationMedia_Title: String { return self._s[3695]! } - public var EncryptionKey_Title: String { return self._s[3697]! } - public var TwoStepAuth_EnterPasswordTitle: String { return self._s[3698]! } - public var Notification_Exceptions_AddException: String { return self._s[3699]! } - public var PrivacySettings_BlockedPeersEmpty: String { return self._s[3700]! } - public var Profile_MessageLifetime1m: String { return self._s[3701]! } + 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[3702]!, self._r[3702]!, [_1]) + return formatWithArgumentRanges(self._s[3705]!, self._r[3705]!, [_1]) } - public var Month_GenMay: String { return self._s[3703]! } + public var Month_GenMay: String { return self._s[3706]! } public func LiveLocationUpdated_TodayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3704]!, self._r[3704]!, [_0]) + return formatWithArgumentRanges(self._s[3707]!, self._r[3707]!, [_0]) } - public var PeopleNearby_Users: String { return self._s[3705]! } - public var Wallet_Send_AddressInfo: String { return self._s[3706]! } - public var ChannelMembers_WhoCanAddMembersAllHelp: String { return self._s[3707]! } - public var AutoDownloadSettings_ResetSettings: String { return self._s[3708]! } + 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[3710]!, self._r[3710]!, [_0]) + return formatWithArgumentRanges(self._s[3713]!, self._r[3713]!, [_0]) } - public var Stats_LoadingTitle: String { return self._s[3711]! } - public var Conversation_EmptyPlaceholder: String { return self._s[3712]! } - public var Passport_Address_AddPassportRegistration: String { return self._s[3713]! } - public var Notifications_ChannelNotificationsAlert: String { return self._s[3714]! } - public var ChatSettings_AutoDownloadUsingCellular: String { return self._s[3715]! } - public var Camera_TapAndHoldForVideo: String { return self._s[3716]! } - public var Channel_JoinChannel: String { return self._s[3718]! } - public var Appearance_Animations: String { return self._s[3721]! } + 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[3722]!, self._r[3722]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3725]!, self._r[3725]!, [_1, _2]) } - public var Stickers_GroupStickers: String { return self._s[3724]! } - public var Appearance_ShareTheme: String { return self._s[3725]! } - public var TwoFactorSetup_Hint_Placeholder: String { return self._s[3726]! } - public var ConvertToSupergroup_HelpTitle: String { return self._s[3728]! } - public var StickerPackActionInfo_RemovedTitle: String { return self._s[3729]! } - public var Passport_Address_Street: String { return self._s[3730]! } - public var Conversation_AddContact: String { return self._s[3731]! } - public var Login_PhonePlaceholder: String { return self._s[3732]! } - public var Channel_Members_InviteLink: String { return self._s[3734]! } - public var Bot_Stop: String { return self._s[3735]! } - public var SettingsSearch_Synonyms_Proxy_UseForCalls: String { return self._s[3737]! } - public var Notification_PassportValueAddress: String { return self._s[3738]! } - public var Month_ShortJuly: String { return self._s[3739]! } - public var Passport_Address_TypeTemporaryRegistrationUploadScan: String { return self._s[3740]! } - public var Channel_AdminLog_BanSendMedia: String { return self._s[3741]! } - public var Passport_Identity_ReverseSide: String { return self._s[3742]! } - public var Watch_Stickers_Recents: String { return self._s[3745]! } - public var PrivacyLastSeenSettings_EmpryUsersPlaceholder: String { return self._s[3747]! } - public var Map_SendThisLocation: String { return self._s[3748]! } + 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[3749]!, self._r[3749]!, [_0]) + return formatWithArgumentRanges(self._s[3752]!, self._r[3752]!, [_0]) } public func InviteText_SingleContact(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3750]!, self._r[3750]!, [_0]) - } - public var ConvertToSupergroup_Note: String { return self._s[3751]! } - public var Wallet_Intro_NotNow: String { return self._s[3752]! } - public func FileSize_MB(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3753]!, self._r[3753]!, [_0]) } - public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3754]! } + 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[3756]!, self._r[3756]!, [_0]) + } + public var NetworkUsageSettings_GeneralDataSection: String { return self._s[3757]! } public func Compatibility_SecretMediaVersionTooLow(_ _0: String, _ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3755]!, self._r[3755]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3758]!, self._r[3758]!, [_0, _1]) } - public var Login_CallRequestState3: String { return self._s[3757]! } - public var Wallpaper_SearchShort: String { return self._s[3758]! } - public var SettingsSearch_Synonyms_Appearance_ColorTheme: String { return self._s[3760]! } - public var PasscodeSettings_UnlockWithFaceId: String { return self._s[3761]! } - public var Channel_BotDoesntSupportGroups: String { return self._s[3762]! } + 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[3763]!, self._r[3763]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3766]!, self._r[3766]!, [_1, _2]) } - public var Channel_AdminLogFilter_Title: String { return self._s[3764]! } - public var Appearance_ThemePreview_Chat_4_Text: String { return self._s[3766]! } - public var Notifications_GroupNotificationsExceptions: String { return self._s[3769]! } + 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[3770]!, self._r[3770]!, [_0]) - } - public var Passport_CorrectErrors: String { return self._s[3771]! } - public var VoiceOver_Chat_YourAnonymousPoll: String { return self._s[3772]! } - public func Channel_MessageTitleUpdated(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3773]!, self._r[3773]!, [_0]) } - public var Map_SendMyCurrentLocation: String { return self._s[3774]! } - public var Channel_DiscussionGroup: String { return self._s[3775]! } - public var TwoFactorSetup_Email_SkipConfirmationSkip: String { return self._s[3776]! } + 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[3776]!, self._r[3776]!, [_0]) + } + 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[3777]!, self._r[3777]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3780]!, self._r[3780]!, [_1, _2]) } - public var SharedMedia_SearchNoResults: String { return self._s[3778]! } - public var Permissions_NotificationsText_v0: String { return self._s[3779]! } - public var Channel_EditAdmin_PermissionDeleteMessagesOfOthers: String { return self._s[3780]! } - public var Appearance_AppIcon: String { return self._s[3781]! } - public var Appearance_ThemePreview_ChatList_3_AuthorName: String { return self._s[3782]! } - public var LoginPassword_FloodError: String { return self._s[3783]! } - public var Wallet_Send_OwnAddressAlertProceed: String { return self._s[3785]! } - public var Group_Setup_HistoryHiddenHelp: String { return self._s[3786]! } + 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[3787]!, self._r[3787]!, [_0]) + return formatWithArgumentRanges(self._s[3790]!, self._r[3790]!, [_0]) } - public var Passport_Language_bn: String { return self._s[3788]! } + public var Passport_Language_bn: String { return self._s[3791]! } public func DialogList_SingleUploadingPhotoSuffix(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3789]!, self._r[3789]!, [_0]) - } - public var ChatList_Context_Pin: String { return self._s[3790]! } - public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3791]!, self._r[3791]!, [_0]) - } - public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3792]!, self._r[3792]!, [_0]) } - public var Wallet_Navigation_Close: String { return self._s[3793]! } - public var GroupInfo_InvitationLinkGroupFull: String { return self._s[3797]! } - public var Group_EditAdmin_PermissionChangeInfo: String { return self._s[3799]! } - public var Wallet_Month_GenDecember: String { return self._s[3800]! } - public var Contacts_PermissionsAllow: String { return self._s[3801]! } - public var ReportPeer_ReasonCopyright: String { return self._s[3802]! } - public var Channel_EditAdmin_PermissinAddAdminOn: String { return self._s[3803]! } - public var WallpaperPreview_Pattern: String { return self._s[3804]! } - public var Paint_Duplicate: String { return self._s[3805]! } - public var Passport_Address_Country: String { return self._s[3806]! } - public var Notification_RenamedChannel: String { return self._s[3808]! } - public var DialogList_UnknownPinLimitError: String { return self._s[3809]! } - public var CheckoutInfo_ErrorPostcodeInvalid: String { return self._s[3810]! } - public var ChatList_Context_Unmute: String { return self._s[3811]! } - public var Group_MessagePhotoUpdated: String { return self._s[3812]! } - public var Channel_BanUser_PermissionSendMedia: String { return self._s[3813]! } - public var Conversation_ContextMenuBan: String { return self._s[3814]! } - public var TwoStepAuth_EmailSent: String { return self._s[3815]! } - public var MessagePoll_NoVotes: String { return self._s[3816]! } - public var Wallet_Send_ErrorNotEnoughFundsTitle: String { return self._s[3817]! } - public var Passport_Language_is: String { return self._s[3819]! } - public var PeopleNearby_UsersEmpty: String { return self._s[3821]! } - public var Tour_Text5: String { return self._s[3822]! } + public var ChatList_Context_Pin: String { return self._s[3793]! } + public func Notification_PinnedAudioMessage(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3794]!, self._r[3794]!, [_0]) + } + public func Channel_AdminLog_MessageChangedGroupStickerPack(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[3795]!, self._r[3795]!, [_0]) + } + 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[3825]!, self._r[3825]!, [_1, _2]) + return formatWithArgumentRanges(self._s[3828]!, self._r[3828]!, [_1, _2]) } - public var Undo_SecretChatDeleted: String { return self._s[3826]! } - public var SocksProxySetup_ShareQRCode: String { return self._s[3827]! } + 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[3828]!, self._r[3828]!, [_0]) + return formatWithArgumentRanges(self._s[3831]!, self._r[3831]!, [_0]) } - public var Forward_ErrorDisabledForChat: String { return self._s[3829]! } - public var LogoutOptions_ChangePhoneNumberText: String { return self._s[3830]! } - public var Paint_Edit: String { return self._s[3832]! } - public var ScheduledMessages_ReminderNotification: String { return self._s[3834]! } - public var Undo_DeletedGroup: String { return self._s[3836]! } - public var LoginPassword_ForgotPassword: String { return self._s[3837]! } - public var Wallet_WordImport_IncorrectTitle: String { return self._s[3838]! } - public var GroupInfo_GroupNamePlaceholder: String { return self._s[3839]! } + 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[3840]!, self._r[3840]!, [_0, _1]) + return formatWithArgumentRanges(self._s[3843]!, self._r[3843]!, [_0, _1]) } - public var AppWallet_TransactionInfo_FeeInfoURL: String { return self._s[3841]! } - public var Conversation_InputTextCaptionPlaceholder: String { return self._s[3842]! } - public var AutoDownloadSettings_VideoMessagesTitle: String { return self._s[3843]! } - public var Passport_Language_uz: String { return self._s[3844]! } - public var Conversation_PinMessageAlertGroup: String { return self._s[3845]! } - public var SettingsSearch_Synonyms_Privacy_GroupsAndChannels: String { return self._s[3846]! } - public var Map_StopLiveLocation: String { return self._s[3848]! } - public var VoiceOver_MessageContextSend: String { return self._s[3850]! } - public var PasscodeSettings_Help: String { return self._s[3851]! } - public var NotificationsSound_Input: String { return self._s[3852]! } - public var Share_Title: String { return self._s[3855]! } - public var LogoutOptions_Title: String { return self._s[3856]! } - public var Wallet_Send_AddressText: String { return self._s[3857]! } - public var Login_TermsOfServiceAgree: String { return self._s[3858]! } - public var Compose_NewEncryptedChatTitle: String { return self._s[3859]! } - public var Channel_AdminLog_TitleSelectedEvents: String { return self._s[3860]! } - public var Channel_EditAdmin_PermissionEditMessages: String { return self._s[3861]! } - public var EnterPasscode_EnterTitle: String { return self._s[3862]! } + 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[3863]!, self._r[3863]!, [_0]) - } - public var Settings_CopyPhoneNumber: String { return self._s[3864]! } - public var Conversation_AddToContacts: String { return self._s[3865]! } - public func VoiceOver_Chat_ReplyFrom(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[3866]!, self._r[3866]!, [_0]) } - public var NotificationsSound_Keys: String { return self._s[3867]! } + 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[3869]!, self._r[3869]!, [_0]) + } + public var NotificationsSound_Keys: String { return self._s[3870]! } public func Call_ParticipantVersionOutdatedError(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3868]!, self._r[3868]!, [_0]) + return formatWithArgumentRanges(self._s[3871]!, self._r[3871]!, [_0]) } - public var Notification_MessageLifetime1w: String { return self._s[3869]! } - public var Message_Video: String { return self._s[3870]! } - public var AutoDownloadSettings_CellularTitle: String { return self._s[3871]! } + 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[3872]!, self._r[3872]!, [_1]) + return formatWithArgumentRanges(self._s[3875]!, self._r[3875]!, [_1]) } - public var Wallet_Receive_AmountInfo: String { return self._s[3875]! } - public var Stats_Overview: String { return self._s[3876]! } + 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[3877]!, self._r[3877]!, [_0]) + return formatWithArgumentRanges(self._s[3880]!, self._r[3880]!, [_0]) } public func PrivacySettings_LastSeenContactsPlus(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3878]!, self._r[3878]!, [_0]) + return formatWithArgumentRanges(self._s[3881]!, self._r[3881]!, [_0]) } - public var ChatListFolder_ExcludeChatsTitle: String { return self._s[3879]! } - public var Passport_Language_mk: String { return self._s[3880]! } - public var ChatListFolder_CategoryNonContacts: String { return self._s[3881]! } + 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[3882]!, self._r[3882]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3885]!, self._r[3885]!, [_1, _2, _3]) } - public var CreatePoll_CancelConfirmation: String { return self._s[3883]! } - public var MessagePoll_LabelAnonymousQuiz: String { return self._s[3884]! } - public var Conversation_SilentBroadcastTooltipOn: String { return self._s[3886]! } - public var PrivacyPolicy_Decline: String { return self._s[3887]! } - public var Passport_Identity_DoesNotExpire: String { return self._s[3888]! } - public var Channel_AdminLogFilter_EventsRestrictions: String { return self._s[3889]! } - public var AuthSessions_AddDeviceIntro_Action: String { return self._s[3890]! } - public var Permissions_SiriAllow_v0: String { return self._s[3892]! } - public var Wallet_Month_ShortAugust: String { return self._s[3893]! } - public var Appearance_ThemeCarouselNight: String { return self._s[3894]! } + 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[3895]!, self._r[3895]!, [_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[3896]!, self._r[3896]!, [_0]) + return formatWithArgumentRanges(self._s[3899]!, self._r[3899]!, [_0]) } - public var Paint_Regular: String { return self._s[3897]! } - public var ChatSettings_AutoDownloadReset: String { return self._s[3898]! } - public var SocksProxySetup_ShareLink: String { return self._s[3899]! } - public var Wallet_Qr_Title: String { return self._s[3900]! } - public var BlockedUsers_SelectUserTitle: String { return self._s[3901]! } - public var VoiceOver_Chat_RecordModeVoiceMessage: String { return self._s[3903]! } - public var Wallet_Settings_Configuration: String { return self._s[3904]! } - public var GroupInfo_InviteByLink: String { return self._s[3905]! } - public var MessageTimer_Custom: String { return self._s[3906]! } - public var UserInfo_NotificationsDefaultEnabled: String { return self._s[3907]! } - public var Conversation_StopQuizConfirmationTitle: String { return self._s[3908]! } - public var Passport_Address_TypeTemporaryRegistration: String { return self._s[3910]! } - public var Conversation_SendMessage_SetReminder: String { return self._s[3911]! } - public var VoiceOver_Chat_Selected: String { return self._s[3912]! } - public var Paint_Pen: String { return self._s[3913]! } - public var ChatSettings_AutoDownloadUsingWiFi: String { return self._s[3914]! } - public var Channel_Username_InvalidTaken: String { return self._s[3915]! } - public var Conversation_ClousStorageInfo_Description3: String { return self._s[3916]! } - public var Wallet_WordCheck_TryAgain: String { return self._s[3917]! } - public var Wallet_Info_TransactionPendingHeader: String { return self._s[3918]! } - public var Settings_ChatBackground: String { return self._s[3919]! } - public var Channel_Subscribers_Title: String { return self._s[3920]! } - public var Wallet_Receive_InvoiceUrlHeader: String { return self._s[3921]! } - public var ApplyLanguage_ChangeLanguageTitle: String { return self._s[3922]! } - public var Watch_ConnectionDescription: String { return self._s[3923]! } - public var OldChannels_NoticeText: String { return self._s[3926]! } - public var Wallet_Configuration_ApplyErrorTitle: String { return self._s[3927]! } - public var IntentsSettings_SuggestBy: String { return self._s[3929]! } - public var Theme_ThemeChangedText: String { return self._s[3930]! } - public var ChatList_ArchivedChatsTitle: String { return self._s[3931]! } - public var Wallpaper_ResetWallpapers: String { return self._s[3932]! } - public var Wallet_Send_TransactionInProgress: String { return self._s[3933]! } - public var Conversation_SendDice: String { return self._s[3934]! } - public var EditProfile_Title: String { return self._s[3935]! } - public var NotificationsSound_Bamboo: String { return self._s[3937]! } - public var Channel_AdminLog_MessagePreviousMessage: String { return self._s[3939]! } - public var Login_SmsRequestState2: String { return self._s[3940]! } - public var Passport_Language_ar: String { return self._s[3941]! } + 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[3942]!, self._r[3942]!, [_0]) + return formatWithArgumentRanges(self._s[3945]!, self._r[3945]!, [_0]) } - public var SettingsSearch_Synonyms_EditProfile_Title: String { return self._s[3943]! } - public var Wallet_Created_Text: String { return self._s[3944]! } - public var Conversation_MessageDialogEdit: String { return self._s[3946]! } - public var Wallet_Created_Proceed: String { return self._s[3947]! } - public var Wallet_Words_Done: String { return self._s[3948]! } - public var VoiceOver_Media_PlaybackPause: String { return self._s[3949]! } - public var ChatListFolder_NameChannels: String { return self._s[3950]! } + 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[3951]!, self._r[3951]!, [_1]) + return formatWithArgumentRanges(self._s[3954]!, self._r[3954]!, [_1]) } - public var Common_Close: String { return self._s[3952]! } - public var GroupInfo_PublicLink: String { return self._s[3953]! } - public var Channel_OwnershipTransfer_ErrorPrivacyRestricted: String { return self._s[3954]! } - public var SettingsSearch_Synonyms_Notifications_GroupNotificationsPreview: String { return self._s[3955]! } + 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[3959]!, self._r[3959]!, [_0]) + return formatWithArgumentRanges(self._s[3962]!, self._r[3962]!, [_0]) } - public var UserInfo_About_Placeholder: String { return self._s[3960]! } + public var UserInfo_About_Placeholder: String { return self._s[3963]! } public func Conversation_FileHowToText(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3961]!, self._r[3961]!, [_0]) + return formatWithArgumentRanges(self._s[3964]!, self._r[3964]!, [_0]) } - public var GroupInfo_Permissions_SectionTitle: String { return self._s[3962]! } - public var Channel_Info_Banned: String { return self._s[3964]! } + 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[3965]!, self._r[3965]!, [_0]) + return formatWithArgumentRanges(self._s[3968]!, self._r[3968]!, [_0]) } - public var Appearance_Other: String { return self._s[3966]! } - public var Passport_Language_my: String { return self._s[3967]! } - public var Group_Setup_BasicHistoryHiddenHelp: String { return self._s[3968]! } + 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[3969]!, self._r[3969]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[3972]!, self._r[3972]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Privacy_PasscodeAndFaceId: String { return self._s[3970]! } - public var IntentsSettings_SuggestedAndSpotlightChatsInfo: String { return self._s[3971]! } - public var Preview_CopyAddress: String { return self._s[3972]! } + 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[3973]!, self._r[3973]!, [_0]) + return formatWithArgumentRanges(self._s[3976]!, self._r[3976]!, [_0]) } - public var KeyCommand_JumpToPreviousChat: String { return self._s[3974]! } - public var UserInfo_BotSettings: String { return self._s[3975]! } - public var LiveLocation_MenuStopAll: String { return self._s[3977]! } - public var Passport_PasswordCreate: String { return self._s[3978]! } - public var StickerSettings_MaskContextInfo: String { return self._s[3979]! } - public var Message_PinnedLocationMessage: String { return self._s[3980]! } - public var Map_Satellite: String { return self._s[3981]! } - public var Watch_Message_Unsupported: String { return self._s[3982]! } - public var Username_TooManyPublicUsernamesError: String { return self._s[3983]! } - public var TwoStepAuth_EnterPasswordInvalid: String { return self._s[3984]! } + 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[3985]!, self._r[3985]!, [_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[3986]!, self._r[3986]!, [_0]) + return formatWithArgumentRanges(self._s[3989]!, self._r[3989]!, [_0]) } - public var Wallet_WordImport_Continue: String { return self._s[3987]! } + public var Wallet_WordImport_Continue: String { return self._s[3990]! } public func TwoFactorSetup_EmailVerification_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[3988]!, self._r[3988]!, [_0]) + return formatWithArgumentRanges(self._s[3991]!, self._r[3991]!, [_0]) } - public var Notifications_ChannelNotificationsHelp: String { return self._s[3989]! } - public var Privacy_Calls_P2PContacts: String { return self._s[3990]! } - public var NotificationsSound_None: String { return self._s[3991]! } - public var Wallet_TransactionInfo_StorageFeeHeader: String { return self._s[3992]! } - public var Channel_DiscussionGroup_UnlinkGroup: String { return self._s[3994]! } - public var AccessDenied_VoiceMicrophone: String { return self._s[3995]! } + 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[3996]!, self._r[3996]!, [_1]) + return formatWithArgumentRanges(self._s[3999]!, self._r[3999]!, [_1]) } - public var Cache_Indexing: String { return self._s[3997]! } - public var DialogList_RecentTitlePeople: String { return self._s[3999]! } - public var DialogList_EncryptionRejected: String { return self._s[4000]! } - public var GroupInfo_Administrators: String { return self._s[4001]! } - public var Passport_ScanPassportHelp: String { return self._s[4002]! } - public var Application_Name: String { return self._s[4003]! } - public var Channel_AdminLogFilter_ChannelEventsInfo: String { return self._s[4004]! } - public var Conversation_Timer_Title: String { return self._s[4005]! } - public var ChatList_PeerTypeGroup: String { return self._s[4006]! } - public var PeopleNearby_MakeVisible: String { return self._s[4008]! } - public var Appearance_ThemeCarouselDay: String { return self._s[4009]! } - public var Stats_GrowthTitle: String { return self._s[4010]! } - public var Passport_Identity_TranslationHelp: String { return self._s[4011]! } + 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[4012]!, self._r[4012]!, [_0]) + return formatWithArgumentRanges(self._s[4015]!, self._r[4015]!, [_0]) } public func Notification_JoinedGroupByLink(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4013]!, self._r[4013]!, [_0]) + return formatWithArgumentRanges(self._s[4016]!, self._r[4016]!, [_0]) } public func DialogList_EncryptedChatStartedOutgoing(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4014]!, self._r[4014]!, [_0]) + return formatWithArgumentRanges(self._s[4017]!, self._r[4017]!, [_0]) } - public var Channel_EditAdmin_PermissionDeleteMessages: String { return self._s[4015]! } - public var Privacy_ChatsTitle: String { return self._s[4016]! } - public var DialogList_ClearHistoryConfirmation: String { return self._s[4017]! } - public var SettingsSearch_Synonyms_Data_Storage_ClearCache: String { return self._s[4018]! } - public var Watch_Suggestion_HoldOn: String { return self._s[4019]! } - public var Group_EditAdmin_TransferOwnership: String { return self._s[4020]! } - public var WebBrowser_Title: String { return self._s[4021]! } - public var Group_LinkedChannel: String { return self._s[4022]! } - public var VoiceOver_Chat_SeenByRecipient: String { return self._s[4023]! } - public var SocksProxySetup_RequiredCredentials: String { return self._s[4024]! } - public var Passport_Address_TypeRentalAgreementUploadScan: String { return self._s[4025]! } - public var Appearance_TextSize_UseSystem: String { return self._s[4026]! } - public var TwoStepAuth_EmailSkipAlert: String { return self._s[4027]! } - public var ScheduledMessages_RemindersTitle: String { return self._s[4029]! } - public var Channel_Setup_TypePublic: String { return self._s[4031]! } + 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[4032]!, self._r[4032]!, [_0]) + return formatWithArgumentRanges(self._s[4035]!, self._r[4035]!, [_0]) } - public var Channel_TypeSetup_Title: String { return self._s[4034]! } - public var MessagePoll_ViewResults: String { return self._s[4035]! } - public var Map_OpenInMaps: String { return self._s[4037]! } + 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[4038]!, self._r[4038]!, [_1]) + return formatWithArgumentRanges(self._s[4041]!, self._r[4041]!, [_1]) } - public var NotificationsSound_Tremolo: String { return self._s[4040]! } + 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[4041]!, self._r[4041]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4044]!, self._r[4044]!, [_1, _2, _3]) } - public var ConversationProfile_UnknownAddMemberError: String { return self._s[4042]! } - public var Channel_OwnershipTransfer_PasswordPlaceholder: String { return self._s[4043]! } - public var Passport_PasswordHelp: String { return self._s[4045]! } - public var Login_CodeExpiredError: String { return self._s[4046]! } - public var Channel_EditAdmin_PermissionChangeInfo: String { return self._s[4047]! } - public var Conversation_TitleUnmute: String { return self._s[4048]! } - public var Passport_Identity_ScansHelp: String { return self._s[4049]! } - public var Passport_Language_lo: String { return self._s[4050]! } - public var Camera_FlashAuto: String { return self._s[4051]! } - public var Conversation_OpenBotLinkOpen: String { return self._s[4052]! } - public var Common_Cancel: String { return self._s[4053]! } - public var DialogList_SavedMessagesTooltip: String { return self._s[4054]! } - public var TwoStepAuth_SetupPasswordTitle: String { return self._s[4055]! } - public var Appearance_TintAllColors: String { return self._s[4056]! } + 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[4057]!, self._r[4057]!, [_1]) + return formatWithArgumentRanges(self._s[4060]!, self._r[4060]!, [_1]) } - public var Conversation_ReportSpamConfirmation: String { return self._s[4058]! } - public var ChatSettings_Title: String { return self._s[4060]! } - public var Passport_PasswordReset: String { return self._s[4061]! } - public var SocksProxySetup_TypeNone: String { return self._s[4062]! } - public var EditTheme_Title: String { return self._s[4065]! } - public var PhoneNumberHelp_Help: String { return self._s[4066]! } - public var Checkout_EnterPassword: String { return self._s[4067]! } - public var Activity_UploadingDocument: String { return self._s[4069]! } - public var Share_AuthTitle: String { return self._s[4070]! } - public var State_Connecting: String { return self._s[4071]! } - public var Profile_MessageLifetime1w: String { return self._s[4072]! } - public var Conversation_ContextMenuReport: String { return self._s[4073]! } - public var CheckoutInfo_ReceiverInfoPhone: String { return self._s[4074]! } - public var AutoNightTheme_ScheduledTo: String { return self._s[4075]! } + 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[4076]!, self._r[4076]!, [_0]) + return formatWithArgumentRanges(self._s[4079]!, self._r[4079]!, [_0]) } - public var AuthSessions_Terminate: String { return self._s[4077]! } - public var Wallet_WordImport_CanNotRemember: String { return self._s[4078]! } - public var PeerInfo_PaneAudio: String { return self._s[4079]! } + 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[4080]!, self._r[4080]!, [_0]) + return formatWithArgumentRanges(self._s[4083]!, self._r[4083]!, [_0]) } - public var Checkout_NewCard_CardholderNamePlaceholder: String { return self._s[4082]! } - public var KeyCommand_JumpToPreviousUnreadChat: String { return self._s[4083]! } - public var PhotoEditor_Set: String { return self._s[4084]! } - public var EmptyGroupInfo_Title: String { return self._s[4085]! } - public var Login_PadPhoneHelp: String { return self._s[4087]! } - public var AutoDownloadSettings_TypeGroupChats: String { return self._s[4089]! } - public var PrivacyPolicy_DeclineLastWarning: String { return self._s[4091]! } - public var NotificationsSound_Complete: String { return self._s[4092]! } - public var SettingsSearch_Synonyms_Privacy_Data_Title: String { return self._s[4093]! } - public var Group_Info_AdminLog: String { return self._s[4094]! } - public var GroupPermission_NotAvailableInPublicGroups: String { return self._s[4095]! } + 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[4096]!, self._r[4096]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4099]!, self._r[4099]!, [_1, _2, _3]) } - public var Channel_AdminLog_InfoPanelAlertText: String { return self._s[4097]! } - public var Group_Location_CreateInThisPlace: String { return self._s[4099]! } - public var Conversation_Admin: String { return self._s[4100]! } - public var Conversation_GifTooltip: String { return self._s[4101]! } - public var Passport_NotLoggedInMessage: String { return self._s[4102]! } + 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[4104]!, self._r[4104]!, [_0]) + return formatWithArgumentRanges(self._s[4107]!, self._r[4107]!, [_0]) } - public var Profile_MessageLifetimeForever: String { return self._s[4105]! } - public var SharedMedia_EmptyTitle: String { return self._s[4107]! } - public var Channel_Edit_PrivatePublicLinkAlert: String { return self._s[4109]! } - public var Username_Help: String { return self._s[4110]! } - public var DialogList_LanguageTooltip: String { return self._s[4112]! } - public var Map_LoadError: String { return self._s[4113]! } - public var Login_PhoneNumberAlreadyAuthorized: String { return self._s[4114]! } - public var Channel_AdminLog_AddMembers: String { return self._s[4115]! } - public var ArchivedChats_IntroTitle2: String { return self._s[4116]! } - public var Notification_Exceptions_NewException: String { return self._s[4117]! } - public var TwoStepAuth_EmailTitle: String { return self._s[4118]! } - public var WatchRemote_AlertText: String { return self._s[4119]! } + 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[4120]!, self._r[4120]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4123]!, self._r[4123]!, [_1, _2, _3]) } - public var ChatSettings_ConnectionType_Title: String { return self._s[4124]! } + 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[4125]!, self._r[4125]!, [_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[4126]!, self._r[4126]!, [_0]) + return formatWithArgumentRanges(self._s[4129]!, self._r[4129]!, [_0]) } - public var SettingsSearch_Synonyms_Calls_CallTab: String { return self._s[4127]! } - public var WebBrowser_DefaultBrowser: String { return self._s[4128]! } - public var Passport_Address_CountryPlaceholder: String { return self._s[4129]! } + 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[4130]!, self._r[4130]!, [_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[4131]!, self._r[4131]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4134]!, self._r[4134]!, [_1, _2, _3]) } - public var Group_AdminLog_EmptyText: String { return self._s[4132]! } - public var SettingsSearch_Synonyms_Appearance_Title: String { return self._s[4133]! } - public var Conversation_PrivateChannelTooltip: String { return self._s[4135]! } - public var Wallet_Created_ExportErrorText: String { return self._s[4136]! } - public var ChatList_UndoArchiveText1: String { return self._s[4137]! } - public var ChatListFolder_IncludedSectionHeader: String { return self._s[4138]! } - public var AccessDenied_VideoMicrophone: String { return self._s[4139]! } - public var Conversation_ContextMenuStickerPackAdd: String { return self._s[4140]! } - public var Cache_ClearNone: String { return self._s[4141]! } - public var SocksProxySetup_FailedToConnect: String { return self._s[4142]! } - public var Permissions_NotificationsTitle_v0: String { return self._s[4143]! } + 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[4144]!, self._r[4144]!, [_0]) - } - public var Passport_Identity_Country: String { return self._s[4145]! } - public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4146]!, self._r[4146]!, [_0]) - } - public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4147]!, self._r[4147]!, [_0]) } - public var Exceptions_AddToExceptions: String { return self._s[4148]! } - public var AccessDenied_Settings: String { return self._s[4149]! } - public var Passport_Address_TypeUtilityBillUploadScan: String { return self._s[4150]! } - public var Month_ShortMay: String { return self._s[4152]! } - public var Compose_NewGroup: String { return self._s[4154]! } - public var Group_Setup_TypePrivate: String { return self._s[4156]! } - public var Login_PadPhoneHelpTitle: String { return self._s[4158]! } - public var Appearance_ThemeDayClassic: String { return self._s[4159]! } - public var Channel_AdminLog_MessagePreviousCaption: String { return self._s[4160]! } - public var AutoDownloadSettings_OffForAll: String { return self._s[4161]! } - public var Privacy_GroupsAndChannels_WhoCanAddMe: String { return self._s[4162]! } - public var Conversation_typing: String { return self._s[4164]! } - public var Undo_ScheduledMessagesCleared: String { return self._s[4165]! } - public var Paint_Masks: String { return self._s[4166]! } - public var Contacts_DeselectAll: String { return self._s[4167]! } - public func Wallet_Updated_YesterdayAt(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4168]!, self._r[4168]!, [_0]) + public var Passport_Identity_Country: String { return self._s[4148]! } + public func ChatSettings_AutoDownloadSettings_TypeFile(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4149]!, self._r[4149]!, [_0]) } - public var CreatePoll_MultipleChoiceQuizAlert: String { return self._s[4169]! } - public var Username_InvalidTaken: String { return self._s[4170]! } - public var Call_StatusNoAnswer: String { return self._s[4171]! } - public var TwoStepAuth_EmailAddSuccess: String { return self._s[4172]! } - public var SettingsSearch_Synonyms_Privacy_BlockedUsers: String { return self._s[4173]! } - public var Passport_Identity_Selfie: String { return self._s[4174]! } - public var Login_InfoLastNamePlaceholder: String { return self._s[4175]! } - public var Privacy_SecretChatsLinkPreviewsHelp: String { return self._s[4176]! } - public var Conversation_ClearSecretHistory: String { return self._s[4177]! } - public var PeopleNearby_Description: String { return self._s[4179]! } - public var NetworkUsageSettings_Title: String { return self._s[4180]! } - public var Your_cards_security_code_is_invalid: String { return self._s[4182]! } - public var Stats_EnabledNotifications: String { return self._s[4183]! } + public func Notification_CreatedChat(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4150]!, self._r[4150]!, [_0]) + } + 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[4171]!, self._r[4171]!, [_0]) + } + 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[4185]!, self._r[4185]!, [_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[4186]!, self._r[4186]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4189]!, self._r[4189]!, [_1, _2]) } - public var SaveIncomingPhotosSettings_From: String { return self._s[4188]! } - public var VoiceOver_Navigation_Search: String { return self._s[4189]! } - public var Map_LiveLocationTitle: String { return self._s[4190]! } - public var Login_InfoAvatarAdd: String { return self._s[4191]! } - public var Passport_Identity_FilesView: String { return self._s[4192]! } - public var ChatListFolderSettings_Title: String { return self._s[4193]! } - public var UserInfo_GenericPhoneLabel: String { return self._s[4194]! } - public var Privacy_Calls_NeverAllow: String { return self._s[4195]! } - public var VoiceOver_Chat_File: String { return self._s[4196]! } - public var Wallet_Settings_DeleteWalletInfo: String { return self._s[4197]! } + 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[4198]!, self._r[4198]!, [_0]) + return formatWithArgumentRanges(self._s[4201]!, self._r[4201]!, [_0]) } - public var ChatList_EmptyChatList: String { return self._s[4200]! } - public var ContactInfo_PhoneNumberHidden: String { return self._s[4201]! } - public var TwoStepAuth_ConfirmationText: String { return self._s[4202]! } - public var ChatSettings_AutomaticVideoMessageDownload: String { return self._s[4203]! } + 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[4204]!, self._r[4204]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4207]!, self._r[4207]!, [_1, _2, _3]) } - public var Channel_AdminLogFilter_AdminsAll: String { return self._s[4205]! } - public var Wallet_Intro_CreateErrorText: String { return self._s[4206]! } - public var Tour_Title2: String { return self._s[4207]! } - public var Wallet_Sent_ViewWallet: String { return self._s[4208]! } - public var Conversation_FileOpenIn: String { return self._s[4209]! } - public var Checkout_ErrorPrecheckoutFailed: String { return self._s[4210]! } - public var Wallet_Send_ErrorInvalidAddress: String { return self._s[4211]! } - public var Wallpaper_Set: String { return self._s[4212]! } - public var Passport_Identity_Translations: String { return self._s[4214]! } + 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[4215]!, self._r[4215]!, [_0]) + return formatWithArgumentRanges(self._s[4218]!, self._r[4218]!, [_0]) } - public var Channel_LeaveChannel: String { return self._s[4216]! } + public var Channel_LeaveChannel: String { return self._s[4219]! } public func PINNED_INVOICE(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4217]!, self._r[4217]!, [_1]) + return formatWithArgumentRanges(self._s[4220]!, self._r[4220]!, [_1]) } - public var SettingsSearch_Synonyms_Proxy_AddProxy: String { return self._s[4219]! } - public var PhotoEditor_HighlightsTint: String { return self._s[4220]! } - public var MessagePoll_LabelPoll: String { return self._s[4221]! } - public var Passport_Email_Delete: String { return self._s[4222]! } - public var Conversation_Mute: String { return self._s[4224]! } - public var Channel_AddBotAsAdmin: String { return self._s[4225]! } - public var Channel_AdminLog_CanSendMessages: String { return self._s[4227]! } - public var Wallet_Configuration_BlockchainNameChangedText: String { return self._s[4228]! } - public var ChatSettings_IntentsSettings: String { return self._s[4230]! } - public var Channel_Management_LabelOwner: String { return self._s[4231]! } + 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[4232]!, self._r[4232]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4235]!, self._r[4235]!, [_1, _2]) } - public var Calls_CallTabDescription: String { return self._s[4233]! } - public var Passport_Identity_NativeNameHelp: String { return self._s[4234]! } - public var Common_No: String { return self._s[4235]! } - public var Weekday_Sunday: String { return self._s[4236]! } - public var Notification_Reply: String { return self._s[4237]! } - public var Conversation_ViewMessage: String { return self._s[4238]! } + 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[4239]!, self._r[4239]!, [_0]) + return formatWithArgumentRanges(self._s[4242]!, self._r[4242]!, [_0]) } public func Map_LiveLocationPrivateDescription(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4240]!, self._r[4240]!, [_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[4241]!, self._r[4241]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4244]!, self._r[4244]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_EditProfile_AddAccount: String { return self._s[4242]! } - public var Wallet_Send_Title: String { return self._s[4243]! } - public var Message_PinnedDocumentMessage: String { return self._s[4244]! } - public var Wallet_Info_RefreshErrorText: String { return self._s[4245]! } - public var DialogList_TabTitle: String { return self._s[4247]! } - public var ChatSettings_AutoPlayTitle: String { return self._s[4248]! } - public var Passport_FieldEmail: String { return self._s[4249]! } - public var Conversation_UnpinMessageAlert: String { return self._s[4250]! } - public var Passport_Address_TypeBankStatement: String { return self._s[4251]! } - public var Wallet_SecureStorageReset_Title: String { return self._s[4252]! } - public var Passport_Identity_ExpiryDate: String { return self._s[4253]! } - public var Privacy_Calls_P2P: String { return self._s[4254]! } + 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[4256]!, self._r[4256]!, [_0]) + return formatWithArgumentRanges(self._s[4259]!, self._r[4259]!, [_0]) } - public var SocksProxySetup_UseForCallsHelp: String { return self._s[4257]! } + 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[4258]!, self._r[4258]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4261]!, self._r[4261]!, [_1, _2]) } - public var Stickers_ClearRecent: String { return self._s[4259]! } - public var EnterPasscode_ChangeTitle: String { return self._s[4260]! } - public var TwoFactorSetup_Email_Title: String { return self._s[4261]! } - public var Passport_InfoText: String { return self._s[4262]! } - public var Checkout_NewCard_SaveInfoEnableHelp: String { return self._s[4263]! } + 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[4264]!, self._r[4264]!, [_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[4265]!, self._r[4265]!, [_1, _2, _3]) + return formatWithArgumentRanges(self._s[4268]!, self._r[4268]!, [_1, _2, _3]) } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChannels: String { return self._s[4266]! } - public var ScheduledMessages_PollUnavailable: String { return self._s[4267]! } - public var VoiceOver_Navigation_Compose: String { return self._s[4268]! } - public var Passport_Identity_EditDriversLicense: String { return self._s[4269]! } - public var Conversation_TapAndHoldToRecord: String { return self._s[4271]! } - public var SettingsSearch_Synonyms_Notifications_BadgeIncludeMutedChats: String { return self._s[4272]! } + 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[4273]!, self._r[4273]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4276]!, self._r[4276]!, [_1, _2]) } - public var Channel_EditAdmin_PermissionInviteViaLink: String { return self._s[4276]! } - public var ChatSettings_OpenLinksIn: String { return self._s[4277]! } - public var Map_HomeAndWorkTitle: String { return self._s[4278]! } + 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[4280]!, self._r[4280]!, [_0]) + return formatWithArgumentRanges(self._s[4283]!, self._r[4283]!, [_0]) } - public var DialogList_Unread: String { return self._s[4281]! } + 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[4282]!, self._r[4282]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4285]!, self._r[4285]!, [_1, _2]) } - public var User_DeletedAccount: String { return self._s[4283]! } - public var ChatList_TabIconFoldersTooltipEmptyFolders: String { return self._s[4284]! } - public var OwnershipTransfer_SetupTwoStepAuth: String { return self._s[4285]! } + 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[4286]!, self._r[4286]!, [_0]) + return formatWithArgumentRanges(self._s[4289]!, self._r[4289]!, [_0]) } - public var UserInfo_NotificationsDefault: String { return self._s[4287]! } - public var SharedMedia_CategoryMedia: String { return self._s[4288]! } - public var SocksProxySetup_ProxyStatusUnavailable: String { return self._s[4289]! } - public var Channel_AdminLog_MessageRestrictedForever: String { return self._s[4290]! } - public var Watch_ChatList_Compose: String { return self._s[4291]! } - public var Notifications_MessageNotificationsExceptionsHelp: String { return self._s[4292]! } - public var AutoDownloadSettings_Delimeter: String { return self._s[4293]! } - public var Watch_Microphone_Access: String { return self._s[4294]! } - public var Group_Setup_HistoryHeader: String { return self._s[4295]! } - public var Map_SetThisLocation: String { return self._s[4296]! } - public var Appearance_ThemePreview_Chat_2_ReplyName: String { return self._s[4297]! } - public var Activity_UploadingPhoto: String { return self._s[4298]! } - public var Conversation_Edit: String { return self._s[4300]! } - public var Group_ErrorSendRestrictedMedia: String { return self._s[4301]! } - public var Login_TermsOfServiceDecline: String { return self._s[4302]! } - public var Message_PinnedContactMessage: String { return self._s[4303]! } + 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[4304]!, self._r[4304]!, [_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[4305]!, self._r[4305]!, [_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[4306]! } - public var TwoStepAuth_AdditionalPassword: String { return self._s[4308]! } - public var EditTheme_Edit_Preview_IncomingReplyText: String { return self._s[4309]! } + 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[4310]!, self._r[4310]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4313]!, self._r[4313]!, [_1, _2]) } - public var Passport_Phone_EnterOtherNumber: String { return self._s[4311]! } - public var Message_PinnedPhotoMessage: String { return self._s[4312]! } - public var Passport_FieldPhone: String { return self._s[4313]! } - public var TwoStepAuth_RecoveryEmailAddDescription: String { return self._s[4314]! } - public var Stats_NotificationsTitle: String { return self._s[4315]! } - public var ChatSettings_AutoPlayGifs: String { return self._s[4316]! } - public var InfoPlist_NSCameraUsageDescription: String { return self._s[4318]! } - public var Conversation_Call: String { return self._s[4319]! } - public var Common_TakePhoto: String { return self._s[4321]! } - public var Group_EditAdmin_RankTitle: String { return self._s[4322]! } - public var Wallet_Receive_CommentHeader: String { return self._s[4323]! } - public var Channel_NotificationLoading: String { return self._s[4324]! } + 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[4325]!, self._r[4325]!, [_0]) + return formatWithArgumentRanges(self._s[4328]!, self._r[4328]!, [_0]) } public func ScheduledMessages_ScheduledDate(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4326]!, self._r[4326]!, [_0]) - } - public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4327]!, self._r[4327]!, [_1]) - } - public var Permissions_SiriTitle_v0: String { return self._s[4328]! } - public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { return formatWithArgumentRanges(self._s[4329]!, self._r[4329]!, [_0]) } + public func PUSH_CHANNEL_MESSAGE_VIDEO(_ _1: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4330]!, self._r[4330]!, [_1]) + } + public var Permissions_SiriTitle_v0: String { return self._s[4331]! } + public func VoiceOver_Chat_VoiceMessageFrom(_ _0: String) -> (String, [(Int, NSRange)]) { + return formatWithArgumentRanges(self._s[4332]!, self._r[4332]!, [_0]) + } public func Login_ResetAccountProtected_Text(_ _0: String) -> (String, [(Int, NSRange)]) { - return formatWithArgumentRanges(self._s[4330]!, self._r[4330]!, [_0]) + return formatWithArgumentRanges(self._s[4333]!, self._r[4333]!, [_0]) } - public var Channel_MessagePhotoRemoved: String { return self._s[4331]! } - public var Wallet_Info_ReceiveGrams: String { return self._s[4332]! } - public var ClearCache_FreeSpace: String { return self._s[4333]! } - public var Appearance_BubbleCorners_Apply: String { return self._s[4334]! } - public var Common_edit: String { return self._s[4335]! } - public var PrivacySettings_AuthSessions: String { return self._s[4336]! } - public var Month_ShortJune: String { return self._s[4337]! } - public var PrivacyLastSeenSettings_AlwaysShareWith_Placeholder: String { return self._s[4338]! } - public var Call_ReportSend: String { return self._s[4339]! } - public var Watch_LastSeen_JustNow: String { return self._s[4340]! } - public var Notifications_MessageNotifications: String { return self._s[4341]! } - public var WallpaperSearch_ColorGreen: String { return self._s[4342]! } - public var BroadcastListInfo_AddRecipient: String { return self._s[4344]! } - public var Group_Status: String { return self._s[4345]! } + 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[4346]!, self._r[4346]!, [_0, _1]) + return formatWithArgumentRanges(self._s[4349]!, self._r[4349]!, [_0, _1]) } - public var TextFormat_AddLinkTitle: String { return self._s[4347]! } - public var ShareMenu_ShareTo: String { return self._s[4348]! } - public var Conversation_Moderate_Ban: String { return self._s[4349]! } + 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[4350]!, self._r[4350]!, [_0]) + return formatWithArgumentRanges(self._s[4353]!, self._r[4353]!, [_0]) } - public var SharedMedia_ViewInChat: String { return self._s[4351]! } - public var Map_LiveLocationFor8Hours: String { return self._s[4352]! } + 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[4353]!, self._r[4353]!, [_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[4354]!, self._r[4354]!, [_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[4356]!, self._r[4356]!, [_0]) + return formatWithArgumentRanges(self._s[4359]!, self._r[4359]!, [_0]) } - public var Map_OpenInHereMaps: String { return self._s[4357]! } - public var Appearance_ReduceMotion: String { return self._s[4358]! } + 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[4359]!, self._r[4359]!, [_1, _2]) + return formatWithArgumentRanges(self._s[4362]!, self._r[4362]!, [_1, _2]) } - public var Channel_Setup_TypePublicHelp: String { return self._s[4360]! } - public var Passport_Identity_EditInternalPassport: String { return self._s[4361]! } - public var PhotoEditor_Skip: String { return self._s[4362]! } - public func MuteExpires_Minutes(_ 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[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func ServiceMessage_GameScoreSimple(_ value: Int32) -> String { + public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 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[2 * 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[3 * 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[4 * 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[5 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_VIDEOS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[6 * 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[7 * 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[8 * 6 + Int(form.rawValue)]!, _2, _1, _3) - } - public func MessageTimer_Months(_ 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 ForwardedAuthorsOthers(_ selector: Int32, _ _0: String, _ _1: String) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, _0, _1) - } - public func ForwardedContacts(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Hours(_ 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 MessageTimer_Hours(_ 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 Wallpaper_DeleteConfirmation(_ 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 PUSH_CHANNEL_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[15 * 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[16 * 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[17 * 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[18 * 6 + Int(form.rawValue)]!, stringValue) - } - public func ChatList_MessagePhotos(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[19 * 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[20 * 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[21 * 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[22 * 6 + Int(form.rawValue)]!, stringValue) - } - public func LastSeen_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[23 * 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[24 * 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[25 * 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[26 * 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[27 * 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[28 * 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[29 * 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[30 * 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[31 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PUSH_CHANNEL_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[32 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Conversation_SelectedMessages(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[33 * 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[34 * 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[35 * 6 + Int(form.rawValue)]!, stringValue) - } - public func OldChannels_InactiveWeek(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[36 * 6 + Int(form.rawValue)]!, stringValue) - } - public func Call_Minutes(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[37 * 6 + Int(form.rawValue)]!, stringValue) - } - public func InstantPage_Views(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[38 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Link(_ 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 Notifications_Exceptions(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[40 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHANNEL_MESSAGE_VIDEOS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[41 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func VoiceOver_Chat_ContactPhoneNumberCount(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[42 * 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[43 * 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[44 * 6 + Int(form.rawValue)]!, stringValue) + 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[45 * 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[46 * 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[47 * 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[48 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MuteExpires_Days(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[49 * 6 + Int(form.rawValue)]!, stringValue) + 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[50 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[4 * 6 + Int(form.rawValue)]!, stringValue) } - public func VoiceOver_Chat_PollOptionCount(_ value: Int32) -> String { + public func PeopleNearby_ShowMorePeople(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[51 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[5 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendItem(_ value: Int32) -> String { + public func Notifications_Exceptions(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[52 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[6 * 6 + Int(form.rawValue)]!, stringValue) } - public func InviteText_ContactsCountText(_ value: Int32) -> String { + public func ChatListFilter_ShowMoreChats(_ 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 QuickSend_Photos(_ 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 Media_SharePhoto(_ 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 ForwardedStickers(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[56 * 6 + Int(form.rawValue)]!, stringValue) - } - public func SharedMedia_Video(_ 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 UserCount(_ 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 Notifications_ExceptionMuteExpires_Days(_ 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 Wallet_Updated_MinutesAgo(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[60 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[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[61 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[8 * 6 + Int(form.rawValue)]!, stringValue) } - public func PasscodeSettings_FailedAttempts(_ value: Int32) -> String { + public func PollResults_ShowMore(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[62 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[9 * 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[63 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func PUSH_MESSAGE_ROUNDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { - let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[64 * 6 + Int(form.rawValue)]!, _1, _2) - } - public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { + public func ForwardedLocations(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[65 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[10 * 6 + Int(form.rawValue)]!, stringValue) } - public func PUSH_CHAT_MESSAGE_ROUNDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_MESSAGES(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[66 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[11 * 6 + Int(form.rawValue)]!, _1, _2) } - public func StickerPack_AddStickerCount(_ value: Int32) -> String { + public func ForwardedGifs(_ 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[12 * 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[68 * 6 + Int(form.rawValue)]!, _1, _2) + 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 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 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 Notifications_ExceptionMuteExpires_Minutes(_ 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[16 * 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[17 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Hours(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[18 * 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[19 * 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[20 * 6 + Int(form.rawValue)]!, stringValue) + } + public func MessageTimer_Seconds(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[21 * 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[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[23 * 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[24 * 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[25 * 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[26 * 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[27 * 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[29 * 6 + Int(form.rawValue)]!, stringValue) + } + public func OldChannels_Leave(_ value: Int32) -> String { + let form = getPluralizationForm(self.lc, value) + let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) + return String(format: self._ps[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[50 * 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[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[70 * 6 + Int(form.rawValue)]!, _1, _2) + return String(format: self._ps[58 * 6 + Int(form.rawValue)]!, _1, _2) } - public func Map_ETAMinutes(_ value: Int32) -> String { + 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 MessageTimer_Minutes(_ value: Int32) -> String { + 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) @@ -5238,297 +5244,294 @@ public final class PresentationStrings: Equatable { let form = getPluralizationForm(self.lc, selector) return String(format: self._ps[73 * 6 + Int(form.rawValue)]!, _1, _2) } - public func Watch_UserInfo_Mute(_ value: Int32) -> String { + 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_ShortSeconds(_ value: Int32) -> String { + 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 Call_Seconds(_ value: Int32) -> String { + 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 ForwardedGifs(_ value: Int32) -> String { + 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 Watch_LastSeen_MinutesAgo(_ value: Int32) -> String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[78 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortWeeks(_ value: Int32) -> String { + public func ServiceMessage_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[79 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_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 PrivacyLastSeenSettings_AddUsers(_ 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 StickerPack_RemoveStickerCount(_ 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 Wallet_Updated_HoursAgo(_ 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) } - public func MessageTimer_ShortMinutes(_ value: Int32) -> String { + public func MessageTimer_Years(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[84 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_ShortHours(_ 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 Media_ShareItem(_ 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 MessagePoll_VotedCount(_ value: Int32) -> String { + public func InstantPage_Views(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[87 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Generic(_ value: Int32) -> String { + public func ServiceMessage_GameScoreExtended(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[88 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notification_GameScoreSelfExtended(_ 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[89 * 6 + Int(form.rawValue)]!, stringValue) } - public func Conversation_LiveLocationMembersCount(_ 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[90 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Days(_ 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[91 * 6 + Int(form.rawValue)]!, stringValue) } - public func SharedMedia_Photo(_ value: Int32) -> String { + public func MessagePoll_QuizCount(_ 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 Notification_GameScoreExtended(_ 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[93 * 6 + Int(form.rawValue)]!, stringValue) } - public func StickerPack_RemoveMaskCount(_ 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[94 * 6 + Int(form.rawValue)]!, stringValue) } - public func AttachmentMenu_SendVideo(_ value: Int32) -> String { + 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_StatusMembers(_ value: Int32) -> String { + public func Conversation_LiveLocationMembersCount(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[96 * 6 + Int(form.rawValue)]!, stringValue) } - public func OldChannels_GroupFormat(_ value: Int32) -> String { + public func MessageTimer_ShortMinutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[97 * 6 + Int(form.rawValue)]!, stringValue) } - public func MessageTimer_Years(_ value: Int32) -> String { + 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 Call_ShortMinutes(_ value: Int32) -> String { + 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 AttachmentMenu_SendPhoto(_ value: Int32) -> String { + public func MessageTimer_Minutes(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[100 * 6 + Int(form.rawValue)]!, stringValue) } - public func Invitation_Members(_ value: Int32) -> String { + public func Notification_GameScoreSelfSimple(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[101 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_ImportersCount(_ value: Int32) -> String { + public func Call_ShortSeconds(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[102 * 6 + Int(form.rawValue)]!, stringValue) } - public func Contacts_InviteContacts(_ value: Int32) -> String { + public func MessageTimer_Months(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[103 * 6 + Int(form.rawValue)]!, stringValue) } - public func GroupInfo_ShowMoreMembers(_ value: Int32) -> String { + public func OldChannels_GroupFormat(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[104 * 6 + Int(form.rawValue)]!, stringValue) } - public func Notifications_ExceptionMuteExpires_Hours(_ value: Int32) -> String { + 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_SendGif(_ value: Int32) -> String { + public func AttachmentMenu_SendItem(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[106 * 6 + Int(form.rawValue)]!, stringValue) } - public func Chat_DeleteMessagesConfirmation(_ value: Int32) -> String { + public func Notifications_ExceptionMuteExpires_Days(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[107 * 6 + Int(form.rawValue)]!, stringValue) } - public func Theme_UsersCount(_ value: Int32) -> String { + 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 LastSeen_HoursAgo(_ value: Int32) -> String { + public func Forward_ConfirmMultipleFiles(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[109 * 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[110 * 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 ForwardedLocations(_ value: Int32) -> String { + public func ForwardedContacts(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[111 * 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[112 * 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[113 * 6 + Int(form.rawValue)]!, stringValue) - } - public func PUSH_CHAT_MESSAGE_FWDS(_ selector: Int32, _ _2: String, _ _1: String, _ _3: Int32) -> String { + public func PUSH_MESSAGE_FWDS(_ selector: Int32, _ _1: String, _ _2: Int32) -> String { let form = getPluralizationForm(self.lc, selector) - return String(format: self._ps[114 * 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[115 * 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[116 * 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[117 * 6 + Int(form.rawValue)]!, stringValue) - } - public func MessageTimer_Seconds(_ value: Int32) -> String { - let form = getPluralizationForm(self.lc, value) - let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[118 * 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[119 * 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[120 * 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[121 * 6 + Int(form.rawValue)]!, _1, _2) + 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[122 * 6 + Int(form.rawValue)]!, _2, _1, _3) + return String(format: self._ps[113 * 6 + Int(form.rawValue)]!, _2, _1, _3) } - public func MessageTimer_ShortDays(_ value: Int32) -> String { + public func MuteFor_Hours(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[123 * 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[124 * 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[125 * 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[126 * 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[127 * 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[128 * 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[129 * 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[130 * 6 + Int(form.rawValue)]!, stringValue) + 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[131 * 6 + Int(form.rawValue)]!, stringValue) + return String(format: self._ps[115 * 6 + Int(form.rawValue)]!, stringValue) } - public func ForwardedVideoMessages(_ value: Int32) -> String { + public func Conversation_SelectedMessages(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = presentationStringsFormattedNumber(value, self.groupingSeparator) - return String(format: self._ps[132 * 6 + Int(form.rawValue)]!, stringValue) + 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) { diff --git a/submodules/TelegramUI/Resources/PresentationStrings.mapping b/submodules/TelegramUI/Resources/PresentationStrings.mapping index 5b0864dc7cc3db230042c499599b49a60aa9ba00..2c3b952f62566be9b1d972cf086e9dc2fd66c4ad 100644 GIT binary patch delta 24961 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 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 { @@ -2741,6 +2745,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) { @@ -4711,7 +4716,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: {})] @@ -4998,6 +5003,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) { @@ -5021,6 +5078,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) { @@ -7799,7 +7860,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 { @@ -7846,7 +7907,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 @@ -7859,7 +7920,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 { @@ -7877,7 +7938,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 @@ -7982,7 +8043,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)) @@ -8245,13 +8306,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/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/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/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/WalletUI/Resources/WalletStrings.mapping b/submodules/WalletUI/Resources/WalletStrings.mapping index 1246758922535bca4d24a763b4150cc1ff0b4957..d38b0e0300080115b02bd8f6670183d9196a04fa 100644 GIT binary patch delta 17 ZcmaFn_{?#`Duu}>6=WG1Cofl!0{}_;2HXGu delta 17 ZcmaFn_{?#`Duv0X6{Hy%Cofk}002q>2HpSw diff --git a/submodules/WalletUI/Sources/WalletStrings.swift b/submodules/WalletUI/Sources/WalletStrings.swift index b25bf2d505..759572d1b4 100644 --- a/submodules/WalletUI/Sources/WalletStrings.swift +++ b/submodules/WalletUI/Sources/WalletStrings.swift @@ -449,12 +449,12 @@ public final class WalletStrings: Equatable { public var Wallet_SecureStorageReset_Title: String { return self._s[219]! } public var Wallet_Receive_CommentHeader: String { return self._s[220]! } public var Wallet_Info_ReceiveGrams: String { return self._s[221]! } - public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { + public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[0 * 6 + Int(form.rawValue)]!, stringValue) } - public func Wallet_Updated_MinutesAgo(_ value: Int32) -> String { + public func Wallet_Updated_HoursAgo(_ value: Int32) -> String { let form = getPluralizationForm(self.lc, value) let stringValue = walletStringsFormattedNumber(value, self.groupingSeparator) return String(format: self._ps[1 * 6 + Int(form.rawValue)]!, stringValue) From 446e5a5a8611bf86314c02ceda089e4c6bc9e236 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Sun, 7 Jun 2020 18:13:32 +0400 Subject: [PATCH 7/9] Fix legacy group type selection control --- .../PeerInfoUI/Sources/ChannelVisibilityController.swift | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) 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 From 1e777ef1db714aac50286ca8d65b1f07aba291c2 Mon Sep 17 00:00:00 2001 From: Ali <> Date: Sun, 7 Jun 2020 18:18:15 +0400 Subject: [PATCH 8/9] Update submodule url --- .gitmodules | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) 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 From e7b181e12acf6875061cb2406255b038a0347b75 Mon Sep 17 00:00:00 2001 From: Ilya Laktyushin Date: Mon, 8 Jun 2020 13:30:18 +0300 Subject: [PATCH 9/9] Photo editor fixes --- .../Sources/TGPhotoPaintController.m | 2 +- .../Sources/TGPhotoTextEntityView.m | 59 +++++++++++++------ .../Sources/TGVideoMessageCaptureController.m | 2 +- .../Sources/RequestEditMessage.swift | 3 + .../TelegramUI/Sources/ChatController.swift | 5 +- .../Sources/LegacyWebSearchGallery.swift | 16 ++++- .../Sources/WebSearchController.swift | 6 ++ .../Sources/WebSearchControllerNode.swift | 4 +- 8 files changed, 71 insertions(+), 26 deletions(-) diff --git a/submodules/LegacyComponents/Sources/TGPhotoPaintController.m b/submodules/LegacyComponents/Sources/TGPhotoPaintController.m index 37a4cea68e..fd797df610 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoPaintController.m +++ b/submodules/LegacyComponents/Sources/TGPhotoPaintController.m @@ -543,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; diff --git a/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m b/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m index bf44bcb018..c65161751b 100644 --- a/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m +++ b/submodules/LegacyComponents/Sources/TGPhotoTextEntityView.m @@ -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]; 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/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/TelegramUI/Sources/ChatController.swift b/submodules/TelegramUI/Sources/ChatController.swift index 2fed0a5e52..fa000fb9f4 100644 --- a/submodules/TelegramUI/Sources/ChatController.swift +++ b/submodules/TelegramUI/Sources/ChatController.swift @@ -1923,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 })) } @@ -4983,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 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 39f4b7bda6..140e9fba8e 100644 --- a/submodules/WebSearchUI/Sources/WebSearchController.swift +++ b/submodules/WebSearchUI/Sources/WebSearchController.swift @@ -149,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 diff --git a/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift b/submodules/WebSearchUI/Sources/WebSearchControllerNode.swift index ce53c77724..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 @@ -703,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 {